Add buildlib option; Add wizard script.
git-svn-id: https://rt-thread.googlecode.com/svn/trunk@2316 bbd45198-f89e-11dd-88c7-29a3b14d5316
This commit is contained in:
parent
2114b73b4b
commit
3816661798
|
@ -77,6 +77,12 @@ def PrepareBuilding(env, root_directory, has_libcpu=False, remove_components = [
|
||||||
default=False,
|
default=False,
|
||||||
help='copy header of rt-thread directory to local.')
|
help='copy header of rt-thread directory to local.')
|
||||||
|
|
||||||
|
# add build library option
|
||||||
|
AddOption('--buildlib',
|
||||||
|
dest='buildlib',
|
||||||
|
type='string',
|
||||||
|
help='building library of a component')
|
||||||
|
|
||||||
# add target option
|
# add target option
|
||||||
AddOption('--target',
|
AddOption('--target',
|
||||||
dest='target',
|
dest='target',
|
||||||
|
@ -212,6 +218,10 @@ def DefineGroup(name, src, depend, **parameters):
|
||||||
Env.Append(CPPDEFINES = group['CPPDEFINES'])
|
Env.Append(CPPDEFINES = group['CPPDEFINES'])
|
||||||
if group.has_key('LINKFLAGS'):
|
if group.has_key('LINKFLAGS'):
|
||||||
Env.Append(LINKFLAGS = group['LINKFLAGS'])
|
Env.Append(LINKFLAGS = group['LINKFLAGS'])
|
||||||
|
if group.has_key('LIBS'):
|
||||||
|
Env.Append(LIBS = group['LIBS'])
|
||||||
|
if group.has_key('LIBPATH'):
|
||||||
|
Env.Append(LIBPATH = group['LIBPATH'])
|
||||||
|
|
||||||
objs = Env.Object(group['src'])
|
objs = Env.Object(group['src'])
|
||||||
|
|
||||||
|
@ -237,6 +247,23 @@ def GetCurrentDir():
|
||||||
path = os.path.dirname(fn.abspath)
|
path = os.path.dirname(fn.abspath)
|
||||||
return path
|
return path
|
||||||
|
|
||||||
|
def DoBuilding(target, objects):
|
||||||
|
program = None
|
||||||
|
# check whether special buildlib option
|
||||||
|
lib_name = GetOption('buildlib')
|
||||||
|
if lib_name:
|
||||||
|
print lib_name
|
||||||
|
# build library with special component
|
||||||
|
for Group in Projects:
|
||||||
|
if Group['name'] == lib_name:
|
||||||
|
objects = Env.Object(Group['src'])
|
||||||
|
program = Env.Library(lib_name, objects)
|
||||||
|
break
|
||||||
|
else:
|
||||||
|
program = Env.Program(target, objects)
|
||||||
|
|
||||||
|
EndBuilding(target, program)
|
||||||
|
|
||||||
def EndBuilding(target, program = None):
|
def EndBuilding(target, program = None):
|
||||||
import rtconfig
|
import rtconfig
|
||||||
from keil import MDKProject
|
from keil import MDKProject
|
||||||
|
|
|
@ -0,0 +1,70 @@
|
||||||
|
#! /usr/bin/env python
|
||||||
|
#coding=utf-8
|
||||||
|
|
||||||
|
"""
|
||||||
|
wizard.py - a script to generate SConscript in RT-Thread RTOS.
|
||||||
|
|
||||||
|
`wizard --component name' to generate SConscript for name component.
|
||||||
|
`wizard --bridge' to generate SConscript as a bridge to connect each
|
||||||
|
SConscript script file of sub-directory.
|
||||||
|
"""
|
||||||
|
|
||||||
|
import sys
|
||||||
|
|
||||||
|
SConscript_com = '''# RT-Thread building script for component
|
||||||
|
|
||||||
|
from building import *
|
||||||
|
|
||||||
|
cwd = GetCurrentDir()
|
||||||
|
src = Glob('*.c')
|
||||||
|
CPPPATH = [cwd]
|
||||||
|
|
||||||
|
group = DefineGroup('COMPONENT_NAME', src, depend = [''], CPPPATH = CPPPATH)
|
||||||
|
|
||||||
|
Return('group')
|
||||||
|
'''
|
||||||
|
|
||||||
|
SConscript_bridge = '''# RT-Thread building script for bridge
|
||||||
|
|
||||||
|
import os
|
||||||
|
|
||||||
|
cwd = GetCurrentDir()
|
||||||
|
objs = []
|
||||||
|
list = os.listdir(cwd)
|
||||||
|
|
||||||
|
for d in list:
|
||||||
|
path = os.path.join(cwd, d)
|
||||||
|
if os.path.isfile(os.path.join(path, 'SConscript')):
|
||||||
|
objs = objs + SConscript(os.path.join(d, 'SConscript'))
|
||||||
|
|
||||||
|
Return('objs')
|
||||||
|
'''
|
||||||
|
|
||||||
|
def usage():
|
||||||
|
print 'wizard --component name'
|
||||||
|
print 'wizard --bridge'
|
||||||
|
|
||||||
|
def gen_component(name):
|
||||||
|
print 'generate SConscript for ' + name
|
||||||
|
text = SConscript_com.replace('COMPONENT_NAME', name)
|
||||||
|
f = file('SConscript', 'w')
|
||||||
|
f.write(text)
|
||||||
|
f.close()
|
||||||
|
|
||||||
|
def gen_bridge():
|
||||||
|
print 'generate SConscript for bridge'
|
||||||
|
f = file('SConscript', 'w')
|
||||||
|
f.write(SConscript_bridge)
|
||||||
|
f.close()
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
if len(sys.argv) == 1:
|
||||||
|
usage()
|
||||||
|
sys.exit(2)
|
||||||
|
|
||||||
|
if sys.argv[1] == '--component':
|
||||||
|
gen_component(sys.argv[2])
|
||||||
|
elif sys.argv[1] == '--bridge':
|
||||||
|
gen_bridge()
|
||||||
|
else:
|
||||||
|
usage()
|
Loading…
Reference in New Issue