Loading...
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 | # SPDX-License-Identifier: GPL-2.0+ # Copyright (c) 2012 The Chromium OS Authors. import configparser import os import io config_fname = None 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.ConfigParser() 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') create_buildman_config_file(config_fname) print('To install tool chains, please use the --fetch-arch option') if config_fname: settings.read(config_fname) def add_file(data): settings.read_file(io.StringIO(data)) def add_section(name): settings.add_section(name) def get_items(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 get_global_item_value(name): """Get an item from the 'global' section of the config. Args: name: name of item to retrieve Returns: str: Value of item, or None if not present """ return settings.get('global', name, fallback=None) def set_item(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 create_buildman_config_file(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('''[toolchain] # name = path # e.g. x86 = /opt/gcc-4.6.3-nolibc/x86_64-linux other = / [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 riscv = riscv32 sh = sh4 x86 = i386 [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 ''', file=f) f.close(); |