a common lisp implementation of the Open Sound Control protocol aka OSC
Find a file
2022-08-24 18:52:24 +02:00
devices Cleaning 2022-08-24 18:25:04 +02:00
LGPL.txt seed 2005-01-26 21:52:24 +08:00
LICENCE.txt recognosce 2005-11-29 19:11:26 +08:00
osc-data.lisp Cleaning 2022-08-24 18:25:04 +02:00
osc-dispatch.lisp Cleaning 2022-08-24 18:25:04 +02:00
osc-examples.lisp remind user of the docs of ip addr syntax 2022-08-24 18:40:35 +02:00
osc-time.lisp Cleaning 2022-08-24 18:25:04 +02:00
osc.asd Cleaning 2022-08-24 18:25:04 +02:00
osc.lisp Use Read-time evaluation to make code more readable 2022-08-24 18:52:24 +02:00
package.lisp Cleaning 2022-08-24 18:25:04 +02:00
README.md Cleaning 2022-08-24 18:25:04 +02:00

Open Sound Control

This is a common lisp implementation of the Open Sound Control Protocol aka OSC. The code should be close to the ansi standard, and does not rely on any external code/ffi/etc+ to do the basic encoding and decoding of packets. since OSC does not specify a transport layer, messages can be send using TCP or UDP (or carrier pigeons), however it seems UDP is more common amongst the programmes that communicate using the OSC protocol. the osc-examples.lisp file contains a few simple examples of how to send and recieve OSC via UDP, and so far seems reasonably compatible with the packets send from/to max-msp, pd, supercollider and liblo. more details about OSC can be found at https://opensoundcontrol.org/

The devices/examples/osc-device-examples.lisp contains examples of a higher-level API for sending and receiving OSC messages.

the current version of this code is avilable from github

git clone https://github.com/zzkt/osc

or via quicklisp.. .

(ql:quickload "osc")

limitations

  • will raise an exception if input is malformed
  • doesn't do any pattern matching on addresses
  • float en/decoding only tested on sbcl, cmucl, openmcl and allegro
  • only supports the type(tag)s specified in the OSC spec

things to do in :osc

  • address patterns using pcre
  • data checking and error handling
  • portable en/decoding of floats -=> ieee754 tests
  • doubles and other defacto typetags

things to do in :osc-ex[tensions|tras]

  • liblo like network wrapping
  • add namespace exploration using cl-zeroconf

changes

  • 2022-08-22
    • version 0.6
    • further improvements from jamieforth
  • 2019-04-02
    • encoder/decoder refactoring from Javier Olaechea @PuercoPop
  • 2017-12-10
    • osc-examples use usocket for portability from @boqs
  • 2015-08-25
  • 2015-08-21
    • implement nested bundles
  • 2011-04-19
    • converted repo from darcs->git
  • 2010-09-25
    • add osc-devices API from jamieforth
  • 2010-09-10
  • 2007-02-20
  • 2006-02-11
    • version 0.4
    • partial timetag implementation
  • 2005-12-05
    • version 0.3
    • fixed openmcl float bug (decode-uint32)
  • 2005-11-29
    • version 0.2
    • openmcl float en/decoding
  • 2005-08-12
  • 2005-08-11
    • version 0.1
  • 2005-03-16
    • packaged as an asdf installable lump
  • 2005-03-11
    • bundle and blob en/de- coding
  • 2005-03-05
    • 'declare' scattering and other optimisations
  • 2005-02-08
    • in-package'd
    • basic dispatcher
  • 2005-03-01
    • fixed address string bug
  • 2005-01-26
    • fixed string handling bug
  • 2005-01-24
    • sends and receives multiple arguments
    • tests in osc-tests.lisp
  • 2004-12-18
    • initial version, single args only