Skip to content

Latest commit

 

History

History
270 lines (168 loc) · 21.5 KB

README.md

File metadata and controls

270 lines (168 loc) · 21.5 KB

VS Code Extension for the Production Flow Description Language (PFDL)

Tests and Code Coverage Lint Check Build REUSE status

This extension helps you to develop your PFDL programs.

Table of Contents

Features

PFDL Language Support

Syntax Highlighting

Syntax highlighting is provided for the PFDL grammar to support the reading/writing of PFDL programs. This includes Tasks, Structs, Services, Parallels, Conditions and Loops as well as comments. See some examples below.

Example of Syntax highlighting for a Struct and two Tasks

Language Configuration and Auto Completion

Auto-completion is provided for the PFDL grammar. This also includes closing code-blocks, e.g., End to close a Task or Struct declaration. Correct identations are also inserted when entering a new line.

Example of auto-completion of PFDL code

Display of Errors

Opening or modifying PFDL code triggers error detection. Detected errors are highlighted in the code and listed in the Problems tab of VS Code.

Example of error detection in VS Code

Code Visualization

The PFDL Scheduler automatically generates a graphical representation of the corresponding PFDL program. This extension provides a dynamic webview of this static representation for use during development. This code visualization can be displayed next to the PFDL program and is updated reactively on file changes. The orientation of the graph can be chosen between horizontal and vertical, whichever is more convenient for you!

Example of code visualized as a graph next to a simple PFDL program

Component Interactions

Any of the graph nodes (including the single nodes, transition nodes and containers) can be grabbed and moved, while node overlap is prohibited. The labels for individual nodes are hidden for readability reasons and are only displayed when the mouse is over them. Box labels are displayed by default but can be hidden as well.

Example of moving components

As your PFDL program grows and becomes more and more complex, the visualization will also become more confusing. It may be helpful to collapse large components into a single one. Within the webview, you can select a specific component to collapse or choose to collapse all components at once. There is also an option to collapse only the top level components, i.e., those that are nested the deepest. Expanding nodes again is done accordingly. Try it out!

Example of collapsing a component

Interaction with VS Code

Whenever a PFDL program is open in the active text editor in VS Code, the two buttons that are shown in the image below will appear in the top right corner. Buttons for displaying and downloading the code visualization of a PFDL program

Generate the Code Visualization

Visualize Code displays a graph visualizing the PFDL program of the .pfdl file in the active editor as described above. You can also use this option again to reload the visualization after making some unwanted changes.

Download the Visualized Code locally

Download PNG will create a .png file of the currently displayed graph, i.e., it will contain any changes that you may have made, and will ask where to save it on your local system.

Hot Reload on Save

The graph with the visualized code is always updated when the PFDL program is saved. If the file contains errors, the error messages are displayed instead.

Example of a hot reload on saving

Install

To install the extension, use the already built extension file in the build folder or build it yourself. Use the latest build for the best experience. There are also some additional tools required that need to be installed before use.

Requirements

  • Python (>= v3.10)

  • GraphViz (>= v2.42.2)

  • Pip packages from requirements.txt (install with pip install -r requirements.txt)

  • (For development only) NodeJS (>=v18.17.1)

NOTE: The pip packages must be accessible to the extension. Especially on macOS, consider installing them globally by adding the --break-system-packages flag.

Install from VSIX file

Installing the extension from an already built VSIX file is the easiest and fastest way to test the extension. Find the current version as the artifact of the newest build pipeline in the repository. Then just open the Extensions tab in VS Code and find the dialogue shown in the image below.

How to install the extension from a VSIX file

Build it yourself

You can also build the project directly after downloading the extension repository. Just follow these steps:

  • Install vsce: npm install -g vsce
  • Make sure you are in the project root directory, then run vsce package --out "./pfdl-vs-code-extension-<version_number>.vsix". Replace <version_number> with your version number
  • Note: It should have a specific format like described here

This will create a .vsix in the root directory of your project.

Notes for Developers

If you want to run this project directly in VS Code or want to debug it during development the first step is to initialize the submodules. This project uses the PFDL Scheduler, include it with:

git clone --recurse-submodules [email protected]:iml130/pfdl.git git submodule update --init --recursive

To finally set up the project, run npm install in the project root folder. A folder called node_modules should be installed. Afterwards, run npm run compile to generate javascript files out of the typescript code. Now you can run/debug the extension by selecting and running Client+Server in the debug window. This should open a new window (the Extension Development Host) where you can open .pfdl files and test the extension.

Usage

PFDL Language Support

The extension is used to help you with your .pfdl files. Opening a file with this ending will automatically enable the editor features syntax highlighting, language configuration, auto-completion and displaying of error messages.

Generate Code Visualization

To graphically visualize the code for a PFDL program, make sure the file is open in the active VS Code editor. As described here, you can view and download a displayed graph by clicking one of the buttons that appear. Saving a .pfdl file will also display an updated version of the visualization. Note that

  • If a PFDL program is already visualized, it will be replaced when the webview is updated. Any visual changes to the previously displayed graph will be discarded.
  • A code visualization must always be drawn and displayed in the webview before it can be downloaded. I.e., you can't download a graph that hasn't been drawn yet.
  • The Download PNG button will always download the currently visible graph, even if the active text editor contains a different PFDL program!

Webview Interaction

Action Description
Move nodes Use drag and drop to move individual nodes and groups of nodes.
Zooming Use the mouse wheel to zoom in and out of the webview.
Display a node's label Hover over a single / container node to display its label.
Collapse a compound Click into a compound to collapse all the nodes inside it into a single representation node.
Collapse multiple compounds Right click on the background to bring up the context menu. Then select either Collapse all Nodes to collapse all nodes into a single compound (the productionTask) or Collapse Nodes at highest level to collapse only the deepest nested compound nodes in the current view.
Expand a compound Click into a collapsed compound to reveal any previously hidden nodes inside it.
Expand multiple compounds Right click on the background to bring up the context menu. Then select either Expand all Nodes to expand all previously collapsed nodes, or Expand Nodes at lowest level to expand only those compound nodes that are the flattest nested in the current view.
Rotate the graph by 90° Right click on the background to bring up the context menu. Then choose Rotate View to change the orientation of the graph from vertical to horizontal and vice versa.
Rescale the webview If you want to rescale the webview to show the whole program again after some interactions, right-click on the background to bring up the context menu and choose Rescale the view.
Dowload the current code visualization This has the same effect as clicking the Download PNG button in VS Code. Right click on the background to bring up the context menu and choose Download graph as PNG.
Hide compound node labels The compound node labels are shown by default. To hide them, right-click on the background to bring up the context menu and select Show / Hide Box Labels. Selecting this option again will undo this action.

Examples

Here are some examples of graphs generated from .pfdl files of increasing complexity. To get a better idea of how useful the code visualization can be when developing PFDL programs, the original Scheduler-generated graph from the example files is shown in the rightmost column. Feel free to try out the following examples with the extension as well. You can find them here.

The Task 1_simple_task is not that complex and therefore, can also be understood with the simple PNG generated by the PFDL Scheduler. However, a comparison with the code visualization generated by the extension already shows the advantages of clustering and coloring components instead of displaying each of the node's label. In this example we have chosen to use the horizontal display of the graph.
A simple PFDL program, the webview visualization has been rotated by 90°.

For the Task 2_intermediate_task we manually collapsed all the individual Services as they all have the same structure and this makes it easier to focus on what the PFDL program is supposed to do. We also hovered over the condition node to display the specific condition. The other information needed to read the visualized code can be obtained from the compound labels and the node colors. An intermediate PFDL program. The compounds in the webview have been manually collapsed to get a better overall view.

The PFDL program for the Task 3_complex_task is too long to display nicely. You can find it in the example_programs directory, along with the other examples. We tried again to make some space by collapsing and moving nodes, this time by using the Collapse Nodes at highest level option twice. After moving the nodes together, we used the Rescale the view command to zoom in as much as possible while the whole graph can still be observed on the screen. Of course, we lose information by repeatedly collapsing compound nodes, but this may be acceptable when trying to get an overall view of the PFDL program first. Later, when we want to focus on the details, we can always expand them again.
A complex PFDL program. The compounds at the highest and second highest level have been collapsed and then moved.

Architecture

The extension mainly consists of a server, which acts as an observer for the active VS Code instance and is responsible for code completion, and a corresponding client, which is informed about changes by the server and is responsible for creating the webview where the code visualization is displayed. The server also communicates with the PFDL scheduler to initiate the generation of new .dot files when necessary.

When a PFDL program is opened/modified, the server calls the scheduler to validate the file in the active VS Code editor and passes the validation result to the client. The following figure illustrates this interaction.

The interaction of the components of the PFDL VS Code extension when opening/modifying a PFDL program

When a .pfdl file is saved or the Visualize Code button is clicked, the request to visualize the code is passed to the client, as shown in the figure below. The client decides whether to generate the graph or to display error messages received before from the server in the webview.

The interaction of the components of the PFDL VS Code extension when trying to visualize a PFDL program

Known Issues

  • A curvy edge that is part of a code visualization may disappear when its source or target node is moved. This is intended by the graph library, when the edge would otherwise form into angles that are impossible to draw. This problem usually occurs when nodes are moved towards each other. Moving them back will make the edge visible again. The image below shows an example of such a curvy edge.

    Example of a curvy edge connecting a transition node and a single node

Troubleshooting

The server does not start/the debugger cannot connect to it

Try changing the port used in the launch.json file in the .vscode folder. Note: You also need to change the port in the extension.ts file.

Errors while running/debugging the extension

Make sure that you have installed all the programs and packages listed in the requirements section. Some parts will work even if you have not installed everything.

No graph is generated/there is an error when visualizing the code

Check that you have installed GraphViz correctly (on Windows you need to put the bin folder inside the GraphViz folder in the PATH environment variable. On Ubuntu it should be fine if you install GraphViz via apt-get).

Sometimes the analysis of the PFDL program may still be in progress, especially if the .pfdl file is large. In this case you should get an error message. A retry after a few moments should normally work as expected.

The program crashes and it has something to do with the Scheduler the extension uses

To display errors and to generate the code visualization, the extension calls the Scheduler. The Scheduler is still under development, so there may be bugs. If the extension crashes because of the Scheduler please open an issue in that repo.

Release Notes

For each release, a .vsix installation file for VS Code is provided, as well as a bundle.js source code file, containing the code that is responsible for the code visualization.

Additionally, a license file is generated using the OSS Review Toolkit (ORT) to automatically collect and summarize licenses and copyright information declared in the dependencies of this project (excluding devDependencies for npm). The file can be reproduced by following the ORT installation guide and running the following commands from inside the downloaded ORT repository:

cli/build/install/ort/bin/ort analyze -i path/to/pfdl-vs-code-extension -o path/to/output/directory

cli/build/install/ort/bin/ort -P ort.enableRepositoryPackageCurations=true -P ort.enableRepositoryPackageConfigurations=true -P ort.scanner.skipExcluded=true scan -i path/to/output/directory/analyzer-result.yml -o path/to/output/directory

cli/build/install/ort/bin/ort report -f PdfTemplate -i path/to/output/directory/scan-result.yml -o path/to/output/directory

Note that the copyright information of this project found by ORT are not complete and had to be completed manually.

v0.1.0

  • First release

v0.1.1

  • Code Visualization: Provide global methods that can be accessed by external modules
  • Achieve REUSE compliance for the project
  • Add github workflows

v0.1.2

  • Enable multi-platform support

License

VS Code Extension for the Production Flow Description Language (PFDL) is licensed under the MIT License. See LICENSE for details on the licensing terms.