15

在尝试编译标准“Hello World”示例 [2] 时,我尝试在 Windows 7 + Node.js 平台上使用 node-gyp 失败了 [3]。注意:在尝试使用或不使用“-g”时,node-gyp 以类似的方式 [3] 失败npm install contextify,因此这些可能是相关问题。

配置:

  • 节点gyp 0.12.2
  • 视窗 7 x64 SP1
  • 蟒蛇 2.7
  • Node.js 0.10.24
  • 每个 [1] 的 Visual Studio 2010(也在 2012 年尝试过)
  • VS SDK 7.1 per [1](尝试 32 和 64 位版本)
  • 从标准 Windows 命令提示符或 SDK7.1 cmd 提示符运行 node-gyp

参考文献:
[1] https://github.com/TooTallNate/node-gyp/wiki/Visual-Studio-2010-Setup

[2] https://github.com/joyent/node/tree/master/test/addons/hello-world

[3] "hello world"[2] 项目上的 "node-gyp rebuild" 产生以下 2 个错误:

....node-gyp\0.10.24\deps\uv\include\win.h(8738):错误 C2371:'SYSTEM_POWER_STATUS':重新定义;不同的基本类型 [...\build\test.vcxproj]

....node-gyp\0.10.24\deps\uv\include\mswsock.h(27):致命错误 C 1083:无法打开包含文件:'_mingw.h':没有这样的文件或目录 [... \build\test.vcxproj]

并遵循 2 个警告:

....node-gyp\0.10.24\deps\uv\include\win.h(13513): 警告 C4005: 'UNALIGNED' : 宏重新定义 [...\build\test.vcxproj]

....node-gyp\0.10.24\deps\uv\include\mswsock.h(26):警告 C4068:未知编译指示 [...\build\test.vcxproj]

完整的跟踪如下:

C:\sigma\node_modules\x>node-gyp rebuild
gyp info it worked if it ends with ok
gyp info using node-gyp@0.12.2
gyp info using node@0.10.24 | win32 | x64
gyp info spawn python
gyp info spawn args [ 'C:\\Users\\Anybody\\AppData\\Roaming\\npm\\node_modules\\node-gyp\\gyp\\gyp_main.py',
gyp info spawn args   'binding.gyp',
gyp info spawn args   '-f',
gyp info spawn args   'msvs',
gyp info spawn args   '-G',
gyp info spawn args   'msvs_version=auto',
gyp info spawn args   '-I',
gyp info spawn args   'C:\\sigma\\node_modules\\x\\build\\config.gypi',
gyp info spawn args   '-I',
gyp info spawn args   'C:\\Users\\Anybody\\AppData\\Roaming\\npm\\node_modules\\node-gyp\\addon.gypi',
gyp info spawn args   '-I',
gyp info spawn args   'C:\\Users\\Anybody\\.node-gyp\\0.10.24\\common.gypi',
gyp info spawn args   '-Dlibrary=shared_library',
gyp info spawn args   '-Dvisibility=default',
gyp info spawn args   '-Dnode_root_dir=C:\\Users\\Anybody\\.node-gyp\\0.10.24',
gyp info spawn args   '-Dmodule_root_dir=C:\\sigma\\node_modules\\x',
gyp info spawn args   '--depth=.',
gyp info spawn args   '--generator-output',
gyp info spawn args   'C:\\sigma\\node_modules\\x\\build',
gyp info spawn args   '-Goutput_dir=.' ]
gyp info spawn msbuild
gyp info spawn args [ 'build/binding.sln',
gyp info spawn args   '/clp:Verbosity=minimal',
gyp info spawn args   '/nologo',
gyp info spawn args   '/p:Configuration=Release;Platform=x64' ]
Building the projects in this solution one at a time. To enable parallel build, please add the "/m" switch.  test.cpp
C:\Users\Anybody\.node-gyp\0.10.24\deps\uv\include\win.h(8738): error C2371: 'SYSTEM_POWER_STATUS' : redefinition; different basic types [C:\sigma\node_modules\x\build\test.vcxproj]  C:\Users\Anybody\.node-gyp\0.10.24\deps\uv\include\win.h(8737) : see declaration of 'SYSTEM_POWER_STATUS'

C:\Users\Anybody\.node-gyp\0.10.24\deps\uv\include\win.h(13513): warning C4005: 'UNALIGNED' : macro redefinition [C:\sigma\node_modules\x\build\test.vcxproj] C:\Program Files (x86)\Microsoft Visual Studio 10.0\VC\include\crtdef s.h(502) : see previous definition of 'UNALIGNED'

C:\Users\Anybody\.node-gyp\0.10.24\deps\uv\include\mswsock.h(26): warning C4068 : unknown pragma [C:\sigma\node_modules\x\build\test.vcxproj] C:\Users\Anybody\.node-gyp\0.10.24\deps\uv\include\_mingw.h(33): warning C4068: unknown pragma [C:\sigma\node_modules\x\build\test.vcxproj]

C:\Users\Anybody\.node-gyp\0.10.24\deps\uv\include\_mingw.h(51): fatal error C1 189: #error :  ERROR: You must use a GNU Compiler. [C:\sigma\node_modules\x\build\test.vcxproj]

gyp ERR! build error
gyp ERR! stack Error: msbuild failed with exit code: 1
gyp ERR! stack at ChildProcess.onExit (C:\Users\Anybody\AppData\Roaming\npm\
node_modules\node-gyp\lib\build.js:267:23)
gyp ERR! stack at ChildProcess.EventEmitter.emit (events.js:98:17)
gyp ERR! stack at Process.ChildProcess._handle.onexit (child_process.js:789:12)
gyp ERR! System Windows_NT 6.1.7601
gyp ERR! command "node" "C:\\Users\\Anybody\\AppData\\Roaming\\npm\\node_modules\\node-gyp\\bin\\node-gyp.js" "rebuild"
gyp ERR! cwd C:\sigma\node_modules\x
gyp ERR! node -v v0.10.24
gyp ERR! node-gyp -v v0.12.2
gyp ERR! not ok   
4

3 回答 3

9

虽然这个问题是一个月前的,但我最终在网上搜索,这是搜索结果的一部分。

所以这是一个不应该做但它有效的答案。

首先,我不熟悉node-gyp或整个 Visual Studio 编译之类的东西,我真的为依赖于 python 的 node-gyp 感到抱歉(一个非常沉默的WTF

因此,出于未知原因,nodejs 版本早于 0.10.22(我现在正在运行它,所以我假设它从哪里开始)

如果您在系统中搜索文件“uv.h”,如果您之前安装了 nodejs 版本,您可能会得到一些结果,否则您可以继续阅读。

我以前的 0.10.3 nodejs 版本已uv.h进入 node-gyp 之类的

<DRIVERLETTER>:\Users\<USERNAME>\.node-gyp\0.10.3\deps\uv

因此,如果您阅读 npm 文档,您会发现论点npm install

--nodedir=/path/to/node/source 参数将允许 npm 找到节点源代码,以便 npm 可以编译本机模块。

所以最终的命令应该是

npm install <package> --nodedir="<DRIVERLETTER>:\Users\<USERNAME\.node-gyp\0.10.3"

您可能会收到一些警告,但它应该会成功完成。

于 2014-03-03T10:37:00.800 回答
1

在你做任何事情之前,通过从节点网站安装来更新节点和 NPM(通过 npm 更新节点和 npm 似乎在 Windows 上被破坏了。我不确定那些删除并重新安装一切的指令是最新的但这肯定会是一个主要的 PITA,这激发了我寻找替代方案,因为那个帖子在节点年代有点旧。

最终,这解决了我使用 node-gyp 作为 pg 模块的依赖项的问题,并且我相信它与 vs 2013 一起运行(或者至少在它开始工作之前它似乎正在寻找它)。

于 2014-11-16T17:14:19.380 回答
0

这就是帮助我解决它的原因:

出于某种原因,我在两个不同的目录中有 node-gyp。

目录1:

C:\Users\Imran Bughio\.node-gyp\0.10.21\

目录 2:

C:\Users\Imran Bughio\Documents\.node-gyp\0.10.21\


在第二个目录中,我在文件夹中有一个uv文件deps夹,但该文件夹不在第一个目录中。

这是路径——注意里面有uv.h文件。

C:\Users\Imran Bughio\.node-gyp\0.10.21\deps\uv

解决方案:

我只是将 uv 和所有其他额外文件夹从目录 2 移动到目录 1。

@Phoenix 的回答给了我一点提示,最终帮助我解决了这个问题,谢谢 Phoenix。

于 2014-05-22T16:05:12.453 回答