错误:命名空间“std”中没有名为“remove_cv_t”的模板;你的意思是“remove_cv”? node-sass is not yet compatible with node v16如何让你的 Rails 应用使用 node 14

问题描述

我的问题似乎与 this 问题类似,但它发生在我在 Rails 应用中运行 yarn install 时。

当我运行yarn install时,它成功运行了一段时间,然后

../src/libsass/src/ast.hpp:1614:25: warning: loop variable 'numerator' of type 'const std::__1::basic_string<char>' creates a copy from type 'const std::__1::basic_string<char>' [-Wrange-loop-analysis]
        for (const auto numerator : numerators)
                        ^
../src/libsass/src/ast.hpp:1614:14: note: use reference type 'const std::__1::basic_string<char> &' to prevent copying
        for (const auto numerator : numerators)
             ^~~~~~~~~~~~~~~~~~~~~~
                        &
../src/libsass/src/ast.hpp:1616:25: warning: loop variable 'denominator' of type 'const std::__1::basic_string<char>' creates a copy from type 'const std::__1::basic_string<char>' [-Wrange-loop-analysis]
        for (const auto denominator : denominators)
                        ^
../src/libsass/src/ast.hpp:1616:14: note: use reference type 'const std::__1::basic_string<char> &' to prevent copying
        for (const auto denominator : denominators)
             ^~~~~~~~~~~~~~~~~~~~~~~~
                        &
2 warnings generated.
  rm -f Release/sass.a && ./gyp-mac-tool filter-libtool libtool  -static -o Release/sass.a Release/obj.target/libsass/src/libsass/src/ast.o Release/obj.target/libsass/src/libsass/src/ast_fwd_decl.o Release/obj.target/libsass/src/libsass/src/backtrace.o Release/obj.target/libsass/src/libsass/src/base64vlq.o Release/obj.target/libsass/src/libsass/src/bind.o Release/obj.target/libsass/src/libsass/src/cencode.o Release/obj.target/libsass/src/libsass/src/check_nesting.o Release/obj.target/libsass/src/libsass/src/color_maps.o Release/obj.target/libsass/src/libsass/src/constants.o Release/obj.target/libsass/src/libsass/src/context.o Release/obj.target/libsass/src/libsass/src/cssize.o Release/obj.target/libsass/src/libsass/src/emitter.o Release/obj.target/libsass/src/libsass/src/environment.o Release/obj.target/libsass/src/libsass/src/error_handling.o Release/obj.target/libsass/src/libsass/src/eval.o Release/obj.target/libsass/src/libsass/src/expand.o Release/obj.target/libsass/src/libsass/src/extend.o Release/obj.target/libsass/src/libsass/src/file.o Release/obj.target/libsass/src/libsass/src/functions.o Release/obj.target/libsass/src/libsass/src/inspect.o Release/obj.target/libsass/src/libsass/src/json.o Release/obj.target/libsass/src/libsass/src/lexer.o Release/obj.target/libsass/src/libsass/src/listize.o Release/obj.target/libsass/src/libsass/src/memory/SharedPtr.o Release/obj.target/libsass/src/libsass/src/node.o Release/obj.target/libsass/src/libsass/src/operators.o Release/obj.target/libsass/src/libsass/src/output.o Release/obj.target/libsass/src/libsass/src/parser.o Release/obj.target/libsass/src/libsass/src/plugins.o Release/obj.target/libsass/src/libsass/src/position.o Release/obj.target/libsass/src/libsass/src/prelexer.o Release/obj.target/libsass/src/libsass/src/remove_placeholders.o Release/obj.target/libsass/src/libsass/src/sass.o Release/obj.target/libsass/src/libsass/src/sass2scss.o Release/obj.target/libsass/src/libsass/src/sass_context.o Release/obj.target/libsass/src/libsass/src/sass_functions.o Release/obj.target/libsass/src/libsass/src/sass_util.o Release/obj.target/libsass/src/libsass/src/sass_values.o Release/obj.target/libsass/src/libsass/src/source_map.o Release/obj.target/libsass/src/libsass/src/subset_map.o Release/obj.target/libsass/src/libsass/src/to_c.o Release/obj.target/libsass/src/libsass/src/to_value.o Release/obj.target/libsass/src/libsass/src/units.o Release/obj.target/libsass/src/libsass/src/utf8_string.o Release/obj.target/libsass/src/libsass/src/util.o Release/obj.target/libsass/src/libsass/src/values.o
  c++ '-DNODE_GYP_MODULE_NAME=binding' '-DUSING_UV_SHARED=1' '-DUSING_V8_SHARED=1' '-DV8_DEPRECATION_WARNINGS=1' '-DV8_DEPRECATION_WARNINGS' '-DV8_IMmineNT_DEPRECATION_WARNINGS' '-D_GLIBCXX_USE_CXX11_ABI=1' '-D_DARWIN_USE_64_BIT_INODE=1' '-D_LARGEFILE_SOURCE' '-D_FILE_OFFSET_BITS=64' '-DBUILDING_NODE_EXTENSION' -I/Users/st/.node-gyp/16.0.0/include/node -I/Users/st/.node-gyp/16.0.0/src -I/Users/st/.node-gyp/16.0.0/deps/openssl/config -I/Users/st/.node-gyp/16.0.0/deps/openssl/openssl/include -I/Users/st/.node-gyp/16.0.0/deps/uv/include -I/Users/st/.node-gyp/16.0.0/deps/zlib -I/Users/st/.node-gyp/16.0.0/deps/v8/include -I../../nan -I../src/libsass/include  -O3 -gdwarf-2 -mmacosx-version-min=10.7 -arch x86_64 -Wall -Wendif-labels -W -Wno-unused-parameter -std=c++11 -stdlib=libc++ -fno-rtti -fno-exceptions -fno-strict-aliasing -MMD -MF ./Release/.deps/Release/obj.target/binding/src/binding.o.d.raw   -c -o Release/obj.target/binding/src/binding.o ../src/binding.cpp
In file included from ../src/binding.cpp:1:
In file included from ../../nan/nan.h:56:
In file included from /Users/st/.node-gyp/16.0.0/include/node/node.h:63:
In file included from /Users/st/.node-gyp/16.0.0/include/node/v8.h:30:
/Users/st/.node-gyp/16.0.0/include/node/v8-internal.h:452:38: error: no template named 'remove_cv_t' in namespace 'std'; did you mean 'remove_cv'?
            !std::is_same<Data,std::remove_cv_t<T>>::value>::Perform(data);
                                ~~~~~^~~~~~~~~~~
                                     remove_cv
/Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/../include/c++/v1/type_traits:697:50: note: 'remove_cv' declared here
template <class _Tp> struct _LIBCPP_TEMPLATE_VIS remove_cv
                                                 ^
1 error generated.
make: *** [Release/obj.target/binding/src/binding.o] Error 1
gyp ERR! build error 
gyp ERR! stack Error: `make` Failed with exit code: 2
gyp ERR! stack     at ChildProcess.onExit (/Users/st/rails/myapp/node_modules/node-gyp/lib/build.js:262:23)
gyp ERR! stack     at ChildProcess.emit (node:events:365:28)
gyp ERR! stack     at Process.ChildProcess._handle.onexit (node:internal/child_process:290:12)
gyp ERR! System Darwin 20.3.0
gyp ERR! command "/usr/local/Cellar/node/16.0.0/bin/node" "/Users/st/rails/myapp/node_modules/node-gyp/bin/node-gyp.js" "rebuild" "--verbose" "--libsass_ext=" "--libsass_cflags=" "--libsass_ldflags=" "--libsass_library="
gyp ERR! cwd /Users/st/rails/myapp/node_modules/node-sass
gyp ERR! node -v v16.0.0
gyp ERR! node-gyp -v v3.8.0
gyp ERR! not ok 

任何想法如何解决这个问题? (我什至不确定这是不是 xcode/node/rails/c++ 的问题)

其他注意事项

  • /usr/bin/xcodebuild -version 返回
Xcode 12.4
Build version 12D4e
  • cpp --version 返回
Apple clang version 12.0.0 (clang-1200.0.32.29)
Target: x86_64-apple-darwin20.3.0
Thread model: posix
InstalledDir: /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin

请注意:我不在 cpp 中编码,所以我对如何解决的上下文知识知之甚少。

解决方法

您看到的是 node-sass 编译期间的错误。这是一个处理你的 Sass/SCSS 样式的包,它是用 C++ 编写的,并且只重新打包为一个 JavaScript 库。它是用 C++ 编写的,这意味着它需要在安装期间在您的设备上编译(这是由一个名为 node-gyp 的工具在内部完成的,您也可以在错误输出中找到它)。

问题是 node-sass 不支持 Node 16 在撰写此答案时,请参阅跟踪问题:https://github.com/sass/node-sass/issues/3077 没有估计何时会支持它(这是公平的,因为这是一个志愿者驱动的项目)。即使您设法在 Node 16 上安装 node-sass,我也建议您不要这样做,因为该行为可能未定义。

正确的解决方案是将您的 Node 安装降级到受支持的版本(我可以看到 14 和 15 在他们的 CI 中进行了测试)。如果您 git 克隆了一个项目并且它不会安装在您的机器上,但可以为您的同事或生产服务器工作,则该项目可能也考虑了不同版本的 Node,并且未在 Node 16 上进行测试,所以我建议不要在 Node 16 上开发它。如果该项目几天前对您有用,但现在不起作用,则很可能您最近升级了系统设置(例如 Homebrew),将您升级到 Node 16(这就是发生在我身上的事情以及我的方式发现这个问题)。

您应该与项目的作者核实它运行的 Node 的生产服务器版本是什么,并在本地安装该版本。作为最佳实践,将来保持生产版本和您本地版本的 Node(以及 yarn 或 npm)同步。要管理多个 Node 版本,您可以使用此工具 https://github.com/nvm-sh/nvm

,

node-sass is not yet compatible with node v16

明智的做法是降级 node(例如 to version 14),直到 node-sass 与 v16 兼容。要使用 nvm 降级节点,只需运行:

nvm install 14

通过 running 全局设置版本 14(因此每个新的终端窗口默认为节点版本 14):

nvm alias default 14

现在您已经安装了节点 14 并将其设置为默认值! ..现在你只需要让你的应用使用 v14。


如何让你的 Rails 应用使用 node 14

安装节点 14(见上文)。打开终端并前往您应用的根目录,然后:

  1. 如果 Rails 服务器正在运行,请停止它
  2. 打开一个新的终端窗口(以便 node --version 返回 14.x(不是 16)
  3. 运行spring stop
  4. 删除yarn.lock
  5. 使用 rm -rf node_modules 删除现有的节点模块
  6. 检查 node --version 是否返回 14。如果它没有再次运行 nvm install 14
  7. 现在使用 yarn install 重新安装模块(如果节点 14 没有纱线,请使用 npm install --global yarn 安装)
  8. 它应该会成功!
  9. 重启你的 rails 服务器,它就可以工作了!
,

恢复到最新的 Node v14 LTS 以使用 node-sass

brew install node@14
brew unlink node
brew link node@14
node -v
spring stop

在您的 Rails 项目中运行:

yarn install

PS:节点 16 有一个错误,node-sass https://github.com/nodejs/node/issues/38367#issuecomment-825461899

,

与@murb 类似,前几天我在构建盒上运行了 brew 更新,并注意到节点 16 已安装。将它放回节点 12 为我解决了这个问题,直到我可以更新我的整个构建系统以在较新版本的节点上正常工作。

,

由于此问题的一些答案,新版本的 node-sass (v6) 已发布,通过添加对节点 16 的支持来修复该问题。

就我而言,Rails 依赖于旧版本的 node-sass,因为我的 @rails/webpacker (package.json) 中有 4.3.0 的版本。在此回答 5.4.0 时将其更新到当前版本之后的版本解决了问题。

,

我试图用 cpp --version 查看我当前的版本

cpp --version Apple clang version 12.0.0 (clang-1200.0.32.29)
Target: x86_64-apple-darwin20.3.0
Thread model: posix
InstalledDir: /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin

编译器版本不是C++标准版本。

前者是工具的版本,后者是C++标准的版本。

最近所有主要的 C++ 编译器(我知道)同时支持多种 C++ 标准。

如果要开发可移植(符合标准)的代码,C++ 标准很重要——与特定的编译器无关。这允许为多个平台开发代码,由不同的编译器编译。它还有助于以更好的质量进行开发——代码中的弱点可能会在一个供应商的编译器中漏掉(即可以容忍),而在另一个供应商中可能会被抱怨。

在编译器中明确选择 C++ 标准也很重要:

  • 最新支持的编译器标准可能仍处于试验阶段。
  • 开发人员可能会针对某个(较旧的)标准进行开发(以与可用编译器尚不支持最新 C++ 标准的其他平台保持兼容),并希望确保不会出现更新的内容。立>

具有特定编译器版本的编译器通常默认为特定 C++ 标准。 (可以在文档中或在线找到它。)不过,这不一定是最新支持的 C++ 标准。

C++ 标准的明确选择可以通过命令行参数来完成:

  • g++ 和 clang:-std=(可能还有其他供应商的编译器)
  • MSVC:/std:

例如g++ -std=c++14 调用强制为 C++14 标准的 G++。

这个命令行参数对于所有编译器/供应商来说并不完全相同,这有点令人遗憾。因此,在使用的构建工具中定义所需的 C++ 标准更方便。 (构建的工具会根据找到/使用的编译器来选择合适的命令行参数。)

对于 CMake(我在日常工作中使用的),这是

set(CMAKE_CXX_STANDARD 17)
set(CMAKE_CXX_STANDARD_REQUIRED ON)
set(CMAKE_CXX_EXTENSIONS OFF)

(对于极端情况,可能需要额外的设置,因为我曾经痛苦地发现:SO: Pointer to member variable as static member。)

OP 使用 yarn,我承认以前从未听说过。

他报告说 yarn install -std=c++17 解决了他的问题。 (我试图在网上找到某种文档。但我失败了。)

,

也许不是这个问题的直接答案,但我在 TravisCI 中调试失败的构建时遇到了这个问题,并导致我推动了很多提交来修复。对我来说,这是几天前由 the fact that Node 16 was released 引起的。我注意到我在 before_script 中使用了 nvm install node,它总是默认为最新的,而不是 nvm install,它实际上遵循 .nvmrc 中指定的版本。虽然使用旧版本的东西不是一个长期的解决方案; yarn install -std=c++14 就在那条线上对我来说已经失败了。

,

我在使用 Node 16 时遇到了同样的问题。降级到 Node 14 对我来说效果很好。 以下是有关如何执行相同操作的简单步骤(使用 Homebrew):

  • 检查您当前的节点版本

    节点 -v

  • 检查可用的节点版本

    brew 搜索节点

  • 取消与当前版本的链接

    brew unlink 节点

  • 使用以下命令安装您想要的版本(例如版本 14)

    brew install node@14

  • 将其链接到已安装的版本

    酿造链接节点@14

最后,请确保您使用第一步中的命令安装了正确的版本。

,

升级到最近发布的 node-sass@6 added support for Node 16

,

我在构建 node-sass 时遇到此错误。

/Users/shahwarkhalid/.node-gyp/16.6.1/include/node/v8-internal.h:488:38: error: no template named 'remove_cv_t' in namespace 'std'; did you mean 'remove_cv'?

这个 hack 解决了我的问题:

cd /Users/shahwarkhalid/.node-gyp/16.6.1/include/node/

在编辑器中打开 v8-internal.h 文件。

在第 488 行将 remove_cv_t 更改为 remove_cv

再次

yarn install,问题得到解决。

,

我不知道 const auto numerator

但是当我编辑 ~/Library/Caches/node-gyp/16.4.0/include/node/v8-internal.h(你的目录不同)时,如我的终端错误所示,它继续编译,没有错误。

我的解决方案:

我按照错误消息的指示将 remove_cv_t 重命名为 remove_cv

然后继续编译。


在这个临时修复之后我下一步计划是更新 ng xcode。也许它具有错误消息中提示的更新模板定义

template <class _Tp> struct _LIBCPP_TEMPLATE_VIS remove_cv
,

对于苹果 M1 芯片,工作方式是:

sudo xcode-select --install
curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.37.2/install.sh | bash
nvm install v15
nvm cache clear
,

就我而言,我只是将节点从 12 切换到 10:

nvm use 10