mirror of
https://github.com/YunoHost/moulinette.git
synced 2024-09-03 20:06:31 +02:00
Refactoring
This commit is contained in:
parent
3f30dee108
commit
df77aa9858
1 changed files with 83 additions and 93 deletions
176
yunohost
176
yunohost
|
@ -24,14 +24,22 @@ import argparse
|
||||||
sys.path.append('lib') # Local temporary hack
|
sys.path.append('lib') # Local temporary hack
|
||||||
|
|
||||||
|
|
||||||
""" Useful string-to-function definition """
|
def str_to_func(astr):
|
||||||
def str2fun(astr):
|
''' Call a function from a string name
|
||||||
|
|
||||||
|
Keyword arguments:
|
||||||
|
astr -- Name of function to call
|
||||||
|
|
||||||
|
Returns:
|
||||||
|
Function
|
||||||
|
|
||||||
|
'''
|
||||||
module, _, function = astr.rpartition('.')
|
module, _, function = astr.rpartition('.')
|
||||||
if module:
|
if module:
|
||||||
__import__(module)
|
__import__(module)
|
||||||
mod = sys.modules[module]
|
mod = sys.modules[module]
|
||||||
else:
|
else:
|
||||||
mod = sys.modules['__main__'] # or whatever's the "default module"
|
mod = sys.modules['__main__'] # default module
|
||||||
|
|
||||||
try:
|
try:
|
||||||
func = getattr(mod, function)
|
func = getattr(mod, function)
|
||||||
|
@ -41,41 +49,79 @@ def str2fun(astr):
|
||||||
return func
|
return func
|
||||||
|
|
||||||
|
|
||||||
"""""""""""""""""""""""""""""""""""""""""""""""""""""
|
def dict_to_parsers(action_dict):
|
||||||
CATEGORIES / ACTIONS
|
''' Turn action dictionnary to parser and subparsers (2 level)
|
||||||
|
|
||||||
|
Keyword arguments:
|
||||||
|
action_dict -- Multi-level dictionnary of categories/actions list
|
||||||
|
|
||||||
|
Returns:
|
||||||
|
Dictionnrary of parsers
|
||||||
|
|
||||||
array = {
|
'''
|
||||||
'category1' : {
|
|
||||||
'actions' : {
|
|
||||||
'action1' : 'text of action1 help'
|
|
||||||
'action2' : 'text of action2 help'
|
|
||||||
'action3' : 'text of action3 help'
|
|
||||||
},
|
|
||||||
'help' : 'text of category1 help'
|
|
||||||
},
|
|
||||||
'category2' : {
|
|
||||||
'actions' : {
|
|
||||||
'action4' : 'text of action4 help'
|
|
||||||
'action5' : 'text of action5 help'
|
|
||||||
'action6' : 'text of action6 help'
|
|
||||||
},
|
|
||||||
'help' : 'text of category2 help'
|
|
||||||
},
|
|
||||||
}
|
|
||||||
|
|
||||||
Leads to functions:
|
# Intialize parsers
|
||||||
category1_action1()
|
parsers = subparsers_category = subparsers_action = dict()
|
||||||
category1_action2()
|
parsers['general'] = argparse.ArgumentParser()
|
||||||
category1_action3()
|
subparsers = parsers['general'].add_subparsers()
|
||||||
category2_action4()
|
|
||||||
category2_action5()
|
|
||||||
category6_action6()
|
|
||||||
|
|
||||||
"""""""""""""""""""""""""""""""""""""""""""""""""""""
|
# Compute dictionnary
|
||||||
|
for category, info in action_dict.items():
|
||||||
|
subparsers_category[category] = subparsers.add_parser(category, help = info['help'])
|
||||||
|
subparsers_action[category] = subparsers_category[category].add_subparsers()
|
||||||
|
for action, helper in info['actions'].items():
|
||||||
|
parsers[category + '_' + action] = subparsers_action[category].add_parser(action, help = helper)
|
||||||
|
parsers[category + '_' + action].set_defaults(func = str_to_func('yunohost_' + category + '.' + category + '_' + action))
|
||||||
|
|
||||||
def parse_args(parser):
|
return parsers
|
||||||
|
|
||||||
parser_array = {
|
|
||||||
|
def parse_args(parsers):
|
||||||
|
''' Add and parse arguments
|
||||||
|
|
||||||
|
Keyword arguments:
|
||||||
|
parsers -- parsers and subparsers as a dict
|
||||||
|
|
||||||
|
Returns:
|
||||||
|
Namespace of arguments
|
||||||
|
|
||||||
|
Usage:
|
||||||
|
Add general argument: parsers['general'].add_argument( options )
|
||||||
|
Add specific argument: parsers['user_delete'].add_argument( options )
|
||||||
|
|
||||||
|
Documentation:
|
||||||
|
http://docs.python.org/dev/library/argparse.html
|
||||||
|
#argparse.ArgumentParser.add_argument
|
||||||
|
|
||||||
|
'''
|
||||||
|
|
||||||
|
# General
|
||||||
|
parsers['general'].add_argument(
|
||||||
|
'-v',
|
||||||
|
'--version',
|
||||||
|
action = 'version',
|
||||||
|
version = '%(prog)s '+ __version__
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
# User
|
||||||
|
parsers['user_list'].add_argument(
|
||||||
|
'-a',
|
||||||
|
'--all',
|
||||||
|
action = 'store'
|
||||||
|
)
|
||||||
|
|
||||||
|
# Call arguments parsing
|
||||||
|
args = parsers['general'].parse_args()
|
||||||
|
|
||||||
|
return args
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
def main():
|
||||||
|
''' Main instructions '''
|
||||||
|
|
||||||
|
action_dict = {
|
||||||
'user' : {
|
'user' : {
|
||||||
'actions' : {
|
'actions' : {
|
||||||
'list' : 'list users'
|
'list' : 'list users'
|
||||||
|
@ -100,66 +146,10 @@ def parse_args(parser):
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
""" Intialize parsers """
|
parsers = dict_to_parsers(action_dict)
|
||||||
subparsers = parser.add_subparsers()
|
args = parse_args(parsers)
|
||||||
parsers = subparsers_category = subparsers_action = dict()
|
|
||||||
|
|
||||||
"""
|
|
||||||
Turn above array into subparsers (e.g. parsers['user_list'])
|
|
||||||
and assign functions related to (e.g. user_list())
|
|
||||||
"""
|
|
||||||
for category, info in parser_array.items():
|
|
||||||
subparsers_category[category] = subparsers.add_parser(category, help = info['help'])
|
|
||||||
subparsers_action[category] = subparsers_category[category].add_subparsers()
|
|
||||||
for action, helper in info['actions'].items():
|
|
||||||
parsers[category + '_' + action] = subparsers_action[category].add_parser(action, help = helper)
|
|
||||||
parsers[category + '_' + action].set_defaults(func = str2fun('yunohost_' + category + '.' + category + '_' + action))
|
|
||||||
|
|
||||||
|
|
||||||
"""""""""""""""""""""""""""""""""""""""""""""""""""""""""
|
|
||||||
ARGUMENT PARSING
|
|
||||||
|
|
||||||
|
|
||||||
Add general argument:
|
|
||||||
parser.add_argument( options )
|
|
||||||
|
|
||||||
Add specific argument:
|
|
||||||
parsers['user_delete'].add_argument( options )
|
|
||||||
|
|
||||||
Documentation:
|
|
||||||
http://docs.python.org/dev/library/argparse.html
|
|
||||||
#argparse.ArgumentParser.add_argument
|
|
||||||
|
|
||||||
"""""""""""""""""""""""""""""""""""""""""""""""""""""""""
|
|
||||||
|
|
||||||
|
|
||||||
""" General """
|
|
||||||
parser.add_argument(
|
|
||||||
'-v',
|
|
||||||
'--version',
|
|
||||||
action = 'version',
|
|
||||||
version = '%(prog)s '+ version
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
""" User """
|
|
||||||
parsers['user_list'].add_argument(
|
|
||||||
'-a',
|
|
||||||
'--all',
|
|
||||||
action = 'store'
|
|
||||||
)
|
|
||||||
|
|
||||||
""" Call arguments parsing """
|
|
||||||
args = parser.parse_args()
|
|
||||||
|
|
||||||
return args
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
def main(args):
|
|
||||||
parser = argparse.ArgumentParser()
|
|
||||||
args = parse_args(parser)
|
|
||||||
args.func(vars(args))
|
args.func(vars(args))
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
main(args)
|
main()
|
||||||
|
|
Loading…
Reference in a new issue