-
Notifications
You must be signed in to change notification settings - Fork 21
Home
This is a Visual Studio Code (VS Code) extension which enables the interactive debugging of Data Format Description Language (DFDL) schema parsing using Apache Daffodil. DFDL, also known as Daffodil, is a data modeling language used to describe file formats. The DFDL modeling language is a subset of XML Schema Definition (XSD). Just as file formats are rich and complex, so is the modeling language to describe them. Developing DFDL schemas can be a huge challenge, requiring a lot of iterative development, and testing. The purpose of these tools are to ease the burden on DFDL schema developers, enabling them to develop high quality, high resolution DFDL schemas, in less time. Developing the tools for Visual Studio Code (VS Code) seems the natural choice as VS Code is free, open source, cross-platform, well-maintained, extensible, and ubiquitous in the developer community.
- Daffodil Syntax Highlighting
The DFDL modeling language is rich and complex. Developers using modern IDEs expect some degree of built-in language support for the language they are developing in, and DFDL should be no different. The tools provide syntax highlighting to improve the readability and context of the text in addition to feedback to the developer indicating at least the structure and code appear syntactically correct.
- Daffodil Schema Code Completion
Code completion, also known as “Intellisense”, offers context-aware code segment predictions that can speed up schema development by reducing keyboard input, reduce memorization by the developer, and reduce typos.
- Daffodil Data Parse Debugger
The debugger allows the developer to carefully control the execution of a Daffodil file parse. Given a DFDL schema and a target data file, the developer can step through the execution of a parse line by line, or until the parse reaches some developer-defined line, known as a break point, in the schema. What is particularly helpful is that the developer can watch the parsed output, known as the infoset, as it’s being created by the parser. This enables the developer to quickly discover and correct issues, improving the development and testing cycles.
- Daffodil Data Editor
The integrated data editor is a new experimental feature that is under heavy development. It is akin to a hex editor, but tuned specifically for challenging Daffodil use cases. It is designed from scratch to handle virtually any sized file, well beyond the limits of Visual Studio Code’s standard text editor, and of course it can handle non-text data just as well as text data. It will have support for setting Daffodil debugger breakpoints on offsets in the data file in addition to line positions in the DFDL schema. It will handle non-standard byte sizes and non-aligned bytes. The least significant byte can be the first or last bit in a byte. As an editor designed for Daffodil developers by Daffodil developers, features of the tool can evolve quickly to address the specific needs of the Daffodil community.
This guide assumes you have Visual Studio Code (VS Code) and a Java Runtime Environment installed.
- Install VS Code
- Install Java Runtime 11 or greater
- Install SBT 0.13.8 or higher
- Install Node 10 or higher
- Install Yarn
The extension is available in the VS Code Extension Marketplace.
The latest .vsix
file can also be downloaded from the releases page and installed by either:
- using the "Extensions: Install from VSIX" command from within VS Code by opening the Command Palette (Mac = Command+Shift+P, Windows/Linux = Ctrl+Shift+P), and typing
vsix
to bring up the command and pointing it at the downloadedvsix
file; or - on the command-line via
code --install-extension <path-to-downloaded-vsix>
.
Debugging a schema needs both the schema to use and a data file to parse. Instead of having to select the schema and the data file each time from a file picker, a "launch configuration" can be created, which is a JSON description of the debugging session.
To create the launch profile:
-
Select
Run -> Open Configurations
from the VS Code menubar. This will load alaunch.json
file into the editor. You may have existingconfigurations
, or it may be empty. -
Press
Add Configuration...
and select theDaffodil Debug - Launch
option.
Once the launch.json has been created it will look something like this
{
"type": "dfdl",
"request": "launch",
"name": "Ask for file name",
"program": "${command:AskForProgramName}",
"stopOnEntry": true,
"data": "${command:AskForDataName}",
"infosetOutput": {
"type": "file",
"path": "${workspaceFolder}/infoset.xml"
},
"debugServer": 4711
}
This default configuration will prompt you to select the schema and data files. You can also map the "program" and "data" elements to your files to avoid being prompted each time.
Note the use of ${workspaceFolder}
for files in the VS Code workspace and the absolute paths for files outside of it.
{
"type": "dfdl",
"request": "launch",
"name": "DFDL parse: My Data",
"program": "${workspaceFolder}/schema.dfdl.xsd",
"stopOnEntry": true,
"data": "/path/to/my/data",
"infosetOutput": {
"type": "file",
"path": "${workspaceFolder}/infoset.xml"
},
"debugServer": 4711
}
Using the launch profile above you'd see a DFDL parse: My Data
menu item at the top of the "Run and Debug" pane (Command-Shift-D). Then press the "play" button to start the debugging session.
In the Terminal you'll see log output from the debugger backend. If something isn't working as expected, check the output in this Terminal window.
The schema file will also be loaded in VS Code and there should be a visible marking at the beginning where the debugger has paused upon entry to the debugging session. Control the debugger using the available VS Code debugger controls.
-
Option 1:
- Open up the schema file you wish to debug
- From inside the file open the Command Palette (Mac = Command+Shift+P, Windows/Linux = Ctrl+Shift+P)
- Once the command Palette is opened start typing
Daffodil Debug:
- Option 1 =
Daffodil Debug: Debug File
- This will allow for the user to fully step through the schema (WIP), once fully completed will produce a infoset to a file namedSCHEMA-infoset.xml
which it then opened as well. - Option 2 =
Daffodil Debug: Run File
- This will just run the schema through producing the infoset to a file namedSCHEMA-infoset.xml
.
- Option 1 =
-
Option 2:
- Open up the schema file you wish to debug
- Click the play button in the top right, you will get two options:
- Option 1 =
Debug File
- This will allow for the user to fully step through the schema (WIP), once fully completed will produce a infoset to a file namedSCHEMA-infoset.xml
which it then opened as well. - Option 2 =
Run File
- This will just run the schema through producing the infoset to a file namedSCHEMA-infoset.xml
which it then opened as well.
- Option 1 =
Find the infoset tools from the command menu (Mac = Command+Shift+P, Windows/Linux = Ctrl+Shift+P)
Find the hex view from the command menu (Mac = Command+Shift+P, Windows/Linux = Ctrl+Shift+P)
To enable the Daffodil VS Code extension experimental features, from the command menu start typing 'daffodil', then select Daffodil Debug: Enable Experimental Features
, then select 'Yes'.
Ωedit is being integrated as the experimental data editor. Once experimental features are enabled, find it in the command menu by typing 'omega', then select OmegaEdit: Data Editor
.
After selecting a file to edit, a Data Editor tab will appear.
As of v1.2.0, this experimental feature is far from functional, but will be improving over time.
- Wrong JDK. Be sure you're running Java 11.
On MacOS, using Homebrew:
# Install Java 11 from a macOS terminal
brew install java11
Add change JAVA_HOME
in your ~/.zshrc or equivalant:
# Java 11
export JAVA_HOME=/usr/local/Cellar/openjdk@11/11.0.12
Be sure code
is in your PATH
by following the instructions here.
With JAVA_HOME
set to the Java 11 install, run code
in your shell terminal.
If problems are encountered or new features are desired, create tickets here.
If you need help or guidance on using Daffodil and its tooling, please engage with our community on our mailing lists or review the archives.
Copyright © 2023 The Apache Software Foundation. Licensed under the Apache License, Version 2.0.
Apache, Apache Daffodil, Daffodil, and the Apache Daffodil logo are trademarks of The Apache Software Foundation.