Orca ist eine esoterische Programmiersprache und ein Live-Editor zur schnellen Erstellung prozeduraler Sequenzer. Jeder Buchstabe des Alphabets ist eine Operation, Kleinbuchstaben werden bei *bang*
ausgeführt und Großbuchstaben führen bei jedem Frame aus.
Dies ist die C-Implementierung der ORCΛ-Sprache und der Terminal-Livecoding-Umgebung. Es ist energieeffizient konzipiert. Es kann große Dateien verarbeiten, selbst wenn Ihr Terminal klein ist.
Orca ist kein Synthesizer, sondern eine flexible Livecoding-Umgebung, die MIDI, OSC und UDP an Ihre audiovisuellen Schnittstellen wie Ableton, Renoise, VCV Rack oder SuperCollider senden kann.
Haupt-Git-Repo | GitHub-Spiegel |
---|---|
git.sr.ht/~rabbits/orca | github.com/hundredrabbits/Orca-c |
sudo apt-get install git libncurses5-dev libncursesw5-dev libportmidi-dev
git clone https://github.com/hundredrabbits/Orca-c.git
cd Orca-c
make # Compile orca
build/orca # Run orca
Um Ihr MIDI-Ausgabegerät auszuwählen, drücken Sie F1
(oder Ctrl+D
), um das Hauptmenü zu öffnen, und wählen Sie dann MIDI Output...
aus.
┌ ORCA ───────────────┐┌ PortMidi Device Selection ─────┐
│ New ││ > (*) #0 - Midi Through Port-0 │
│ Open... ││ ( ) #2 - ES1371 │
│ Save │└────────────────────────────────┘
│ Save As... │
│ │
│ Set BPM... │
│ Set Grid Size... │
│ Auto-fit Grid │
│ │
│ OSC Output... │
│ > MIDI Output... │
│ │
│ Clock & Timing... │
│.....................│
Kernbibliothek: Ein C99-Compiler (keine VLAs erforderlich) plus ausreichend libc für malloc
, realloc
, free
, memcpy
, memset
und memmove
. (Außerdem muss #pragma once
unterstützt werden.)
Befehlszeileninterpreter: Das Obige, plus POSIX und genügend libc für die allgemeinen String-Operationen ( strlen
, strcmp
usw.)
Livecoding-Terminal-Benutzeroberfläche: Das Obige, plus ncurses (oder eine kompatible Curses-Bibliothek) und Gleitkomma-Unterstützung (für das Timing). Optional kann PortMidi verwendet werden, um die direkte MIDI-Ausgabe zu ermöglichen.
Das Build-Skript, einfach tool
genannt, ist in POSIX sh
geschrieben. Es sollte mit gcc
(einschließlich des Wrappers musl-gcc
), tcc
und clang
funktionieren und Ihren Compiler automatisch erkennen. Sie können einen Compiler manuell mit der Option -c
angeben.
Derzeit ist bekannt, dass es auf macOS ( gcc
, clang
, tcc
) und Linux ( gcc
, musl-gcc
, tcc
und clang
, optional mit LLD
) und Windows über Cygwin oder WSL ( gcc
oder clang
, tcc
ungetestet) aufbaut.
Um das Build-Skript herum gibt es einen Fire-and-Forget- make
Wrapper.
PortMidi ist eine optionale Abhängigkeit. Es kann durch Hinzufügen der Option --portmidi
beim Ausführen des tool
Build-Skripts aktiviert werden.
Die Mauserkennung kann durch Hinzufügen der Option --no-mouse
deaktiviert werden.
tool
-Build-Skript Führen Sie ./tool help
aus, um Nutzungsinformationen anzuzeigen. Beispiele:
./tool build -c clang-7 --portmidi orca
# Build the livecoding environment with a compiler
# named clang-7, with optimizations enabled, and
# with PortMidi enabled for MIDI output.
# Binary placed at build/orca
./tool build -d orca
# Debug build of the livecoding environment.
# Binary placed at build/debug/orca
./tool build -d cli
# Debug build of the headless CLI interpreter.
# Binary placed at build/debug/cli
./tool clean
# Same as make clean. Removes build/
make
-Wrapper make release # optimized build, binary placed at build/orca
make debug # debugging build, binary placed at build/debug/orca
make clean # removes build/
Der make
-Wrapper aktiviert standardmäßig --portmidi
. Wenn Sie das tool
Build-Skript alleine ausführen, ist --portmidi
standardmäßig nicht aktiviert.
orca
Livecoding-Umgebung Usage: orca [options] [file]
General options:
--undo-limit <number> Set the maximum number of undo steps.
If you plan to work with large files,
set this to a low number.
Default: 100
--initial-size <nxn> When creating a new grid file, use these
starting dimensions.
--bpm <number> Set the tempo (beats per minute).
Default: 120
--seed <number> Set the seed for the random function.
Default: 1
-h or --help Print this message and exit.
OSC/MIDI options:
--strict-timing
Reduce the timing jitter of outgoing MIDI and OSC messages.
Uses more CPU time.
--osc-midi-bidule <path>
Set MIDI to be sent via OSC formatted for Plogue Bidule.
The path argument is the path of the Plogue OSC MIDI device.
Example: /OSC_MIDI_0/MIDI
orca
Livecoding-Umgebung mit MIDI-Ausgabe $ ./tool build --portmidi orca # compile orca using build script
$ build/orca # run orca
orca
Livecoding-Umgebungskontrollen ┌ Controls ───────────────────────────────────────────┐
│ Ctrl+Q Quit │
│ Arrow Keys Move Cursor │
│ Ctrl+D or F1 Open Main Menu │
│ 0-9, A-Z, a-z, Insert Character │
│ ! : % / = # * │
│ Spacebar Play/Pause │
│ Ctrl+Z or Ctrl+U Undo │
│ Ctrl+X Cut │
│ Ctrl+C Copy │
│ Ctrl+V Paste │
│ Ctrl+S Save │
│ Ctrl+F Frame Step Forward │
│ Ctrl+R Reset Frame Number │
│ Ctrl+I or Insert Append/Overwrite Mode │
│ ' (quote) Rectangle Selection Mode │
│ Shift+Arrow Keys Adjust Rectangle Selection │
│ Alt+Arrow Keys Slide Selection │
│ ` (grave) or ~ Slide Selection Mode │
│ Escape Return to Normal Mode or Deselect │
│ ( ) _ + [ ] { } Adjust Grid Size and Rulers │
│ < and > Adjust BPM │
│ ? Controls (this message) │
└─────────────────────────────────────────────────────┘
cli
-Befehlszeilenschnittstelleninterpreter Die CLI ( cli
Binärdatei) liest aus einer Datei und führt die Orca-Simulation für einen Zeitschritt (Standard) oder eine angegebene Anzahl (Option -t
) aus und schreibt den resultierenden Status des Rasters in stdout.
cli [-t timesteps] infile
Sie können cli
auch von stdin lesen lassen:
echo -e " ...na34n... " | cli /dev/stdin