"""Part of the Mission Operation Database Exporter for the EVIE project. Event exporter. """ import datetime import time import os from pathlib import Path from fsfwgen.events.event_parser import ( handle_csv_export, handle_cpp_export, SubsystemDefinitionParser, EventParser, EventDictT, ) from fsfwgen.parserbase.file_list_parser import FileListParser from fsfwgen.utility.printer import PrettyPrinter from fsfwgen.utility.file_management import copy_file from fsfwgen.logging import get_console_logger from definitions import BspType, ROOT_DIR, OBSW_ROOT_DIR LOGGER = get_console_logger() DATE_TODAY = datetime.datetime.now() DATE_STRING_FULL = DATE_TODAY.strftime("%Y-%m-%d %H:%M:%S") GENERATE_CPP = True GENERATE_CPP_H = True GENERATE_CSV = True COPY_CPP_FILE = True COPY_CPP_H_FILE = True MOVE_CSV_FILE = True PARSE_HOST_BSP = True # Store these files relative to the events folder CPP_FILENAME = Path( f"{os.path.dirname(os.path.realpath(__file__))}/translateEvents.cpp" ) CPP_H_FILENAME = Path( f"{os.path.dirname(os.path.realpath(__file__))}/translateEvents.h" ) BSP_SELECT = BspType.BSP_Q7S BSP_DIR_NAME = BSP_SELECT.value # Store this file in the root of the generators folder CSV_FILENAME = Path(f"{ROOT_DIR}/{BSP_SELECT.value}_events.csv") CSV_COPY_DEST = Path(f"{OBSW_ROOT_DIR}/tmtc/config/events.csv") if BSP_SELECT == BspType.BSP_Q7S or BSP_SELECT == BspType.BSP_LINUX_BOARD: FSFW_CONFIG_ROOT = Path(f"{OBSW_ROOT_DIR}/linux/fsfwconfig") else: FSFW_CONFIG_ROOT = Path(f"{OBSW_ROOT_DIR}/{BSP_DIR_NAME}/fsfwconfig") CPP_COPY_DESTINATION = Path(f"{FSFW_CONFIG_ROOT}/events/") FILE_SEPARATOR = ";" SUBSYSTEM_DEFINITION_DESTINATIONS = [ f"{FSFW_CONFIG_ROOT}/events/subsystemIdRanges.h", f"{OBSW_ROOT_DIR}/fsfw/src/fsfw/events/fwSubsystemIdRanges.h", f"{OBSW_ROOT_DIR}/common/config/eive/eventSubsystemIds.h", ] SUBSYSTEM_DEFS_DEST_AS_PATH = [Path(x) for x in SUBSYSTEM_DEFINITION_DESTINATIONS] HEADER_DEFINITION_DESTINATIONS = [ f"{OBSW_ROOT_DIR}/mission/", f"{OBSW_ROOT_DIR}/fsfw/", f"{FSFW_CONFIG_ROOT}", f"{OBSW_ROOT_DIR}/test/", f"{OBSW_ROOT_DIR}/bsp_q7s/", f"{OBSW_ROOT_DIR}/linux/", ] HEADER_DEFINITION_DESTINATIONS_AS_PATH = [ Path(x) for x in HEADER_DEFINITION_DESTINATIONS ] LOGGER = get_console_logger() def parse_events( generate_csv: bool = True, generate_cpp: bool = True, print_events: bool = True ): LOGGER.info("EventParser: Parsing events: ") # Small delay for clean printout time.sleep(0.01) event_list = generate_event_list() if print_events: PrettyPrinter.pprint(event_list) # Delay for clean printout time.sleep(0.1) if generate_csv: handle_csv_export( file_name=CSV_FILENAME, event_list=event_list, file_separator=FILE_SEPARATOR ) LOGGER.info(f"Copying CSV file to {CSV_COPY_DEST}") copy_file( filename=CSV_FILENAME, destination=CSV_COPY_DEST, delete_existing_file=True ) if generate_cpp: handle_cpp_export( event_list=event_list, date_string=DATE_STRING_FULL, file_name=CPP_FILENAME, generate_header=GENERATE_CPP_H, header_file_name=CPP_H_FILENAME, ) if COPY_CPP_FILE: LOGGER.info( f"EventParser: Copying CPP translation file to {CPP_COPY_DESTINATION}" ) copy_file(CPP_FILENAME, CPP_COPY_DESTINATION) copy_file(CPP_H_FILENAME, CPP_COPY_DESTINATION) def generate_event_list() -> EventDictT: subsystem_parser = SubsystemDefinitionParser(SUBSYSTEM_DEFS_DEST_AS_PATH) subsystem_table = subsystem_parser.parse_files() LOGGER.info(f"Found {len(subsystem_table)} subsystem definitions.") PrettyPrinter.pprint(subsystem_table) event_header_parser = FileListParser(HEADER_DEFINITION_DESTINATIONS_AS_PATH) event_headers = event_header_parser.parse_header_files( True, "Parsing event header file list:\n", True ) # PrettyPrinter.pprint(event_headers) # myEventList = parseHeaderFiles(subsystem_table, event_headers) event_parser = EventParser(event_headers, subsystem_table) event_parser.obsw_root_path = OBSW_ROOT_DIR event_parser.set_moving_window_mode(moving_window_size=7) event_table = event_parser.parse_files() events_sorted = dict(sorted(event_table.items())) LOGGER.info(f"Found {len(events_sorted)} entries") return events_sorted