Skip to content

transcriptaze/vpd

Repository files navigation

build alpha cloudflare

VPD: VCV Rack 2 Panel Designer

VPD is a web application to create the SVG files for a basic VCV module panel.

There is a brief Getting started section below and a somewhat more comprehensive user guide which describes all the available commands (along with a summary cheatsheet)

Status: ALPHA

It has mostly (well, almost exclusively) been developed using Google Chrome on MacOS. Other browsers are a work in progress:

Chrome Firefox Opera Safari Edge DuckDuckGo
MacOS (130.0) (131.0.3) (114.0) (16.6.1) - (1.110.1)
Linux ? ? ? - - -
Windows ? ? ? - ? ?

Raison d’être

VPD was created mostly as an experiment in implementing a command interface using tree-sitter, but also because having to switch back and forth between between text and paths in Inkscape when creating or modifying a VCV panel is just plain annoying.

Getting Started

Assuming that you have already installed the VCV plugin SDK:

  1. Create a sample VCV plugin:

    $RACK_DIR/helper.py createplugin bodacious
    cd bodacious
    make
    
  2. Open the VPD web application in a browser.

  3. Create a sample panel by either:

    • Downloading the quickstart.vpd project file and opening it by clicking on the Load () button (or alternatively by executing the load project command)

      -- OR --

    • Downloading the quickstart.vpx script file and opening it by Alt-clicking on the Load () button (or alternatively by executing the load script command)

      -- OR --

    • Following the Getting started instructions in the User Guide

  4. Export the SVG files to the plugin res folder using either the Export SVG buttons ( ) or the commands:

    export panel svg
    export panel svg dark
    
  5. Generate a module using the VCV helper script and add the module to the plugin:

    $RACK_DIR/helper.py createmodule bodacious res/bodacious.svg src/bodacious.cpp
    

    plugin.hpp

    #pragma once
    #include <rack.hpp>
    
    using namespace rack;
    
    extern Plugin* pluginInstance;
    extern Model* modelBodacious;
    

    plugin.cpp

    #include "plugin.hpp"
    
    Plugin* pluginInstance;
    
    void init(Plugin* p) {
        pluginInstance = p;
    
        p->addModel(modelBodacious);
    }
    
  6. Compile and link and (optionally) install:

    make
    make install
    

Releases

web app

The VPD web app is currently hosted on Cloudflare Pages.

Running locally

VPD application

  1. Download the vpd executable archive from a release or the latest alpha build and extract it to a folder of your choice.
  2. Open the vpd application in a terminal window (on a Mac you may have to Ctrl-Open the file the first time to grant it permissions to run).
  3. Open http://localhost:9876 in your browser.
  4. Voilá, you're good to go!

Command line

vpd [--debug] [--port <port>] [--html <folder>]

Options:
--debug          Enables verbose internal debug logging
--port <port>    Serves the web application on the specifed port (the default port is 9876)
--html <folder>  External folder for the HTML files - by default it serves the web application
                 embedded in the executable. A tar.gz file with the base version of the HTML
                 can be downloaded from the Github releases or the latest 'alpha' build.

Python

  1. Download the HTML artifact from either a release or the latest alpha build and unzip it to a folder.
  2. Start an HTTP server to serve the unzipped files:
    cd vpd
    python3 -m http.server 9876 -d html
    

NodeJS

  1. Download the HTML artifact from either a release or the latest alpha build and unzip it to a folder.
  2. Start an HTTP server to serve the unzipped files:
    cd vpd
    npx http-server html --port 9876
    

Building from source

You need a bunch of tools:

NOTES:

  1. apt install sass on Ubuntu installs ruby-sass which was marked obsolete in 2019. Please follow the installation instructions on the Sass homepage to install the current version.

  2. The web app is not bundled because I cannot for the life of me figure out how to resolve all the wasm dependencies.

  3. The DuckDuckGo browser for Mac does not support:

    • Object.hasOwn
    • OPFS

Build instructions

  1. Clone the repository
    git clone https://github.com/transcriptaze/vpd
    cd vpd
    
  2. Start docker
  3. Build everything:
    make build-all
    

Attribution

  1. undo icon by Michael Kussmaul from Noun Project (CC BY 3.0)
  2. redo icon by Michael Kussmaul from Noun Project (CC BY 3.0)
  3. The remaining icons are from the SVG Silh project.