# DAWproject Open exchange format for user data between Digital Audio Workstations (DAWs) ## Motivation The DAWproject format provides a (vendor-agnostic) way of transferring user data between different music applications (DAWs). Currently, there is no file-format which is purpose-built for this task. Standard MIDI files can represent note data, but it is often a lower-level representation (no ramps) of data than what the DAW uses internally, which forces consolidation on export. AAF only covers audio and doesn't have any concept of musical-time, which limits it to post-audio workflows . Most plug-ins do allow you to save presets to a shared location, but this has to be done for each instance. What most users end up doing is just exporting audio as stems. The aim of this project is to export all translatable project data (audio/note/automation/plug-in) along with the structure surrounding it into a single DAWproject file. The table below aims to explain the scope format from a music-production perspective and how it compares to other methods of data transfer. | | DAWproject | Standard MIDI Files | Advanced Authoring Format (AAF) | |---------------------------------|:--------------------------------------------------------------------------------------------------------------------------------------:|:-------------------------------------------------------------:|:---------------------------------------------------------------------:| | Intended Use | Music Production | MIDI Sequencing | Video Post-Production | | Time Format
(seconds/beats) | Beats and seconds can be combined | Beats | Seconds | | Audio | Audio
Events/Clips
Fades
Crossfades
Amplitude
Pan
Time Warping
Transpose | - | Audio
Events/Clips
Fades
Crossfades
Amplitude
Pan | | Notes | Notes
Note Expressions | Notes | - | | Automation | Tempo
Time Signature
MIDI Messages
Volume
Pan
Mute
Sends
Plug-in Parameters
Built-in Device Parameters | Tempo
Time Signature
MIDI Messages
SysEx Messages | Volume
Pan
Video Related Parameters | | Plug-ins | Stores full plug-in state
and automation of parameters | - | - | | Built-in Devices | Generic EQ
Generic Compressor
Generic Gate
Generic Limiter | - | - | | Clip Launcher | Clips
Scenes | - | - | ## Status The format is version 1.0 and is stable. ## Goals * Package all user data of a project/song into a single file. * Audio timeline data * Note timeline data * Note expression data * Automation timeline data * Audio data (embedded or referenced) * Plug-in states (always embedded) * The format should be able to preserve as much user created data as feasible. * The format should be able to express the track and timeline structures of the exporting DAW as is, leaving it up to the importer to use this data and flatten it as needed. * Simple to implement * Built upon established open standards * Language agnostic, no special dependencies * Open & free ## Non-goals * Being the native file-format for a DAW * Optimal performance (like a binary format could provide) * Storing low-level MIDI events directly (but rather relying on higher level abstractions) * Storing non-session data (view settings, preferences) ## Format Specification * File Extension: .dawproject * Container: ZIP * Format: XML (project.xml, metadata.xml) * Text encoding: UTF-8 * The exporting DAW is free to choose the directory structure it wants for media and plug-in files. * [DAWproject XML Reference](https://htmlpreview.github.io/?https://github.com/bitwig/dawproject/blob/main/Reference.html) * [Project XML Schema](Project.xsd) * [MetaData XML Schema](MetaData.xsd) ## Language Support DAWproject is based on plain XML/ZIP and can be used with any programming language that can parse those. The DOM of DAWproject is defined by a set of Java classes which have XML-related annotations and HTML-induced Javadoc comments. Those are used (via reflection) to generate XML Documentation and Schemas. Potentially, the same approach could be used to generate code for other languages (contributions welcome). ## Building the Library, Documentation and Tests Requires Java Runtime version 16 or later. To build (using Gradle): ``` ./gradlew build ``` ## Example project The exporting application is free to structure tracks and timelines in a way that fits its internal model. The choice is left to the importing application to either use the level of structure provided (if applicable) or to flatten/convert it to match its model. As an example, here's the project.xml of a simple file saved in Bitwig Studio 5.0 with one instrument track and one audio track. As the audio clips in Bitwig Studio are themselves a timeline of audio events, you will notice that there are two levels of elements, id25 representing the clip timeline on the arrangement, and id26 representing the audio events inside the clip. ```xml ``` ## DAW Support DAWproject 1.0 is currently supported by the following DAWs * Bitwig Studio 5.0.9 * PreSonus Studio One 6.5