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 113 114 115 116 117 118 119 120 121 122 123 124 | # SPDX-License-Identifier: GPL-2.0+ # Copyright (c) 2012 The Chromium OS Authors. """Handles settings for buildman, reading from a config file.""" import configparser import io import os # pylint: disable=C0103 settings = None config_fname = None def setup(fname=''): """Set up the buildman settings module by reading config files Args: fname (str): Config filename to read ('' for default) """ global settings # pylint: disable=W0603 global config_fname # pylint: disable=W0603 settings = configparser.ConfigParser(allow_no_value=True) if fname is not None: config_fname = fname if config_fname == '': config_fname = f"{os.getenv('HOME')}/.buildman" 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): """Add settings from a string Args: data (str): Config data in INI format """ settings.read_file(io.StringIO(data)) def add_section(name): """Add a new section to the settings Args: name (str): Name of section to add """ settings.add_section(name) def get_items(section): """Get the items from a section of the config. Args: section (str): name of section to retrieve Returns: list of tuple: List of (name, value) tuples for the section """ try: return settings.items(section) except configparser.NoSectionError: return [] def get_global_item_value(name): """Get an item from the 'global' section of the config. Args: name (str): 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""" settings.set(section, tag, value) if config_fname is not None: with open(config_fname, 'w', encoding='utf-8') as fd: settings.write(fd) def create_buildman_config_file(cfgname): """Creates a new config file with no tool chain information. Args: cfgname (str): Config filename to create """ try: with open(cfgname, 'w', encoding='utf-8') as out: 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 [machines] # Remote build machines for distributed builds # List hostnames, one per line (or user@hostname) # e.g. # ohau # moa # user@build-server ''', file=out) except IOError: print(f"Couldn't create buildman config file '{cfgname}'\n") raise |