100 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Python
		
	
	
	
			
		
		
	
	
			100 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Python
		
	
	
	
# Copyright (c) 2012 The Chromium OS Authors.
 | 
						|
#
 | 
						|
# SPDX-License-Identifier:	GPL-2.0+
 | 
						|
#
 | 
						|
 | 
						|
import ConfigParser
 | 
						|
import os
 | 
						|
import StringIO
 | 
						|
 | 
						|
 | 
						|
def Setup(fname=''):
 | 
						|
    """Set up the buildman settings module by reading config files
 | 
						|
 | 
						|
    Args:
 | 
						|
        config_fname:   Config filename to read ('' for default)
 | 
						|
    """
 | 
						|
    global settings
 | 
						|
    global config_fname
 | 
						|
 | 
						|
    settings = ConfigParser.SafeConfigParser()
 | 
						|
    if fname is not None:
 | 
						|
        config_fname = fname
 | 
						|
        if config_fname == '':
 | 
						|
            config_fname = '%s/.buildman' % os.getenv('HOME')
 | 
						|
        if not os.path.exists(config_fname):
 | 
						|
            print 'No config file found ~/.buildman\nCreating one...\n'
 | 
						|
            CreateBuildmanConfigFile(config_fname)
 | 
						|
            print 'To install tool chains, please use the --fetch-arch option'
 | 
						|
        if config_fname:
 | 
						|
            settings.read(config_fname)
 | 
						|
 | 
						|
def AddFile(data):
 | 
						|
    settings.readfp(StringIO.StringIO(data))
 | 
						|
 | 
						|
def GetItems(section):
 | 
						|
    """Get the items from a section of the config.
 | 
						|
 | 
						|
    Args:
 | 
						|
        section: name of section to retrieve
 | 
						|
 | 
						|
    Returns:
 | 
						|
        List of (name, value) tuples for the section
 | 
						|
    """
 | 
						|
    try:
 | 
						|
        return settings.items(section)
 | 
						|
    except ConfigParser.NoSectionError as e:
 | 
						|
        return []
 | 
						|
    except:
 | 
						|
        raise
 | 
						|
 | 
						|
def SetItem(section, tag, value):
 | 
						|
    """Set an item and write it back to the settings file"""
 | 
						|
    global settings
 | 
						|
    global config_fname
 | 
						|
 | 
						|
    settings.set(section, tag, value)
 | 
						|
    if config_fname is not None:
 | 
						|
        with open(config_fname, 'w') as fd:
 | 
						|
            settings.write(fd)
 | 
						|
 | 
						|
def CreateBuildmanConfigFile(config_fname):
 | 
						|
    """Creates a new config file with no tool chain information.
 | 
						|
 | 
						|
    Args:
 | 
						|
        config_fname: Config filename to create
 | 
						|
 | 
						|
    Returns:
 | 
						|
        None
 | 
						|
    """
 | 
						|
    try:
 | 
						|
        f = open(config_fname, 'w')
 | 
						|
    except IOError:
 | 
						|
        print "Couldn't create buildman config file '%s'\n" % config_fname
 | 
						|
        raise
 | 
						|
 | 
						|
    print >>f, '''[toolchain]
 | 
						|
# name = path
 | 
						|
# e.g. x86 = /opt/gcc-4.6.3-nolibc/x86_64-linux
 | 
						|
 | 
						|
[toolchain-prefix]
 | 
						|
# name = path to prefix
 | 
						|
# e.g. x86 = /opt/gcc-4.6.3-nolibc/x86_64-linux/bin/x86_64-linux-
 | 
						|
 | 
						|
[toolchain-alias]
 | 
						|
# arch = alias
 | 
						|
# Indicates which toolchain should be used to build for that arch
 | 
						|
x86 = i386
 | 
						|
blackfin = bfin
 | 
						|
nds32 = nds32le
 | 
						|
openrisc = or1k
 | 
						|
 | 
						|
[make-flags]
 | 
						|
# Special flags to pass to 'make' for certain boards, e.g. to pass a test
 | 
						|
# flag and build tag to snapper boards:
 | 
						|
# snapper-boards=ENABLE_AT91_TEST=1
 | 
						|
# snapper9260=${snapper-boards} BUILD_TAG=442
 | 
						|
# snapper9g45=${snapper-boards} BUILD_TAG=443
 | 
						|
'''
 | 
						|
    f.close();
 |