1234567891011121314151617181920212223242526272829303132333435363738394041424344454647 |
- # Copyright (c) 2018 Foundries.io
- #
- # SPDX-License-Identifier: Apache-2.0
- '''Helpers shared by multiple west extension command modules.
- Note that common helpers used by the flash and debug extension
- commands are in run_common -- that's for common code used by
- commands which specifically execute runners.'''
- import os
- from pathlib import Path
- from west import log
- from west.commands import WestCommand
- # This relies on this file being zephyr/scripts/foo/bar.py.
- # If you move this file, you'll break it, so be careful.
- THIS_ZEPHYR = Path(__file__).parent.parent.parent
- ZEPHYR_BASE = Path(os.environ.get('ZEPHYR_BASE', THIS_ZEPHYR))
- # FIXME we need a nicer way to handle imports from scripts and cmake than this.
- ZEPHYR_SCRIPTS = ZEPHYR_BASE / 'scripts'
- ZEPHYR_CMAKE = ZEPHYR_BASE / 'cmake'
- class Forceable(WestCommand):
- '''WestCommand subclass for commands with a --force option.'''
- @staticmethod
- def add_force_arg(parser):
- '''Add a -f / --force option to the parser.'''
- parser.add_argument('-f', '--force', action='store_true',
- help='ignore any errors and try to proceed')
- def check_force(self, cond, msg):
- '''Abort if the command needs to be forced and hasn't been.
- The "forced" predicate must be in self.args.forced.
- If cond and self.args.force are both False, scream and die
- with message msg. Otherwise, return. That is, "cond" is a
- condition which means everything is OK; if it's False, only
- self.args.force being True can allow execution to proceed.
- '''
- if not (cond or self.args.force):
- log.err(msg)
- log.die('refusing to proceed without --force due to above error')
|