- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我浏览了此处构建的 scons 示例,发现他们希望提供适合我的项目的解决方案。
结构如下:
root/
Module_A/
include/
foo.h
bar.h
src/
foo.cpp
bar.cpp
Module_.../
每个模块都遵循相同的结构,一个用于所有 .h 的包含文件夹和一个用于 cpps 的 src 文件。每个模块构建成一个共享对象。没有可执行文件。
模块具有交叉依赖性。例如,Module_A 是日志记录机制,用于模块 B、C、D 等。同样,Module_B 是配置加载器,用于其他几个模块。 Module_C 将是 IPC 模块,几乎在列出的每个模块中都有使用。最后,Module_D 是命令中心并链接到所有其他模块(字面意思)。
我有兴趣替换我们使用递归 make 构建项目的当前设置。我正在尝试构建这样做所必需的 sconstruct 和 SConscripts,但我什至还很陌生,更不用说 scons 了。
我有兴趣将每个模块的 .cpp 和 .h 转换为 .so 并像现在使用 make 那样自动解析其依赖关系。
在 SConscript 中,我目前使用 glob 获取 *.cpps,然后将模块的“./include”包含在 CPPPATH 中。我用过
env.SharedLibrary(CPPATH='./include', source= (cpps 列表))
但是因为这依赖于其他模块,所以它不会工作,说明使用的其他模块的功能“未声明”。
如何使用分层 scons 设置来构建这种复杂的结构?
最佳答案
使用 SCons 应该很容易做到这一点。您可能希望在每个模块的根目录下都有一个 SConscript 脚本。这些都将由位于整个项目根目录的 SConstruct 脚本调用。
如果我理解正确,模块之间的依赖关系问题可以通过正确指定所有模块的包含路径来解决。这可以在 SConstruct 中创建的环境中一次完成,然后应该将其传递给模块 SConscript 脚本。
这是一个简单的例子:
构建
env = Environment()
# Notice that the '#' in paths makes the path relative to the root SConstruct
includePaths = [
'#/Module_A/include',
'#/Module_B/include',
'#/Module_N/include',
]
env.Append(CPPPATH=includePaths)
SConscript('Module_A/SConscript', exports='env', duplicate=0)
SConscript('Module_B/SConscript', exports='env', duplicate=0)
SConscript('Module_N/SConscript', exports='env', duplicate=0)
Module_A/SConscript
Import('env')
# Notice the CPPPATH's have already been set on the env created in the SConstruct
env.SharedLibrary(target = 'moduleA', source = ModuleA_SourceFiles)
Module_B/SConscript
Import('env')
# Notice the CPPPATH's have already been set on the env created in the SConstruct
env.SharedLibrary(target = 'moduleB', source = ModuleB_SourceFiles)
Module_N/SConscript
Import('env')
# Notice the CPPPATH's have already been set on the env created in the SConstruct
env.SharedLibrary(target = 'moduleN', source = ModuleN_SourceFiles)
关于build - Scons分层构建,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14388552/
我正在为 scons 扩展一个命令,但来源不完整。一些 xml pdf 文档不存在。 根据 scons wiki,我可以使用scons -i (--ignore-errors,忽略为重建文件而执行的命
在构建我的程序时,区分不存在的文件和空文件很重要。但是,scons 似乎对它们一视同仁,并且在源文件从这些状态之一更改为另一种状态时忽略了重建目标。 逐步示例: 第 0 步: 构造 foo = Com
我正在使用 scons 构建两个项目。一个效果很好,而另一个(更复杂的)项目非常令人沮丧。这是我在为第二个项目运行 scons 时看到的: S time scons scons: Reading SC
我最近从 make 转换为 SCons。我通常在 make 中做的一件事是有一个从源文件生成预处理源的方法,其中包含将应用于正常构建的所有编译器选项。这对于确定 header 的包含方式很有用。 在
我有一个使用 scons 构建的大型 C++ 项目。 它的构建速度很慢,我想进行一些更改以使其构建速度更快。 现在我想集中我的时间来加速构建中最慢的部分。 如何确定哪些文件需要最长的编译时间? 最佳答
我想对所有 .o 做一些后期处理文件(例如由 Object 或 StaticObject Builders 生成的文件),无论用户使用什么 Builder。 我试图像这样“覆盖”或“ Hook ”基础
更新作为构建一部分的文件内容的正确 SCONS 方法是什么? 我使用 SCONS 来构建一个相当大的项目。但是为了一个简单的问题,假设它看起来像这样: env.Program("foo", ["foo
我不想使用 scons --n,我想看看某些东西是如何构建的,而不是现在如何构建。 我认为它可以以某种方式使用 .sconsdblite。 有人做过吗? 最佳答案 SCons man pages解释了
我正在尝试让 SCons 检查我需要的 git 存储库(并希望使该存储库保持最新状态)。问题是我必须告诉它 git repo 包含哪些文件才能在构建中使用它们,如果我这样做,SCons 将在尝试克隆它
我需要作为自定义构建器的一部分按顺序运行两个程序。 其中一个程序我被困住了,无法处理绝对/相对路径,因此我必须使用构建器的 chdir=1 选项才能运行其操作与目标位于同一目录中。 第二个是位于项目的
我正在尝试建立一个涉及代码生成器的构建系统。在生成器运行之前,生成的确切文件是未知的,但我希望能够通过模式匹配运行进一步的构建步骤(在具有某些扩展名的所有文件上运行一些程序)。这可能吗? 这里涉及代码
我有一个简单的项目构建系统,我使用SCons将其组合在一起。 。该项目有相当多的源文件,我认为在构建过程中显示某种进度信息将是用户友好的。 SCons 提供了诸如 CXXCOMSTR 之类的构造变量,
我正在为不同的编译器使用 scons。vc10 和瑞萨编译器。如果我使用 env.program(---) 编译程序,我得到的链接标志为 “链接/nologo/subsystem:console/pd
我有一个分层构建,它使用 SConscript 递归地声明构建目标;所以我事先不知道目标。每个构建都会产生一些额外的文件,比如 *.err *.out ,这些文件不在目标中。当我运行 scons -c
我正在使用 scons 来构建一个项目。效果很好。但是我们的构建命令只是将结果输出到标准输出,我需要让它对我们的软件团队更有用一点。 以下是我想要的行为,按优先顺序排列。有人可以帮我实现它们吗? 没有
我的团队正在创建一个基于 SCons 的构建系统。我们在自己的 site_scons/site_tools 文件夹中创建了一堆辅助类。 我的任务是使用 pyunit 在我们的代码上创建和运行测试。测试
我有一个自定义构建器如下 my_builder = Builder(action = ['mytool' + env['TESTFLAG'] + ' $SOURCE -o $TARGET')],
我有一个仅包含头文件的库,其中包含一个文件夹层次结构和一堆 .hpp我想安装的文件。我的问题是,该 scons 不会将该文件夹复制到构建文件夹中。 这是我的目录布局的样子: root SConst
我正在使用 scons 为一个较大的软件项目实现构建系统。有一个目录结构将各个库和程序的代码分离到它们自己的目录中。使用我们现有的 make 系统,我可以在单个程序目录中执行“make clean”,
默认情况下,SCons 似乎会查看用于构建程序的“配方”并从中提取隐式依赖项。例如假设我的 SConstruct 包含: Command('foo', 'foocreator.py', '/usr/b
我是一名优秀的程序员,十分优秀!