jack_control - shell mode and update (#821)
* jack_control: move to tools for a while * jack_control: shell mode command This command runs loop, which executes commands from stdin until EOF (Ctrl+D in terminal). Command status is printed to stdout. * jack_control: optimize some functions * jack_control: unused function * jack_control: more informative message about dbus typesig error * jack_control: Fix shell mode I/O * restore jack_control path
This commit is contained in:
parent
aa27576236
commit
3a19b628f8
|
@ -5,6 +5,8 @@ name_base = 'org.jackaudio'
|
|||
control_interface_name = name_base + '.JackControl'
|
||||
configure_interface_name = name_base + '.Configure'
|
||||
service_name = name_base + '.service'
|
||||
control_iface = None
|
||||
configure_iface = None
|
||||
|
||||
import sys
|
||||
import os
|
||||
|
@ -13,33 +15,21 @@ from traceback import print_exc
|
|||
import dbus
|
||||
|
||||
def bool_convert(str_value):
|
||||
if str_value.lower() == "false":
|
||||
return False
|
||||
|
||||
if str_value.lower() == "off":
|
||||
return False
|
||||
|
||||
if str_value.lower() == "no":
|
||||
return False
|
||||
|
||||
if str_value == "0":
|
||||
return False
|
||||
|
||||
if str_value.lower() == "(null)":
|
||||
if str_value == "0" or str_value.lower() in ["false","off","no","(null)"]:
|
||||
return False
|
||||
|
||||
return bool(str_value)
|
||||
|
||||
def dbus_type_to_python_type(dbus_value):
|
||||
if type(dbus_value) == dbus.Boolean:
|
||||
t = type(dbus_value)
|
||||
if t == dbus.Boolean:
|
||||
return bool(dbus_value)
|
||||
if type(dbus_value) == dbus.Int32 or type(dbus_value) == dbus.UInt32:
|
||||
if t == dbus.Int32 or t == dbus.UInt32:
|
||||
return int(dbus_value)
|
||||
return dbus_value
|
||||
|
||||
def python_type_to_jackdbus_type(value, type_char):
|
||||
type_char = str(type_char)
|
||||
|
||||
if type_char == "b":
|
||||
return bool_convert(value);
|
||||
elif type_char == "y":
|
||||
|
@ -51,20 +41,6 @@ def python_type_to_jackdbus_type(value, type_char):
|
|||
|
||||
return value
|
||||
|
||||
def dbus_type_to_type_string(dbus_value):
|
||||
if type(dbus_value) == dbus.Boolean:
|
||||
return "bool"
|
||||
if type(dbus_value) == dbus.Int32:
|
||||
return "sint"
|
||||
if type(dbus_value) == dbus.UInt32:
|
||||
return "uint"
|
||||
if type(dbus_value) == dbus.Byte:
|
||||
return "char"
|
||||
if type(dbus_value) == dbus.String:
|
||||
return "str"
|
||||
|
||||
return None # throw exception here?
|
||||
|
||||
def dbus_typesig_to_type_string(type_char):
|
||||
type_char = str(type_char)
|
||||
if type_char == 'i':
|
||||
|
@ -78,7 +54,7 @@ def dbus_typesig_to_type_string(type_char):
|
|||
if type_char == 'b':
|
||||
return "bool"
|
||||
|
||||
print('shit')
|
||||
print('err: unknown dbus typesig "%s"' % type_char)
|
||||
return None # throw exception here?
|
||||
|
||||
def get_parameters(iface, path):
|
||||
|
@ -105,6 +81,7 @@ def get_parameters(iface, path):
|
|||
def print_help():
|
||||
print("Usage: %s [command] [command] ..." % os.path.basename(sys.argv[0]))
|
||||
print("Commands:")
|
||||
print(" shell - execute commands from stdin until End Of File (Ctrl+D in terminal)")
|
||||
print(" exit - exit jack dbus service (stops jack server if currently running)")
|
||||
print(" help - print this help text")
|
||||
print(" status - check whether jack server is started, return value is 0 if running and 1 otherwise")
|
||||
|
@ -151,34 +128,24 @@ def maybe_print_param_constraint(iface, param):
|
|||
for value in values:
|
||||
print(("%*s'%s' - %s" % (1 + max_len - len(str(value[0])), "", str(value[0]), str(value[1]))))
|
||||
|
||||
def main():
|
||||
if len(sys.argv) == 1 or sys.argv[1] in ["-h", "--help", "help"]:
|
||||
print_help()
|
||||
return 0
|
||||
|
||||
bus = dbus.SessionBus()
|
||||
|
||||
controller = bus.get_object(service_name, "/org/jackaudio/Controller")
|
||||
control_iface = dbus.Interface(controller, control_interface_name)
|
||||
configure_iface = dbus.Interface(controller, configure_interface_name)
|
||||
|
||||
def parse_argv(argv):
|
||||
global control_iface, configure_iface
|
||||
|
||||
# check arguments
|
||||
index = 1
|
||||
while index < len(sys.argv):
|
||||
arg = sys.argv[index]
|
||||
index = 0
|
||||
while index < len(argv):
|
||||
arg = argv[index]
|
||||
index += 1
|
||||
try:
|
||||
if arg == "exit":
|
||||
if arg == 'exit':
|
||||
print("--- exit")
|
||||
control_iface.Exit()
|
||||
elif arg == "status":
|
||||
elif arg == 'status':
|
||||
print("--- status")
|
||||
if control_iface.IsStarted():
|
||||
print("started")
|
||||
return 0
|
||||
return (0, "started")
|
||||
else:
|
||||
print("stopped")
|
||||
return 1
|
||||
return (1, "stoped")
|
||||
elif arg == 'start':
|
||||
print("--- start")
|
||||
control_iface.StartServer()
|
||||
|
@ -203,11 +170,10 @@ def main():
|
|||
isset, default, value = configure_iface.GetParameterValue(['engine', 'driver'])
|
||||
print(value)
|
||||
elif arg == 'ds':
|
||||
if index >= len(sys.argv):
|
||||
print("driver select command requires driver name argument")
|
||||
return 1
|
||||
if index >= len(argv):
|
||||
return (1, "driver select command requires driver name argument")
|
||||
|
||||
arg = sys.argv[index]
|
||||
arg = argv[index]
|
||||
index += 1
|
||||
|
||||
print("--- driver select \"%s\"" % arg)
|
||||
|
@ -216,11 +182,10 @@ def main():
|
|||
print("--- get driver parameters (type:isset:default:value)")
|
||||
get_parameters(configure_iface, ['driver'])
|
||||
elif arg == 'dpd':
|
||||
if index >= len(sys.argv):
|
||||
print("get driver parameter long description command requires parameter name argument")
|
||||
return 1
|
||||
if index >= len(argv):
|
||||
return (1, "get driver parameter long description command requires parameter name argument")
|
||||
|
||||
param = sys.argv[index]
|
||||
param = argv[index]
|
||||
index += 1
|
||||
|
||||
print("--- get driver parameter description (%s)" % param)
|
||||
|
@ -228,13 +193,12 @@ def main():
|
|||
print(long_descr)
|
||||
maybe_print_param_constraint(configure_iface, ['driver', param])
|
||||
elif arg == 'dps':
|
||||
if index + 1 >= len(sys.argv):
|
||||
print("driver parameter set command requires parameter name and value arguments")
|
||||
return 1
|
||||
if index + 1 >= len(argv):
|
||||
return (1, "driver parameter set command requires parameter name and value arguments")
|
||||
|
||||
param = sys.argv[index]
|
||||
param = argv[index]
|
||||
index += 1
|
||||
value = sys.argv[index]
|
||||
value = argv[index]
|
||||
index += 1
|
||||
|
||||
print("--- driver param set \"%s\" -> \"%s\"" % (param, value))
|
||||
|
@ -242,11 +206,10 @@ def main():
|
|||
type_char, name, short_descr, long_descr = configure_iface.GetParameterInfo(['driver', param])
|
||||
configure_iface.SetParameterValue(['driver', param], python_type_to_jackdbus_type(value, type_char))
|
||||
elif arg == 'dpr':
|
||||
if index >= len(sys.argv):
|
||||
print("driver parameter reset command requires parameter name argument")
|
||||
return 1
|
||||
if index >= len(argv):
|
||||
return (1, "driver parameter reset command requires parameter name argument")
|
||||
|
||||
param = sys.argv[index]
|
||||
param = argv[index]
|
||||
index += 1
|
||||
|
||||
print("--- driver param reset \"%s\"" % param)
|
||||
|
@ -255,11 +218,10 @@ def main():
|
|||
print("--- get engine parameters (type:isset:default:value)")
|
||||
get_parameters(configure_iface, ['engine'])
|
||||
elif arg == 'epd':
|
||||
if index >= len(sys.argv):
|
||||
print("get engine parameter long description command requires parameter name argument")
|
||||
return 1
|
||||
if index >= len(argv):
|
||||
return (1, "get engine parameter long description command requires parameter name argument")
|
||||
|
||||
param_name = sys.argv[index]
|
||||
param_name = argv[index]
|
||||
index += 1
|
||||
|
||||
print("--- get engine parameter description (%s)" % param_name)
|
||||
|
@ -268,13 +230,12 @@ def main():
|
|||
print(long_descr)
|
||||
maybe_print_param_constraint(configure_iface, ['engine', param_name])
|
||||
elif arg == 'eps':
|
||||
if index + 1 >= len(sys.argv):
|
||||
print("engine parameter set command requires parameter name and value arguments")
|
||||
return 1
|
||||
if index + 1 >= len(argv):
|
||||
return (1, "engine parameter set command requires parameter name and value arguments")
|
||||
|
||||
param = sys.argv[index]
|
||||
param = argv[index]
|
||||
index += 1
|
||||
value = sys.argv[index]
|
||||
value = argv[index]
|
||||
index += 1
|
||||
|
||||
print("--- engine param set \"%s\" -> \"%s\"" % (param, value))
|
||||
|
@ -282,11 +243,10 @@ def main():
|
|||
type_char, name, short_descr, long_descr = configure_iface.GetParameterInfo(['engine', param])
|
||||
configure_iface.SetParameterValue(['engine', param], python_type_to_jackdbus_type(value, type_char))
|
||||
elif arg == 'epr':
|
||||
if index >= len(sys.argv):
|
||||
print("engine parameter reset command requires parameter name")
|
||||
return 1
|
||||
if index >= len(argv):
|
||||
return (1, "engine parameter reset command requires parameter name")
|
||||
|
||||
param = sys.argv[index]
|
||||
param = argv[index]
|
||||
index += 1
|
||||
|
||||
print("--- engine param reset \"%s\"" % param)
|
||||
|
@ -301,37 +261,34 @@ def main():
|
|||
elif arg == 'ip':
|
||||
print("--- get internal parameters (type:isset:default:value)")
|
||||
|
||||
if index >= len(sys.argv):
|
||||
print("internal parameters command requires internal name argument")
|
||||
return 1
|
||||
if index >= len(argv):
|
||||
return (1, "internal parameters command requires internal name argument")
|
||||
|
||||
internal_name = sys.argv[index]
|
||||
internal_name = argv[index]
|
||||
index += 1
|
||||
|
||||
get_parameters(configure_iface, ['internals', internal_name])
|
||||
elif arg == 'ipd':
|
||||
if index + 1 >= len(sys.argv):
|
||||
print("get internal parameter long description command requires internal and parameter name arguments")
|
||||
return 1
|
||||
if index + 1 >= len(argv):
|
||||
return (1, "get internal parameter long description command requires internal and parameter name arguments")
|
||||
|
||||
name = sys.argv[index]
|
||||
name = argv[index]
|
||||
index += 1
|
||||
param = sys.argv[index]
|
||||
param = argv[index]
|
||||
index += 1
|
||||
|
||||
print("--- get internal parameter description (%s)" % param)
|
||||
type_char, name, short_descr, long_descr = configure_iface.GetParameterInfo(['internals', name, param])
|
||||
print(long_descr)
|
||||
elif arg == 'ips':
|
||||
if index + 2 >= len(sys.argv):
|
||||
print("internal parameter set command requires internal, parameter name and value arguments")
|
||||
return 1
|
||||
if index + 2 >= len(argv):
|
||||
return (1, "internal parameter set command requires internal, parameter name and value arguments")
|
||||
|
||||
internal_name = sys.argv[index]
|
||||
internal_name = argv[index]
|
||||
index += 1
|
||||
param = sys.argv[index]
|
||||
param = argv[index]
|
||||
index += 1
|
||||
value = sys.argv[index]
|
||||
value = argv[index]
|
||||
index += 1
|
||||
|
||||
print("--- internal param set \"%s\" -> \"%s\"" % (param, value))
|
||||
|
@ -339,13 +296,12 @@ def main():
|
|||
type_char, name, short_descr, long_descr = configure_iface.GetParameterInfo(['internals', internal_name, param])
|
||||
configure_iface.SetParameterValue(['internals', internal_name, param], python_type_to_jackdbus_type(value, type_char))
|
||||
elif arg == 'ipr':
|
||||
if index + 1 >= len(sys.argv):
|
||||
print("reset internal parameter command requires internal and parameter name arguments")
|
||||
return 1
|
||||
if index + 1 >= len(argv):
|
||||
return (1, "reset internal parameter command requires internal and parameter name arguments")
|
||||
|
||||
internal_name = sys.argv[index]
|
||||
internal_name = argv[index]
|
||||
index += 1
|
||||
param = sys.argv[index]
|
||||
param = argv[index]
|
||||
index += 1
|
||||
|
||||
print("--- internal param reset \"%s\"" % param)
|
||||
|
@ -354,50 +310,82 @@ def main():
|
|||
elif arg == 'iload':
|
||||
print("--- load internal")
|
||||
|
||||
if index >= len(sys.argv):
|
||||
print("load internal command requires internal name argument")
|
||||
return 1
|
||||
if index >= len(argv):
|
||||
return (1, "load internal command requires internal name argument")
|
||||
|
||||
name = sys.argv[index]
|
||||
name = argv[index]
|
||||
index += 1
|
||||
result = control_iface.LoadInternal(name)
|
||||
elif arg == 'iunload':
|
||||
print("--- unload internal")
|
||||
|
||||
if index >= len(sys.argv):
|
||||
print("unload internal command requires internal name argument")
|
||||
return 1
|
||||
if index >= len(argv):
|
||||
return (1, "unload internal command requires internal name argument")
|
||||
|
||||
name = sys.argv[index]
|
||||
name = argv[index]
|
||||
index += 1
|
||||
result = control_iface.UnloadInternal(name)
|
||||
elif arg == 'asd':
|
||||
print("--- add slave driver")
|
||||
|
||||
if index >= len(sys.argv):
|
||||
print("add slave driver command requires driver name argument")
|
||||
return 1
|
||||
if index >= len(argv):
|
||||
return (1, "add slave driver command requires driver name argument")
|
||||
|
||||
name = sys.argv[index]
|
||||
name = argv[index]
|
||||
index += 1
|
||||
result = control_iface.AddSlaveDriver(name)
|
||||
elif arg == 'rsd':
|
||||
print("--- remove slave driver")
|
||||
|
||||
if index >= len(sys.argv):
|
||||
print("remove slave driver command requires driver name argument")
|
||||
return 1
|
||||
if index >= len(argv):
|
||||
return (1, "remove slave driver command requires driver name argument")
|
||||
|
||||
name = sys.argv[index]
|
||||
name = argv[index]
|
||||
index += 1
|
||||
result = control_iface.RemoveSlaveDriver(name)
|
||||
elif arg == 'help':
|
||||
print_help()
|
||||
else:
|
||||
print("Unknown command '%s'" % arg)
|
||||
return (0, "Unknown command '%s'" % arg)
|
||||
except dbus.DBusException as e:
|
||||
print("DBus exception: %s" % str(e))
|
||||
return 1
|
||||
return (1, "DBus exception: %s" % str(e))
|
||||
|
||||
return (0, "")
|
||||
|
||||
return 0
|
||||
def shell():
|
||||
from click.parser import split_arg_string
|
||||
from sys import stdin
|
||||
while True:
|
||||
try:
|
||||
cmd = stdin.readline()
|
||||
if (cmd == ''):
|
||||
break
|
||||
s,t = parse_argv(split_arg_string(cmd))
|
||||
print("%i: %s" % (s, t), flush=True)
|
||||
except:
|
||||
break
|
||||
|
||||
def main():
|
||||
global control_iface, configure_iface
|
||||
|
||||
if len(sys.argv) == 1 or sys.argv[1] in ["-h", "--help"]:
|
||||
print_help()
|
||||
return 0
|
||||
|
||||
bus = dbus.SessionBus()
|
||||
controller = bus.get_object(service_name, "/org/jackaudio/Controller")
|
||||
|
||||
control_iface = dbus.Interface(controller, control_interface_name)
|
||||
configure_iface = dbus.Interface(controller, configure_interface_name)
|
||||
|
||||
# check arguments
|
||||
if sys.argv[1] == "shell":
|
||||
shell()
|
||||
else:
|
||||
s, t = parse_argv(sys.argv[1:])
|
||||
if (t):
|
||||
print(t)
|
||||
return s
|
||||
|
||||
if __name__ == '__main__':
|
||||
sys.exit(main())
|
||||
|
|
Loading…
Reference in New Issue