[DEV] update at the new external argument parser (death)
This commit is contained in:
parent
017cbc50ba
commit
6386467b45
21
bin/lutin
21
bin/lutin
@ -14,7 +14,8 @@ import os
|
|||||||
import copy
|
import copy
|
||||||
from realog import debug as debug
|
from realog import debug as debug
|
||||||
import lutin
|
import lutin
|
||||||
import lutin.arg as arguments
|
import death.Arguments as arguments
|
||||||
|
import death.ArgElement as arg_element
|
||||||
import lutin.host as host
|
import lutin.host as host
|
||||||
import lutin.module as module
|
import lutin.module as module
|
||||||
import lutin.target as target
|
import lutin.target as target
|
||||||
@ -24,7 +25,7 @@ import lutin.tools as tools
|
|||||||
import lutin.host as lutinHost
|
import lutin.host as lutinHost
|
||||||
import lutin.tools as lutinTools
|
import lutin.tools as lutinTools
|
||||||
|
|
||||||
myArgs = arguments.LutinArg()
|
myArgs = arguments.Arguments()
|
||||||
myArgs.add("h", "help", desc="Display this help")
|
myArgs.add("h", "help", desc="Display this help")
|
||||||
myArgs.add("H", "HELP", desc="Display this help (with all compleate information)")
|
myArgs.add("H", "HELP", desc="Display this help (with all compleate information)")
|
||||||
myArgs.add_section("option", "Can be set one time in all case")
|
myArgs.add_section("option", "Can be set one time in all case")
|
||||||
@ -301,42 +302,42 @@ if os.path.isfile(config_file) == True:
|
|||||||
if "get_parsing_depth" in dir(configuration_file):
|
if "get_parsing_depth" in dir(configuration_file):
|
||||||
data = configuration_file.get_parsing_depth()
|
data = configuration_file.get_parsing_depth()
|
||||||
debug.debug(" get default config 'get_parsing_depth' val='" + str(data) + "'")
|
debug.debug(" get default config 'get_parsing_depth' val='" + str(data) + "'")
|
||||||
parseGenericArg(arguments.ArgElement("depth", str(data)), True)
|
parseGenericArg(arg_element.ArgElement("depth", str(data)), True)
|
||||||
|
|
||||||
if "get_ccache" in dir(configuration_file):
|
if "get_ccache" in dir(configuration_file):
|
||||||
data = configuration_file.get_ccache()
|
data = configuration_file.get_ccache()
|
||||||
debug.debug(" get default config 'get_ccache' val='" + str(data) + "'")
|
debug.debug(" get default config 'get_ccache' val='" + str(data) + "'")
|
||||||
parseGenericArg(arguments.ArgElement("ccache", str(data)), True)
|
parseGenericArg(arg_element.ArgElement("ccache", str(data)), True)
|
||||||
|
|
||||||
if "get_default_jobs" in dir(configuration_file):
|
if "get_default_jobs" in dir(configuration_file):
|
||||||
data = configuration_file.get_default_jobs()
|
data = configuration_file.get_default_jobs()
|
||||||
debug.debug(" get default config 'get_default_jobs' val='" + str(data) + "'")
|
debug.debug(" get default config 'get_default_jobs' val='" + str(data) + "'")
|
||||||
parseGenericArg(arguments.ArgElement("jobs", str(data)), True)
|
parseGenericArg(arg_element.ArgElement("jobs", str(data)), True)
|
||||||
|
|
||||||
if "get_default_color" in dir(configuration_file):
|
if "get_default_color" in dir(configuration_file):
|
||||||
data = configuration_file.get_default_color()
|
data = configuration_file.get_default_color()
|
||||||
debug.debug(" get default config 'get_default_color' val='" + str(data) + "'")
|
debug.debug(" get default config 'get_default_color' val='" + str(data) + "'")
|
||||||
parseGenericArg(arguments.ArgElement("color", str(data)), True)
|
parseGenericArg(arg_element.ArgElement("color", str(data)), True)
|
||||||
|
|
||||||
if "get_default_debug_level" in dir(configuration_file):
|
if "get_default_debug_level" in dir(configuration_file):
|
||||||
data = configuration_file.get_default_debug_level()
|
data = configuration_file.get_default_debug_level()
|
||||||
debug.debug(" get default config 'get_default_debug_level' val='" + str(data) + "'")
|
debug.debug(" get default config 'get_default_debug_level' val='" + str(data) + "'")
|
||||||
parseGenericArg(arguments.ArgElement("verbose", str(data)), True)
|
parseGenericArg(arg_element.ArgElement("verbose", str(data)), True)
|
||||||
|
|
||||||
if "get_default_print_pretty" in dir(configuration_file):
|
if "get_default_print_pretty" in dir(configuration_file):
|
||||||
data = configuration_file.get_default_print_pretty()
|
data = configuration_file.get_default_print_pretty()
|
||||||
debug.debug(" get default config 'get_default_print_pretty' val='" + str(data) + "'")
|
debug.debug(" get default config 'get_default_print_pretty' val='" + str(data) + "'")
|
||||||
parseGenericArg(arguments.ArgElement("pretty", str(data)), True)
|
parseGenericArg(arg_element.ArgElement("pretty", str(data)), True)
|
||||||
|
|
||||||
if "get_default_force_optimisation" in dir(configuration_file):
|
if "get_default_force_optimisation" in dir(configuration_file):
|
||||||
data = configuration_file.get_default_force_optimisation()
|
data = configuration_file.get_default_force_optimisation()
|
||||||
debug.debug(" get default config 'get_default_force_optimisation' val='" + str(data) + "'")
|
debug.debug(" get default config 'get_default_force_optimisation' val='" + str(data) + "'")
|
||||||
parseGenericArg(arguments.ArgElement("force-optimisation", str(data)), True)
|
parseGenericArg(arg_element.ArgElement("force-optimisation", str(data)), True)
|
||||||
|
|
||||||
if "get_default_isolate_system" in dir(configuration_file):
|
if "get_default_isolate_system" in dir(configuration_file):
|
||||||
data = configuration_file.get_default_isolate_system()
|
data = configuration_file.get_default_isolate_system()
|
||||||
debug.debug(" get default config 'get_default_isolate_system' val='" + str(data) + "'")
|
debug.debug(" get default config 'get_default_isolate_system' val='" + str(data) + "'")
|
||||||
parseGenericArg(arguments.ArgElement("isolate-system", str(data)), True)
|
parseGenericArg(arg_element.ArgElement("isolate-system", str(data)), True)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
378
lutin/arg.py
378
lutin/arg.py
@ -1,378 +0,0 @@
|
|||||||
#!/usr/bin/python
|
|
||||||
# -*- coding: utf-8 -*-
|
|
||||||
##
|
|
||||||
## @author Edouard DUPIN
|
|
||||||
##
|
|
||||||
## @copyright 2012, Edouard DUPIN, all right reserved
|
|
||||||
##
|
|
||||||
## @license MPL v2.0 (see license file)
|
|
||||||
##
|
|
||||||
import sys
|
|
||||||
from realog import debug
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Single argument class. It permit to define the getted argument.
|
|
||||||
##
|
|
||||||
class ArgElement:
|
|
||||||
##
|
|
||||||
## @brief Contructor.
|
|
||||||
## @param[in] self Class handle
|
|
||||||
## @param[in] option (string) Option name (write in fullmode ex: '--verbose' even if user write '-v')
|
|
||||||
## @param[in] value (string) Writed value by the user (defult '')
|
|
||||||
##
|
|
||||||
def __init__(self, option, value=""):
|
|
||||||
self.option = option;
|
|
||||||
self.arg = value;
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Get the name of the argument: (write in fullmode ex: '--verbose' even if user write '-v')
|
|
||||||
## @param[in] self Class handle
|
|
||||||
## @return (string) The argument name
|
|
||||||
##
|
|
||||||
def get_option_name(self):
|
|
||||||
return self.option
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Get argument data set by the user
|
|
||||||
## @param[in] self Class handle
|
|
||||||
## @return (string) The argument value
|
|
||||||
##
|
|
||||||
def get_arg(self):
|
|
||||||
return self.arg
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Display the Argument property
|
|
||||||
## @param[in] self Class handle
|
|
||||||
##
|
|
||||||
def display(self):
|
|
||||||
if len(self.arg) == 0:
|
|
||||||
debug.info("option : " + self.option)
|
|
||||||
elif len(self.option) == 0:
|
|
||||||
debug.info("element : " + self.arg)
|
|
||||||
else:
|
|
||||||
debug.info("option : " + self.option + ":" + self.arg)
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Declare a possibility of an argument value
|
|
||||||
##
|
|
||||||
class ArgDefine:
|
|
||||||
##
|
|
||||||
## @brief Contructor.
|
|
||||||
## @param[in] self Class handle
|
|
||||||
## @param[in] smallOption (char) Value for the small option ex: '-v' '-k' ... 1 single char element (no need of '-')
|
|
||||||
## @param[in] bigOption (string) Value of the big option name ex: '--verbose' '--kill' ... stated with -- and with the full name (no need of '--')
|
|
||||||
## @param[in] list ([[string,string],...]) Optionnal list of availlable option: '--mode=debug' ==> [['debug', 'debug mode'],['release', 'release the software']]
|
|
||||||
## @param[in] desc (string) user friendly description with this parameter (default "")
|
|
||||||
## @param[in] haveParam (bool) The option must have a parameter (default False)
|
|
||||||
##
|
|
||||||
def __init__(self,
|
|
||||||
smallOption="", # like v for -v
|
|
||||||
bigOption="", # like verbose for --verbose
|
|
||||||
list=[], # ["val", "description"]
|
|
||||||
desc="",
|
|
||||||
haveParam=False):
|
|
||||||
self.option_small = smallOption;
|
|
||||||
self.option_big = bigOption;
|
|
||||||
self.list = list;
|
|
||||||
if len(self.list)!=0:
|
|
||||||
self.have_param = True
|
|
||||||
else:
|
|
||||||
if True==haveParam:
|
|
||||||
self.have_param = True
|
|
||||||
else:
|
|
||||||
self.have_param = False
|
|
||||||
self.description = desc;
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Get the small name of the option ex: '-v'
|
|
||||||
## @param[in] self Class handle
|
|
||||||
## @return (string) Small name value
|
|
||||||
##
|
|
||||||
def get_option_small(self):
|
|
||||||
return self.option_small
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Get the big name of the option ex: '--verbose'
|
|
||||||
## @param[in] self Class handle
|
|
||||||
## @return (string) Big name value
|
|
||||||
##
|
|
||||||
def get_option_big(self):
|
|
||||||
return self.option_big
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Get the status of getting user parameter value
|
|
||||||
## @param[in] self Class handle
|
|
||||||
## @return True The user must write a value
|
|
||||||
## @return False The user must NOT write a value
|
|
||||||
##
|
|
||||||
def need_parameters(self):
|
|
||||||
return self.have_param
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Compatibility with @ref ArgSection class
|
|
||||||
## @param[in] self Class handle
|
|
||||||
## @return (string) empty string
|
|
||||||
##
|
|
||||||
def get_porperties(self):
|
|
||||||
return ""
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Check if the user added value is correct or not with the list of availlable value
|
|
||||||
## @param[in] self Class handle
|
|
||||||
## @param[in] argument (string) User parameter value (string)
|
|
||||||
## @return True The parameter is OK
|
|
||||||
## @return False The parameter is NOT Availlable
|
|
||||||
##
|
|
||||||
def check_availlable(self, argument):
|
|
||||||
if len(self.list)==0:
|
|
||||||
return True
|
|
||||||
for element,desc in self.list:
|
|
||||||
if element == argument:
|
|
||||||
return True
|
|
||||||
return False
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Display the argument property when user request help
|
|
||||||
## @param[in] self Class handle
|
|
||||||
##
|
|
||||||
def display(self):
|
|
||||||
color = debug.get_color_set()
|
|
||||||
if self.option_small != "" and self.option_big != "":
|
|
||||||
print(" " + color['red'] + "-" + self.option_small + "" + color['default'] + " / " + color['red'] + "--" + self.option_big + color['default'])
|
|
||||||
elif self.option_small != "":
|
|
||||||
print(" " + color['red'] + "-" + self.option_small + color['default'])
|
|
||||||
elif self.option_big != "":
|
|
||||||
print(" " + color['red'] + "--" + self.option_big + color['default'])
|
|
||||||
else:
|
|
||||||
print(" ???? ==> internal error ...")
|
|
||||||
if self.description != "":
|
|
||||||
print(" " + self.description)
|
|
||||||
if len(self.list)!=0:
|
|
||||||
hasDescriptiveElement=False
|
|
||||||
for val,desc in self.list:
|
|
||||||
if desc!="":
|
|
||||||
hasDescriptiveElement=True
|
|
||||||
break;
|
|
||||||
if hasDescriptiveElement==True:
|
|
||||||
for val,desc in self.list:
|
|
||||||
print(" " + val + " : " + desc)
|
|
||||||
else:
|
|
||||||
tmpElementPrint = ""
|
|
||||||
for val,desc in self.list:
|
|
||||||
if len(tmpElementPrint)!=0:
|
|
||||||
tmpElementPrint += " / "
|
|
||||||
tmpElementPrint += val
|
|
||||||
print(" { " + tmpElementPrint + " }")
|
|
||||||
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Section Class definition (permit to add a comment when requesting help
|
|
||||||
##
|
|
||||||
class ArgSection:
|
|
||||||
##
|
|
||||||
## @brief Constructor
|
|
||||||
## @param[in] self Class handle
|
|
||||||
## @param[in] sectionName (string) Name of the cestion ex: "option" is displayed [option]
|
|
||||||
## @param[in] desc (string) Comment assiciated with the group
|
|
||||||
##
|
|
||||||
def __init__(self,
|
|
||||||
sectionName="",
|
|
||||||
desc=""):
|
|
||||||
self.section = sectionName;
|
|
||||||
self.description = desc;
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Compatibility with @ref ArgDefine class
|
|
||||||
## @param[in] self Class handle
|
|
||||||
## @return empty string
|
|
||||||
##
|
|
||||||
def get_option_small(self):
|
|
||||||
return ""
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Compatibility with @ref ArgDefine class
|
|
||||||
## @param[in] self Class handle
|
|
||||||
## @return empty string
|
|
||||||
##
|
|
||||||
def get_option_big(self):
|
|
||||||
return ""
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief get property print value with the correct writing mode
|
|
||||||
## @param[in] self Class handle
|
|
||||||
## @return String to display in the short line help
|
|
||||||
##
|
|
||||||
def get_porperties(self):
|
|
||||||
color = debug.get_color_set()
|
|
||||||
return " [" + color['blue'] + self.section + color['default'] + "]"
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Display the argument property when user request help
|
|
||||||
## @param[in] self Class handle
|
|
||||||
##
|
|
||||||
def display(self):
|
|
||||||
color = debug.get_color_set()
|
|
||||||
print(" [" + color['blue'] + self.section + color['default'] + "] : " + self.description)
|
|
||||||
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Class to define the agmument list availlable for a program
|
|
||||||
##
|
|
||||||
class LutinArg:
|
|
||||||
##
|
|
||||||
## @brief Constructor.
|
|
||||||
## @param[in] self Class handle
|
|
||||||
##
|
|
||||||
def __init__(self):
|
|
||||||
self.list_properties = []
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Add a new argument possibilities...
|
|
||||||
## @param[in] self Class handle
|
|
||||||
## @param[in] smallOption (char) Value for the small option ex: '-v' '-k' ... 1 single char element (no need of '-')
|
|
||||||
## @param[in] bigOption (string) Value of the big option name ex: '--verbose' '--kill' ... stated with -- and with the full name (no need of '--')
|
|
||||||
## @param[in] list ([[string,string],...]) Optionnal list of availlable option: '--mode=debug' ==> [['debug', 'debug mode'],['release', 'release the software']]
|
|
||||||
## @param[in] desc (string) user friendly description with this parameter (default "")
|
|
||||||
## @param[in] haveParam (bool) The option must have a parameter (default False)
|
|
||||||
##
|
|
||||||
def add(self, smallOption="", bigOption="", list=[], desc="", haveParam=False):
|
|
||||||
self.list_properties.append(ArgDefine(smallOption, bigOption, list, desc, haveParam))
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Add section on argument list
|
|
||||||
## @param[in] self Class handle
|
|
||||||
## @param[in] sectionName (string) Name of the cestion ex: "option" is displayed [option]
|
|
||||||
## @param[in] sectionDesc (string) Comment assiciated with the group
|
|
||||||
##
|
|
||||||
def add_section(self, sectionName, sectionDesc):
|
|
||||||
self.list_properties.append(ArgSection(sectionName, sectionDesc))
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Parse the argument set in the command line
|
|
||||||
## @param[in] self Class handle
|
|
||||||
##
|
|
||||||
def parse(self):
|
|
||||||
listArgument = [] # composed of list element
|
|
||||||
NotparseNextElement=False
|
|
||||||
for iii in range(1, len(sys.argv)):
|
|
||||||
# special case of parameter in some elements
|
|
||||||
if NotparseNextElement==True:
|
|
||||||
NotparseNextElement = False
|
|
||||||
continue
|
|
||||||
debug.verbose("parse [" + str(iii) + "]=" + sys.argv[iii])
|
|
||||||
argument = sys.argv[iii]
|
|
||||||
optionList = argument.split("=")
|
|
||||||
debug.verbose(str(optionList))
|
|
||||||
if type(optionList) == type(str()):
|
|
||||||
option = optionList
|
|
||||||
else:
|
|
||||||
option = optionList[0]
|
|
||||||
optionParam = argument[len(option)+1:]
|
|
||||||
debug.verbose(option)
|
|
||||||
argumentFound=False;
|
|
||||||
if option[:2]=="--":
|
|
||||||
# big argument
|
|
||||||
for prop in self.list_properties:
|
|
||||||
if prop.get_option_big()=="":
|
|
||||||
continue
|
|
||||||
if prop.get_option_big() == option[2:]:
|
|
||||||
# find it
|
|
||||||
debug.verbose("find argument 2 : " + option[2:])
|
|
||||||
if prop.need_parameters()==True:
|
|
||||||
internalSub = option[2+len(prop.get_option_big()):]
|
|
||||||
if len(internalSub)!=0:
|
|
||||||
if len(optionParam)!=0:
|
|
||||||
# wrong argument ...
|
|
||||||
debug.warning("maybe wrong argument for : '" + prop.get_option_big() + "' cmdLine='" + argument + "'")
|
|
||||||
prop.display()
|
|
||||||
continue
|
|
||||||
optionParam = internalSub
|
|
||||||
if len(optionParam)==0:
|
|
||||||
#Get the next parameters
|
|
||||||
if len(sys.argv) > iii+1:
|
|
||||||
optionParam = sys.argv[iii+1]
|
|
||||||
NotparseNextElement=True
|
|
||||||
else :
|
|
||||||
# missing arguments
|
|
||||||
debug.warning("parsing argument error : '" + prop.get_option_big() + "' Missing : subParameters ... cmdLine='" + argument + "'")
|
|
||||||
prop.display()
|
|
||||||
exit(-1)
|
|
||||||
if prop.check_availlable(optionParam)==False:
|
|
||||||
debug.warning("argument error : '" + prop.get_option_big() + "' SubParameters not availlable ... cmdLine='" + argument + "' option='" + optionParam + "'")
|
|
||||||
prop.display()
|
|
||||||
exit(-1)
|
|
||||||
listArgument.append(ArgElement(prop.get_option_big(),optionParam))
|
|
||||||
argumentFound = True
|
|
||||||
else:
|
|
||||||
if len(optionParam)!=0:
|
|
||||||
debug.warning("parsing argument error : '" + prop.get_option_big() + "' need no subParameters : '" + optionParam + "' cmdLine='" + argument + "'")
|
|
||||||
prop.display()
|
|
||||||
listArgument.append(ArgElement(prop.get_option_big()))
|
|
||||||
argumentFound = True
|
|
||||||
break;
|
|
||||||
if False==argumentFound:
|
|
||||||
debug.error("UNKNOW argument : '" + argument + "'")
|
|
||||||
elif option[:1]=="-":
|
|
||||||
# small argument
|
|
||||||
for prop in self.list_properties:
|
|
||||||
if prop.get_option_small()=="":
|
|
||||||
continue
|
|
||||||
if prop.get_option_small() == option[1:1+len(prop.get_option_small())]:
|
|
||||||
# find it
|
|
||||||
debug.verbose("find argument 1 : " + option[1:1+len(prop.get_option_small())])
|
|
||||||
if prop.need_parameters()==True:
|
|
||||||
internalSub = option[1+len(prop.get_option_small()):]
|
|
||||||
if len(internalSub)!=0:
|
|
||||||
if len(optionParam)!=0:
|
|
||||||
# wrong argument ...
|
|
||||||
debug.warning("maybe wrong argument for : '" + prop.get_option_big() + "' cmdLine='" + argument + "'")
|
|
||||||
prop.display()
|
|
||||||
continue
|
|
||||||
optionParam = internalSub
|
|
||||||
if len(optionParam)==0:
|
|
||||||
#Get the next parameters
|
|
||||||
if len(sys.argv) > iii+1:
|
|
||||||
optionParam = sys.argv[iii+1]
|
|
||||||
NotparseNextElement=True
|
|
||||||
else :
|
|
||||||
# missing arguments
|
|
||||||
debug.warning("parsing argument error : '" + prop.get_option_big() + "' Missing : subParameters cmdLine='" + argument + "'")
|
|
||||||
prop.display()
|
|
||||||
exit(-1)
|
|
||||||
if prop.check_availlable(optionParam)==False:
|
|
||||||
debug.warning("argument error : '" + prop.get_option_big() + "' SubParameters not availlable ... cmdLine='" + argument + "' option='" + optionParam + "'")
|
|
||||||
prop.display()
|
|
||||||
exit(-1)
|
|
||||||
listArgument.append(ArgElement(prop.get_option_big(),optionParam))
|
|
||||||
argumentFound = True
|
|
||||||
else:
|
|
||||||
if len(optionParam)!=0:
|
|
||||||
debug.warning("parsing argument error : '" + prop.get_option_big() + "' need no subParameters : '" + optionParam + "' cmdLine='" + argument + "'")
|
|
||||||
prop.display()
|
|
||||||
listArgument.append(ArgElement(prop.get_option_big()))
|
|
||||||
argumentFound = True
|
|
||||||
break;
|
|
||||||
|
|
||||||
if argumentFound==False:
|
|
||||||
#unknow element ... ==> just add in the list ...
|
|
||||||
debug.verbose("unknow argument : " + argument)
|
|
||||||
listArgument.append(ArgElement("", argument))
|
|
||||||
|
|
||||||
#for argument in listArgument:
|
|
||||||
# argument.display()
|
|
||||||
#exit(0)
|
|
||||||
return listArgument;
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Display help on console output
|
|
||||||
## @param[in] self Class handle
|
|
||||||
##
|
|
||||||
def display(self):
|
|
||||||
print("usage:")
|
|
||||||
listOfPropertiesArg = "";
|
|
||||||
for element in self.list_properties :
|
|
||||||
listOfPropertiesArg += element.get_porperties()
|
|
||||||
print(" " + sys.argv[0] + listOfPropertiesArg + " ...")
|
|
||||||
for element in self.list_properties :
|
|
||||||
element.display()
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user