Refactoring stuff
This commit is contained in:
parent
8c69cdebe5
commit
cbf5706845
@ -4,11 +4,16 @@
|
|||||||
SolarFM is a Gtk+ Python file manager.
|
SolarFM is a Gtk+ Python file manager.
|
||||||
|
|
||||||
# Notes
|
# Notes
|
||||||
```sudo apt-get install python3 wget ffmpegthumbnailer steamcmd```
|
<b>Still Work in progress! Use at own risk!</b>
|
||||||
|
|
||||||
|
<h6>Install Setup</h6>
|
||||||
|
```
|
||||||
|
sudo apt-get install python3 wget ffmpegthumbnailer steamcmd
|
||||||
|
```
|
||||||
|
|
||||||
# TODO
|
# TODO
|
||||||
<ul>
|
<ul>
|
||||||
<li>Add prompt guards for actions.</li>
|
<li><b>Fix the wonky file handler situation and add prompt guards for actions.</b></li>
|
||||||
<li>Add path bar search dropdown.</li>
|
<li>Add path bar search dropdown.</li>
|
||||||
<li>Add "clear trash", "restore from trash" options.</li>
|
<li>Add "clear trash", "restore from trash" options.</li>
|
||||||
<li>Add drive size free and consumed info to bottom bar.</li>
|
<li>Add drive size free and consumed info to bottom bar.</li>
|
||||||
|
@ -35,9 +35,16 @@ class Launcher:
|
|||||||
else:
|
else:
|
||||||
command = ["xdg-open", file]
|
command = ["xdg-open", file]
|
||||||
|
|
||||||
|
self.execute(command)
|
||||||
|
|
||||||
|
|
||||||
|
def execute(self, command, start_dir=os.getenv("HOME"), use_os_system=None):
|
||||||
self.logger.debug(command)
|
self.logger.debug(command)
|
||||||
|
if use_os_system:
|
||||||
|
os.system(command)
|
||||||
|
else:
|
||||||
DEVNULL = open(os.devnull, 'w')
|
DEVNULL = open(os.devnull, 'w')
|
||||||
subprocess.Popen(command, start_new_session=True, stdout=DEVNULL, stderr=DEVNULL, close_fds=True)
|
subprocess.Popen(command, cwd=start_dir, shell=False, start_new_session=True, stdout=DEVNULL, stderr=DEVNULL, close_fds=True)
|
||||||
|
|
||||||
|
|
||||||
def remux_video(self, hash, file):
|
def remux_video(self, hash, file):
|
||||||
|
@ -21,7 +21,7 @@ def threaded(fn):
|
|||||||
class Controller(Controller_Data, ShowHideMixin, KeyboardSignalsMixin, \
|
class Controller(Controller_Data, ShowHideMixin, KeyboardSignalsMixin, \
|
||||||
WidgetFileActionMixin, PaneMixin, WindowMixin):
|
WidgetFileActionMixin, PaneMixin, WindowMixin):
|
||||||
def __init__(self, args, unknownargs, _settings):
|
def __init__(self, args, unknownargs, _settings):
|
||||||
sys.excepthook = self.my_except_hook
|
# sys.excepthook = self.custom_except_hook
|
||||||
self.settings = _settings
|
self.settings = _settings
|
||||||
self.setup_controller_data()
|
self.setup_controller_data()
|
||||||
|
|
||||||
@ -65,7 +65,7 @@ class Controller(Controller_Data, ShowHideMixin, KeyboardSignalsMixin, \
|
|||||||
print(repr(e))
|
print(repr(e))
|
||||||
|
|
||||||
|
|
||||||
def my_except_hook(self, exctype, value, _traceback):
|
def custom_except_hook(self, exctype, value, _traceback):
|
||||||
trace = ''.join(traceback.format_tb(_traceback))
|
trace = ''.join(traceback.format_tb(_traceback))
|
||||||
data = f"Exectype: {exctype} <--> Value: {value}\n\n{trace}\n\n\n\n"
|
data = f"Exectype: {exctype} <--> Value: {value}\n\n{trace}\n\n\n\n"
|
||||||
start_itr = self.message_buffer.get_start_iter()
|
start_itr = self.message_buffer.get_start_iter()
|
||||||
@ -104,22 +104,12 @@ class Controller(Controller_Data, ShowHideMixin, KeyboardSignalsMixin, \
|
|||||||
save_location_prompt.destroy()
|
save_location_prompt.destroy()
|
||||||
|
|
||||||
|
|
||||||
def do_edit_files(self, widget=None, eve=None):
|
|
||||||
self.to_rename_files = self.selected_files
|
|
||||||
self.rename_files()
|
|
||||||
|
|
||||||
def set_arc_buffer_text(self, widget=None, eve=None):
|
def set_arc_buffer_text(self, widget=None, eve=None):
|
||||||
id = widget.get_active_id()
|
id = widget.get_active_id()
|
||||||
self.arc_command_buffer.set_text(self.arc_commands[int(id)])
|
self.arc_command_buffer.set_text(self.arc_commands[int(id)])
|
||||||
|
|
||||||
|
|
||||||
def execute(self, _command, start_dir=os.getenv("HOME"), use_os_system=None):
|
|
||||||
if use_os_system:
|
|
||||||
os.system(_command)
|
|
||||||
else:
|
|
||||||
DEVNULL = open(os.devnull, 'w')
|
|
||||||
command = _command.split()
|
|
||||||
subprocess.Popen(command, cwd=start_dir, shell=False, start_new_session=True, stdout=DEVNULL, stderr=DEVNULL)
|
|
||||||
|
|
||||||
def do_action_from_menu_controls(self, widget, eventbutton):
|
def do_action_from_menu_controls(self, widget, eventbutton):
|
||||||
action = widget.get_name()
|
action = widget.get_name()
|
||||||
@ -128,15 +118,14 @@ class Controller(Controller_Data, ShowHideMixin, KeyboardSignalsMixin, \
|
|||||||
self.hide_new_file_menu()
|
self.hide_new_file_menu()
|
||||||
self.hide_edit_file_menu()
|
self.hide_edit_file_menu()
|
||||||
|
|
||||||
|
if action == "open":
|
||||||
|
self.open_files()
|
||||||
|
if action == "open_with":
|
||||||
|
self.show_appchooser_menu()
|
||||||
if action == "execute":
|
if action == "execute":
|
||||||
self.execute_files()
|
self.execute_files()
|
||||||
if action == "execute_in_terminal":
|
if action == "execute_in_terminal":
|
||||||
self.execute_files(in_terminal=True)
|
self.execute_files(in_terminal=True)
|
||||||
if action == "create":
|
|
||||||
self.create_file()
|
|
||||||
self.hide_new_file_menu()
|
|
||||||
if action == "open":
|
|
||||||
self.open_files()
|
|
||||||
if action == "rename":
|
if action == "rename":
|
||||||
self.to_rename_files = self.selected_files
|
self.to_rename_files = self.selected_files
|
||||||
self.rename_files()
|
self.rename_files()
|
||||||
@ -157,6 +146,11 @@ class Controller(Controller_Data, ShowHideMixin, KeyboardSignalsMixin, \
|
|||||||
if action == "go_to_trash":
|
if action == "go_to_trash":
|
||||||
self.builder.get_object("path_entry").set_text(self.trash_files_path)
|
self.builder.get_object("path_entry").set_text(self.trash_files_path)
|
||||||
|
|
||||||
|
|
||||||
|
if action == "create":
|
||||||
|
self.create_file()
|
||||||
|
self.hide_new_file_menu()
|
||||||
|
|
||||||
self.ctrlDown = False
|
self.ctrlDown = False
|
||||||
|
|
||||||
|
|
||||||
|
@ -78,4 +78,4 @@ class KeyboardSignalsMixin:
|
|||||||
wid, tid = self.window_controller.get_active_data()
|
wid, tid = self.window_controller.get_active_data()
|
||||||
view = self.get_fm_window(wid).get_view_by_id(tid)
|
view = self.get_fm_window(wid).get_view_by_id(tid)
|
||||||
dir = view.get_current_directory()
|
dir = view.get_current_directory()
|
||||||
self.execute("terminator", dir)
|
view.execute(f"{view.terminal_app}", dir)
|
||||||
|
@ -106,7 +106,7 @@ class ShowHideMixin:
|
|||||||
name = widget.get_name()
|
name = widget.get_name()
|
||||||
if name == "rename":
|
if name == "rename":
|
||||||
self.builder.get_object("edit_file_menu").hide()
|
self.builder.get_object("edit_file_menu").hide()
|
||||||
|
else:
|
||||||
keyname = Gdk.keyval_name(eve.keyval).lower()
|
keyname = Gdk.keyval_name(eve.keyval).lower()
|
||||||
if "return" in keyname or "enter" in keyname:
|
if "return" in keyname or "enter" in keyname:
|
||||||
self.builder.get_object("edit_file_menu").hide()
|
self.builder.get_object("edit_file_menu").hide()
|
||||||
|
@ -52,28 +52,6 @@ class WidgetFileActionMixin:
|
|||||||
tab_label.set_label(view.get_end_of_path())
|
tab_label.set_label(view.get_end_of_path())
|
||||||
self.set_bottom_labels(view)
|
self.set_bottom_labels(view)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
def create_file(self):
|
|
||||||
fname_field = self.builder.get_object("context_menu_fname")
|
|
||||||
file_name = fname_field.get_text().strip()
|
|
||||||
type = self.builder.get_object("context_menu_type_toggle").get_state()
|
|
||||||
|
|
||||||
wid, tid = self.window_controller.get_active_data()
|
|
||||||
view = self.get_fm_window(wid).get_view_by_id(tid)
|
|
||||||
target = f"{view.get_current_directory()}"
|
|
||||||
|
|
||||||
if file_name:
|
|
||||||
file_name = "file://" + target + "/" + file_name
|
|
||||||
if type == True: # Create File
|
|
||||||
self.handle_file([file_name], "create_file")
|
|
||||||
else: # Create Folder
|
|
||||||
self.handle_file([file_name], "create_dir")
|
|
||||||
|
|
||||||
fname_field.set_text("")
|
|
||||||
|
|
||||||
|
|
||||||
def get_current_state(self):
|
def get_current_state(self):
|
||||||
wid, tid = self.window_controller.get_active_data()
|
wid, tid = self.window_controller.get_active_data()
|
||||||
view = self.get_fm_window(wid).get_view_by_id(tid)
|
view = self.get_fm_window(wid).get_view_by_id(tid)
|
||||||
@ -81,15 +59,7 @@ class WidgetFileActionMixin:
|
|||||||
store = iconview.get_model()
|
store = iconview.get_model()
|
||||||
return wid, tid, view, iconview, store
|
return wid, tid, view, iconview, store
|
||||||
|
|
||||||
def execute_files(self, in_terminal=False):
|
|
||||||
wid, tid, view, iconview, store = self.get_current_state()
|
|
||||||
paths = self.format_to_uris(store, wid, tid, self.selected_files, True)
|
|
||||||
current_dir = view.get_current_directory()
|
|
||||||
command = None
|
|
||||||
|
|
||||||
for path in paths:
|
|
||||||
command = f"sh -c '{path}'" if not in_terminal else f"{view.terminal_app} -e '{path}'"
|
|
||||||
self.execute(command, current_dir)
|
|
||||||
|
|
||||||
|
|
||||||
def open_files(self):
|
def open_files(self):
|
||||||
@ -107,6 +77,26 @@ class WidgetFileActionMixin:
|
|||||||
|
|
||||||
app_info.launch([file], None)
|
app_info.launch([file], None)
|
||||||
|
|
||||||
|
def execute_files(self, in_terminal=False):
|
||||||
|
wid, tid, view, iconview, store = self.get_current_state()
|
||||||
|
paths = self.format_to_uris(store, wid, tid, self.selected_files, True)
|
||||||
|
current_dir = view.get_current_directory()
|
||||||
|
command = None
|
||||||
|
|
||||||
|
for path in paths:
|
||||||
|
command = f"sh -c '{path}'" if not in_terminal else f"{view.terminal_app} -e '{path}'"
|
||||||
|
view.execute(command.split(), current_dir)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
##################################################################################################
|
||||||
|
|
||||||
|
# NOTE: Everything below is trash and needs yet another rewrite because it doesn't work properly.
|
||||||
|
|
||||||
|
##################################################################################################
|
||||||
|
|
||||||
def rename_files(self):
|
def rename_files(self):
|
||||||
rename_label = self.builder.get_object("file_to_rename_label")
|
rename_label = self.builder.get_object("file_to_rename_label")
|
||||||
rename_input = self.builder.get_object("new_rename_fname")
|
rename_input = self.builder.get_object("new_rename_fname")
|
||||||
@ -143,21 +133,6 @@ class WidgetFileActionMixin:
|
|||||||
self.hide_new_file_menu()
|
self.hide_new_file_menu()
|
||||||
self.to_rename_files.clear()
|
self.to_rename_files.clear()
|
||||||
|
|
||||||
def archive_files(self, archiver_dialogue):
|
|
||||||
wid, tid, view, iconview, store = self.get_current_state()
|
|
||||||
paths = self.format_to_uris(store, wid, tid, self.selected_files)
|
|
||||||
|
|
||||||
save_target = archiver_dialogue.get_filename();
|
|
||||||
start_itr, end_itr = self.arc_command_buffer.get_bounds()
|
|
||||||
command = self.arc_command_buffer.get_text(start_itr, end_itr, False)
|
|
||||||
|
|
||||||
command = command.replace("%o", save_target)
|
|
||||||
command = command.replace("%N", ' '.join(paths))
|
|
||||||
final_command = f"terminator -e '{command}'"
|
|
||||||
self.execute(final_command, start_dir=None, use_os_system=True)
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
def cut_files(self):
|
def cut_files(self):
|
||||||
wid, tid, view, iconview, store = self.get_current_state()
|
wid, tid, view, iconview, store = self.get_current_state()
|
||||||
uris = self.format_to_uris(store, wid, tid, self.selected_files)
|
uris = self.format_to_uris(store, wid, tid, self.selected_files)
|
||||||
@ -180,11 +155,18 @@ class WidgetFileActionMixin:
|
|||||||
elif len(self.to_cut_files) > 0:
|
elif len(self.to_cut_files) > 0:
|
||||||
self.handle_file(self.to_cut_files, "move", target)
|
self.handle_file(self.to_cut_files, "move", target)
|
||||||
|
|
||||||
|
def archive_files(self, archiver_dialogue):
|
||||||
|
wid, tid, view, iconview, store = self.get_current_state()
|
||||||
|
paths = self.format_to_uris(store, wid, tid, self.selected_files)
|
||||||
|
|
||||||
|
save_target = archiver_dialogue.get_filename();
|
||||||
|
start_itr, end_itr = self.arc_command_buffer.get_bounds()
|
||||||
|
command = self.arc_command_buffer.get_text(start_itr, end_itr, False)
|
||||||
|
|
||||||
|
command = command.replace("%o", save_target)
|
||||||
def move_files(self, files, target):
|
command = command.replace("%N", ' '.join(paths))
|
||||||
self.handle_file(files, "move", target)
|
final_command = f"terminator -e '{command}'"
|
||||||
|
self.execute(final_command, start_dir=None, use_os_system=True)
|
||||||
|
|
||||||
def delete_files(self):
|
def delete_files(self):
|
||||||
wid, tid, view, iconview, store = self.get_current_state()
|
wid, tid, view, iconview, store = self.get_current_state()
|
||||||
@ -199,6 +181,27 @@ class WidgetFileActionMixin:
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
def create_file(self):
|
||||||
|
fname_field = self.builder.get_object("context_menu_fname")
|
||||||
|
file_name = fname_field.get_text().strip()
|
||||||
|
type = self.builder.get_object("context_menu_type_toggle").get_state()
|
||||||
|
|
||||||
|
wid, tid = self.window_controller.get_active_data()
|
||||||
|
view = self.get_fm_window(wid).get_view_by_id(tid)
|
||||||
|
target = f"{view.get_current_directory()}"
|
||||||
|
|
||||||
|
if file_name:
|
||||||
|
file_name = "file://" + target + "/" + file_name
|
||||||
|
if type == True: # Create File
|
||||||
|
self.handle_file([file_name], "create_file")
|
||||||
|
else: # Create Folder
|
||||||
|
self.handle_file([file_name], "create_dir")
|
||||||
|
|
||||||
|
fname_field.set_text("")
|
||||||
|
|
||||||
|
def move_files(self, files, target):
|
||||||
|
self.handle_file(files, "move", target)
|
||||||
|
|
||||||
# NOTE: While not fully race condition proof, we happy path it first
|
# NOTE: While not fully race condition proof, we happy path it first
|
||||||
# and then handle anything after as a conflict for renaming before
|
# and then handle anything after as a conflict for renaming before
|
||||||
# copy, move, or edit. This is literally the oppopsite of what Gtk says to do.
|
# copy, move, or edit. This is literally the oppopsite of what Gtk says to do.
|
||||||
|
Loading…
Reference in New Issue
Block a user