- SCons除了作为编译框架,本身也具备dag调度的能力,因此可以作为执行任何有依赖关系的任务的调度框架。
- SCons提供执行任意python函数的能力,假设每个函数执行一个特定的任务,定义了任务的内容。SCons则提供了描述这些函数之间关系的能力,即先执行哪些任务,后执行哪些任务。
- 例子:使用SCons执行自定义函数test_scons和shell命令,并且指定两者的先后顺序 – shell命令依赖于test_scons任务,即必须先执行test_scons函数定义的任务,后执行shell命令定义的任务。
def test_scons(target, source, env):
# self-defined function
print("I m scons")
first = Builder(action=test_scons)
second = Builder(action="echo ""I m two""")
import os
env = Environment(BUILDERS={"first":first,
"second":second},
ENV=os.environ)
pro = env.first("kk", "SConstruct")
he = env.second("main", pro)
注意:
自定义函数必须定义一系列的入参为target(目标),source(源文件),env(环境)这3个参数的函数,可以不使用这3个参数,但是必须要进行定义,这个是和调用者(executor)之间的约定。至于函数中再去调用其他的python函数、shell脚本等,没有任何约束,这个是唯一的约束。