14 Commits

Author SHA1 Message Date
onyx-and-iris
38973810d7 add variadic example in events section 2022-10-16 17:24:51 +01:00
onyx-and-iris
be6a49e3bc event Add() and Remove() now variadic.
in strip, vban, log warning then return zero value instead of panic.

update readme
2022-10-10 18:51:30 +01:00
onyx-and-iris
76ed3320d3 when parsing, notify of errors but do not exit
return scanner.err if not nil
2022-10-06 11:31:39 +01:00
onyx-and-iris
8f630d52e7 upd dep files for hotkeys, obs examples 2022-10-05 21:35:13 +01:00
onyx-and-iris
174db162c8 add verbosePrinter to vm-cli example
add info exit from interactive in README
2022-10-05 21:34:59 +01:00
onyx-and-iris
c7a265fb33 fix bug in togglecmd 2022-10-05 13:12:12 +01:00
onyx-and-iris
8bb8336599 interactive mode added to vm-cli example
toggle, get and set refactored into separate functions

flag vars moved from global  scope

-i flag added to README
2022-10-04 20:56:38 +01:00
onyx-and-iris
5b3f10c4b8 print bus level values in observer example 2022-10-04 20:18:48 +01:00
onyx-and-iris
7022c5dacf fix type error in getLevel 2022-10-04 20:18:26 +01:00
onyx-and-iris
5bb7eb9668 remove logrus from vm-cli 2022-09-29 19:04:32 +01:00
onyx-and-iris
5e5a82f198 upd -v flag description 2022-09-29 18:31:15 +01:00
onyx-and-iris
d8de82b90e add note to install in vm-cli 2022-09-29 18:27:26 +01:00
onyx-and-iris
5b4592f484 upd dep ver for obs, hotkeys examples 2022-09-29 18:25:23 +01:00
onyx-and-iris
b2dd96abc4 add install to vm-cli readme 2022-09-29 18:17:23 +01:00
14 changed files with 237 additions and 130 deletions

View File

@@ -147,19 +147,19 @@ sets many parameters in script format eg. ("Strip[0].Mute=1;Bus[3].Gain=3.6")
#### `vm.Register(o observer)` #### `vm.Register(o observer)`
register an object as an observer register an observer type as an observer
#### `vm.Deregister(o observer)` #### `vm.Deregister(o observer)`
deregister an object as an observer deregister an observer type as an observer
#### `vm.EventAdd(<event>)` #### `vm.EventAdd(<events>)`
adds an event to the pooler eg. vm.EventAdd("ldirty") adds a single or multiple events to the pooler. Accepts a string or slice of strings.
#### `vm.EventRemove(<event>)` #### `vm.EventRemove(<events>)`
removes an event to the pooler eg. vm.EventRemove("pdirty") removes a single or multiple events from the pooler. Accepts a string or slice of strings.
#### `vm.Pdirty()` #### `vm.Pdirty()`
@@ -481,9 +481,11 @@ By default level updates are disabled. Any event may be enabled or disabled. The
example: example:
```go ```go
vm.EventAdd("ldirty") events := []string{"ldirty", "mdirty", "pdirty"}
vm.EventRemove("pdirty") vm.EventAdd(events...)
vm.EventRemove(events...)
``` ```
### Run tests ### Run tests

View File

@@ -315,7 +315,7 @@ func getDeviceDescription(i int, dir string) (string, uint64, string, error) {
// getLevel returns a single level value of type type_ for channel[i] // getLevel returns a single level value of type type_ for channel[i]
func getLevel(type_, i int) (float64, error) { func getLevel(type_, i int) (float64, error) {
var val float64 var val float32
res, _, _ := vmGetLevelFloat.Call( res, _, _ := vmGetLevelFloat.Call(
uintptr(type_), uintptr(type_),
uintptr(i), uintptr(i),
@@ -325,7 +325,7 @@ func getLevel(type_, i int) (float64, error) {
err := fmt.Errorf("VBVMR_GetLevel returned %d", res) err := fmt.Errorf("VBVMR_GetLevel returned %d", res)
return 0, err return 0, err
} }
return val, nil return float64(val), nil
} }
// getMidiMessage gets midi channel, pitch and velocity for a single midi input // getMidiMessage gets midi channel, pitch and velocity for a single midi input

View File

@@ -4,7 +4,7 @@ go 1.19
require ( require (
github.com/eiannone/keyboard v0.0.0-20220611211555-0d226195f203 github.com/eiannone/keyboard v0.0.0-20220611211555-0d226195f203
github.com/onyx-and-iris/voicemeeter v1.9.0 github.com/onyx-and-iris/voicemeeter v1.10.1
github.com/sirupsen/logrus v1.9.0 github.com/sirupsen/logrus v1.9.0
) )

View File

@@ -3,8 +3,8 @@ github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c
github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
github.com/eiannone/keyboard v0.0.0-20220611211555-0d226195f203 h1:XBBHcIb256gUJtLmY22n99HaZTz+r2Z51xUPi01m3wg= github.com/eiannone/keyboard v0.0.0-20220611211555-0d226195f203 h1:XBBHcIb256gUJtLmY22n99HaZTz+r2Z51xUPi01m3wg=
github.com/eiannone/keyboard v0.0.0-20220611211555-0d226195f203/go.mod h1:E1jcSv8FaEny+OP/5k9UxZVw9YFWGj7eI4KR/iOBqCg= github.com/eiannone/keyboard v0.0.0-20220611211555-0d226195f203/go.mod h1:E1jcSv8FaEny+OP/5k9UxZVw9YFWGj7eI4KR/iOBqCg=
github.com/onyx-and-iris/voicemeeter v1.9.0 h1:4LbPP9iUj/P6FPymYqyh94ysfdvOunex+i2wUDSDn6s= github.com/onyx-and-iris/voicemeeter v1.10.1 h1:kpPN/cTYe1JG2aLUD+/m/bMUbp7wXrqrk1fL+sV8yko=
github.com/onyx-and-iris/voicemeeter v1.9.0/go.mod h1:bBWCYzL//4QmH4VL3TNpNIj9W89Oa+E6J5hgyt27mKg= github.com/onyx-and-iris/voicemeeter v1.10.1/go.mod h1:LayUoN/MWSqKXSOGQ7AcLvwoefsL+zQ9CjncLs3WqsU=
github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM= github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM=
github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4= github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
github.com/sirupsen/logrus v1.9.0 h1:trlNQbNUG3OdDrDil03MCb1H2o9nJ1x4/5LYw7byDE0= github.com/sirupsen/logrus v1.9.0 h1:trlNQbNUG3OdDrDil03MCb1H2o9nJ1x4/5LYw7byDE0=

View File

@@ -5,7 +5,7 @@ go 1.18
require ( require (
github.com/BurntSushi/toml v1.2.0 github.com/BurntSushi/toml v1.2.0
github.com/andreykaipov/goobs v0.10.0 github.com/andreykaipov/goobs v0.10.0
github.com/onyx-and-iris/voicemeeter v1.9.0 github.com/onyx-and-iris/voicemeeter v1.10.1
github.com/sirupsen/logrus v1.9.0 github.com/sirupsen/logrus v1.9.0
) )

View File

@@ -13,8 +13,8 @@ github.com/hashicorp/logutils v1.0.0 h1:dLEQVugN8vlakKOUE3ihGLTZJRB4j+M2cdTm/ORI
github.com/hashicorp/logutils v1.0.0/go.mod h1:QIAnNjmIWmVIIkWDTG1z5v++HQmx9WQRO+LraFDTW64= github.com/hashicorp/logutils v1.0.0/go.mod h1:QIAnNjmIWmVIIkWDTG1z5v++HQmx9WQRO+LraFDTW64=
github.com/nu7hatch/gouuid v0.0.0-20131221200532-179d4d0c4d8d h1:VhgPp6v9qf9Agr/56bj7Y/xa04UccTW04VP0Qed4vnQ= github.com/nu7hatch/gouuid v0.0.0-20131221200532-179d4d0c4d8d h1:VhgPp6v9qf9Agr/56bj7Y/xa04UccTW04VP0Qed4vnQ=
github.com/nu7hatch/gouuid v0.0.0-20131221200532-179d4d0c4d8d/go.mod h1:YUTz3bUH2ZwIWBy3CJBeOBEugqcmXREj14T+iG/4k4U= github.com/nu7hatch/gouuid v0.0.0-20131221200532-179d4d0c4d8d/go.mod h1:YUTz3bUH2ZwIWBy3CJBeOBEugqcmXREj14T+iG/4k4U=
github.com/onyx-and-iris/voicemeeter v1.9.0 h1:4LbPP9iUj/P6FPymYqyh94ysfdvOunex+i2wUDSDn6s= github.com/onyx-and-iris/voicemeeter v1.10.1 h1:kpPN/cTYe1JG2aLUD+/m/bMUbp7wXrqrk1fL+sV8yko=
github.com/onyx-and-iris/voicemeeter v1.9.0/go.mod h1:bBWCYzL//4QmH4VL3TNpNIj9W89Oa+E6J5hgyt27mKg= github.com/onyx-and-iris/voicemeeter v1.10.1/go.mod h1:LayUoN/MWSqKXSOGQ7AcLvwoefsL+zQ9CjncLs3WqsU=
github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM= github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM=
github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4= github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
github.com/sirupsen/logrus v1.9.0 h1:trlNQbNUG3OdDrDil03MCb1H2o9nJ1x4/5LYw7byDE0= github.com/sirupsen/logrus v1.9.0 h1:trlNQbNUG3OdDrDil03MCb1H2o9nJ1x4/5LYw7byDE0=

View File

@@ -42,16 +42,11 @@ func (o observer) OnUpdate(subject string) {
var val = o.vm.Midi.Get(current) var val = o.vm.Midi.Get(current)
fmt.Printf("Value of midi button %d: %d\n", current, val) fmt.Printf("Value of midi button %d: %d\n", current, val)
} else if subject == "ldirty" { } else if subject == "ldirty" {
fmt.Printf("%v %v %v %v %v %v %v %v\n", for _, bus := range o.vm.Bus {
o.vm.Bus[0].Levels().IsDirty(), if bus.Levels().IsDirty() {
o.vm.Bus[1].Levels().IsDirty(), fmt.Println(bus, bus.Levels().All())
o.vm.Bus[2].Levels().IsDirty(), }
o.vm.Bus[3].Levels().IsDirty(), }
o.vm.Bus[4].Levels().IsDirty(),
o.vm.Bus[5].Levels().IsDirty(),
o.vm.Bus[6].Levels().IsDirty(),
o.vm.Bus[7].Levels().IsDirty(),
)
} }
} }

View File

@@ -2,19 +2,24 @@
A simple voicemeeter-cli program. Offers ability to toggle, get and set parameters. A simple voicemeeter-cli program. Offers ability to toggle, get and set parameters.
## Install
First build and install it with `go install` (skip this step if using binary from [Releases](https://github.com/onyx-and-iris/voicemeeter/releases))
## Use ## Use
Toggle with `!` prefix, get by excluding `=` and set by including `=`. Mix and match arguments. Toggle with `!` prefix, get by excluding `=` and set by including `=`. Mix and match arguments.
You may pass the following optional flags: You may pass the following optional flags:
- -v: (-verbose) to toggle console output. Defaults to false. - -v: (-verbose) to toggle console output.
- -i: (-interactive) to toggle interactive mode.
- -k: (-kind) to set the kind of Voicemeeter. Defaults to banana. - -k: (-kind) to set the kind of Voicemeeter. Defaults to banana.
- -d: (-delay) to set a delay on the getters. Defaults to 20ms. - -d: (-delay) to set a delay on the getters. Defaults to 20ms.
for example: for example:
`go run .\main.go -v -k=potato -d=25 strip[0].mute=0 strip[0].mute !strip[0].mute strip[0].mute bus[0].gain=-8.8 command.lock=1` `vm-cli.exe -v -k=potato -d=25 strip[0].mute=0 strip[0].mute !strip[0].mute strip[0].mute bus[0].gain=-8.8 command.lock=1`
Expected output: Expected output:
@@ -26,3 +31,5 @@ Value of strip[0].mute is: 1
Running command bus[0].gain=-8.8 Running command bus[0].gain=-8.8
Running command command.lock=1 Running command command.lock=1
``` ```
If running in interactive mode enter `q`, `quit` or `<Enter>` to exit.

View File

@@ -1,28 +1,55 @@
package main package main
import ( import (
"bufio"
"flag" "flag"
"fmt" "fmt"
"log"
"os"
"strings" "strings"
log "github.com/sirupsen/logrus"
"github.com/onyx-and-iris/voicemeeter" "github.com/onyx-and-iris/voicemeeter"
) )
type (
verbosePrinter struct {
verbose bool
}
)
func newVerbosePrinter() *verbosePrinter {
return &verbosePrinter{}
}
func (v *verbosePrinter) printf(format string, a ...interface{}) {
if v.verbose {
fmt.Printf(format+"\n", a...)
}
}
var (
vPrinter *verbosePrinter
)
func init() {
vPrinter = newVerbosePrinter()
}
func main() {
var ( var (
kind string kind string
delay int delay int
verbose bool interactive bool
) )
func main() {
flag.StringVar(&kind, "kind", "banana", "kind of voicemeeter") flag.StringVar(&kind, "kind", "banana", "kind of voicemeeter")
flag.StringVar(&kind, "k", "banana", "kind of voicemeeter (shorthand)") flag.StringVar(&kind, "k", "banana", "kind of voicemeeter (shorthand)")
flag.IntVar(&delay, "delay", 20, "delay between commands") flag.IntVar(&delay, "delay", 20, "delay between commands")
flag.IntVar(&delay, "d", 20, "delay between commands (shorthand)") flag.IntVar(&delay, "d", 20, "delay between commands (shorthand)")
flag.BoolVar(&verbose, "verbose", false, "toggle console output") flag.BoolVar(&vPrinter.verbose, "verbose", false, "toggle console output")
flag.BoolVar(&verbose, "v", false, "toggle console output (shorthand)") flag.BoolVar(&vPrinter.verbose, "v", false, "toggle console output (shorthand)")
flag.BoolVar(&interactive, "interactive", false, "toggle interactive mode")
flag.BoolVar(&interactive, "i", false, "toggle interactive mode (shorthand)")
flag.Parse() flag.Parse()
vm, err := vmConnect(kind, delay) vm, err := vmConnect(kind, delay)
@@ -31,7 +58,7 @@ func main() {
} }
defer vm.Logout() defer vm.Logout()
err = runCommands(vm, verbose) err = runCommands(vm, interactive)
if err != nil { if err != nil {
fmt.Println(err) fmt.Println(err)
} }
@@ -51,46 +78,99 @@ func vmConnect(kind string, delay int) (*voicemeeter.Remote, error) {
return vm, nil return vm, nil
} }
func runCommands(vm *voicemeeter.Remote, verbose bool) error { func runCommands(vm *voicemeeter.Remote, interactive bool) error {
for _, arg := range flag.Args() { if interactive {
if arg[0] == '!' { return interactiveMode(vm)
val, err := vm.GetFloat(arg[1:]) }
if err != nil { args := flag.Args()
err = fmt.Errorf("unable to toggle %s", arg[1:]) if len(args) == 0 {
err := fmt.Errorf("must provide some commands to run")
return err return err
} }
vm.SetFloat(arg[1:], 1-val) for _, arg := range args {
if verbose { err := parse(vm, arg)
fmt.Println("Toggling", arg[1:]) if err != nil {
} vPrinter.printf(err.Error())
} else { }
if strings.Contains(arg, "=") { }
if verbose { return nil
fmt.Println("Running command", arg) }
}
err := vm.SendText(arg) func interactiveMode(vm *voicemeeter.Remote) error {
vPrinter.printf("running in interactive mode... waiting for input")
scanner := bufio.NewScanner(os.Stdin)
for scanner.Scan() {
input := scanner.Text()
if input == "q" || input == "quit" || input == "" {
return nil
}
for _, cmd := range strings.Split(input, " ") {
err := parse(vm, cmd)
if err != nil {
vPrinter.printf(err.Error())
}
}
}
if scanner.Err() != nil {
return scanner.Err()
}
return nil
}
func parse(vm *voicemeeter.Remote, cmd string) error {
if cmd[0] == '!' {
err := toggleCmd(vm, cmd[1:])
if err != nil { if err != nil {
err = fmt.Errorf("unable to set %s", arg)
return err return err
} }
} else { } else {
valF, err := vm.GetFloat(arg) if strings.Contains(cmd, "=") {
err := setCmd(vm, cmd)
if err != nil { if err != nil {
valS, err := vm.GetString(arg)
if err != nil {
err = fmt.Errorf("unable to get %s", arg)
return err return err
} }
if verbose {
fmt.Println("Value of", arg, "is:", valS)
}
} else { } else {
if verbose { err := getCmd(vm, cmd)
fmt.Println("Value of", arg, "is:", valF) if err != nil {
} return err
}
} }
} }
} }
return nil return nil
} }
func toggleCmd(vm *voicemeeter.Remote, cmd string) error {
val, err := vm.GetFloat(cmd)
if err != nil {
err = fmt.Errorf("unable to toggle %s", cmd)
return err
}
vm.SetFloat(cmd, 1-val)
vPrinter.printf("Toggling %s", cmd)
return nil
}
func setCmd(vm *voicemeeter.Remote, cmd string) error {
vPrinter.printf("Running command %s", cmd)
err := vm.SendText(cmd)
if err != nil {
err = fmt.Errorf("unable to set %s", cmd)
return err
}
return nil
}
func getCmd(vm *voicemeeter.Remote, cmd string) error {
valF, err := vm.GetFloat(cmd)
if err != nil {
valS, err := vm.GetString(cmd)
if err != nil {
err = fmt.Errorf("unable to get %s", cmd)
return err
}
vPrinter.printf("Value of %s is: %s", cmd, valS)
} else {
vPrinter.printf("Value of %s is: %v", cmd, valF)
}
return nil
}

View File

@@ -2,6 +2,8 @@ package voicemeeter
import ( import (
"time" "time"
log "github.com/sirupsen/logrus"
) )
// observer defines the interface any registered observers must satisfy // observer defines the interface any registered observers must satisfy
@@ -51,8 +53,9 @@ func newEvent() *event {
return &event{true, true, true, false} return &event{true, true, true, false}
} }
func (e *event) Add(ev string) { func (e *event) Add(events ...string) {
switch ev { for _, event := range events {
switch event {
case "pdirty": case "pdirty":
e.pdirty = true e.pdirty = true
case "mdirty": case "mdirty":
@@ -62,10 +65,13 @@ func (e *event) Add(ev string) {
case "ldirty": case "ldirty":
e.ldirty = true e.ldirty = true
} }
log.Info(event, " added to the pooler")
}
} }
func (e *event) Remove(ev string) { func (e *event) Remove(events ...string) {
switch ev { for _, event := range events {
switch event {
case "pdirty": case "pdirty":
e.pdirty = false e.pdirty = false
case "mdirty": case "mdirty":
@@ -75,6 +81,8 @@ func (e *event) Remove(ev string) {
case "ldirty": case "ldirty":
e.ldirty = false e.ldirty = false
} }
log.Info(event, " removed from the pooler")
}
} }
// pooler continuously polls the dirty paramters // pooler continuously polls the dirty paramters

View File

@@ -8,7 +8,7 @@ import (
log "github.com/sirupsen/logrus" log "github.com/sirupsen/logrus"
) )
// A Remote type represents the API for a kind // Remote represents the API for a kind
type Remote struct { type Remote struct {
Kind *kind Kind *kind
Strip []iStrip Strip []iStrip
@@ -85,7 +85,7 @@ func (r *Remote) Sync() {
} }
} }
// Gets a float parameter value // GetFloat gets a float parameter value
func (r *Remote) GetFloat(name string) (float64, error) { func (r *Remote) GetFloat(name string) (float64, error) {
val, err := getParameterFloat(name) val, err := getParameterFloat(name)
if err != nil { if err != nil {
@@ -94,7 +94,7 @@ func (r *Remote) GetFloat(name string) (float64, error) {
return val, nil return val, nil
} }
// Sets a float paramter value // SetFloat sets a float paramter value
func (r *Remote) SetFloat(name string, value float64) error { func (r *Remote) SetFloat(name string, value float64) error {
err := setParameterFloat(name, value) err := setParameterFloat(name, value)
if err != nil { if err != nil {
@@ -103,7 +103,7 @@ func (r *Remote) SetFloat(name string, value float64) error {
return nil return nil
} }
// Gets a string parameter value // GetString gets a string parameter value
func (r *Remote) GetString(name string) (string, error) { func (r *Remote) GetString(name string) (string, error) {
val, err := getParameterString(name) val, err := getParameterString(name)
if err != nil { if err != nil {
@@ -112,7 +112,7 @@ func (r *Remote) GetString(name string) (string, error) {
return val, nil return val, nil
} }
// Sets a string paramter value // SetString sets a string parameter value
func (r *Remote) SetString(name, value string) error { func (r *Remote) SetString(name, value string) error {
err := setParameterString(name, value) err := setParameterString(name, value)
if err != nil { if err != nil {
@@ -140,14 +140,14 @@ func (r *Remote) Deregister(o observer) {
r.pooler.Deregister(o) r.pooler.Deregister(o)
} }
// EventAdd adds an event to the Pooler // EventAdd adds events to the Pooler
func (r *Remote) EventAdd(event string) { func (r *Remote) EventAdd(events ...string) {
r.pooler.event.Add(event) r.pooler.event.Add(events...)
} }
// EventRemove removes an event from the Pooler // EventRemove removes events from the Pooler
func (r *Remote) EventRemove(event string) { func (r *Remote) EventRemove(events ...string) {
r.pooler.event.Remove(event) r.pooler.event.Remove(events...)
} }
// remoteBuilder defines the interface builder types must satisfy // remoteBuilder defines the interface builder types must satisfy
@@ -165,7 +165,7 @@ type remoteBuilder interface {
Get() *Remote Get() *Remote
} }
// directory is responsible for directing the genericBuilder // director is responsible for directing the genericBuilder
type director struct { type director struct {
builder remoteBuilder builder remoteBuilder
} }

View File

@@ -3,9 +3,11 @@ package voicemeeter
import ( import (
"fmt" "fmt"
"time" "time"
log "github.com/sirupsen/logrus"
) )
// iStrip defines the interface bus types must satisfy // iStrip defines the interface strip types must satisfy
type iStrip interface { type iStrip interface {
String() string String() string
GetMute() bool GetMute() bool
@@ -179,14 +181,16 @@ func (p *physicalStrip) SetAudibility(val float64) {
p.setter_float("Audibility", val) p.setter_float("Audibility", val)
} }
// GetMc panics reason invalid parameter // GetMc logs a warning reason invalid parameter
// it always returns zero value
func (p *physicalStrip) GetMc() bool { func (p *physicalStrip) GetMc() bool {
panic("invalid parameter MC for physicalStrip") log.Warn("invalid parameter MC for physicalStrip")
return false
} }
// SetMc panics reason invalid parameter // SetMc logs a warning reason invalid parameter
func (p *physicalStrip) SetMc(val bool) { func (p *physicalStrip) SetMc(val bool) {
panic("invalid parameter MC for physicalStrip") log.Warn("invalid parameter MC for physicalStrip")
} }
// virtualStrip represents a single virtual strip // virtualStrip represents a single virtual strip
@@ -221,34 +225,40 @@ func (v *virtualStrip) SetMc(val bool) {
v.setter_bool("MC", val) v.setter_bool("MC", val)
} }
// GetComp panics reason invalid parameter // GetComp logs a warning reason invalid parameter
// it always returns zero value
func (v *virtualStrip) GetComp() float64 { func (v *virtualStrip) GetComp() float64 {
panic("invalid parameter Comp for virtualStrip") log.Warn("invalid parameter Comp for virtualStrip")
return 0
} }
// SetComp panics reason invalid parameter // SetComp logs a warning reason invalid parameter
func (v *virtualStrip) SetComp(val float64) { func (v *virtualStrip) SetComp(val float64) {
panic("invalid parameter Comp for virtualStrip") log.Warn("invalid parameter Comp for virtualStrip")
} }
// GetGate panics reason invalid parameter // GetGate logs a warning reason invalid parameter
// it always returns zero value
func (v *virtualStrip) GetGate() float64 { func (v *virtualStrip) GetGate() float64 {
panic("invalid parameter Gate for virtualStrip") log.Warn("invalid parameter Gate for virtualStrip")
return 0
} }
// SetGate panics reason invalid parameter // SetGate logs a warning reason invalid parameter
func (v *virtualStrip) SetGate(val float64) { func (v *virtualStrip) SetGate(val float64) {
panic("invalid parameter Gate for virtualStrip") log.Warn("invalid parameter Gate for virtualStrip")
} }
// GetAudibility panics reason invalid parameter // GetAudibility logs a warning reason invalid parameter
// it always returns zero value
func (v *virtualStrip) GetAudibility() float64 { func (v *virtualStrip) GetAudibility() float64 {
panic("invalid parameter Audibility for virtualStrip") log.Warn("invalid parameter Audibility for virtualStrip")
return 0
} }
// SetAudibility panics reason invalid parameter // SetAudibility logs a warning reason invalid parameter
func (v *virtualStrip) SetAudibility(val float64) { func (v *virtualStrip) SetAudibility(val float64) {
panic("invalid parameter Audibility for virtualStrip") log.Warn("invalid parameter Audibility for virtualStrip")
} }
// AppGain sets the gain in db by val for the app matching name. // AppGain sets the gain in db by val for the app matching name.

View File

@@ -28,8 +28,8 @@ func roundFloat(val float64, precision uint) float64 {
// convertLevel performs the necessary math for a channel level // convertLevel performs the necessary math for a channel level
func convertLevel(i float64) float64 { func convertLevel(i float64) float64 {
if i > 0 { if i > 0 {
val := 20 * math.Log10(float64(i)) val := 20 * math.Log10(i)
return float64(roundFloat(float64(val), 1)) return roundFloat(val, 1)
} }
return -200.0 return -200.0
} }

21
vban.go
View File

@@ -1,6 +1,10 @@
package voicemeeter package voicemeeter
import "fmt" import (
"fmt"
log "github.com/sirupsen/logrus"
)
// iVban defines the interface vban types must satisfy // iVban defines the interface vban types must satisfy
type iVban interface { type iVban interface {
@@ -105,7 +109,8 @@ func (v *vbanStream) SetBit(val int) {
case 24: case 24:
val = 2 val = 2
default: default:
panic("expected value 16 or 24") log.Warn("expected value 16 or 24")
return
} }
v.setter_int("Bit", val) v.setter_int("Bit", val)
} }
@@ -139,19 +144,19 @@ func newVbanInStream(i int) iVban {
return iVban(&vbi) return iVban(&vbi)
} }
// SetSr panics reason read only // SetSr logs a warning reason read only
func (vbi *vbanInStream) SetSr(val int) { func (vbi *vbanInStream) SetSr(val int) {
panic("SR is readonly for vban instreams") log.Warn("SR is readonly for vban instreams")
} }
// SetChannel panics reason read only // SetChannel logs a warning reason read only
func (vbi *vbanInStream) SetChannel(val int) { func (vbi *vbanInStream) SetChannel(val int) {
panic("channel is readonly for vban instreams") log.Warn("channel is readonly for vban instreams")
} }
// SetBit panics reason read only // SetBit logs a warning reason read only
func (vbi *vbanInStream) SetBit(val int) { func (vbi *vbanInStream) SetBit(val int) {
panic("bit is readonly for vban instreams") log.Warn("bit is readonly for vban instreams")
} }
type vbanOutStream struct { type vbanOutStream struct {