Подтвердить что ты не робот

Getopt.h: Компиляция C-кода Linux в Windows

Я пытаюсь получить набор из девяти файлов .c(и девять связанных файлов *.h) для компиляции под Windows.

Код изначально был разработан в Linux для принятия аргументов командной строки с использованием стандартной библиотеки GNU-Linux/C "getopt.h" . И эта библиотека не применяется для создания C-кода в Windows.

Я хочу игнорировать то, что делает мой код прямо сейчас, и задать следующий вопрос. Для тех из вас, кто знаком с этой C-библиотекой "getopt.h" : будет ли возможно создавать и запускать мой код в Windows, если это зависит от аргументов командной строки в стиле POSIX? Или мне придется переписать код для работы в Windows, передавая входные файлы по-разному (и отбрасывая зависимость "getopt.h" )?

4b9b3361

Ответ 1

Вы правы. getopt() - это POSIX, а не Windows, вам, как правило, придется перезаписать весь код анализа аргумента командной строки.

К счастью, есть проект Xgetopt, предназначенный для классов Windows/MFC.

http://www.codeproject.com/Articles/1940/XGetopt-A-Unix-compatible-getopt-for-MFC-and-Win32

Если вы можете заставить это работать в своем проекте, оно должно сэкономить вам немного кода и не дать вам переработать весь синтаксический анализ.

Кроме того, он поставляется с хорошим графическим интерфейсом, которое вы должны найти полезным.

Удачи!

Ответ 2

getopt() на самом деле действительно простая функция. Я сделал github gist для него, код здесь ниже тоже

#include <string.h>
#include <stdio.h>

int     opterr = 1,             /* if error message should be printed */
  optind = 1,             /* index into parent argv vector */
  optopt,                 /* character checked for validity */
  optreset;               /* reset getopt */
char    *optarg;                /* argument associated with option */

#define BADCH   (int)'?'
#define BADARG  (int)':'
#define EMSG    ""

/*
* getopt --
*      Parse argc/argv argument vector.
*/
int
  getopt(int nargc, char * const nargv[], const char *ostr)
{
  static char *place = EMSG;              /* option letter processing */
  const char *oli;                        /* option letter list index */

  if (optreset || !*place) {              /* update scanning pointer */
    optreset = 0;
    if (optind >= nargc || *(place = nargv[optind]) != '-') {
      place = EMSG;
      return (-1);
    }
    if (place[1] && *++place == '-') {      /* found "--" */
      ++optind;
      place = EMSG;
      return (-1);
    }
  }                                       /* option letter okay? */
  if ((optopt = (int)*place++) == (int)':' ||
    !(oli = strchr(ostr, optopt))) {
      /*
      * if the user didn't specify '-' as an option,
      * assume it means -1.
      */
      if (optopt == (int)'-')
        return (-1);
      if (!*place)
        ++optind;
      if (opterr && *ostr != ':')
        (void)printf("illegal option -- %c\n", optopt);
      return (BADCH);
  }
  if (*++oli != ':') {                    /* don't need argument */
    optarg = NULL;
    if (!*place)
      ++optind;
  }
  else {                                  /* need an argument */
    if (*place)                     /* no white space */
      optarg = place;
    else if (nargc <= ++optind) {   /* no arg */
      place = EMSG;
      if (*ostr == ':')
        return (BADARG);
      if (opterr)
        (void)printf("option requires an argument -- %c\n", optopt);
      return (BADCH);
    }
    else                            /* white space */
      optarg = nargv[optind];
    place = EMSG;
    ++optind;
  }
  return (optopt);                        /* dump back option letter */
}

Ответ 3

Я скомпилировал код getopt под окнами.

Я сделал это так, как хотел explicilty использовать его синтаксический анализ в командной строке.

Я успешно сделал это, используя VC2010.

Насколько я помню, у меня не было никаких существенных проблем.

getopt.c getoptl.c

Ответ 5

Из того, что я помню из getopt.h, все, что он делает, представляет собой удобный парсер для обработки argv из вашей основной функции:

int main(int argc, char * argv[])
{
}

У консольных программ Windows по-прежнему есть основной метод, поэтому вы можете просто пропустить свой массив argv и самостоятельно проанализировать параметры. например.

for ( int i = 1; i < argc; i++ )
{
  if (!strcmp(argv[i], "-f"))
    filename = argv[++i];
}

Ответ 6

Вы можете попробовать искать glib-2.0 в качестве альтернативы. Это было бы немного большим для простого использования парсера параметров. Наверху сторона имела бы доступ ко всем другим замечательным игрушкам в glib.

Просто, честно говоря, я не пытался заставить это работать (я придерживаюсь в основном Linux), поэтому YMMV.

Получение glib для работы в окнах: HowTo

О, вы можете изучить использование mingw для среды сборки и визуальную студию для вашей среды IDE.

Glib для Win32: HowTo

Anywho, надеюсь, что это поможет.

Ответ 7

если вы просто хотите, чтобы getopt использовался в visual С++ без других зависимостей, у меня есть порт getopt.c из последнего gnu libc 2.12 со всеми новыми функциями. Единственное различие заключается в том, что вы должны использовать TCHAR вместо char, но это очень часто встречается в окнах.

просто загрузите исходный код, сделайте, скопируйте libgetopt.lib и getopt.h getopt_int.h в свой проект.

вы также можете использовать его с помощью CMakeList.txt в корневом каталоге.

загрузить источник из github