add many experimental plugins
This commit is contained in:
parent
9a6caa2453
commit
7c4dead5cf
11 changed files with 172 additions and 3 deletions
10
src/lang.zig
10
src/lang.zig
|
@ -27,6 +27,11 @@ pub const CommandType = enum {
|
|||
Vinyl,
|
||||
RevDelay,
|
||||
Gate,
|
||||
Detune,
|
||||
Overdrive,
|
||||
Degrade,
|
||||
RePsycho,
|
||||
TalkBox,
|
||||
|
||||
Noise,
|
||||
WildNoise,
|
||||
|
@ -186,12 +191,17 @@ pub const Lang = struct {
|
|||
_ = try self.keywords.put("vinyl", .Vinyl);
|
||||
_ = try self.keywords.put("revdelay", .RevDelay);
|
||||
_ = try self.keywords.put("gate", .Gate);
|
||||
_ = try self.keywords.put("detune", .Detune);
|
||||
_ = try self.keywords.put("overdrive", .Overdrive);
|
||||
_ = try self.keywords.put("talkbox", .TalkBox);
|
||||
|
||||
// custom implementations (not lv2)
|
||||
_ = try self.keywords.put("noise", .Noise);
|
||||
_ = try self.keywords.put("wildnoise", .WildNoise);
|
||||
_ = try self.keywords.put("write", .Write);
|
||||
_ = try self.keywords.put("embed", .Embed);
|
||||
_ = try self.keywords.put("degrade", .Degrade);
|
||||
_ = try self.keywords.put("repsycho", .RePsycho);
|
||||
|
||||
// even more custom
|
||||
_ = try self.keywords.put("rotate", .Rotate);
|
||||
|
|
|
@ -21,6 +21,11 @@ pub fn printList(list: langs.CommandList, stream: var) !void {
|
|||
.Vinyl => "vinyl",
|
||||
.RevDelay => "revdelay",
|
||||
.Gate => "gate",
|
||||
.Detune => "detune",
|
||||
.Overdrive => "overdrive",
|
||||
.Degrade => "Degrade",
|
||||
.RePsycho => "repsycho",
|
||||
.TalkBox => "talkbox",
|
||||
|
||||
.Noise => "noise",
|
||||
.WildNoise => "wildnoise",
|
||||
|
|
|
@ -299,6 +299,31 @@ pub const Runner = struct {
|
|||
try image.runPlugin("http://hippie.lt/lv2/gate", pos, params);
|
||||
}
|
||||
|
||||
fn detuneCmd(self: *Runner, pos: Position, params: ParamList) !void {
|
||||
var image = try self.getImage();
|
||||
try image.runPlugin("http://drobilla.net/plugins/mda/Detune", pos, params);
|
||||
}
|
||||
|
||||
fn overdriveCmd(self: *Runner, pos: Position, params: ParamList) !void {
|
||||
var image = try self.getImage();
|
||||
try image.runPlugin("http://drobilla.net/plugins/mda/Overdrive", pos, params);
|
||||
}
|
||||
|
||||
fn degradeCmd(self: *Runner, pos: Position, params: ParamList) !void {
|
||||
var image = try self.getImage();
|
||||
try image.runPlugin("http://drobilla.net/plugins/mda/Degrade", pos, params);
|
||||
}
|
||||
|
||||
fn repsychoCmd(self: *Runner, pos: Position, params: ParamList) !void {
|
||||
var image = try self.getImage();
|
||||
try image.runPlugin("http://drobilla.net/plugins/mda/RePsycho", pos, params);
|
||||
}
|
||||
|
||||
fn talkboxCmd(self: *Runner, pos: Position, params: ParamList) !void {
|
||||
var image = try self.getImage();
|
||||
try image.runPlugin("http://drobilla.net/plugins/mda/TalkBox", pos, params);
|
||||
}
|
||||
|
||||
fn runCommand(self: *Runner, cmd: *lang.Command) !void {
|
||||
var params = ParamList.init(self.allocator);
|
||||
defer params.deinit();
|
||||
|
@ -493,6 +518,54 @@ pub const Runner = struct {
|
|||
try self.gateCmd(pos, params);
|
||||
},
|
||||
|
||||
.Detune => {
|
||||
const pos = try cmd.consumePosition();
|
||||
try cmd.appendParam(¶ms, "detune");
|
||||
try cmd.appendParam(¶ms, "mix");
|
||||
try cmd.appendParam(¶ms, "output");
|
||||
try cmd.appendParam(¶ms, "latency");
|
||||
try self.detuneCmd(pos, params);
|
||||
},
|
||||
|
||||
.Overdrive => {
|
||||
const pos = try cmd.consumePosition();
|
||||
try cmd.appendParam(¶ms, "drive");
|
||||
try cmd.appendParam(¶ms, "muffle");
|
||||
try cmd.appendParam(¶ms, "output");
|
||||
try self.overdriveCmd(pos, params);
|
||||
},
|
||||
|
||||
.Degrade => {
|
||||
const pos = try cmd.consumePosition();
|
||||
try cmd.appendParam(¶ms, "headroom");
|
||||
try cmd.appendParam(¶ms, "quant");
|
||||
try cmd.appendParam(¶ms, "rate");
|
||||
try cmd.appendParam(¶ms, "post_filt");
|
||||
try cmd.appendParam(¶ms, "non_lin");
|
||||
try cmd.appendParam(¶ms, "output");
|
||||
try self.degradeCmd(pos, params);
|
||||
},
|
||||
|
||||
.RePsycho => {
|
||||
const pos = try cmd.consumePosition();
|
||||
try cmd.appendParam(¶ms, "tune");
|
||||
try cmd.appendParam(¶ms, "fine");
|
||||
try cmd.appendParam(¶ms, "decay");
|
||||
try cmd.appendParam(¶ms, "thresh");
|
||||
try cmd.appendParam(¶ms, "hold");
|
||||
try cmd.appendParam(¶ms, "mix");
|
||||
try cmd.appendParam(¶ms, "quality");
|
||||
try self.repsychoCmd(pos, params);
|
||||
},
|
||||
|
||||
.TalkBox => {
|
||||
const pos = try cmd.consumePosition();
|
||||
try cmd.appendParam(¶ms, "wet");
|
||||
try cmd.appendParam(¶ms, "dry");
|
||||
try cmd.appendParam(¶ms, "carrier");
|
||||
try cmd.appendParam(¶ms, "quality");
|
||||
try self.talkboxCmd(pos, params);
|
||||
},
|
||||
else => blk: {
|
||||
std.debug.warn("Unsupported command: {}\n", .{cmd.command});
|
||||
break :blk RunError.UnknownCommand;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue