Skip to content
jeremyspencer39171 edited this page Jun 4, 2018 · 8 revisions

What is the IOC Generator

Generates the boilerplate structure required for developing an IBEX IOC.

How you use it

Use these instructions.

How to edit it/how it works/file locations

Clone the repository into C:\Instrument\Dev.

This program makes git branches and pushes to the remote repo, you can stop this by adding a return statement at the start of each method in git_utils (including the RepoWrapper constructor).

The program starts in IBEX_device_generator.py, so we'll start there. generate_device calls create_component for each component you might want, passing in an instance method. These instance methods are grouped into classes:

  • support_utils (generic IOC config)
  • ioc_utils (ISIS specific IOC config)
  • ioc_test_framework_utils (testing)
  • emulator_utils (emulation)
  • gui_utils (opi template creation)

support_utils

Makes files in C:\Instrument\Apps\EPICS\support

create_submodule

Creates the top level directory in C:\Instrument\Apps\EPICS\support, adds a makefile and tries to create a new git repo.

apply_support_dir_template

Requires the directories made by create_submodule. This will call a Perl script which generates the .db and .proto files for the support module. The Perl script is C:\Instrument\Apps\EPICS\support\asyn\master\bin\windows-x64\makeSupport.pl. The Perl script uses the templates in C:\Instrument\Apps\EPICS\support\asyn\master\templates\streamSCPI_NAME_Sup.

ioc_utils

Makes files in C:\Instrument\Apps\EPICS\ioc\master

ioc_test_framework_utils

emulator_utils

gui_utils

Generates an opi template for the IOC.

Clone this wiki locally