All panels and lex files updating now
This commit is contained in:
parent
2eb8c32e30
commit
a54c9f1c12
30
lex_scan.py
30
lex_scan.py
@ -69,6 +69,26 @@ def extract_title_prefix(controller_path):
|
|||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
return prefix
|
return prefix
|
||||||
|
|
||||||
|
def find_matching_files_variable_part(input_string, directory):
|
||||||
|
# Extract the first alphanumeric part from the input string
|
||||||
|
match = re.match(r"([A-Za-z0-9]+)", input_string)
|
||||||
|
if not match:
|
||||||
|
return []
|
||||||
|
variable_part = match.group(1)
|
||||||
|
|
||||||
|
# Try matching the full variable_part, then progressively remove last characters
|
||||||
|
for length in range(len(variable_part), 1, -1):
|
||||||
|
sub_part = variable_part[:length]
|
||||||
|
matching_files = []
|
||||||
|
for fname in os.listdir(directory):
|
||||||
|
name, ext = os.path.splitext(fname)
|
||||||
|
if name.startswith(sub_part): # match with extra characters allowed
|
||||||
|
matching_files.append(os.path.join(directory, fname))
|
||||||
|
if matching_files:
|
||||||
|
return matching_files
|
||||||
|
return []
|
||||||
|
|
||||||
|
|
||||||
def scan_application_files(system, panel, prefix, scan_general=False):
|
def scan_application_files(system, panel, prefix, scan_general=False):
|
||||||
extracted_strings = {}
|
extracted_strings = {}
|
||||||
|
|
||||||
@ -84,11 +104,19 @@ def scan_application_files(system, panel, prefix, scan_general=False):
|
|||||||
logger.info(f"Scanning Custom controller file: {controller_custom_path}")
|
logger.info(f"Scanning Custom controller file: {controller_custom_path}")
|
||||||
scan_file_for_lexical_strings(controller_custom_path, prefix, extracted_strings, scan_general)
|
scan_file_for_lexical_strings(controller_custom_path, prefix, extracted_strings, scan_general)
|
||||||
|
|
||||||
|
|
||||||
# Template files
|
# Template files
|
||||||
themes = ["default", "AdminLTE"]
|
themes = ["default", "AdminLTE"]
|
||||||
for theme in themes:
|
for theme in themes:
|
||||||
template_base_path = os.path.join(full_base_path, "themes", theme, "templates")
|
template_base_path = os.path.join(full_base_path, "themes", theme, "templates")
|
||||||
|
if panel in ['Backup','Yum','Bugreport']:
|
||||||
|
#find the extra layout type files that these use (they do not have partials)
|
||||||
|
template_files = find_matching_files_variable_part(panel.lower(),template_base_path)
|
||||||
|
# print(f"Matching template files: {panel.lower()!r} -> Matches: {[os.path.basename(m) for m in template_files]}")
|
||||||
|
for file_path in template_files:
|
||||||
|
panel_template_path = os.path.join(template_base_path, f"{file_path}")
|
||||||
|
logger.warning(f"Scanning panel template file: {panel_template_path}")
|
||||||
|
scan_file_for_lexical_strings(panel_template_path, prefix, extracted_strings, scan_general)
|
||||||
|
else:
|
||||||
panel_template_path = os.path.join(template_base_path, f"{panel.lower()}.html.ep")
|
panel_template_path = os.path.join(template_base_path, f"{panel.lower()}.html.ep")
|
||||||
logger.info(f"Scanning panel template file: {panel_template_path}")
|
logger.info(f"Scanning panel template file: {panel_template_path}")
|
||||||
scan_file_for_lexical_strings(panel_template_path, prefix, extracted_strings, scan_general)
|
scan_file_for_lexical_strings(panel_template_path, prefix, extracted_strings, scan_general)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user