Argparse update and IPC events
This commit is contained in:
parent
35cf150fbc
commit
9f1da21127
@ -1,5 +1,5 @@
|
|||||||
# Python imports
|
# Python imports
|
||||||
import inspect, time
|
import os, inspect, time
|
||||||
|
|
||||||
# Gtk imports
|
# Gtk imports
|
||||||
|
|
||||||
@ -10,19 +10,27 @@ from __builtins__ import Builtins
|
|||||||
|
|
||||||
|
|
||||||
class Main(Builtins):
|
class Main(Builtins):
|
||||||
def __init__(self, args):
|
def __init__(self, args, unknownargs):
|
||||||
event_system.create_ipc_server()
|
event_system.create_ipc_server()
|
||||||
time.sleep(0.5)
|
time.sleep(0.5)
|
||||||
if not event_system.is_ipc_alive:
|
if not event_system.is_ipc_alive:
|
||||||
if args.new_tab:
|
if unknownargs:
|
||||||
|
for arg in unknownargs:
|
||||||
|
if os.path.isdir(arg):
|
||||||
|
message = f"FILE|{arg}"
|
||||||
|
event_system.send_ipc_message(message)
|
||||||
|
|
||||||
|
if args.new_tab and os.path.isdir(args.new_tab):
|
||||||
message = f"FILE|{args.new_tab}"
|
message = f"FILE|{args.new_tab}"
|
||||||
event_system.send_ipc_message(message)
|
event_system.send_ipc_message(message)
|
||||||
raise Exception("IPC Server Exists: Will send message to it and close...")
|
|
||||||
|
raise Exception("IPC Server Exists: Will send path(s) to it and close...")
|
||||||
|
|
||||||
|
|
||||||
settings = Settings()
|
settings = Settings()
|
||||||
settings.createWindow()
|
settings.createWindow()
|
||||||
|
|
||||||
signals = Signals(args, settings)
|
signals = Signals(args, unknownargs, settings)
|
||||||
if not signals:
|
if not signals:
|
||||||
raise Exception("Signals exited...")
|
raise Exception("Signals exited...")
|
||||||
|
|
||||||
@ -39,4 +47,3 @@ class Main(Builtins):
|
|||||||
pass
|
pass
|
||||||
|
|
||||||
settings.builder.connect_signals(handlers)
|
settings.builder.connect_signals(handlers)
|
||||||
window = settings.createWindow()
|
|
||||||
|
@ -24,12 +24,13 @@ if __name__ == "__main__":
|
|||||||
faulthandler.enable() # For better debug info
|
faulthandler.enable() # For better debug info
|
||||||
parser = argparse.ArgumentParser()
|
parser = argparse.ArgumentParser()
|
||||||
# Add long and short arguments
|
# Add long and short arguments
|
||||||
parser.add_argument("--new-tab", "-t", help="Open a file into new tab.")
|
parser.add_argument("--new-tab", "-t", default="", help="Open a file into new tab.")
|
||||||
parser.add_argument("--new-window", "-w", help="Open a file into a new window.")
|
parser.add_argument("--new-window", "-w", default="", help="Open a file into a new window.")
|
||||||
|
|
||||||
# Read arguments (If any...)
|
# Read arguments (If any...)
|
||||||
args = parser.parse_args()
|
args, unknownargs = parser.parse_known_args()
|
||||||
Main(args)
|
|
||||||
|
Main(args, unknownargs)
|
||||||
Gtk.main()
|
Gtk.main()
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
event_system.keep_ipc_alive = False
|
event_system.keep_ipc_alive = False
|
||||||
|
@ -24,11 +24,14 @@ class DBusControllerMixin:
|
|||||||
print(f"New Connection: {listener.last_accepted}")
|
print(f"New Connection: {listener.last_accepted}")
|
||||||
while True:
|
while True:
|
||||||
msg = conn.recv()
|
msg = conn.recv()
|
||||||
|
if debug:
|
||||||
print(msg)
|
print(msg)
|
||||||
|
|
||||||
if "FILE|" in msg:
|
if "FILE|" in msg:
|
||||||
file = msg.split("FILE|")[1].strip()
|
file = msg.split("FILE|")[1].strip()
|
||||||
|
if file:
|
||||||
event_system.push_gui_event(["create_tab_from_ipc", None, file])
|
event_system.push_gui_event(["create_tab_from_ipc", None, file])
|
||||||
|
|
||||||
conn.close()
|
conn.close()
|
||||||
break
|
break
|
||||||
|
|
||||||
|
@ -21,7 +21,7 @@ def threaded(fn):
|
|||||||
|
|
||||||
|
|
||||||
class Signals(WidgetFileActionMixin, PaneMixin, WindowMixin):
|
class Signals(WidgetFileActionMixin, PaneMixin, WindowMixin):
|
||||||
def __init__(self, args, settings):
|
def __init__(self, args, unknownargs, settings):
|
||||||
self.settings = settings
|
self.settings = settings
|
||||||
self.builder = self.settings.builder
|
self.builder = self.settings.builder
|
||||||
self.logger = self.settings.logger
|
self.logger = self.settings.logger
|
||||||
@ -30,10 +30,10 @@ class Signals(WidgetFileActionMixin, PaneMixin, WindowMixin):
|
|||||||
self.state = self.window_controller.load_state()
|
self.state = self.window_controller.load_state()
|
||||||
|
|
||||||
self.window = self.settings.getMainWindow()
|
self.window = self.settings.getMainWindow()
|
||||||
self.window1 = self.builder.get_object("window1")
|
self.window1 = self.builder.get_object("window_1")
|
||||||
self.window2 = self.builder.get_object("window2")
|
self.window2 = self.builder.get_object("window_2")
|
||||||
self.window3 = self.builder.get_object("window3")
|
self.window3 = self.builder.get_object("window_3")
|
||||||
self.window4 = self.builder.get_object("window4")
|
self.window4 = self.builder.get_object("window_4")
|
||||||
self.notebooks = [self.window1, self.window2, self.window3, self.window4]
|
self.notebooks = [self.window1, self.window2, self.window3, self.window4]
|
||||||
self.selected_files = []
|
self.selected_files = []
|
||||||
self.to_copy_files = []
|
self.to_copy_files = []
|
||||||
@ -56,10 +56,21 @@ class Signals(WidgetFileActionMixin, PaneMixin, WindowMixin):
|
|||||||
GLib.unix_signal_add(GLib.PRIORITY_DEFAULT, signal.SIGINT, self.tear_down)
|
GLib.unix_signal_add(GLib.PRIORITY_DEFAULT, signal.SIGINT, self.tear_down)
|
||||||
self.gui_event_observer()
|
self.gui_event_observer()
|
||||||
|
|
||||||
|
if unknownargs:
|
||||||
|
for arg in unknownargs:
|
||||||
|
if os.path.isdir(arg):
|
||||||
|
message = f"FILE|{arg}"
|
||||||
|
event_system.send_ipc_message(message)
|
||||||
|
|
||||||
|
if args.new_tab and os.path.isdir(args.new_tab):
|
||||||
|
message = f"FILE|{args.new_tab}"
|
||||||
|
event_system.send_ipc_message(message)
|
||||||
|
|
||||||
|
|
||||||
def tear_down(self, widget=None, eve=None):
|
def tear_down(self, widget=None, eve=None):
|
||||||
self.window_controller.save_state()
|
self.window_controller.save_state()
|
||||||
event_system.send_ipc_message("close server")
|
|
||||||
event_system.monitor_events = False
|
event_system.monitor_events = False
|
||||||
|
event_system.send_ipc_message("close server")
|
||||||
time.sleep(event_sleep_time)
|
time.sleep(event_sleep_time)
|
||||||
Gtk.main_quit()
|
Gtk.main_quit()
|
||||||
|
|
||||||
|
@ -11,8 +11,14 @@ class TabMixin(WidgetMixin):
|
|||||||
|
|
||||||
def create_tab_from_ipc(data):
|
def create_tab_from_ipc(data):
|
||||||
self, path = data
|
self, path = data
|
||||||
wid, tid = self.window_controller.get_active_data()
|
if not self.is_pane1_hidden:
|
||||||
self.create_tab(wid, path)
|
self.create_tab(1, path)
|
||||||
|
elif not self.is_pane2_hidden:
|
||||||
|
self.create_tab(2, path)
|
||||||
|
elif not self.is_pane3_hidden:
|
||||||
|
self.create_tab(3, path)
|
||||||
|
elif not self.is_pane4_hidden:
|
||||||
|
self.create_tab(4, path)
|
||||||
|
|
||||||
|
|
||||||
def create_tab(self, wid, path=None):
|
def create_tab(self, wid, path=None):
|
||||||
|
Loading…
Reference in New Issue
Block a user