Compilation 跳过某些操作系统的端口编译?
我有一个基于钢筋的Erlang应用程序,它构建了一个端口程序。此端口程序特定于Linux,因此在Mac OS上编译失败。但是,我希望钢筋在Mac OS上构建时跳过端口程序。我该怎么做Compilation 跳过某些操作系统的端口编译?,compilation,erlang,rebar,Compilation,Erlang,Rebar,我有一个基于钢筋的Erlang应用程序,它构建了一个端口程序。此端口程序特定于Linux,因此在Mac OS上编译失败。但是,我希望钢筋在Mac OS上构建时跳过端口程序。我该怎么做 rebar.config中的当前规范如下所示: {port_specs, [{"priv/my_port", ["c_src/foo.c", "c_src/bar.c"]}]}. {port_specs, [{"linux", "priv/my_port", ["c_src/foo.c", "c_src/bar.
rebar.config
中的当前规范如下所示:
{port_specs, [{"priv/my_port", ["c_src/foo.c", "c_src/bar.c"]}]}.
{port_specs, [{"linux", "priv/my_port", ["c_src/foo.c", "c_src/bar.c"]}]}.
如前所述,port_specs
的列表元素具有另一种形式{ArchRegex,TargetFile,Sources}
。因此,请按照以下方式编写钢筋配置:
{port_specs, [{"priv/my_port", ["c_src/foo.c", "c_src/bar.c"]}]}.
{port_specs, [{"linux", "priv/my_port", ["c_src/foo.c", "c_src/bar.c"]}]}.
“那个正则表达式和什么匹配?”你可能会问。它与的返回值匹配,返回值由以下部分组成,用连字符分隔:
- 由
返回的OTP版本,例如erlang:system\u info(OTP\u release)
“R15B02”
- 由
返回的系统架构。对于类Unix系统,这是由配置脚本确定的CPU供应商操作系统三元组,例如erlang:system\u info(system\u architecture)
或“i386-apple-darwin10.8.0”
“x86\u 64-unknown-linux-gnu”
- 仿真器字号32或64,基于
的返回值erlang:system\u info({wordsize,external})
- 操作系统系列,
或unix
。(由win32
返回的元组的第一个元素)os:type/0
“R15B01-i386-apple-darwin10.8.0-32-unix”
或“R15B02-x86-U 64-unknown-linux-gnu-64-unix”
,因为端口规范的列表元素有另一种形式{ArchRegex,TargetFile,Sources}
。因此,请按照以下方式编写钢筋配置:
{port_specs, [{"priv/my_port", ["c_src/foo.c", "c_src/bar.c"]}]}.
{port_specs, [{"linux", "priv/my_port", ["c_src/foo.c", "c_src/bar.c"]}]}.
“那个正则表达式和什么匹配?”你可能会问。它与的返回值匹配,返回值由以下部分组成,用连字符分隔:
- 由
erlang:system\u info(OTP\u release)
返回的OTP版本,例如“R15B02”
- 由
erlang:system\u info(system\u architecture)
返回的系统架构。对于类Unix系统,这是由配置脚本确定的CPU供应商操作系统三元组,例如“i386-apple-darwin10.8.0”
或“x86\u 64-unknown-linux-gnu”
- 仿真器字号32或64,基于
erlang:system\u info({wordsize,external})
的返回值
- 操作系统系列,
unix
或win32
。(由os:type/0
返回的元组的第一个元素)
因此,最终结果将类似于“R15B01-i386-apple-darwin10.8.0-32-unix”
或“R15B02-x86_64-unknown-linux-gnu-64-unix”