-
Notifications
You must be signed in to change notification settings - Fork 167
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Added documentation about Scopy PDK. Signed-off-by: andreidanila1 <[email protected]>
- Loading branch information
1 parent
0ac9365
commit a3e0c1b
Showing
1 changed file
with
85 additions
and
63 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,87 +1,109 @@ | ||
# Plugin generator | ||
# Plugin generator | ||
|
||
## Pre-request | ||
|
||
`pip install -r requirements.txt` | ||
|
||
## Run plugin generator script: | ||
## Run plugin generator script | ||
|
||
1. If it is run from "scopy/tools/plugingenerator" | ||
`python plugin_generator.py` | ||
|
||
`./plugin_generator.py` | ||
|
||
2. Otherwise | ||
|
||
`python plugin_generator.py --scopy_path=path/to/scopy --config_file_path=path/to/config/file.json` | ||
|
||
For help: `python plugin_generator.py -h` | ||
|
||
### After running the script, you must insert the new plugin in plugins/CMakeLists.txt: | ||
### After running the script, you must insert the new plugin in plugins/CMakeLists.txt | ||
|
||
``` | ||
option(ENABLE_PLUGIN_NEWPLUGIN "Enable NEWPLUGIN plugin" ON) | ||
if(ENABLE_PLUGIN_NEWPLUGIN) | ||
add_subdirectory(new) | ||
list(APPEND PLUGINS ${PLUGIN_NAME}) | ||
add_subdirectory(new) | ||
list(APPEND PLUGINS ${PLUGIN_NAME}) | ||
endif() | ||
``` | ||
## Config.json attributes explanation: | ||
|
||
1. plugin: Contains details specific to the plugin. | ||
1.1 dir_name (string): The name of the plugin directory. | ||
1.2 plugin_name (string): The plugin name. The header and source files will have this name. | ||
1.3 class_name (string): The name of the class that will be created for the plugin. | ||
1.4 cmakelists (bool): If true a CMakeLists file will be created for the plugin. | ||
1.5 namespace (string): The namespace the plugin belongs to. | ||
- The name of namespace should be short, meaningful, concise, and all lower-case. | ||
- Try to avoid use of underscores inside namespace names. | ||
- The keyword "namespace" is filled in automatically. All you have to do is to write the identifier (name of the namespace). | ||
- For nested namespaces use the scope resolution operator (::). | ||
1.6 device_category (string): The category the plugin belogs to. (iio for example) | ||
1.7 tools: List wich contains the tools to be implemented and used by the plugin. | ||
1.7.1 id (string): Tool id. | ||
1.7.2 tool_name (string): The name that appears in Scopy. | ||
1.7.3 file_name (string): The tool header and source file will have this name. | ||
- No special character is allowed in the file name except for underscore (‘_’) and dash (‘-‘). | ||
- Do not use filenames that already exist in /user/include. or any predefined header file name. | ||
1.7.4 class_name (string): The name of the class that will be created for the tool. | ||
- The class name should be a noun. | ||
- Use upper case letters as word separators, and lower case for the rest of the word. | ||
- The first character in the class name must be in upper case. | ||
- No underscores (‘_’) are permitted in the class name. | ||
1.7.5 namespace (string): The namespace the tool belongs to. | ||
|
||
2. cmakelists: Contains the details of the CMakeLists. | ||
2.1 cmake_min_required (float): Require a minimum version of cmake. | ||
2.2 cxx_standard (int): The C++ standard whose features are requested to build this target. | ||
2.3 enable_testing (string): Enables the tests for the plugin. The only accepted variants | ||
are "ON" and "OFF". | ||
|
||
3. test: Contains the details of the plugin tests. | ||
3.1 mkdir (bool): If true the test directory is created. | ||
3.2 cmakelists (bool): If true a CMakeLists file will be created for the tests. | ||
3.3 cmake_min_required (float): Require a minimum version of cmake. | ||
3.4 tst_pluginloader (bool): If true the pluginloader test is created. | ||
4. doc: Contains the details of the plugin documentation. | ||
4.1 mkdir (bool): If true the doc directory is created. | ||
|
||
5. resources: Contains the details of the plugin resources. | ||
5.1 mkdir (bool): If true the res directory is created. | ||
5.2 resources_qrc (bool): If true the resources_qrc file is created. | ||
|
||
*All fields must be filled in. | ||
|
||
## Config.json attributes explanation | ||
|
||
1. **pdk**: Contains the configuration options of the plugin development tool. | ||
1. `enable` (bool): If true a ScopyPluginRunner project will be created at `project_path`. | ||
- If pdk is enabled, the plugin will be generated in the ScopyPluginRunner project. | ||
2. `deps_path` (string): The path to the scopy pdk package (the package must be unzipped). | ||
3. `project_path` (string): The path to the directory where the PluginRunner project is created. | ||
2. **plugin**: Contains details specific to the plugin. | ||
1. `dir_name` (string): The name of the plugin directory. | ||
2. `plugin_name` (string): The plugin name. The header and source files will have this name. | ||
3. `class_name` (string): The name of the class that will be created for the plugin. | ||
4. `cmakelists` (bool): If true a CMakeLists file will be created for the plugin. | ||
5. `namespace` (string): The namespace the plugin belongs to. | ||
- The name of namespace should be short, meaningful, concise, and all lower-case. | ||
- Try to avoid use of underscores inside namespace names. | ||
- The keyword "namespace" is filled in automatically. All you have to do is to write the identifier (name of the namespace). | ||
- For nested namespaces use the scope resolution operator (::). | ||
6. `device_category` (string): The category the plugin belongs to. (iio for example) | ||
7. `tools`: List which contains the tools to be implemented and used by the plugin. | ||
1. `id` (string): Tool id. | ||
2. `tool_name` (string): The name that appears in Scopy. | ||
3. `file_name` (string): The tool header and source file will have this name. | ||
- No special character is allowed in the file name except for underscore (‘_’) and dash (‘-‘). | ||
- Do not use filenames that already exist in /user/include. or any predefined header file name. | ||
4. `class_name` (string): The name of the class that will be created for the tool. | ||
- The class name should be a noun. | ||
- Use upper case letters as word separators, and lower case for the rest of the word. | ||
- The first character in the class name must be in upper case. | ||
- No underscores (‘_’) are permitted in the class name. | ||
5. `namespace` (string): The namespace the tool belongs to. | ||
3. **cmakelists**: Contains the details of the CMakeLists. | ||
1. `cmake_min_required` (float): Require a minimum version of cmake. | ||
2. `cxx_standard` (int): The C++ standard whose features are requested to build this target. | ||
3. `enable_testing` (string): Enables the tests for the plugin. The only accepted variants are "ON" and "OFF". | ||
4. **test**: Contains the details of the plugin tests. | ||
1. `mkdir` (bool): If true the test directory is created. | ||
2. `cmakelists` (bool): If true a CMakeLists file will be created for the tests. | ||
3. `cmake_min_required` (float): Require a minimum version of cmake. | ||
4. `tst_pluginloader` (bool): If true the pluginloader test is created. | ||
5. **doc**: Contains the details of the plugin documentation. | ||
1. `mkdir` (bool): If true the doc directory is created. | ||
6. **resources**: Contains the details of the plugin resources. | ||
1. `mkdir` (bool): If true the res directory is created. | ||
2. `resources_qrc` (bool): If true the resources_qrc file is created. | ||
|
||
*All fields must be filled in. | ||
|
||
## Scopy PDK | ||
|
||
### Add new modules to the PDK package | ||
|
||
If we want a new module from Scopy to be part of the package, then when installing libraries or directories in CMakeLists, the option `COMPONENT ${SCOPY_PDK}` must be added. | ||
|
||
- libraries: `install(TARGETS ${PROJECT_NAME} LIBRARY DESTINATION ${SCOPY_DLL_INSTALL_PATH} COMPONENT ${SCOPY_PDK} RUNTIME DESTINATION ${SCOPY_DLL_INSTALL_PATH})`. | ||
- headers: `install(DIRECTORY include/ DESTINATION include/ COMPONENT ${SCOPY_PDK})`. | ||
- resources: `install(DIRECTORY res/ DESTINATION resources/ COMPONENT ${SCOPY_PDK})`. | ||
|
||
### Develop a new plugin using ScopyPluginRunner | ||
|
||
1. Download the PDK package from the Scopy repository. | ||
- If the package is not available or if changes have been made to the Scopy libraries, then Scopy must be built locally with the `--target package` option. | ||
- In this case a `package` folder will be generated inside the Scopy build folder. | ||
2. Generate the ScopyPluginRunner project using the `plugin_generator.py`. | ||
- Fill in the `config.json` file. | ||
- This project contains a `plugin` submodule where the desired plugin can be developed. | ||
3. Choose an IDE and start working. | ||
- Our recommendation is to use QtCreator. | ||
|
||
## Adding new config specifications | ||
|
||
For fields like "plugin", "tool" and "cmakelists" new specifications can be added. | ||
For fields like `plugin`, `tool` and `cmakelists` new specifications can be added. | ||
A few steps must be completed: | ||
1. Add the new specification in the desired field (add new fields in 'config.json'). | ||
2. Use the specification in the templates. Each template contains a 'config' variable through which | ||
the information from each field can be accessed. A specific syntax must be used because the script uses the | ||
the mako library to render the templates. [Watch mako documentation page for more details.](https://docs.makotemplates.org/en/latest/) | ||
- the changes made in the 'plugin' field will be reflected in the 'plugin_src_template' and 'plugin_header_template' template files | ||
- the changes made in the 'tool' field will be reflected in the 'tool_src_template' and 'tool_header_template' template files | ||
- the changes made in the 'cmakelists' field will be reflected in the 'cmakelists_template' template file | ||
3. Run the plugin_generator.py script. | ||
|
||
|
||
|
||
1. Add the new specification in the desired field (add new fields in `config.json`). | ||
2. Use the specification in the templates. Each template contains a `config` variable through which | ||
the information from each field can be accessed. A specific syntax must be used because the script uses the | ||
the mako library to render the templates. [Watch mako documentation page for more details.](https://docs.makotemplates.org/en/latest/) | ||
- the changes made in the `plugin` field will be reflected in the **plugin_src_template** and **plugin_header_template** template files | ||
- the changes made in the `tool` field will be reflected in the **tool_src_template** and **tool_header_template** template files | ||
- the changes made in the `cmakelists` field will be reflected in the **cmakelists_template** template file | ||
3. Run the `plugin_generator.py` script. |