Compare commits
4 Commits
Author | SHA1 | Date | |
---|---|---|---|
e4ce48df7c | |||
4b094dfcca | |||
020dc8f8de | |||
8d7fd32714 |
@@ -14,10 +14,11 @@ import copy
|
|||||||
# Local import
|
# Local import
|
||||||
from . import host
|
from . import host
|
||||||
from . import tools
|
from . import tools
|
||||||
from . import debug
|
from realog import debug
|
||||||
from . import env
|
from . import env
|
||||||
from . import actions
|
from . import actions
|
||||||
from . import arguments
|
import death.Arguments as arguments
|
||||||
|
import death.ArgElement as arg_element
|
||||||
is_init = False
|
is_init = False
|
||||||
|
|
||||||
|
|
||||||
@@ -60,7 +61,7 @@ init()
|
|||||||
|
|
||||||
debug.verbose("List of actions: " + str(actions.get_list_of_action()))
|
debug.verbose("List of actions: " + str(actions.get_list_of_action()))
|
||||||
|
|
||||||
my_args = arguments.islandArg()
|
my_args = arguments.Arguments()
|
||||||
my_args.add_section("option", "Can be set one time in all case")
|
my_args.add_section("option", "Can be set one time in all case")
|
||||||
my_args.add("h", "help", desc="Display this help")
|
my_args.add("h", "help", desc="Display this help")
|
||||||
my_args.add("v", "verbose", list=[["0","None"],["1","error"],["2","warning"],["3","info"],["4","debug"],["5","verbose"],["6","extreme_verbose"]], desc="display debug level (verbose) default =2")
|
my_args.add("v", "verbose", list=[["0","None"],["1","error"],["2","warning"],["3","info"],["4","debug"],["5","verbose"],["6","extreme_verbose"]], desc="display debug level (verbose) default =2")
|
||||||
@@ -153,37 +154,37 @@ 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_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)
|
||||||
|
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
@@ -9,11 +9,11 @@
|
|||||||
##
|
##
|
||||||
|
|
||||||
# Local import
|
# Local import
|
||||||
from . import debug
|
from realog import debug
|
||||||
import os
|
import os
|
||||||
import sys
|
import sys
|
||||||
from . import env
|
from . import env
|
||||||
from . import arguments
|
import death.Arguments as arguments
|
||||||
|
|
||||||
list_actions = []
|
list_actions = []
|
||||||
|
|
||||||
@@ -86,7 +86,7 @@ def execute(action_name, argument_start_id):
|
|||||||
# finish the parsing
|
# finish the parsing
|
||||||
sys.path.append(os.path.dirname(elem["path"]))
|
sys.path.append(os.path.dirname(elem["path"]))
|
||||||
the_action = __import__(__base_action_name + action_name)
|
the_action = __import__(__base_action_name + action_name)
|
||||||
my_under_args_parser = arguments.islandArg()
|
my_under_args_parser = arguments.Arguments()
|
||||||
my_under_args_parser.add("h", "help", desc="Help of this action")
|
my_under_args_parser.add("h", "help", desc="Help of this action")
|
||||||
if "add_specific_arguments" in dir(the_action):
|
if "add_specific_arguments" in dir(the_action):
|
||||||
the_action.add_specific_arguments(my_under_args_parser, elem["name"])
|
the_action.add_specific_arguments(my_under_args_parser, elem["name"])
|
||||||
|
@@ -8,7 +8,7 @@
|
|||||||
## @license MPL v2.0 (see license file)
|
## @license MPL v2.0 (see license file)
|
||||||
##
|
##
|
||||||
|
|
||||||
from island import debug
|
from realog import debug
|
||||||
from island import tools
|
from island import tools
|
||||||
from island import env
|
from island import env
|
||||||
from island import config
|
from island import config
|
||||||
|
63
island/actions/islandAction_command.py
Normal file
63
island/actions/islandAction_command.py
Normal file
@@ -0,0 +1,63 @@
|
|||||||
|
#!/usr/bin/python
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
##
|
||||||
|
## @author Edouard DUPIN
|
||||||
|
##
|
||||||
|
## @copyright 2012, Edouard DUPIN, all right reserved
|
||||||
|
##
|
||||||
|
## @license MPL v2.0 (see license file)
|
||||||
|
##
|
||||||
|
|
||||||
|
from realog import debug
|
||||||
|
from island import tools
|
||||||
|
from island import env
|
||||||
|
from island import multiprocess
|
||||||
|
from island import config
|
||||||
|
from island import manifest
|
||||||
|
import os
|
||||||
|
|
||||||
|
|
||||||
|
def help():
|
||||||
|
return "write the command you want to be executed in every repository"
|
||||||
|
|
||||||
|
def execute(arguments):
|
||||||
|
cmd = ""
|
||||||
|
for elem in arguments:
|
||||||
|
debug.info("Get data element: " + str(elem.get_arg()))
|
||||||
|
cmd += elem.get_arg() + " "
|
||||||
|
|
||||||
|
# check if .XXX exist (create it if needed)
|
||||||
|
if os.path.exists(env.get_island_path()) == False \
|
||||||
|
or os.path.exists(env.get_island_path_config()) == False \
|
||||||
|
or os.path.exists(env.get_island_path_manifest()) == False:
|
||||||
|
debug.error("System already init have an error: missing data: '" + str(env.get_island_path()) + "'")
|
||||||
|
|
||||||
|
configuration = config.Config()
|
||||||
|
|
||||||
|
file_source_manifest = os.path.join(env.get_island_path_manifest(), configuration.get_manifest_name())
|
||||||
|
if os.path.exists(file_source_manifest) == False:
|
||||||
|
debug.error("Missing manifest file : '" + str(file_source_manifest) + "'")
|
||||||
|
|
||||||
|
mani = manifest.Manifest(file_source_manifest)
|
||||||
|
|
||||||
|
all_project = mani.get_all_configs()
|
||||||
|
debug.info("status of: " + str(len(all_project)) + " projects")
|
||||||
|
id_element = 0
|
||||||
|
for elem in all_project:
|
||||||
|
debug.info("------------------------------------------")
|
||||||
|
id_element += 1
|
||||||
|
debug.info("execute command : " + str(id_element) + "/" + str(len(all_project)) + " : " + str(elem.name))
|
||||||
|
#debug.debug("elem : " + str(elem))
|
||||||
|
git_repo_path = os.path.join(env.get_island_root_path(), elem.path)
|
||||||
|
if os.path.exists(git_repo_path) == False:
|
||||||
|
debug.info("" + str(id_element) + "/" + str(len(all_project)) + " : " + str(elem.name) + "\r\t\t\t\t\t\t\t\t\t" + " (not download)")
|
||||||
|
continue
|
||||||
|
|
||||||
|
debug.verbose("execute : " + cmd)
|
||||||
|
ret = multiprocess.run_command(cmd, cwd=git_repo_path)
|
||||||
|
if ret[0] == 0:
|
||||||
|
debug.info("ret=" + ret[1])
|
||||||
|
debug.info("err=" + ret[2])
|
||||||
|
else:
|
||||||
|
debug.info("Execution ERROR")
|
||||||
|
|
@@ -8,7 +8,7 @@
|
|||||||
## @license MPL v2.0 (see license file)
|
## @license MPL v2.0 (see license file)
|
||||||
##
|
##
|
||||||
|
|
||||||
from island import debug
|
from realog import debug
|
||||||
from island import tools
|
from island import tools
|
||||||
from island import env
|
from island import env
|
||||||
from island import config
|
from island import config
|
||||||
|
@@ -8,7 +8,7 @@
|
|||||||
## @license MPL v2.0 (see license file)
|
## @license MPL v2.0 (see license file)
|
||||||
##
|
##
|
||||||
|
|
||||||
from island import debug
|
from realog import debug
|
||||||
from island import tools
|
from island import tools
|
||||||
from island import env
|
from island import env
|
||||||
from island import config
|
from island import config
|
||||||
|
@@ -8,7 +8,7 @@
|
|||||||
## @license MPL v2.0 (see license file)
|
## @license MPL v2.0 (see license file)
|
||||||
##
|
##
|
||||||
|
|
||||||
from island import debug
|
from realog import debug
|
||||||
from island import tools
|
from island import tools
|
||||||
from island import env
|
from island import env
|
||||||
from island import config
|
from island import config
|
||||||
|
@@ -8,7 +8,7 @@
|
|||||||
## @license MPL v2.0 (see license file)
|
## @license MPL v2.0 (see license file)
|
||||||
##
|
##
|
||||||
|
|
||||||
from island import debug
|
from realog import debug
|
||||||
from island import tools
|
from island import tools
|
||||||
from island import env
|
from island import env
|
||||||
from island import config
|
from island import config
|
||||||
|
@@ -8,7 +8,7 @@
|
|||||||
## @license MPL v2.0 (see license file)
|
## @license MPL v2.0 (see license file)
|
||||||
##
|
##
|
||||||
|
|
||||||
from island import debug
|
from realog import debug
|
||||||
from island import tools
|
from island import tools
|
||||||
from island import env
|
from island import env
|
||||||
from island import multiprocess
|
from island import multiprocess
|
||||||
|
@@ -8,7 +8,7 @@
|
|||||||
## @license MPL v2.0 (see license file)
|
## @license MPL v2.0 (see license file)
|
||||||
##
|
##
|
||||||
|
|
||||||
from island import debug
|
from realog import debug
|
||||||
from island import tools
|
from island import tools
|
||||||
from island import env
|
from island import env
|
||||||
from island import config
|
from island import config
|
||||||
|
@@ -1,517 +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 . 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;
|
|
||||||
|
|
||||||
def is_parsable(self):
|
|
||||||
return True
|
|
||||||
##
|
|
||||||
## @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 Declare an argument value and store it in a parameter
|
|
||||||
##
|
|
||||||
class ArgVolatile:
|
|
||||||
##
|
|
||||||
## @brief Contructor.
|
|
||||||
## @param[in] self Class handle
|
|
||||||
## @param[in] dest_option (string) Where to store the option name
|
|
||||||
## @param[in] optionnal (bool) this element can be not present
|
|
||||||
## @param[in] desc (string) user friendly description with this parameter (default "")
|
|
||||||
##
|
|
||||||
def __init__(self,
|
|
||||||
dest_option="",
|
|
||||||
optionnal=False,
|
|
||||||
desc=""):
|
|
||||||
self.dest_option = dest_option;
|
|
||||||
if dest_option == "":
|
|
||||||
debug.error("volatil argument must be store in an argument name")
|
|
||||||
self.optionnal = optionnal;
|
|
||||||
self.description = desc;
|
|
||||||
self.count = 0;
|
|
||||||
|
|
||||||
def is_parsable(self):
|
|
||||||
return False
|
|
||||||
##
|
|
||||||
## @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 ""
|
|
||||||
|
|
||||||
##
|
|
||||||
## @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.dest_option
|
|
||||||
|
|
||||||
##
|
|
||||||
## @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):
|
|
||||||
if self.count == 0:
|
|
||||||
self.count += 1
|
|
||||||
return True
|
|
||||||
return False
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Compatibility with @ref ArgSection class
|
|
||||||
## @param[in] self Class handle
|
|
||||||
## @return (string) empty string
|
|
||||||
##
|
|
||||||
def get_porperties(self):
|
|
||||||
return " [" + self.dest_option + "]"
|
|
||||||
|
|
||||||
##
|
|
||||||
## @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):
|
|
||||||
return True
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Display the argument property when user request help
|
|
||||||
## @param[in] self Class handle
|
|
||||||
##
|
|
||||||
def display(self):
|
|
||||||
color = debug.get_color_set()
|
|
||||||
print(" " + color['red'] + "[" + self.dest_option + "]" + color['default'])
|
|
||||||
if self.optionnal == True:
|
|
||||||
print("(OPTIONNAL)")
|
|
||||||
if self.description != "":
|
|
||||||
print(" " + self.description)
|
|
||||||
|
|
||||||
##
|
|
||||||
## @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;
|
|
||||||
|
|
||||||
def is_parsable(self):
|
|
||||||
return False
|
|
||||||
|
|
||||||
##
|
|
||||||
## @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 islandArg:
|
|
||||||
##
|
|
||||||
## @brief Constructor.
|
|
||||||
## @param[in] self Class handle
|
|
||||||
##
|
|
||||||
def __init__(self):
|
|
||||||
self.list_properties = []
|
|
||||||
self._list_element_stop = []
|
|
||||||
self._last_element_parsed = 0
|
|
||||||
|
|
||||||
##
|
|
||||||
## @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))
|
|
||||||
|
|
||||||
def add_arg(self, destOption="", optionnal=False, desc=""):
|
|
||||||
self.list_properties.append(ArgVolatile(destOption, optionnal, desc))
|
|
||||||
|
|
||||||
##
|
|
||||||
## @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
|
|
||||||
## @param[in] start_position_parsing position to start the parsing in the arguments
|
|
||||||
##
|
|
||||||
def parse(self, start_position_parsing=1):
|
|
||||||
list_argument = [] # composed of list element
|
|
||||||
not_parse_next_element=False
|
|
||||||
for iii in range(start_position_parsing, len(sys.argv)):
|
|
||||||
self._last_element_parsed = iii
|
|
||||||
# special case of parameter in some elements
|
|
||||||
if not_parse_next_element == True:
|
|
||||||
not_parse_next_element = False
|
|
||||||
continue
|
|
||||||
debug.verbose("parse [" + str(iii) + "]=" + sys.argv[iii])
|
|
||||||
argument = sys.argv[iii]
|
|
||||||
# check if we get a stop parsing element:
|
|
||||||
if argument in self._list_element_stop:
|
|
||||||
debug.warning("stop at position: " + str(iii))
|
|
||||||
list_argument.append(ArgElement("", argument))
|
|
||||||
break;
|
|
||||||
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)
|
|
||||||
argument_found=False;
|
|
||||||
if option[:2] == "--":
|
|
||||||
# big argument
|
|
||||||
for prop in self.list_properties:
|
|
||||||
if prop.is_parsable()==False:
|
|
||||||
continue
|
|
||||||
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]
|
|
||||||
not_parse_next_element=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)
|
|
||||||
list_argument.append(ArgElement(prop.get_option_big(),optionParam))
|
|
||||||
argument_found = True
|
|
||||||
else:
|
|
||||||
if len(optionParam)!=0:
|
|
||||||
debug.warning("parsing argument error : '" + prop.get_option_big() + "' need no subParameters : '" + optionParam + "' cmdLine='" + argument + "'")
|
|
||||||
prop.display()
|
|
||||||
list_argument.append(ArgElement(prop.get_option_big()))
|
|
||||||
argument_found = True
|
|
||||||
break;
|
|
||||||
if argument_found == False:
|
|
||||||
debug.error("UNKNOW argument : '" + argument + "'")
|
|
||||||
elif option[:1]=="-":
|
|
||||||
# small argument
|
|
||||||
for prop in self.list_properties:
|
|
||||||
if prop.is_parsable()==False:
|
|
||||||
continue
|
|
||||||
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]
|
|
||||||
not_parse_next_element=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)
|
|
||||||
list_argument.append(ArgElement(prop.get_option_big(),optionParam))
|
|
||||||
argument_found = True
|
|
||||||
else:
|
|
||||||
if len(optionParam)!=0:
|
|
||||||
debug.warning("parsing argument error : '" + prop.get_option_big() + "' need no subParameters : '" + optionParam + "' cmdLine='" + argument + "'")
|
|
||||||
prop.display()
|
|
||||||
list_argument.append(ArgElement(prop.get_option_big()))
|
|
||||||
argument_found = True
|
|
||||||
break;
|
|
||||||
|
|
||||||
if argument_found==False:
|
|
||||||
# small argument
|
|
||||||
for prop in self.list_properties:
|
|
||||||
if prop.is_parsable() == True \
|
|
||||||
or prop.get_option_big() == "":
|
|
||||||
continue
|
|
||||||
if prop.need_parameters() == True:
|
|
||||||
list_argument.append(ArgElement(prop.get_option_big(), argument))
|
|
||||||
argument_found = True
|
|
||||||
break
|
|
||||||
if argument_found==False:
|
|
||||||
#unknow element ... ==> just add in the list ...
|
|
||||||
debug.verbose("unknow argument : " + argument)
|
|
||||||
list_argument.append(ArgElement("", argument))
|
|
||||||
|
|
||||||
for prop in self.list_properties:
|
|
||||||
if prop.is_parsable() == True \
|
|
||||||
or prop.get_option_big() == "":
|
|
||||||
continue
|
|
||||||
if prop.need_parameters() == True \
|
|
||||||
and prop.optionnal == False:
|
|
||||||
debug.error("Missing argument:" + prop.get_option_big())
|
|
||||||
#for argument in list_argument:
|
|
||||||
# argument.display()
|
|
||||||
#exit(0)
|
|
||||||
return list_argument;
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Stop parsing at a specific position
|
|
||||||
## @param[in] self Class handle
|
|
||||||
## @param[in] list_of_element List of element that stop the parsing
|
|
||||||
##
|
|
||||||
def set_stop_at(self, list_of_element):
|
|
||||||
self._list_element_stop = list_of_element
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief get the last element parsed.
|
|
||||||
## @param[in] self Class handle
|
|
||||||
##
|
|
||||||
def get_last_parsed(self):
|
|
||||||
return self._last_element_parsed
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Display help on console output
|
|
||||||
## @param[in] self Class handle
|
|
||||||
## @param[in] action_name opation to set at the end of the application name
|
|
||||||
##
|
|
||||||
def display(self, action_name=""):
|
|
||||||
print("usage:")
|
|
||||||
listOfPropertiesArg = "";
|
|
||||||
for element in self.list_properties :
|
|
||||||
listOfPropertiesArg += element.get_porperties()
|
|
||||||
print(" " + sys.argv[0] + " " + action_name + " " + listOfPropertiesArg + " ...")
|
|
||||||
for element in self.list_properties :
|
|
||||||
element.display()
|
|
||||||
|
|
@@ -12,7 +12,7 @@ import sys
|
|||||||
import os
|
import os
|
||||||
import copy
|
import copy
|
||||||
# Local import
|
# Local import
|
||||||
from . import debug
|
from realog import debug
|
||||||
from . import tools
|
from . import tools
|
||||||
from . import env
|
from . import env
|
||||||
from . import multiprocess
|
from . import multiprocess
|
||||||
|
258
island/debug.py
258
island/debug.py
@@ -1,258 +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 os
|
|
||||||
import threading
|
|
||||||
import re
|
|
||||||
|
|
||||||
debug_level=3
|
|
||||||
debug_color=False
|
|
||||||
|
|
||||||
color_default= ""
|
|
||||||
color_red = ""
|
|
||||||
color_green = ""
|
|
||||||
color_yellow = ""
|
|
||||||
color_blue = ""
|
|
||||||
color_purple = ""
|
|
||||||
color_cyan = ""
|
|
||||||
|
|
||||||
|
|
||||||
debug_lock = threading.Lock()
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Set log level of the console log system
|
|
||||||
## @param[in] id (int) Value of the log level:
|
|
||||||
## 0: None
|
|
||||||
## 1: error
|
|
||||||
## 2: warning
|
|
||||||
## 3: info
|
|
||||||
## 4: debug
|
|
||||||
## 5: verbose
|
|
||||||
## 6: extreme_verbose
|
|
||||||
##
|
|
||||||
def set_level(id):
|
|
||||||
global debug_level
|
|
||||||
debug_level = id
|
|
||||||
#print "SetDebug level at " + str(debug_level)
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Get the current debug leval
|
|
||||||
## @return The value of the log level. Show: @ref set_level
|
|
||||||
##
|
|
||||||
def get_level():
|
|
||||||
global debug_level
|
|
||||||
return debug_level
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Enable color of the console Log system
|
|
||||||
##
|
|
||||||
def enable_color():
|
|
||||||
global debug_color
|
|
||||||
debug_color = True
|
|
||||||
global color_default
|
|
||||||
color_default= "\033[00m"
|
|
||||||
global color_red
|
|
||||||
color_red = "\033[31m"
|
|
||||||
global color_green
|
|
||||||
color_green = "\033[32m"
|
|
||||||
global color_yellow
|
|
||||||
color_yellow = "\033[33m"
|
|
||||||
global color_blue
|
|
||||||
color_blue = "\033[01;34m"
|
|
||||||
global color_purple
|
|
||||||
color_purple = "\033[35m"
|
|
||||||
global color_cyan
|
|
||||||
color_cyan = "\033[36m"
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Disable color of the console Log system
|
|
||||||
##
|
|
||||||
def disable_color():
|
|
||||||
global debug_color
|
|
||||||
debug_color = True
|
|
||||||
global color_default
|
|
||||||
color_default= ""
|
|
||||||
global color_red
|
|
||||||
color_red = ""
|
|
||||||
global color_green
|
|
||||||
color_green = ""
|
|
||||||
global color_yellow
|
|
||||||
color_yellow = ""
|
|
||||||
global color_blue
|
|
||||||
color_blue = ""
|
|
||||||
global color_purple
|
|
||||||
color_purple = ""
|
|
||||||
global color_cyan
|
|
||||||
color_cyan = ""
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Print a extreme verbose log
|
|
||||||
## @param[in] input (string) Value to print if level is enough
|
|
||||||
## @param[in] force (bool) force display (no check of log level)
|
|
||||||
##
|
|
||||||
def extreme_verbose(input, force=False):
|
|
||||||
global debug_lock
|
|
||||||
global debug_level
|
|
||||||
if debug_level >= 6 \
|
|
||||||
or force == True:
|
|
||||||
debug_lock.acquire()
|
|
||||||
print(color_blue + input + color_default)
|
|
||||||
debug_lock.release()
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Print a verbose log
|
|
||||||
## @param[in] input (string) Value to print if level is enough
|
|
||||||
## @param[in] force (bool) force display (no check of log level)
|
|
||||||
##
|
|
||||||
def verbose(input, force=False):
|
|
||||||
global debug_lock
|
|
||||||
global debug_level
|
|
||||||
if debug_level >= 5 \
|
|
||||||
or force == True:
|
|
||||||
debug_lock.acquire()
|
|
||||||
print(color_blue + input + color_default)
|
|
||||||
debug_lock.release()
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Print a debug log
|
|
||||||
## @param[in] input (string) Value to print if level is enough
|
|
||||||
## @param[in] force (bool) force display (no check of log level)
|
|
||||||
##
|
|
||||||
def debug(input, force=False):
|
|
||||||
global debug_lock
|
|
||||||
global debug_level
|
|
||||||
if debug_level >= 4 \
|
|
||||||
or force == True:
|
|
||||||
debug_lock.acquire()
|
|
||||||
print(color_green + input + color_default)
|
|
||||||
debug_lock.release()
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Print an info log
|
|
||||||
## @param[in] input (string) Value to print if level is enough
|
|
||||||
## @param[in] force (bool) force display (no check of log level)
|
|
||||||
##
|
|
||||||
def info(input, force=False):
|
|
||||||
global debug_lock
|
|
||||||
global debug_level
|
|
||||||
if debug_level >= 3 \
|
|
||||||
or force == True:
|
|
||||||
debug_lock.acquire()
|
|
||||||
print(input + color_default)
|
|
||||||
debug_lock.release()
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Print a warning log
|
|
||||||
## @param[in] input (string) Value to print if level is enough
|
|
||||||
## @param[in] force (bool) force display (no check of log level)
|
|
||||||
##
|
|
||||||
def warning(input, force=False):
|
|
||||||
global debug_lock
|
|
||||||
global debug_level
|
|
||||||
if debug_level >= 2 \
|
|
||||||
or force == True:
|
|
||||||
debug_lock.acquire()
|
|
||||||
print(color_purple + "[WARNING] " + input + color_default)
|
|
||||||
debug_lock.release()
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Print a todo log
|
|
||||||
## @param[in] input (string) Value to print if level is enough
|
|
||||||
## @param[in] force (bool) force display (no check of log level)
|
|
||||||
##
|
|
||||||
def todo(input, force=False):
|
|
||||||
global debug_lock
|
|
||||||
global debug_level
|
|
||||||
if debug_level >= 3 \
|
|
||||||
or force == True:
|
|
||||||
debug_lock.acquire()
|
|
||||||
print(color_purple + "[TODO] " + input + color_default)
|
|
||||||
debug_lock.release()
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Print an error log
|
|
||||||
## @param[in] input (string) Value to print if level is enough
|
|
||||||
## @param[in] thread_id (int) Current thead ID of the builder thread
|
|
||||||
## @param[in] force (bool) force display (no check of log level)
|
|
||||||
## @param[in] crash (bool) build error has appear ==> request stop of all builds
|
|
||||||
##
|
|
||||||
def error(input, thread_id=-1, force=False, crash=True):
|
|
||||||
global debug_lock
|
|
||||||
global debug_level
|
|
||||||
if debug_level >= 1 \
|
|
||||||
or force == True:
|
|
||||||
debug_lock.acquire()
|
|
||||||
print(color_red + "[ERROR] " + input + color_default)
|
|
||||||
debug_lock.release()
|
|
||||||
if crash == True:
|
|
||||||
exit(-1)
|
|
||||||
#os_exit(-1)
|
|
||||||
#raise "error happend"
|
|
||||||
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Print a log for a specific element action like generateing .so or binary ...
|
|
||||||
## @param[in] type (string) type of action. Like: "copy file", "StaticLib", "Prebuild", "Library" ...
|
|
||||||
## @param[in] lib (string) Name of the library/binary/package that action is done
|
|
||||||
## @param[in] dir (string) build direction. ex: "<==", "==>" ...
|
|
||||||
## @param[in] name (string) Destination of the data
|
|
||||||
## @param[in] force (bool) force display (no check of log level)
|
|
||||||
##
|
|
||||||
def print_element(type, lib, dir, name, force=False):
|
|
||||||
global debug_lock
|
|
||||||
global debug_level
|
|
||||||
if debug_level >= 3 \
|
|
||||||
or force == True:
|
|
||||||
debug_lock.acquire()
|
|
||||||
print(color_cyan + type + color_default + " : " + color_yellow + lib + color_default + " " + dir + " " + color_blue + name + color_default)
|
|
||||||
debug_lock.release()
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Print a compilation return (output)
|
|
||||||
## @param[in] my_string (string) Std-error/std-info that is generate by the build system
|
|
||||||
##
|
|
||||||
def print_compilator(my_string):
|
|
||||||
global debug_color
|
|
||||||
global debug_lock
|
|
||||||
if debug_color == True:
|
|
||||||
my_string = my_string.replace('\\n', '\n')
|
|
||||||
my_string = my_string.replace('\\t', '\t')
|
|
||||||
my_string = my_string.replace('error:', color_red+'error:'+color_default)
|
|
||||||
my_string = my_string.replace('warning:', color_purple+'warning:'+color_default)
|
|
||||||
my_string = my_string.replace('note:', color_green+'note:'+color_default)
|
|
||||||
my_string = re.sub(r'([/\w_-]+\.\w+):', r'-COLORIN-\1-COLOROUT-:', my_string)
|
|
||||||
my_string = my_string.replace('-COLORIN-', color_yellow)
|
|
||||||
my_string = my_string.replace('-COLOROUT-', color_default)
|
|
||||||
|
|
||||||
debug_lock.acquire()
|
|
||||||
print(my_string)
|
|
||||||
debug_lock.release()
|
|
||||||
|
|
||||||
##
|
|
||||||
## @brief Get the list of default color
|
|
||||||
## @return A map with keys: "default","red","green","yellow","blue","purple","cyan"
|
|
||||||
##
|
|
||||||
def get_color_set() :
|
|
||||||
global color_default
|
|
||||||
global color_red
|
|
||||||
global color_green
|
|
||||||
global color_yellow
|
|
||||||
global color_blue
|
|
||||||
global color_purple
|
|
||||||
global color_cyan
|
|
||||||
return {
|
|
||||||
"default": color_default,
|
|
||||||
"red": color_red,
|
|
||||||
"green": color_green,
|
|
||||||
"yellow": color_yellow,
|
|
||||||
"blue": color_blue,
|
|
||||||
"purple": color_purple,
|
|
||||||
"cyan": color_cyan,
|
|
||||||
}
|
|
@@ -9,7 +9,7 @@
|
|||||||
##
|
##
|
||||||
|
|
||||||
# Local import
|
# Local import
|
||||||
from . import debug
|
from realog import debug
|
||||||
|
|
||||||
import os
|
import os
|
||||||
|
|
||||||
|
@@ -10,7 +10,7 @@
|
|||||||
import platform
|
import platform
|
||||||
import sys
|
import sys
|
||||||
# Local import
|
# Local import
|
||||||
from . import debug
|
from realog import debug
|
||||||
|
|
||||||
# print os.name # ==> 'posix'
|
# print os.name # ==> 'posix'
|
||||||
if platform.system() == "Linux":
|
if platform.system() == "Linux":
|
||||||
|
@@ -12,7 +12,7 @@ import sys
|
|||||||
import os
|
import os
|
||||||
import copy
|
import copy
|
||||||
# Local import
|
# Local import
|
||||||
from . import debug
|
from realog import debug
|
||||||
from . import tools
|
from . import tools
|
||||||
from . import env
|
from . import env
|
||||||
from . import multiprocess
|
from . import multiprocess
|
||||||
|
@@ -16,7 +16,7 @@ import os
|
|||||||
import subprocess
|
import subprocess
|
||||||
import shlex
|
import shlex
|
||||||
# Local import
|
# Local import
|
||||||
from . import debug
|
from realog import debug
|
||||||
from . import tools
|
from . import tools
|
||||||
from . import env
|
from . import env
|
||||||
|
|
||||||
@@ -57,7 +57,7 @@ def run_command_direct(cmd_line, cwd=None):
|
|||||||
if sys.version_info >= (3, 0):
|
if sys.version_info >= (3, 0):
|
||||||
output = output.decode("utf-8")
|
output = output.decode("utf-8")
|
||||||
err = err.decode("utf-8")
|
err = err.decode("utf-8")
|
||||||
# Check error :
|
# Check errors:
|
||||||
if p.returncode == 0:
|
if p.returncode == 0:
|
||||||
if output == None:
|
if output == None:
|
||||||
return err[:-1];
|
return err[:-1];
|
||||||
|
@@ -14,7 +14,7 @@ import errno
|
|||||||
import fnmatch
|
import fnmatch
|
||||||
import stat
|
import stat
|
||||||
# Local import
|
# Local import
|
||||||
from . import debug
|
from realog import debug
|
||||||
from . import env
|
from . import env
|
||||||
|
|
||||||
"""
|
"""
|
||||||
|
4
setup.py
4
setup.py
@@ -16,7 +16,7 @@ def readme():
|
|||||||
|
|
||||||
# https://pypi.python.org/pypi?%3Aaction=list_classifiers
|
# https://pypi.python.org/pypi?%3Aaction=list_classifiers
|
||||||
setup(name='island',
|
setup(name='island',
|
||||||
version='0.5.1',
|
version='0.6.0',
|
||||||
description='island generic source manager (like repo in simple mode)',
|
description='island generic source manager (like repo in simple mode)',
|
||||||
long_description=readme(),
|
long_description=readme(),
|
||||||
url='http://github.com/HeeroYui/island',
|
url='http://github.com/HeeroYui/island',
|
||||||
@@ -39,6 +39,8 @@ setup(name='island',
|
|||||||
#],
|
#],
|
||||||
install_requires=[
|
install_requires=[
|
||||||
'lxml',
|
'lxml',
|
||||||
|
'realog',
|
||||||
|
'death',
|
||||||
],
|
],
|
||||||
include_package_data = True,
|
include_package_data = True,
|
||||||
zip_safe=False)
|
zip_safe=False)
|
||||||
|
Reference in New Issue
Block a user