⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 cmdline.c

📁 zhcon是工作在Linux控制台下的高效双字节中/日/韩(CJK)虚拟终端
💻 C
字号:
/*  File autogenerated by gengetopt version 2.15  generated with the following command:  gengetopt -u -i zhcon.ggo program   The developers of gengetopt consider the fixed text that goes in all  gengetopt output files to be in the public domain:  we make no copyright claims on it.*//* If we use autoconf.  */#ifdef HAVE_CONFIG_H#include "config.h"#endif#include <stdio.h>#include <stdlib.h>#include <string.h>#include "getopt.h"#include "cmdline.h"staticvoid clear_given (struct gengetopt_args_info *args_info);staticvoid clear_args (struct gengetopt_args_info *args_info);static intcmdline_parser_internal (int argc, char * const *argv, struct gengetopt_args_info *args_info, int override, int initialize, int check_required, const char *additional_error);static char *gengetopt_strdup (const char *s);staticvoid clear_given (struct gengetopt_args_info *args_info){  args_info->help_given = 0 ;  args_info->version_given = 0 ;  args_info->utf8_given = 0 ;  args_info->drv_given = 0 ;}staticvoid clear_args (struct gengetopt_args_info *args_info){  args_info->utf8_flag = 0;  args_info->drv_arg = gengetopt_strdup ("auto");  args_info->drv_orig = NULL;  }voidcmdline_parser_print_version (void){  printf ("%s %s\n", CMDLINE_PARSER_PACKAGE, CMDLINE_PARSER_VERSION);}voidcmdline_parser_print_help (void){  cmdline_parser_print_version ();  printf("\n%s\n", "A Fast CJK Console Environment");  printf("\nUsage: zhcon [OPTIONS]... [FILES]...\n\n");  printf("%s\n","  -h, --help        Print help and exit");  printf("%s\n","  -V, --version     Print version and exit");  printf("%s\n","      --utf8        use iconv filter to convert UTF-8 stream from/to system \n                      encoding  (default=off)");  printf("%s\n","      --drv=STRING  specify video driver (auto, fb, ggi, vga)  (default=`auto')");  }voidcmdline_parser_init (struct gengetopt_args_info *args_info){  clear_given (args_info);  clear_args (args_info);  args_info->inputs = NULL;  args_info->inputs_num = 0;}static voidcmdline_parser_release (struct gengetopt_args_info *args_info){    unsigned int i;  if (args_info->drv_arg)    {      free (args_info->drv_arg); /* free previous argument */      args_info->drv_arg = 0;    }  if (args_info->drv_orig)    {      free (args_info->drv_orig); /* free previous argument */      args_info->drv_orig = 0;    }    for (i = 0; i < args_info->inputs_num; ++i)    free (args_info->inputs [i]);    if (args_info->inputs_num)    free (args_info->inputs);    clear_given (args_info);}intcmdline_parser_file_save(const char *filename, struct gengetopt_args_info *args_info){  FILE *outfile;  int i = 0;  outfile = fopen(filename, "w");  if (!outfile)    {      fprintf (stderr, "%s: cannot open file for writing: %s\n", CMDLINE_PARSER_PACKAGE, filename);      return EXIT_FAILURE;    }  if (args_info->help_given) {    fprintf(outfile, "%s\n", "help");  }  if (args_info->version_given) {    fprintf(outfile, "%s\n", "version");  }  if (args_info->utf8_given) {    fprintf(outfile, "%s\n", "utf8");  }  if (args_info->drv_given) {    if (args_info->drv_orig) {      fprintf(outfile, "%s=\"%s\"\n", "drv", args_info->drv_orig);    } else {      fprintf(outfile, "%s\n", "drv");    }  }    fclose (outfile);  i = EXIT_SUCCESS;  return i;}voidcmdline_parser_free (struct gengetopt_args_info *args_info){  cmdline_parser_release (args_info);}/* gengetopt_strdup() *//* strdup.c replacement of strdup, which is not standard */char *gengetopt_strdup (const char *s){  char *result = NULL;  if (!s)    return result;  result = (char*)malloc(strlen(s) + 1);  if (result == (char*)0)    return (char*)0;  strcpy(result, s);  return result;}intcmdline_parser (int argc, char * const *argv, struct gengetopt_args_info *args_info){  return cmdline_parser2 (argc, argv, args_info, 0, 1, 1);}intcmdline_parser2 (int argc, char * const *argv, struct gengetopt_args_info *args_info, int override, int initialize, int check_required){  int result;  result = cmdline_parser_internal (argc, argv, args_info, override, initialize, check_required, NULL);  if (result == EXIT_FAILURE)    {      cmdline_parser_free (args_info);      exit (EXIT_FAILURE);    }    return result;}intcmdline_parser_required (struct gengetopt_args_info *args_info, const char *prog_name){  return EXIT_SUCCESS;}intcmdline_parser_internal (int argc, char * const *argv, struct gengetopt_args_info *args_info, int override, int initialize, int check_required, const char *additional_error){  int c;	/* Character of the parsed option.  */  int error = 0;  struct gengetopt_args_info local_args_info;  if (initialize)    cmdline_parser_init (args_info);  cmdline_parser_init (&local_args_info);  optarg = 0;  optind = 1;  opterr = 1;  optopt = '?';  while (1)    {      int option_index = 0;      char *stop_char;      static struct option long_options[] = {        { "help",	0, NULL, 'h' },        { "version",	0, NULL, 'V' },        { "utf8",	0, NULL, 0 },        { "drv",	1, NULL, 0 },        { NULL,	0, NULL, 0 }      };      stop_char = 0;      c = getopt_long (argc, argv, "hV", long_options, &option_index);      if (c == -1) break;	/* Exit from `while (1)' loop.  */      switch (c)        {        case 'h':	/* Print help and exit.  */          cmdline_parser_print_help ();          cmdline_parser_free (&local_args_info);          exit (EXIT_SUCCESS);        case 'V':	/* Print version and exit.  */          cmdline_parser_print_version ();          cmdline_parser_free (&local_args_info);          exit (EXIT_SUCCESS);        case 0:	/* Long option with no short option */          /* use iconv filter to convert UTF-8 stream from/to system encoding.  */          if (strcmp (long_options[option_index].name, "utf8") == 0)          {            if (local_args_info.utf8_given)              {                fprintf (stderr, "%s: `--utf8' option given more than once%s\n", argv[0], (additional_error ? additional_error : ""));                goto failure;              }            if (args_info->utf8_given && ! override)              continue;            local_args_info.utf8_given = 1;            args_info->utf8_given = 1;            args_info->utf8_flag = !(args_info->utf8_flag);          }          /* specify video driver (auto, fb, ggi, vga).  */          else if (strcmp (long_options[option_index].name, "drv") == 0)          {            if (local_args_info.drv_given)              {                fprintf (stderr, "%s: `--drv' option given more than once%s\n", argv[0], (additional_error ? additional_error : ""));                goto failure;              }            if (args_info->drv_given && ! override)              continue;            local_args_info.drv_given = 1;            args_info->drv_given = 1;            if (args_info->drv_arg)              free (args_info->drv_arg); /* free previous string */            args_info->drv_arg = gengetopt_strdup (optarg);            if (args_info->drv_orig)              free (args_info->drv_orig); /* free previous string */            args_info->drv_orig = gengetopt_strdup (optarg);          }                    break;        case '?':	/* Invalid option.  */          /* `getopt_long' already printed an error message.  */          goto failure;        default:	/* bug: option not considered.  */          fprintf (stderr, "%s: option unknown: %c%s\n", CMDLINE_PARSER_PACKAGE, c, (additional_error ? additional_error : ""));          abort ();        } /* switch */    } /* while */  cmdline_parser_release (&local_args_info);  if ( error )    return (EXIT_FAILURE);  if (optind < argc)    {      int i = 0 ;      args_info->inputs_num = argc - optind ;      args_info->inputs =        (char **)(malloc ((args_info->inputs_num)*sizeof(char *))) ;      while (optind < argc)        args_info->inputs[ i++ ] = gengetopt_strdup (argv[optind++]) ;    }  return 0;failure:    cmdline_parser_release (&local_args_info);  return (EXIT_FAILURE);}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -