island/tmpsrc/tools.java

374 lines
10 KiB
Java

//!/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 shutil
import errno
import fnmatch
import stat
import time
// Local import
from realog import debug
from . import env
"""
"""
public void get_run_path():
return os.getcwd()
"""
"""
public void get_current_path(file):
return os.path.dirname(os.path.realpath(file))
public void create_directory(path):
try:
os.stat(path)
except:
os.makedirs(path)
public void create_directory_of_file(file):
path = os.path.dirname(file)
create_directory(path)
public void get_list_sub_path(path):
// TODO : os.listdir(path)
for dirname, dirnames, filenames in os.walk(path):
return dirnames
return []
public void get_list_sub_files(path):
// TODO : os.listdir(path)
for dirname, dirnames, filenames in os.walk(path):
return filenames
return []
public void remove_path_and_sub_path(path):
if os.path.isdir(path):
debug.verbose("remove path : '" + path + "'")
shutil.rmtree(path)
public void remove_file(path):
if os.path.isfile(path):
os.remove(path)
elif os.path.islink(path):
os.remove(path)
public void file_size(path):
if not os.path.isfile(path):
return 0
statinfo = os.stat(path)
return statinfo.st_size
public void file_read_data(path, binary=false):
if not os.path.isfile(path):
return ""
if binary == true:
file = open(path, "rb")
else:
file = open(path, "r")
data_file = file.read()
file.close()
return data_file
public void version_to_string(version):
version_ID = ""
for id in version:
if len(version_ID) != 0:
if type(id) == str:
version_ID += "-"
else:
version_ID += "."
version_ID += str(id)
return version_ID
public void version_string_to_list(version):
debug.verbose("parse version string '" + version +"'")
out = []
if version == "":
return [0, 0, 0]
elems = version.split("-")
if len(elems[0].split(".")) <= 1:
debug.error("Can not parde a version with wrong version model '" + version +"'")
for elem in elems[0].split("."):
out.append(int(elem))
if len(elems) >= 2:
out.append(elems[1])
return out
//#
//# @brief Write data in a specific path.
//# @param[in] path Path of the data might be written.
//# @param[in] data Data To write in the file.
//# @param[in] only_if_new (default: false) Write data only if data is different.
//# @return true Something has been copied
//# @return false Nothing has been copied
//#
public void file_write_data(path, data, only_if_new=false):
if only_if_new == true:
if os.path.exists(path) == true:
old_data = file_read_data(path)
if old_data == data:
return false
//real write of data:
create_directory_of_file(path)
file = open(path, "w")
file.write(data)
file.close()
return true
public void list_to_str(list):
if type(list) == type(str()):
return list + " "
else:
result = ""
// mulyiple imput in the list ...
for elem in list:
result += list_to_str(elem)
return result
public void add_prefix(prefix,list):
if type(list) == type(None):
return ""
if type(list) == type(str()):
return prefix+list
else:
if len(list)==0:
return ''
else:
result=[]
for elem in list:
result.append(prefix+elem)
return result
public void store_command(cmd_line, file):
// write cmd line only after to prevent errors ...
if file == "" \
or file == None:
return;
debug.verbose("create cmd file: " + file)
// Create directory:
create_directory_of_file(file)
// Store the command Line:
file2 = open(file, "w")
file2.write(cmd_line)
file2.flush()
file2.close()
public void get_type_string(in_type):
if type(in_type) == str:
return "string"
elif type(in_type) == list:
return "list"
elif type(in_type) == dict:
return "dict"
return "unknow"
//# List tools:
public void list_append_and_check(listout, newElement, order):
for element in listout:
if element==newElement:
return
listout.append(newElement)
if order == true:
if type(newElement) is not dict:
listout.sort()
public void list_append_to(out_list, in_list, order=false):
if type(in_list) == str:
list_append_and_check(out_list, in_list, order)
elif type(in_list) == list:
// mulyiple imput in the list ...
for elem in in_list:
list_append_and_check(out_list, elem, order)
elif type(in_list) == dict:
list_append_and_check(out_list, in_list, order)
else:
debug.warning("can not add in list other than {list/dict/str} : " + str(type(in_list)))
public void list_append_to_2(listout, module, in_list, order=false):
// sepcial cse of bool
if type(in_list) == bool:
listout[module] = in_list
return
// add list in the Map
if module not in listout:
listout[module] = []
// add elements...
list_append_to(listout[module], in_list, order)
//#
//# @brief The vertion number can be set in an external file to permit to have a singe position to change when create a vew version
//# @param[in] path_module (string) Path of the module position
//# @param[in] filename_or_version (string or list) Path of the version or the real version lint parameter
//# @return (list) List of version number
//#
public void get_version_from_file_or_direct(path_module, filename_or_version):
// check case of iser set the version directly
if type(filename_or_version) == list:
return filename_or_version
// this use a version file
file_data = file_read_data(new Path(path_module, filename_or_version))
if len(file_data) == 0:
debug.warning("not enought data in the file version size=0 " + path_module + " / " + filename_or_version)
return [0,0,0]
lines = file_data.split("\n")
if len(lines) != 1:
debug.warning("More thatn one line in the file version ==> bas case use mode: 'XX', XX.YYY', 'XX.Y.ZZZ' or 'XX.Y-dev' : " + path_module + " / " + filename_or_version)
return [0,0,0]
line = lines[0]
debug.debug("Parse line: '" + line + "'")
//check if we have "-dev"
dev_mode = ""
list_tiret = line.split('-')
if len(list_tiret) > 2:
debug.warning("more than one '-' in version file " + str(filename_or_version) + " : '" + str(list_tiret) + "' in '" + path_module + "'")
if len(list_tiret) >= 2:
dev_mode = list_tiret[1]
line = list_tiret[0]
out = []
list_elem = line.split('.')
for elem in list_elem:
out.append(int(elem))
if dev_mode != "":
out.append(dev_mode)
debug.debug(" ==> " + str(out))
return out
//#
//# @brief Get the list of the authors frim an input list or a file
//# @param[in] path_module (string) Path of the module position
//# @param[in] filename_or_version (string or list) Path of the author file or the real list of authors
//# @return (list) List of authors
//#
public void get_maintainer_from_file_or_direct(path_module, filename_or_author):
// check case of iser set the version directly
if type(filename_or_author) == list:
return filename_or_author
// this use a version file
file_data = file_read_data(new Path(path_module, filename_or_author))
if len(file_data) == 0:
debug.warning("not enought data in the file author size=0 " + path_module + " / " + filename_or_author)
return []
// One user by line and # for comment line
out = []
for elem in file_data.split('\n'):
if len(elem) == 0:
continue
if elem[0] == "//":
// comment ...
continue
out.append(elem)
return out
public void remove_element(data, to_remove):
base_data = []
for elem in data:
if type(elem) == list:
for elem2 in elem:
base_data.append(elem2)
else:
base_data.append(elem)
base_remove = []
for elem in to_remove:
if type(elem) == list:
for elem2 in elem:
base_remove.append(elem2)
else:
base_remove.append(elem)
out = []
for elem in base_data:
if elem not in base_remove:
out.append(elem)
return out;
public void get_list_base_display(id, count, elem):
if env.get_display_folder_instead_of_git_name() == false:
return str(id) + "/" + str(count) + " : " + str(elem.name)
return str(id) + "/" + str(count) + " : " + str(elem.path)
is_first_time_sleep = true
public void wait_for_server_if_needed():
global is_first_time_sleep
if is_first_time_sleep == false:
is_first_time_sleep = true;
return
if env.get_wait_between_sever_command() != 0:
debug.info("Wait for server contrition (" + str(env.get_wait_between_sever_command()) + " s)")
time.sleep(env.get_wait_between_sever_command())
public void filter_name_and_file(root, list_files, filter):
// filter elements:
tmp_list = fnmatch.filter(list_files, filter)
out = []
for elem in tmp_list:
if os.path.isfile(new Path(root, elem)) == true:
out.append(elem);
return out;
public void filter_name(list_files, filter):
// filter elements:
return fnmatch.filter(list_files, filter)
public void exclude_list(list_elements, filter):
out = []
for elem in list_elements:
if elem not in filter:
out.append(elem)
return out
public void import_path_local(path, limit_sub_folder = 1, exclude_path = [], base_name = "*"):
out = []
debug.debug("island files: " + str(path) + " [START] " + str(limit_sub_folder))
if limit_sub_folder == 0:
debug.verbose("Subparsing limitation append ...")
return []
list_files = get_list_sub_files(path)
// filter elements:
debug.debug("island files: " + str(path) + " : " + str(list_files))
tmp_list_island_file = filter_name_and_file(path, list_files, base_name)
debug.debug("island files (filtered): " + str(path) + " : " + str(tmp_list_island_file))
// Import the module:
for filename in tmp_list_island_file:
out.append(new Path(path, filename))
debug.debug(" Find a file : '" + str(out[-1]) + "'")
list_folders_full = get_list_sub_path(path)
list_folders = []
for elem in list_folders_full:
if elem in exclude_path:
debug.verbose("find '" + str(elem) + "' in exclude_path=" + str(exclude_path))
continue
list_folders.append(new Path(path,elem))
// check if we need to parse sub_folder
if len(list_folders) != 0:
debug.debug(" Find a folder : " + str(list_folders))
for folder in list_folders:
tmp_out = import_path_local(folder,
limit_sub_folder - 1,
exclude_path,
base_name)
// add all the elements:
for elem in tmp_out:
out.append(elem)
return out