我正在设置SCons来遵循在构建期间自动生成的文件的依赖关系,并且可以使用多线程构建正常工作.
原文链接:https://www.f2er.com/javaschema/281401.html我正在建立的项目是一个CIM提供程序,包括定义数据结构的MOF文件,来自MOF文件的自动生成的源文件和头文件,以及引用自动生成文件的手写源文件和头文件.为了使构建成功,自动生成步骤必须在任何手写文件被编译之前运行完成,否则手写文件依赖的标题将不存在,并且将失败.自动生成步骤创建的.cpp文件也必须添加到源列表中,并在最终版本中编译.
运行单线程构建时,一切正常,因为自动生成步骤在编译步骤之前始终完成,因此生成的头文件就位.但是,当运行构建多线程时,它会在自动生成步骤完成之前尝试编译手写文件,构建失败.我已经指定了一个明确的依赖关系,但是SCons没有跟随它.
这是SConscript文件的相关部分,我删除了cim_targets []中的单个文件名,因为列表很长,但总而言之,cim_targets []是自动生成步骤的目标输出文件列表,provider_sources []是返回的自动步骤完成后的源列表,源[]是手写源文件的列表,GenProvider()是外部定义的执行自动生成步骤的命令构建器,SharedLibrary()是一个外部定义的构建器,它执行听起来像,使用SCons库构建器与一些扩展
# Define directory paths for the CIM schema cim_dir = 'cim-schema-2.26.0' var_smis_dir = Dir('.').abspath # src/lib/XXX in variant cim_sources = [ Glob(os.path.join(cim_dir,'*qualifiers*.mof')),Glob(os.path.join(cim_dir,'Core') + '/CIM_*.mof'),'Device') + '/CIM_*.mof'),'Event') + '/CIM_*.mof'),'XXXXXX') + '/XXX_*.mof'),'Interop') + '/CIM_*.mof'),'Physical') + '/CIM_*.mof'),'System') + '/CIM_*.mof'),] cim_sources_flat = [] for cim in cim_sources: for src in cim: cim_sources_flat.append(src) cim_targets = [ ...... ] sources = [ 'driver.cpp','device.cpp','cim_static_data.cpp','module.cpp','diag_log.cpp','profile_element.cpp',] staticlibs = [ ...... ] dynamiclibs = [ ..... ] var_cim_sources = this_env.Install(var_smis_dir,cim_sources_flat) cim_mof = 'cimv226.mof' cim_linux_mof = os.path.join(cim_dir,'cimv226-gen-flat.mof') var_cim_sources.extend(this_env.Command(cim_mof,cim_linux_mof,Copy('$TARGET','$SOURCE'))) # first generate the provider infrastructure using cimple provider_sources = this_env.GenProvider(cim_targets,var_cim_sources,name,var_smis_dir) # make sure these files don't build until AFTER the provider files have been created this_env.Depends(sources,provider_sources) sources_full = provider_sources + sources # now we can compile the provider this_env.SharedLibrary(libname,source=sources_full,staticlibs=staticlibs,dynamiclibs=dynamiclibs,installpath=install_dir)
我尝试设置一个明确的依赖关系,以便在创建所有生成的源(this_env.Depends(sources,provider_sources))之前手写的源将不会编译,但是当运行多线程时,SCons将忽略此依赖关系,并尝试在之前编译手写文件自动生成步骤已完成.