/* Our own convenience getopt.  Public Domain. */
#include "silcincludes.h"

#ifndef SILC_EPOC
#if !defined(HAVE_GETOPT) && !defined(HAVE_GETOPT_H)
int	opterr = 1;
int	optind = 1;
int	optopt;
char	*optarg;

#define GETOPT_ERR(s, c)			\
do {						\
  if (opterr) {					\
    char errbuf[2];				\
    errbuf[0] = c;				\
    errbuf[1] = '\n';				\
    (void) write(2, argv[0], strlen(argv[0]));	\
    (void) write(2, s, strlen(s));		\
    (void) write(2, errbuf, 2);			\
  }						\
} while(0)

int getopt(int argc, char * const *argv, const char *optstring)
{
  static int sp = 1;
  register int c;
  register char *cp;

  if (sp == 1) {
    if (optind >= argc ||
	argv[optind][0] != '-' || argv[optind][1] == '\0') {
      return EOF;
    } else if (strcmp(argv[optind], "--") == 0) {
      optind++;
      return EOF;
    }
  }
  optopt = c = argv[optind][sp];

  if (c == ':' || (cp=strchr(optstring, c)) == NULL) {
    GETOPT_ERR(": illegal option -- ", c);
    if (argv[optind][++sp] == '\0') {
      optind++;
      sp = 1;
    }
    return '?';
  }

  if (*++cp == ':') {
    if (argv[optind][sp+1] != '\0')
      optarg = &argv[optind++][sp+1];
    else if (++optind >= argc) {
      GETOPT_ERR(": option requires an argument -- ", c);
      sp = 1;
      return '?';
    } else
      optarg = argv[optind++];
    sp = 1;
  } else {
    if (argv[optind][++sp] == '\0') {
      sp = 1;
      optind++;
    }
    optarg = NULL;
  }

  return c;
}
#endif /* !HAVE_GETOPT && !HAVE_GETOPT_H */
#endif /* !SILC_EPOC */


syntax highlighted by Code2HTML, v. 0.9.1