mirror of
https://github.com/onyx-and-iris/voicemeeter.git
synced 2026-04-18 05:23:31 +00:00
Compare commits
5 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
be6a49e3bc | ||
|
|
76ed3320d3 | ||
|
|
8f630d52e7 | ||
|
|
174db162c8 | ||
|
|
c7a265fb33 |
12
README.md
12
README.md
@@ -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()`
|
||||||
|
|
||||||
|
|||||||
@@ -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.10.0
|
github.com/onyx-and-iris/voicemeeter v1.10.1
|
||||||
github.com/sirupsen/logrus v1.9.0
|
github.com/sirupsen/logrus v1.9.0
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|||||||
@@ -3,10 +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/onyx-and-iris/voicemeeter v1.10.0 h1:FIavzL0p33c2fyzOCtuofFOCvIv+8DrL3jFMoTr5/io=
|
|
||||||
github.com/onyx-and-iris/voicemeeter v1.10.0/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=
|
||||||
|
|||||||
@@ -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.10.0
|
github.com/onyx-and-iris/voicemeeter v1.10.1
|
||||||
github.com/sirupsen/logrus v1.9.0
|
github.com/sirupsen/logrus v1.9.0
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|||||||
@@ -13,10 +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/onyx-and-iris/voicemeeter v1.10.0 h1:FIavzL0p33c2fyzOCtuofFOCvIv+8DrL3jFMoTr5/io=
|
|
||||||
github.com/onyx-and-iris/voicemeeter v1.10.0/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=
|
||||||
|
|||||||
@@ -31,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.
|
||||||
|
|||||||
@@ -11,11 +11,34 @@ import (
|
|||||||
"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() {
|
func main() {
|
||||||
var (
|
var (
|
||||||
kind string
|
kind string
|
||||||
delay int
|
delay int
|
||||||
verbose bool
|
|
||||||
interactive bool
|
interactive bool
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -23,8 +46,8 @@ func main() {
|
|||||||
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, "interactive", false, "toggle interactive mode")
|
||||||
flag.BoolVar(&interactive, "i", false, "toggle interactive mode (shorthand)")
|
flag.BoolVar(&interactive, "i", false, "toggle interactive mode (shorthand)")
|
||||||
flag.Parse()
|
flag.Parse()
|
||||||
@@ -35,7 +58,7 @@ func main() {
|
|||||||
}
|
}
|
||||||
defer vm.Logout()
|
defer vm.Logout()
|
||||||
|
|
||||||
err = runCommands(vm, verbose, interactive)
|
err = runCommands(vm, interactive)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Println(err)
|
fmt.Println(err)
|
||||||
}
|
}
|
||||||
@@ -55,20 +78,26 @@ func vmConnect(kind string, delay int) (*voicemeeter.Remote, error) {
|
|||||||
return vm, nil
|
return vm, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func runCommands(vm *voicemeeter.Remote, verbose, interactive bool) error {
|
func runCommands(vm *voicemeeter.Remote, interactive bool) error {
|
||||||
if interactive {
|
if interactive {
|
||||||
return interactiveMode(vm, verbose)
|
return interactiveMode(vm)
|
||||||
}
|
}
|
||||||
for _, arg := range flag.Args() {
|
args := flag.Args()
|
||||||
err := parse(vm, arg, verbose)
|
if len(args) == 0 {
|
||||||
|
err := fmt.Errorf("must provide some commands to run")
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
for _, arg := range args {
|
||||||
|
err := parse(vm, arg)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
vPrinter.printf(err.Error())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func interactiveMode(vm *voicemeeter.Remote, verbose bool) error {
|
func interactiveMode(vm *voicemeeter.Remote) error {
|
||||||
|
vPrinter.printf("running in interactive mode... waiting for input")
|
||||||
scanner := bufio.NewScanner(os.Stdin)
|
scanner := bufio.NewScanner(os.Stdin)
|
||||||
for scanner.Scan() {
|
for scanner.Scan() {
|
||||||
input := scanner.Text()
|
input := scanner.Text()
|
||||||
@@ -76,29 +105,32 @@ func interactiveMode(vm *voicemeeter.Remote, verbose bool) error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
for _, cmd := range strings.Split(input, " ") {
|
for _, cmd := range strings.Split(input, " ") {
|
||||||
err := parse(vm, cmd, verbose)
|
err := parse(vm, cmd)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
vPrinter.printf(err.Error())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if scanner.Err() != nil {
|
||||||
|
return scanner.Err()
|
||||||
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func parse(vm *voicemeeter.Remote, cmd string, verbose bool) error {
|
func parse(vm *voicemeeter.Remote, cmd string) error {
|
||||||
if cmd[0] == '!' {
|
if cmd[0] == '!' {
|
||||||
err := toggleCmd(vm, cmd[1:], verbose)
|
err := toggleCmd(vm, cmd[1:])
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if strings.Contains(cmd, "=") {
|
if strings.Contains(cmd, "=") {
|
||||||
err := setCmd(vm, cmd, verbose)
|
err := setCmd(vm, cmd)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
err := getCmd(vm, cmd, verbose)
|
err := getCmd(vm, cmd)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@@ -107,23 +139,19 @@ func parse(vm *voicemeeter.Remote, cmd string, verbose bool) error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func toggleCmd(vm *voicemeeter.Remote, cmd string, verbose bool) error {
|
func toggleCmd(vm *voicemeeter.Remote, cmd string) error {
|
||||||
val, err := vm.GetFloat(cmd)
|
val, err := vm.GetFloat(cmd)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
err = fmt.Errorf("unable to toggle %s", cmd)
|
err = fmt.Errorf("unable to toggle %s", cmd)
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
vm.SetFloat(cmd[1:], 1-val)
|
vm.SetFloat(cmd, 1-val)
|
||||||
if verbose {
|
vPrinter.printf("Toggling %s", cmd)
|
||||||
fmt.Println("Toggling", cmd)
|
|
||||||
}
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func setCmd(vm *voicemeeter.Remote, cmd string, verbose bool) error {
|
func setCmd(vm *voicemeeter.Remote, cmd string) error {
|
||||||
if verbose {
|
vPrinter.printf("Running command %s", cmd)
|
||||||
fmt.Println("Running command", cmd)
|
|
||||||
}
|
|
||||||
err := vm.SendText(cmd)
|
err := vm.SendText(cmd)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
err = fmt.Errorf("unable to set %s", cmd)
|
err = fmt.Errorf("unable to set %s", cmd)
|
||||||
@@ -132,7 +160,7 @@ func setCmd(vm *voicemeeter.Remote, cmd string, verbose bool) error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func getCmd(vm *voicemeeter.Remote, cmd string, verbose bool) error {
|
func getCmd(vm *voicemeeter.Remote, cmd string) error {
|
||||||
valF, err := vm.GetFloat(cmd)
|
valF, err := vm.GetFloat(cmd)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
valS, err := vm.GetString(cmd)
|
valS, err := vm.GetString(cmd)
|
||||||
@@ -140,13 +168,9 @@ func getCmd(vm *voicemeeter.Remote, cmd string, verbose bool) error {
|
|||||||
err = fmt.Errorf("unable to get %s", cmd)
|
err = fmt.Errorf("unable to get %s", cmd)
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
if verbose {
|
vPrinter.printf("Value of %s is: %s", cmd, valS)
|
||||||
fmt.Println("Value of", cmd, "is:", valS)
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
if verbose {
|
vPrinter.printf("Value of %s is: %v", cmd, valF)
|
||||||
fmt.Println("Value of", cmd, "is:", valF)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|||||||
48
publisher.go
48
publisher.go
@@ -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,29 +53,35 @@ 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 {
|
||||||
case "pdirty":
|
switch event {
|
||||||
e.pdirty = true
|
case "pdirty":
|
||||||
case "mdirty":
|
e.pdirty = true
|
||||||
e.mdirty = true
|
case "mdirty":
|
||||||
case "midi":
|
e.mdirty = true
|
||||||
e.midi = true
|
case "midi":
|
||||||
case "ldirty":
|
e.midi = true
|
||||||
e.ldirty = true
|
case "ldirty":
|
||||||
|
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 {
|
||||||
case "pdirty":
|
switch event {
|
||||||
e.pdirty = false
|
case "pdirty":
|
||||||
case "mdirty":
|
e.pdirty = false
|
||||||
e.mdirty = false
|
case "mdirty":
|
||||||
case "midi":
|
e.mdirty = false
|
||||||
e.midi = false
|
case "midi":
|
||||||
case "ldirty":
|
e.midi = false
|
||||||
e.ldirty = false
|
case "ldirty":
|
||||||
|
e.ldirty = false
|
||||||
|
}
|
||||||
|
log.Info(event, " removed from the pooler")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
24
remote.go
24
remote.go
@@ -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
|
||||||
}
|
}
|
||||||
|
|||||||
44
strip.go
44
strip.go
@@ -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.
|
||||||
|
|||||||
21
vban.go
21
vban.go
@@ -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 {
|
||||||
|
|||||||
Reference in New Issue
Block a user