2021-03-28 15:43:49 +02:00
|
|
|
#!/usr/bin/env python3
|
2021-05-26 19:11:46 +02:00
|
|
|
from generator_tools import *
|
2021-03-28 15:43:49 +02:00
|
|
|
|
2021-05-26 19:11:46 +02:00
|
|
|
# --------------------- GET CONFIGURATION FROM THE TREX.JSON ---------------- #
|
|
|
|
config_file = 'trex.json'
|
|
|
|
trex_config = read_json(config_file)
|
|
|
|
# --------------------------------------------------------------------------- #
|
2021-03-05 16:50:44 +01:00
|
|
|
|
2021-05-26 19:11:46 +02:00
|
|
|
# -------------------------------- [WIP] ------------------------------------ #
|
2021-03-05 16:50:44 +01:00
|
|
|
print('Metadata I/O currently not supported')
|
|
|
|
# TODO, for now remove metadata-related stuff
|
2021-05-26 19:11:46 +02:00
|
|
|
del trex_config['metadata']
|
|
|
|
# for now remove rdm from config because it functions are hardcoded
|
|
|
|
del trex_config['rdm']
|
2021-03-05 16:50:44 +01:00
|
|
|
# TODO, for now remove char-related stuff
|
2021-03-18 21:12:28 +01:00
|
|
|
print('Strings I/O currently not supported')
|
2021-05-26 19:11:46 +02:00
|
|
|
# --------------------------------------------------------------------------- #
|
|
|
|
|
|
|
|
# -------------------- GET ATTRIBUTES FROM THE CONFIGURATION ---------------- #
|
|
|
|
group_dict = get_group_dict(trex_config)
|
|
|
|
detailed_num = get_detailed_num_dict(trex_config)
|
|
|
|
# helper dictionaries contain group, num or dset names as keys
|
|
|
|
datasets = get_dset_dict(trex_config)
|
|
|
|
detailed_dset_nostr, detailed_dset_str = split_dset_dict_detailed(datasets)
|
|
|
|
# consistency check for dimensioning variables
|
|
|
|
check_dim_consistency(detailed_num, datasets)
|
|
|
|
# --------------------------------------------------------------------------- #
|
|
|
|
|
|
|
|
# -------------------- GET TEMPLATED FILES TO BE POPULATED ------------------ #
|
|
|
|
source = ['front', 'text', 'hdf5']
|
|
|
|
# build helper dictionaries with paths per source directory
|
|
|
|
template_paths = get_template_paths(source)
|
|
|
|
# build helper dictionaries with source files per source directory
|
|
|
|
source_files = get_source_files(template_paths)
|
|
|
|
# build helper dictionaries with templated files
|
|
|
|
files_todo = get_files_todo(source_files)
|
|
|
|
# --------------------------------------------------------------------------- #
|
|
|
|
|
|
|
|
# ----------------------- POPULATE TEMPLATED FILES -------------------------- #
|
|
|
|
|
|
|
|
# populate files with iterative scheme, i.e. for unique functions
|
|
|
|
for fname in files_todo['auxiliary']:
|
|
|
|
iterative_populate_file(fname, template_paths, group_dict, detailed_dset_nostr, detailed_num)
|
|
|
|
|
|
|
|
# populate has/read/write_num functions with recursive scheme
|
|
|
|
for fname in files_todo['num']:
|
|
|
|
recursive_populate_file(fname, template_paths, detailed_num)
|
|
|
|
|
|
|
|
# populate has/read/write_dset functions with recursive scheme
|
|
|
|
for fname in files_todo['dset']:
|
|
|
|
recursive_populate_file(fname, template_paths, detailed_dset_nostr)
|
|
|
|
|
|
|
|
# populate group-related functions with mixed (iterative+recursive) scheme [text backend]
|
|
|
|
for fname in files_todo['group']:
|
|
|
|
special_populate_text_group(fname, template_paths, group_dict, detailed_dset_nostr, detailed_num)
|
|
|
|
|
|
|
|
# --------------------------------------------------------------------------- #
|