live: pass our arguments through to the tuhi server
Any args that we don't handle in live mode directly (none right now) should be passed through to the tuhi server. Signed-off-by: Peter Hutterer <peter.hutterer@who-t.net>
This commit is contained in:
parent
cb72111910
commit
2cc9fc778f
|
@ -46,7 +46,7 @@ def open_uhid_process(queue_in, conn_out):
|
||||||
|
|
||||||
def maybe_start_tuhi(queue):
|
def maybe_start_tuhi(queue):
|
||||||
try:
|
try:
|
||||||
should_start, verbose = queue.get()
|
should_start, args = queue.get()
|
||||||
except KeyboardInterrupt:
|
except KeyboardInterrupt:
|
||||||
return 0
|
return 0
|
||||||
|
|
||||||
|
@ -62,9 +62,7 @@ def maybe_start_tuhi(queue):
|
||||||
# live mode. Instead we rely on tuhi-live to take us down when it exits
|
# live mode. Instead we rely on tuhi-live to take us down when it exits
|
||||||
signal.signal(signal.SIGINT, signal.SIG_IGN)
|
signal.signal(signal.SIGINT, signal.SIG_IGN)
|
||||||
|
|
||||||
args = ['tuhi-live'] # argparse in tuhi.base.main skips argv[0]
|
args = ['tuhi-live'] + args # argparse in tuhi.base.main skips argv[0]
|
||||||
if verbose:
|
|
||||||
args.append('--verbose')
|
|
||||||
|
|
||||||
tuhi.base.main(args)
|
tuhi.base.main(args)
|
||||||
|
|
||||||
|
@ -120,7 +118,7 @@ def start_tuhi_server(args):
|
||||||
if not started:
|
if not started:
|
||||||
print(f'No-one is handling {tuhi.dbusclient.TUHI_DBUS_NAME}, attempting to start a daemon')
|
print(f'No-one is handling {tuhi.dbusclient.TUHI_DBUS_NAME}, attempting to start a daemon')
|
||||||
|
|
||||||
queue.put((not started, args.verbose))
|
queue.put((not started, args))
|
||||||
|
|
||||||
|
|
||||||
def run_live(request_fd_queue, conn_fd):
|
def run_live(request_fd_queue, conn_fd):
|
||||||
|
@ -193,21 +191,16 @@ def drop_privileges():
|
||||||
|
|
||||||
|
|
||||||
def parse(args):
|
def parse(args):
|
||||||
desc = 'tool to start the live mode on all devices tuhi knows about'
|
parser = argparse.ArgumentParser(description='Tool to start live mode')
|
||||||
parser = argparse.ArgumentParser(description=desc)
|
ns, remaining_args = parser.parse_known_args(args[1:])
|
||||||
parser.add_argument('-v', '--verbose',
|
return ns, remaining_args
|
||||||
help='Show some debugging informations',
|
|
||||||
action='store_true',
|
|
||||||
default=False)
|
|
||||||
|
|
||||||
return parser.parse_args(args[1:])
|
|
||||||
|
|
||||||
|
|
||||||
def main(args=sys.argv):
|
def main(args=sys.argv):
|
||||||
if not os.geteuid() == 0:
|
if not os.geteuid() == 0:
|
||||||
sys.exit('Script must be run as root')
|
sys.exit('Script must be run as root')
|
||||||
|
|
||||||
args = parse(args)
|
our_args, remaining_args = parse(args)
|
||||||
|
|
||||||
request_fd_queue = multiprocessing.Queue()
|
request_fd_queue = multiprocessing.Queue()
|
||||||
conn_in, conn_out = multiprocessing.Pipe()
|
conn_in, conn_out = multiprocessing.Pipe()
|
||||||
|
@ -218,7 +211,7 @@ def main(args=sys.argv):
|
||||||
|
|
||||||
drop_privileges()
|
drop_privileges()
|
||||||
|
|
||||||
start_tuhi_server(args)
|
start_tuhi_server(remaining_args)
|
||||||
run_live(request_fd_queue, conn_in)
|
run_live(request_fd_queue, conn_in)
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue