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

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

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

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

Ответы на вопрос(8)

яdid скомпилироватьgetopt код под windows.

Я сделал это так, как хотелexplicilty использовать его функцию синтаксического анализа командной строки в приложении Windows (командной строки).

Я успешно сделал это с помощьюVC2010.

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

getopt.c getoptl.c

Getopt.h существует в git, я скачал его и у меня работает:

https://gist.github.com/ashelly/7776712

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

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

Вы также можете сделать это, используя CMakeList.txt в корневом каталоге.

скачать исходник с github

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 */
}

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

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

Начало работы в Windows:Как

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

Glib для Win32:Как

Надеюсь, это поможет.

Существует возможность использовать код из среды выполнения MinGW (Тодд С. Миллер):

http://sourceforge.net/apps/trac/mingw-w64/browser/trunk/mingw-w64-crt/misc

Я создал небольшую библиотеку с этими файлами и сценарием CMake (может генерировать проект VS):

https://github.com/alex85k/wingetopt

Решение Вопроса

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

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

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

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

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

Удачи!

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

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

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

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

Ваш ответ на вопрос