mirror of
https://github.com/slsdetectorgroup/slsDetectorPackage.git
synced 2025-06-23 18:17:59 +02:00
commands code generation (#871)
* commands code generation (#803) * commands code generation for only frames command * fix cmake file and add Caller files * working exptime, fully extended commands file and its variants * start adding template commands * add INT_CMD_VEC_ID template * add list command, generate multiple bins, format code * reach 208 commands using the cpp macros * add tests for command parser * start adding tests for commands parser * fix typo to use commands.yaml * add more tests for command_parser * add all template functions (up to 218 commands) * finish template functions and add more CmdProxy.cpp functions (250+) * 257 commands * 300 commands the rest are very special commands * add special commands without generation * separate special functions from generated c++ file * implementing one command for put and get (buggy) * add infer action in a separate file * generate header for special commands from yaml * allow only 0 or 1 for bool inputs * group all commands in gen_commands.py * add help to gen_commands.py * add autocomplete bash script * autocompletion: add support for module levels and help * remove debugging line * add autocompletion, help to commands, change int [0,1] to bool * copy tests for Caller.cpp. Tests pass * update with the new developer branch changes * fix errors after merging (there is problems with tests) * fixed port/stopport in yaml (intput typo), added '_caller' to the test dac and test on chip dac command in global test for cmdcaller * undo previous test simulator debug change * add documentation for the generated code * reducing the comment to be replaced in length so formatting does not split into 2 lines * removed formatting specific style of C++11 in gen_commands.py to keep with the top level clang format of the project * regeneratign code for commands * automation generated * Redirect deprecated commands (#872) * working implementation, need to fix dac * fixed deprecation redirect for dac command * Detector specific autocomplete (#873) * working implementation, need to fix dac * fixed deprecation redirect for dac command * detector specific completion for dac * added autocomplete using detector specific * fixed error when autocompleting partial words * Generate commands/fix commands (#875) * fix vm_a, im_a etc have deg Celsius suffix, also help missing or changed in some places * dac: require det id for all, arg0 to be printed at output, help for onchip dac and dac, onchipdac: spacing * getscan detid and blocking trigger help * udp_Dstlist det_id fixed, but rx_id invalid * cmdApp in line with cmdLineApp (missing version, receiver_id, not creating det object in help action * added set_command to differentiate between check_det_id and require_det_id (mixed up), args: -1 needs to check for at least one argument * reordering * reordering and checked till integer_command_hex * fixed a lot more commands * fix caller tests for eiger * changes to tests after Bechir left * changing .cmd to .cmdcall for the caller commands * fixed tests for caller, still warning for setexptime about cast input * autocomplete ran * add moench test * regenerating autocomplete and commands * fixing other things from merge conflicts (renaming slsDetectorDefs to defs in commands.yaml) * formatting * added code injection to help (#876) * updated 3 commands to have get output that can be put into put (#877) * updated some commands to have get output that can be put into put * fix tests for clkdiv * adding help to free (#878) * removing old commands and renaming them, (also making it work for parameters command as it was still calling cmdproxy) (#879) * More helpful error messages for unsupported actions (#880) * removing old commands and renaming them, (also making it work for parameters command as it was still calling cmdproxy) * Added specific help for unsupported actions * fixed a vetofile get special exception message. more specific warning for special exception message instead of no function warning * added condition checking true in exceptions for special message --------- Co-authored-by: Bechir Brahem <bachbrahem@gmail.com> Co-authored-by: Erik Frojdh <erik.frojdh@gmail.com> Co-authored-by: Dhanya Thattil <dhanya.thattil@psi.ch>
This commit is contained in:
64
slsDetectorSoftware/generator/infer_action/check_infer.py
Normal file
64
slsDetectorSoftware/generator/infer_action/check_infer.py
Normal file
@ -0,0 +1,64 @@
|
||||
from pathlib import Path
|
||||
|
||||
import argparse
|
||||
import yaml
|
||||
|
||||
|
||||
def check_infer(EXTENDED_COMMANDS_PATH=Path(__file__).parent.parent / "extended_commands.yaml", commands=None):
|
||||
if commands is None:
|
||||
# load yaml file
|
||||
with EXTENDED_COMMANDS_PATH.open('r') as f:
|
||||
commands = yaml.safe_load(f)
|
||||
|
||||
type_distinguishable = {}
|
||||
non_distinguishable = {}
|
||||
|
||||
for command_name, command in commands.items():
|
||||
# todo: remove this (added for debug)
|
||||
# if command_name != 'badchannels':
|
||||
# continue
|
||||
if len(command["actions"]) == 1:
|
||||
action = list(command["actions"].items())[0][1]
|
||||
for arg in action['args']:
|
||||
if arg['argc'] == -1:
|
||||
non_distinguishable[(command_name, arg['argc'])] = ([], arg['arg_types'])
|
||||
continue
|
||||
|
||||
|
||||
get_argcs = {}
|
||||
get_args = command['actions']['GET']['args']
|
||||
for arg in get_args:
|
||||
if arg['argc'] != -1:
|
||||
get_argcs[arg["argc"]] = arg['arg_types']
|
||||
else:
|
||||
non_distinguishable[(command_name, arg['argc'])] = ([], arg['arg_types'])
|
||||
put_args = command['actions']['PUT']['args']
|
||||
for arg in put_args:
|
||||
if arg['argc'] == -1:
|
||||
non_distinguishable[(command_name, arg['argc'])] = ([], arg['arg_types'])
|
||||
elif arg['argc'] in get_argcs:
|
||||
if arg['arg_types'] != get_argcs[arg['argc']]:
|
||||
type_distinguishable[(command_name, arg['argc'])] = (get_argcs[arg['argc']], arg['arg_types'])
|
||||
else:
|
||||
non_distinguishable[(command_name, arg['argc'])] = (get_argcs[arg['argc']], arg['arg_types'])
|
||||
|
||||
return type_distinguishable, non_distinguishable
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
argparse = argparse.ArgumentParser()
|
||||
argparse.add_argument("--print", choices=['all', 'type', 'impossible'], default="all", help="command name")
|
||||
args = argparse.parse_args()
|
||||
|
||||
type_distinguishable, non_distinguishable = check_infer()
|
||||
if args.print == 'type' or args.print == 'all':
|
||||
print("type distinguishable:")
|
||||
print("command_name: argc get_arg_type put_arg_type\n")
|
||||
for (command_name, argc), (get_arg_types, put_arg_types) in type_distinguishable.items():
|
||||
print(f"{command_name}: {argc} {get_arg_types} {put_arg_types}")
|
||||
|
||||
if args.print == 'impossible' or args.print == 'all':
|
||||
print("\n\nimpossible to distinguish:")
|
||||
print("command_name: argc get_arg_type put_arg_type")
|
||||
for (command_name, argc), (get_arg_types, put_arg_types) in non_distinguishable.items():
|
||||
print(f"{command_name}: {argc} {get_arg_types} {put_arg_types}")
|
Reference in New Issue
Block a user