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

📄 smtpclient_getopt.c

📁 smtp客户端工具源代码。
💻 C
📖 第 1 页 / 共 3 页
字号:
                {                  if (opterr)                   if (argv[optind - 1][1] == '-')                    /* --option */                    fprintf (stderr,                     _("%s: option `--%s' doesn't allow an argument\n"),                     argv[0], pfound->name);                   else                    /* +option or -option */                    fprintf (stderr,                     _("%s: option `%c%s' doesn't allow an argument\n"),                     argv[0], argv[optind - 1][0], pfound->name);                  nextchar += strlen (nextchar);                  optopt = pfound->val;                  return '?';                }            }          else if (pfound->has_arg == 1)            {              if (optind < argc)                optarg = argv[optind++];              else                {                  if (opterr)                    fprintf (stderr,                           _("%s: option `%s' requires an argument\n"),                           argv[0], argv[optind - 1]);                  nextchar += strlen (nextchar);                  optopt = pfound->val;                  return optstring[0] == ':' ? ':' : '?';                }            }          nextchar += strlen (nextchar);          if (longind != NULL)            *longind = option_index;          if (pfound->flag)            {              *(pfound->flag) = pfound->val;              return 0;            }          return pfound->val;        }      /* Can't find it as a long option.  If this is not getopt_long_only,         or the option starts with '--' or is not a valid short         option, then it's an error.         Otherwise interpret it as a short option.  */      if (!long_only || argv[optind][1] == '-'          || my_index (optstring, *nextchar) == NULL)        {          if (opterr)            {              if (argv[optind][1] == '-')                /* --option */                fprintf (stderr, _("%s: unrecognized option `--%s'\n"),                         argv[0], nextchar);              else                /* +option or -option */                fprintf (stderr, _("%s: unrecognized option `%c%s'\n"),                         argv[0], argv[optind][0], nextchar);            }          nextchar = (char *) "";          optind++;          optopt = 0;          return '?';        }    }  /* Look at and handle the next short option-character.  */  {    char c = *nextchar++;    char *temp = my_index (optstring, c);    /* Increment `optind' when we start to process its last character.  */    if (*nextchar == '\0')      ++optind;    if (temp == NULL || c == ':')      {        if (opterr)          {            if (posixly_correct)              /* 1003.2 specifies the format of this message.  */              fprintf (stderr, _("%s: illegal option -- %c\n"),                       argv[0], c);            else              fprintf (stderr, _("%s: invalid option -- %c\n"),                       argv[0], c);          }        optopt = c;        return '?';      }    /* Convenience. Treat POSIX -W foo same as long option --foo */    if (temp[0] == 'W' && temp[1] == ';')      {        char *nameend;        const struct option *p;        const struct option *pfound = NULL;        int exact = 0;        int ambig = 0;        int indfound = 0;        int option_index;        /* This is an option that requires an argument.  */        if (*nextchar != '\0')          {            optarg = nextchar;            /* If we end this ARGV-element by taking the rest as an arg,               we must advance to the next element now.  */            optind++;          }        else if (optind == argc)          {            if (opterr)              {                /* 1003.2 specifies the format of this message.  */                fprintf (stderr, _("%s: option requires an argument -- %c\n"),                         argv[0], c);              }            optopt = c;            if (optstring[0] == ':')              c = ':';            else              c = '?';            return c;          }        else          /* We already incremented `optind' once;             increment it again when taking next ARGV-elt as argument.  */          optarg = argv[optind++];        /* optarg is now the argument, see if it's in the           table of longopts.  */        for (nextchar = nameend = optarg; *nameend && *nameend != '='; nameend++)          /* Do nothing.  */ ;        /* Test all long options for either exact match           or abbreviated matches.  */        for (p = longopts, option_index = 0; p->name; p++, option_index++)          if (!strncmp (p->name, nextchar, nameend - nextchar))            {              if ((unsigned int) (nameend - nextchar) == strlen (p->name))                {                  /* Exact match found.  */                  pfound = p;                  indfound = option_index;                  exact = 1;                  break;                }              else if (pfound == NULL)                {                  /* First nonexact match found.  */                  pfound = p;                  indfound = option_index;                }              else                /* Second or later nonexact match found.  */                ambig = 1;            }        if (ambig && !exact)          {            if (opterr)              fprintf (stderr, _("%s: option `-W %s' is ambiguous\n"),                       argv[0], argv[optind]);            nextchar += strlen (nextchar);            optind++;            return '?';          }        if (pfound != NULL)          {            option_index = indfound;            if (*nameend)              {                /* Don't test has_arg with >, because some C compilers don't                   allow it to be used on enums.  */                if (pfound->has_arg)                  optarg = nameend + 1;                else                  {                    if (opterr)                      fprintf (stderr, _("\%s: option `-W %s' doesn't allow an argument\n"),                               argv[0], pfound->name);                    nextchar += strlen (nextchar);                    return '?';                  }              }            else if (pfound->has_arg == 1)              {                if (optind < argc)                  optarg = argv[optind++];                else                  {                    if (opterr)                      fprintf (stderr,                               _("%s: option `%s' requires an argument\n"),                               argv[0], argv[optind - 1]);                    nextchar += strlen (nextchar);                    return optstring[0] == ':' ? ':' : '?';                  }              }            nextchar += strlen (nextchar);            if (longind != NULL)              *longind = option_index;            if (pfound->flag)              {                *(pfound->flag) = pfound->val;                return 0;              }            return pfound->val;          }          nextchar = NULL;          return 'W';   /* Let the application handle it.   */      }    if (temp[1] == ':')      {        if (temp[2] == ':')          {            /* This is an option that accepts an argument optionally.  */            if (*nextchar != '\0')              {                optarg = nextchar;                optind++;              }            else              optarg = NULL;            nextchar = NULL;          }        else          {            /* This is an option that requires an argument.  */            if (*nextchar != '\0')              {                optarg = nextchar;                /* If we end this ARGV-element by taking the rest as an arg,                   we must advance to the next element now.  */                optind++;              }            else if (optind == argc)              {                if (opterr)                  {                    /* 1003.2 specifies the format of this message.  */                    fprintf (stderr,                           _("%s: option requires an argument -- %c\n"),                           argv[0], c);                  }                optopt = c;                if (optstring[0] == ':')                  c = ':';                else                  c = '?';              }            else              /* We already incremented `optind' once;                 increment it again when taking next ARGV-elt as argument.  */              optarg = argv[optind++];            nextchar = NULL;          }      }    return c;  }}intgetopt (argc, argv, optstring)     int argc;     char *const *argv;     const char *optstring;{  return _getopt_internal (argc, argv, optstring,                           (const struct option *) 0,                           (int *) 0,                           0);}#endif  /* Not ELIDE_CODE.  *//* XX getopt1.c XX *//* XX getopt1.c XX *//* XX getopt1.c XX */#if !defined (__STDC__) || !__STDC__/* This is a separate conditional since some stdc systems   reject `defined (const)'.  */#ifndef const#define const#endif#endif#include <stdio.h>/* Comment out all this code if we are using the GNU C Library, and are not   actually compiling the library itself.  This code is part of the GNU C   Library, but also included in many other GNU distributions.  Compiling   and linking in this code is a waste when using the GNU C library   (especially if it is a shared library).  Rather than having every GNU   program understand `configure --with-gnu-libc' and omit the object files,   it is simpler to just do this in the source for each such file.  */#define GETOPT_INTERFACE_VERSION 2#if !defined (_LIBC) && defined (__GLIBC__) && __GLIBC__ >= 2#include <gnu-versions.h>#if _GNU_GETOPT_INTERFACE_VERSION == GETOPT_INTERFACE_VERSION#define ELIDE_CODE#endif#endif#ifndef ELIDE_CODE/* This needs to come after some library #include   to get __GNU_LIBRARY__ defined.  */#ifdef __GNU_LIBRARY__#include <stdlib.h>#endif#ifndef NULL#define NULL 0#endifintgetopt_long (argc, argv, options, long_options, opt_index)     int argc;     char *const *argv;     const char *options;     const struct option *long_options;     int *opt_index;{  return _getopt_internal (argc, argv, options, long_options, opt_index, 0);}/* Like getopt_long, but '-' as well as '--' can indicate a long option.   If an option that starts with '-' (not '--') doesn't match a long option,   but does match a short option, it is parsed as a short option   instead.  */intgetopt_long_only (argc, argv, options, long_options, opt_index)     int argc;     char *const *argv;     const char *options;     const struct option *long_options;     int *opt_index;{  return _getopt_internal (argc, argv, options, long_options, opt_index, 1);}#endif  /* Not ELIDE_CODE.  *//*EOF*/

⌨️ 快捷键说明

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