Есть ли замена для unistd.h для Windows (Visual C)?
Я портирую относительно простую консольную программу, написанную для Unix, на платформу Windows (Visual c/" class="blnk">C++ 8.0). Все исходные файлы включают " unistd.х", которого не существует. Удаляя его, я получаю жалобы на неправильные прототипы для "srandom", "random" и "getopt". Я знаю, что могу заменить случайные функции, и я уверен, что могу найти/взломать реализацию getopt.
но я уверен, что другие столкнулись с той же проблемой. Мой вопрос: есть ли портвейн " unistd.h " к окнам? По крайней мере, один containg тех функций, которые имеют собственную реализацию Windows - мне не нужны трубы или разветвления.
редактировать:
Я знаю, что могу создать свой собственный "unistd.h", который содержит замены для вещей, которые мне нужны, особенно в этом случае, поскольку это ограниченный набор. Но поскольку это кажется общей проблемой, мне было интересно, сделал ли кто-то работу уже для большего подмножества функциональность.
переключение на другой компилятор или среду невозможно на работе - я застрял в Visual Studio.
6 ответов
поскольку мы не можем найти версию в Интернете, давайте начнем здесь.
Большинство портов для Windows, вероятно, требуется только подмножество полного файла Unix.
Вот отправная точка. При необходимости добавьте определения.
#ifndef _UNISTD_H
#define _UNISTD_H 1
/* This is intended as a drop-in replacement for unistd.h on Windows.
* Please add functionality as neeeded.
* https://stackoverflow.com/a/826027/1202830
*/
#include <stdlib.h>
#include <io.h>
#include <getopt.h> /* getopt at: https://gist.github.com/ashelly/7776712 */
#include <process.h> /* for getpid() and the exec..() family */
#include <direct.h> /* for _getcwd() and _chdir() */
#define srandom srand
#define random rand
/* Values for the second argument to access.
These may be OR'd together. */
#define R_OK 4 /* Test for read permission. */
#define W_OK 2 /* Test for write permission. */
//#define X_OK 1 /* execute permission - unsupported in windows*/
#define F_OK 0 /* Test for existence. */
#define access _access
#define dup2 _dup2
#define execve _execve
#define ftruncate _chsize
#define unlink _unlink
#define fileno _fileno
#define getcwd _getcwd
#define chdir _chdir
#define isatty _isatty
#define lseek _lseek
/* read, write, and close are NOT being #defined here, because while there are file handle specific versions for Windows, they probably don't work for sockets. You need to look at your app and consider whether to call e.g. closesocket(). */
#ifdef _WIN64
#define ssize_t __int64
#else
#define ssize_t long
#endif
#define STDIN_FILENO 0
#define STDOUT_FILENO 1
#define STDERR_FILENO 2
/* should be in some equivalent to <sys/types.h> */
typedef __int8 int8_t;
typedef __int16 int16_t;
typedef __int32 int32_t;
typedef __int64 int64_t;
typedef unsigned __int8 uint8_t;
typedef unsigned __int16 uint16_t;
typedef unsigned __int32 uint32_t;
typedef unsigned __int64 uint64_t;
#endif /* unistd.h */
Я бы рекомендовал использовать по MinGW/префикса msys как среда разработки. Особенно, если вы переносите простые консольные программы. Msys реализует Unix-подобную оболочку в Windows, а mingw-порт коллекция компиляторов GNU (GCC) и другие инструменты сборки GNU для платформы Windows. Это проект с открытым исходным кодом и хорошо подходит для этой задачи. В настоящее время я использую его для создания утилит и консольных приложений для Windows XP, и у него, безусловно, есть это
я наткнулся на эту тему, пытаясь найти альтернативу Windows для getpid()
(определена в unistd.h
). Оказывается, что в том числе process.h
делает трюк. Возможно, это поможет людям, которые найдут эту нить в будущем.
нет, IIRC нет getopt () на Windows.
Boost, однако, имеет program_options библиотека... что работает нормально. Сначала это покажется излишним, но это не страшно, особенно учитывая, что он может обрабатывать параметры настройки программы в файлах конфигурации и переменных среды в дополнение к параметрам командной строки.
создайте свой собственный unistd.H заголовок и включить необходимые заголовки для прототипов функций.