# Copyright (c) 2019 Nordic Semiconductor ASA # # SPDX-License-Identifier: Apache-2.0 import argparse import os from west.commands import WestCommand # Relative to the folder where this script lives COMPLETION_REL_PATH = 'completion/west-completion' COMP_DESCRIPTION = '''\ Output shell completion scripts for west. This command outputs completion scripts for different shells by printing them to stdout. Using the completion scripts: bash: # one-time source <(west completion bash) # permanent west completion bash > ~/west-completion.bash # edit your .bashrc or .bash_profile and add: source $HOME/west-completion.bash zsh: # one-time source <(west completion zsh) # permanent (might require sudo) west completion zsh > "${fpath[1]}/_west" fish: # one-time west completion fish | source # permanent west completion fish > $HOME/.config/fish/completions/west.fish positional arguments: source_dir application source directory cmake_opt extra options to pass to cmake; implies -c (these must come after "--" as shown above) ''' class Completion(WestCommand): def __init__(self): super().__init__( 'completion', # Keep this in sync with the string in west-commands.yml. 'output shell completion scripts', COMP_DESCRIPTION, accepts_unknown_args=False) def do_add_parser(self, parser_adder): parser = parser_adder.add_parser( self.name, help=self.help, formatter_class=argparse.RawDescriptionHelpFormatter, description=self.description) # Remember to update west-completion.bash if you add or remove # flags parser.add_argument('shell', nargs=1, choices=['bash', 'zsh', 'fish'], help='''Shell that which the completion script is intended for.''') return parser def do_run(self, args, unknown_args): cf = os.path.join(os.path.dirname(os.path.realpath(__file__)), *COMPLETION_REL_PATH.split('/')) cf += '.' + args.shell[0] try: with open(cf, 'r') as f: print(f.read()) except FileNotFoundError as e: self.die('Unable to find completion file: {}'.format(e))