集成 armcc 到 scons

栏目: Python · 发布时间: 5年前

内容简介:集成 armcc 到 scons 中并不是件容易的事情,如果只是修改 CC/CXX/AR/LINK 几个环境变量,scons 会用 Visual C++的参数调用方式,比如-c 成了/c,导致 armcc 无法识别。花了半天时间去阅读 scons 的源码后,在 SCons/Tool 目录下发现,每种编译器都有一个类似插件的 tool,目测没有发现 armcc 的 tool,自己为 armcc 写一个 tool,应该可以解决这个问题。在

集成 armcc 到 scons

集成 armcc 到 scons 中并不是件容易的事情,如果只是修改 CC/CXX/AR/LINK 几个环境变量,scons 会用 Visual C++的参数调用方式,比如-c 成了/c,导致 armcc 无法识别。

花了半天时间去阅读 scons 的源码后,在 SCons/Tool 目录下发现,每种编译器都有一个类似插件的 tool,目测没有发现 armcc 的 tool,自己为 armcc 写一个 tool,应该可以解决这个问题。

ToolsForFools 这篇文章中,了解到可以自己定义 tool,只要放到项目的 site_scons/site_tools 目录下即可。

为了支持 armcc,我们在 site_scons/site_tools/armcc 目录中创建一个 armcc 的 tool,从头编写一个 tool 还是比较麻烦的,考虑到 armcc 和 cc 类似,就直接把 SCons/Tool/cc.py 拷贝到 site_scons/site_tools/armcc/__init__.py,然后在此基础上进行修改。

在下面这行代码之后

add_common_cc_variables(env)

增加下面的代码:

armcc = SCons.Tool.find_program_path(env, 'armcc.exe');
    armar = SCons.Tool.find_program_path(env, 'armar.exe');
    armlink = SCons.Tool.find_program_path(env, 'armlink.exe');

    env['CC']      = armcc
    env['CXX']     = armcc
    env['AR']      = armar
    env['LINK']      = armlink
    env['CXXCOM']    = '$CC -o $TARGET -c $CFLAGS $CCFLAGS $_CCCOMCOM $SOURCES'
    env['ARFLAGS']     = SCons.Util.CLVar('--create -r')
    env['ARCOM']       = '$AR $ARFLAGS $TARGET $SOURCES'
    env['OBJSUFFIX']      = '.o'
    env['LIBPREFIX']      = 'lib'
    env['LIBSUFFIX']      = '.a'

参考 scons 的 Tool 中的代码,在 SConstruct 文件中,加入下面的代码,来启用我们前面定义的 armcc:

env = DefaultEnvironment();
SCons.Tool.Tool('armcc')(env)

使用 scons 编译,编译正常了,但是在 armar 生成.a 文件时,出现下面的错误:

The command line is too long.

这主要是.o 文件太多所致,armar 并不像 ar 那样可以通过@符合去文件读取参数,不过 armar 可以先创建一个.a 文件,然后一个一个的往里面追加.o 文件。

从 scons 的源码发现,命令最终是在 SCons/Platform/win32.py 里调用的。但这是系统文件,直接修改它并不明智,我们还是写一个 tool 来解决这个问题吧。

为了避免从头去实现,把 SCons/Platform/win32.py 拷贝到 site_scons/site_tools/win4armcc/__init__.py,然后再去修改。

  • 先修改下面几个变量的值为:
env['OBJSUFFIX']      = '.o'
    env['LIBPREFIX']      = 'lib'
    env['LIBSUFFIX']      = '.a'
  • 增加一个 exists 函数
def exists(env):
    return True
  • 重新实现 spawn 函数。
def exe_ar(sh, cmd, args, env):
    armar = args[0]
    #args[1] is --create
    #args[2] is -r
    target = args[3];
    objs = args[4:]
    for i in range(len(objs)):
        ARFLAGS='-r'
        if i == 0:
            ARFLAGS='--create -r'

        all_args= [armar, target,  ARFLAGS, objs[i] ]
        sargs = ' '.join(all_args).replace('\\', '/');
        print(str(i) + ': ' + sargs);
        exec_spawn([sh, '/C', sargs], env)

def spawn(sh, escape, cmd, args, env):
    if cmd.endswith('armar.exe'):
        exe_ar(sh, cmd, args, env);
    else:
        sargs = ' '.join(args).replace('\\', '/');
        return exec_spawn([sh, '/C', sargs], env)

同样,在 SConstruct 文件中启用 win4armcc。

SCons.Tool.Tool('win4armcc')(env)

好了,现在可以用scons调用armcc了。

完整示例请参考: awtk-scons-armcc


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

走出软件作坊

走出软件作坊

阿朱 / 电子工业出版社 / 2009-1 / 39.80

《走出软件作坊》这本书提供了解决国内小型IT企业发展的过程中会遇到的项目管理问题的若干方法。主要以作者自身多年工作的宝贵经验,来谈软件公司的项目管理和团队建设,包括对中小软件公司软件开发组织结构、团队文化、软件过程管理、团队激励、绩效考核、职业发展规划、未来业界发展趋势、个人素质提升等,具有实际指导意义。主要读者对象是IT企业的研发主管、项目经理和软件开人中同,以及即将到IT企业工作的高校毕业生。一起来看看 《走出软件作坊》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具