From a2ac467b845ae8d7995770a5bb5ca706452923c1 Mon Sep 17 00:00:00 2001 From: Ed Warnicke Date: Mon, 23 Jan 2017 22:11:47 +0000 Subject: Add multi-vpp support back into pythonic vppctl Back when vppctl was a shell script, you could use -p or --prefix to set the chroot prefix to drive multiple vpp instances. This patch adds that capability back. Change-Id: Iaa70a20eff13e8d7e206fcceadb7e5d06afa3fc5 Signed-off-by: Ed Warnicke --- src/scripts/vppctl | 27 ++++++++++++++++++++------- 1 file changed, 20 insertions(+), 7 deletions(-) (limited to 'src/scripts') diff --git a/src/scripts/vppctl b/src/scripts/vppctl index 4fdf03c7..01369189 100755 --- a/src/scripts/vppctl +++ b/src/scripts/vppctl @@ -20,6 +20,8 @@ import os import subprocess import re import sys +from optparse import OptionParser + try: import readline except ImportError: @@ -32,6 +34,10 @@ if not persishist: class Vppctl(Cmd): + def __init__(self,api_prefix=None): + Cmd.__init__(self) + self.api_prefix = api_prefix + def historyWrite(self): if readline: readline.set_history_length(persishist_size) @@ -42,10 +48,13 @@ class Vppctl(Cmd): input_command = input_prefix + line line_remove = '^load_one_plugin:' s = '\n' - command = ['vpp_api_test'] + if ( self.api_prefix is None): + command = ['vpp_api_test'] + else: + command = ['vpp_api_test',"chroot prefix %s " % self.api_prefix] if os.geteuid() != 0: - command = ['sudo', 'vpp_api_test'] + command = ['sudo'] + command vpp_process = subprocess.Popen(command, stderr=subprocess.PIPE, @@ -90,15 +99,19 @@ class Vppctl(Cmd): self.historyWrite() if __name__ == '__main__': - command_args = sys.argv - + parser = OptionParser() + parser.add_option("-p","--prefix",action="store",type="string",dest="prefix") + (options,command_args) = parser.parse_args(sys.argv) if not len(command_args) > 1: - prompt = Vppctl() + prompt = Vppctl(options.prefix) red_set = '\033[31m' norm_set = '\033[0m' if sys.stdout.isatty(): - prompt.prompt = 'vpp# ' + if(options.prefix is None): + prompt.prompt = 'vpp# ' + else: + prompt.prompt = '%s# ' % options.prefix try: prompt.cmdloop(red_set + " _______ _ " + norm_set + " _ _____ ___ \n" + red_set + " __/ __/ _ \ (_)__ " + norm_set + " | | / / _ \/ _ \\\n" + @@ -114,7 +127,7 @@ if __name__ == '__main__': else: del command_args[0] stdout_value = " ".join(command_args) - VatAddress = Vppctl() + VatAddress = Vppctl(options.prefix) VatAddress.runVat(stdout_value) -- cgit 1.2.3-korg