summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authornick87720z <nick87720z@gmail.com>2022-04-13 22:31:49 +0500
committerGitHub <noreply@github.com>2022-04-13 18:31:49 +0100
commit3a19b628f87ba4f092e252adfc54663e2448ed48 (patch)
tree232986ed6a192d1341d7bd14c8aeb092aa0c17ea
parentaa275762364b9d71c3bfca673e9c78df6d407aa9 (diff)
downloadjack2-3a19b628f87ba4f092e252adfc54663e2448ed48.tar.gz
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
-rwxr-xr-xdbus/jack_control230
1 files changed, 109 insertions, 121 deletions
diff --git a/dbus/jack_control b/dbus/jack_control
index 4dd2b2e4..818283ec 100755
--- a/dbus/jack_control
+++ b/dbus/jack_control
@@ -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, "")
+
+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
- return 0
+ 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())