🦀 a colorful music making program for your linux terminal 🦀
Find a file
2024-12-10 18:15:53 +01:00
.forgejo/workflows add .forgejo/ with actions 2024-08-18 18:04:30 +03:00
crates add edit phrase selector 2024-12-10 18:15:53 +01:00
.gitignore basic midi import example 2024-11-24 03:47:03 +01:00
.gitmodules link to suil from nixpkgs 2024-07-24 14:50:44 +03:00
Cargo.lock WorldClock/PlayClock 2024-12-09 22:49:49 +01:00
Cargo.toml wip3 (33e): ermh... 2024-12-09 17:31:31 +01:00
Justfile draw note names 2024-12-10 15:05:11 +01:00
LICENSE update license 2024-10-15 09:16:48 +03:00
README.md add no-github badge 2024-11-08 21:42:43 +01:00
shell.nix remove VerticalArrangerGrid/Cursor 2024-10-18 16:03:03 +03:00

tek

Please don't upload to GitHub

a music making program for your terminal

project status

for roadmap, see https://codeberg.org/unspeaker/tek/milestones

Warning

As of 2024-10-25, I'm on track to release tek 0.2.0 sometime in December 2024. I plan to tag the previous working prototype (as seen in the demos published in the tek channel at basspistol's peertube) as 0.1.0— once I've identified the appropriate commit!

I've been dreaming of this project for a decade, and finally had the experience and peace of mind to start building it in late May 2024. I quickly reached the limit of how much of the UI I can write imperatively, so I started refactoring it in a more declarative style. The new interface logic is holding out pretty well, though it's not presently without its warts.

Your moral support means a lot to me. Feel free to contact me on Mastodon! (Especially if you know how to host LV2 plugin UIs in winit; or how to relink abandoned Win32 VST2s into LV2 or CLAP monoliths 😁)

Love,

(a rogue knowledge worker in a cyberpunk dystopia)

what it does

Tek is a MIDI sequencer, sampler, and plugin host for the Linux terminal. It's written in Rust, and targets JACK (or Pipewire's JACK implementation).

design goals

lightweight

My goal is to have a pop-up scratchpad for musical ideas that doesn't get in the way of building upon them. Kind of like Ableton — but for free systems, and without all the bloat!

flexible

Besides Ableton, I'm also inspired by the workflow of trackers and various old-school hardware sequencers (of which I've broken several). I've found that every existing music-making tool takes me about 80% of the way to the music I want to make. And so, after a decade of fucking around, I've decided it's finally time to make good on my old dream to build the instrument that will take me 100% there.

programmable

A secondary goal is to make my music making environment extensible, programmable, and interoperable; the intended project format is an S-expression-based notation (EDN, Steel, or similar... though I've also been looking for an excuse to embed a Forth 😏)

getting started

requirements

  • Linux
  • JACK or Pipewire
  • a terminal supporting 24-bit colors (I use kitty)
  • MIDI controller
  • Samples
  • LV2 plugins

downloads

Warning

Binaries are currently unavailable. Right now your only option is to build from source. In the future I plan to integrate Forgejo Actions / Codeberg CI.

building from source

You need a Rust toolchain and various system libraries. You can obtain the former using rustup and the latter using nix-shell. From there, use the commands in the Justfile, e.g.:

just arranger

usage

Warning

The following applies to tek 0.1.0. I will update it as part of the 0.2.0 release.

Overview

Tek is inspired by "clip launching" workflows as exemplified by Ableton Live, Bitwig Studio, Ardour, and probably others. The main view consists of three sections:

  • The arranger view corresponds to Ableton's Session and Arrangement views. It allows you to put together a musical composition as a sequence of phrases, playing simultaneously across multiple tracks.
  • The sequencer view allows you to edit phrases, which consist of MIDI events.
  • The chain view allows you to add devices to each track. Devices determine how a given phrase will sound. Currently, there are two devices implemented: sampler and plugin.

Note

Use Tab to switch focus between views. Use Enter to exclusively focus the highlighted view, and Esc to unfocus it. When a view is focused, use the Arrow Keys and Enter to navigate. Use ; (semicolon) to open the command palette, which will list the remaining keybindings.