Skip to content
This repository has been archived by the owner on Jul 17, 2024. It is now read-only.

Latest commit

 

History

History
73 lines (64 loc) · 2.79 KB

README.md

File metadata and controls

73 lines (64 loc) · 2.79 KB

jsusfx_pd - Jesusonic FX for Pure Data

The jsusfx implementation is done through 2 externals called jsfx~ and jsusfx~.

jsfx~

jsfx~ is the runtime object to expose JSFX scripts in pure-data. It expect as object creation argument the script to use that should be in the pd path. Upon object creation, each of the sliders will be exposed as an inlet. Any midi message generated from the script will be sent with the last outlet.

  • To change a slider, send message [slider <slider id> <0..1 value>(; the values are normalized from 0 to 1
  • For un-normalized values, send message [uslider <slider id> <raw value>(
  • Use [midi <midi stream>( to send midi data to script
  • Use [describe( to output the associated sliders
  • Use [dumpvars( to dump the current variables values
  • Use [bypass 0/1( to bypass the effect

jsusfx~

jsusfx~ is used for script development and can switch script with the command compile. All the slider parameter are read trought the slider message. At object creation, you can also put the number of inlet/outlet the script is expected to use. If you don't specify it, it will count the number of time in_pin and out_pin is used. Any midi message generated from the script will be sent with the last outlet.

  • To change a slider, send message [slider <slider id> <0..1 value>(; the values are normalized from 0 to 1
  • For un-normalized values, send message [uslider <slider id> <raw value>(
  • Use [midi <midi stream>( to send midi data to script
  • Use [compile( message to recompile your script. Optionally you can specify a new script to compile
  • Use [describe( to output the associated sliders
  • Use [dumpvars( to dump the current variables values
  • Use [bypass 0/1( to bypass the effect

Version 0.4

  • PD Loader support
  • Multi-channel support
  • Native ARM support (Raspberry Pi)
  • Windows build support
  • File API support
  • @import support
  • Midi in/out support
  • Subpatch wrapper generator (see jsfx2abstract.py)
  • More support of extended sliders
  • Various bug fixes
  • CMake now global build system

Subpatch generator

Since jsusfx_pd doesn't support pd_loader, a Python script can be use to generate a patch based on the content of a JSFX script. This patch can then be used as an abstraction wrapper to ease the integration.

To run the script, run the command below. Once it is done, it should generate a .pd file with same name as the script.

$ python jsfx2abstract.py <jsfx script>

Limitations

  • @gfx, @serialize section is ignored

Building

  • cmake is required to build the external
  • php and nasm is required to build native x86_64 support code
$ git clone --recurse-submodules https://github.com/asb2m10/jsusfx.git
$ cd jsusfx/pd
$ cmake .
$ make install