diff --git a/src/versions/solarfm-0.0.1/SolarFM/solarfm/__builtins__.py b/src/versions/solarfm-0.0.1/SolarFM/solarfm/__builtins__.py
index 9f24355..bd0a892 100644
--- a/src/versions/solarfm-0.0.1/SolarFM/solarfm/__builtins__.py
+++ b/src/versions/solarfm-0.0.1/SolarFM/solarfm/__builtins__.py
@@ -26,41 +26,41 @@ class EventSystem(IPCServer):
# Makeshift fake "events" type system FIFO
- def _pop_gui_event(self):
+ def _pop_gui_event(self) -> None:
if len(self._gui_events) > 0:
return self._gui_events.pop(0)
return None
- def _pop_module_event(self):
+ def _pop_module_event(self) -> None:
if len(self._module_events) > 0:
return self._module_events.pop(0)
return None
- def push_gui_event(self, event):
+ def push_gui_event(self, eventevent: list) -> None:
if len(event) == 3:
self._gui_events.append(event)
return None
raise Exception("Invald event format! Please do: [type, target, (data,)]")
- def push_module_event(self, event):
+ def push_module_event(self, event: list) -> None:
if len(event) == 3:
self._module_events.append(event)
return None
raise Exception("Invald event format! Please do: [type, target, (data,)]")
- def read_gui_event(self):
+ def read_gui_event(self) -> list:
return self._gui_events[0]
- def read_module_event(self):
+ def read_module_event(self) -> list:
return self._module_events[0]
- def consume_gui_event(self):
+ def consume_gui_event(self) -> list:
return self._pop_gui_event()
- def consume_module_event(self):
+ def consume_module_event(self) -> list:
return self._pop_module_event()
@@ -70,5 +70,5 @@ class EventSystem(IPCServer):
builtins.app_name = "SolarFM"
builtins.event_system = EventSystem()
builtins.event_sleep_time = 0.2
-builtins.debug = False
builtins.trace_debug = False
+builtins.debug = False
diff --git a/src/versions/solarfm-0.0.1/SolarFM/solarfm/context/controller_data.py b/src/versions/solarfm-0.0.1/SolarFM/solarfm/context/controller_data.py
index fe4be1e..12437a8 100644
--- a/src/versions/solarfm-0.0.1/SolarFM/solarfm/context/controller_data.py
+++ b/src/versions/solarfm-0.0.1/SolarFM/solarfm/context/controller_data.py
@@ -2,6 +2,7 @@
import sys, os, signal
# Lib imports
+import gi
from gi.repository import GLib
# Application imports
@@ -11,17 +12,17 @@ from plugins.plugins import Plugins
class State:
- wid = None
- tid = None
- tab = None
- icon_grid = None
- store = None
+ wid: int = None
+ tid: int = None
+ tab: type = None
+ icon_grid: gi.overrides.Gtk.IconView = None
+ store: gi.overrides.Gtk.ListStore = None
class Controller_Data:
""" Controller_Data contains most of the state of the app at ay given time. It also has some support methods. """
- def setup_controller_data(self, _settings):
+ def setup_controller_data(self, _settings: type) -> None:
self.settings = _settings
self.builder = self.settings.get_builder()
self.logger = self.settings.get_logger()
@@ -58,6 +59,7 @@ class Controller_Data:
self.trash_files_path = f"{GLib.get_user_data_dir()}/Trash/files"
self.trash_info_path = f"{GLib.get_user_data_dir()}/Trash/info"
+ self.icon_theme = self.settings.get_icon_theme()
# In compress commands:
# %n: First selected filename/dir to archive
@@ -117,7 +119,7 @@ class Controller_Data:
GLib.unix_signal_add(GLib.PRIORITY_DEFAULT, signal.SIGINT, self.tear_down)
- def get_current_state(self):
+ def get_current_state(self) -> State:
'''
Returns the state info most useful for any given context and action intent.
@@ -132,14 +134,15 @@ class Controller_Data:
state.tab = self.get_fm_window(state.wid).get_tab_by_id(state.tid)
state.icon_grid = self.builder.get_object(f"{state.wid}|{state.tid}|icon_grid")
state.store = state.icon_grid.get_model()
+
return state
- def clear_console(self):
+ def clear_console(self) -> None:
''' Clears the terminal screen. '''
os.system('cls' if os.name == 'nt' else 'clear')
- def call_method(self, _method_name, data = None):
+ def call_method(self, _method_name: str, data: type = None) -> type:
'''
Calls a method from scope of class.
@@ -156,11 +159,11 @@ class Controller_Data:
method = getattr(self, method_name, lambda data: f"No valid key passed...\nkey={method_name}\nargs={data}")
return method(data) if data else method()
- def has_method(self, obj, name):
+ def has_method(self, obj, name) -> type:
''' Checks if a given method exists. '''
return callable(getattr(obj, name, None))
- def clear_children(self, widget):
+ def clear_children(self, widget: type) -> None:
''' Clear children of a gtk widget. '''
for child in widget.get_children():
widget.remove(child)
diff --git a/src/versions/solarfm-0.0.1/SolarFM/solarfm/context/mixins/ui/grid_mixin.py b/src/versions/solarfm-0.0.1/SolarFM/solarfm/context/mixins/ui/grid_mixin.py
index 696167e..a654c56 100644
--- a/src/versions/solarfm-0.0.1/SolarFM/solarfm/context/mixins/ui/grid_mixin.py
+++ b/src/versions/solarfm-0.0.1/SolarFM/solarfm/context/mixins/ui/grid_mixin.py
@@ -27,8 +27,10 @@ class GridMixin:
dir = tab.get_current_directory()
files = tab.get_files()
- for i, file in enumerate(files):
+ for file in files:
store.append([None, file[0]])
+
+ for i, file in enumerate(files):
self.create_icon(i, tab, store, dir, file[0])
# NOTE: Not likely called often from here but it could be useful
@@ -41,40 +43,30 @@ class GridMixin:
GLib.idle_add(self.update_store, *(i, store, icon, tab, dir, file,))
def update_store(self, i, store, icon, tab, dir, file):
- fpath = f"{dir}/{file}"
-
- loop = True
- while loop:
+ while True:
try:
- itr = store.get_iter(i)
- loop = False
+ itr = store.get_iter(i)
+ break
except:
pass
if not icon:
- icon = self.get_system_thumbnail(fpath, tab.SYS_ICON_WH[0])
- if not icon:
- icon = GdkPixbuf.Pixbuf.new_from_file(tab.DEFAULT_ICON)
+ path = f"{dir}/{file}"
+ icon = self.get_system_thumbnail(path, tab.SYS_ICON_WH[0])
+
+ if not icon:
+ icon = GdkPixbuf.Pixbuf.new_from_file(tab.DEFAULT_ICON)
store.set_value(itr, 0, icon)
def get_system_thumbnail(self, filename, size):
try:
- if os.path.exists(filename):
- gioFile = Gio.File.new_for_path(filename)
- info = gioFile.query_info('standard::icon' , 0, Gio.Cancellable())
- icon = info.get_icon().get_names()[0]
- iconTheme = Gtk.IconTheme.get_default()
- iconData = iconTheme.lookup_icon(icon , size , 0)
- if iconData:
- iconPath = iconData.get_filename()
- return GdkPixbuf.Pixbuf.new_from_file(iconPath)
- else:
- return None
- else:
- return None
+ gio_file = Gio.File.new_for_path(filename)
+ info = gio_file.query_info('standard::icon' , 0, None)
+ icon = info.get_icon().get_names()[0]
+ icon_path = self.icon_theme.lookup_icon(icon , size , 0).get_filename()
+ return GdkPixbuf.Pixbuf.new_from_file(icon_path)
except Exception as e:
- print("System icon generation issue:")
return None
diff --git a/src/versions/solarfm-0.0.1/SolarFM/solarfm/plugins/plugins.py b/src/versions/solarfm-0.0.1/SolarFM/solarfm/plugins/plugins.py
index 49230f5..c28817b 100644
--- a/src/versions/solarfm-0.0.1/SolarFM/solarfm/plugins/plugins.py
+++ b/src/versions/solarfm-0.0.1/SolarFM/solarfm/plugins/plugins.py
@@ -11,15 +11,15 @@ from gi.repository import Gtk, Gio
class Plugin:
- name = None
- module = None
- reference = None
+ name: str = None
+ module: str = None
+ reference: type = None
class Plugins:
"""Plugins controller"""
- def __init__(self, settings):
+ def __init__(self, settings: type):
self._settings = settings
self._builder = self._settings.get_builder()
self._plugins_path = self._settings.get_plugins_path()
@@ -27,11 +27,11 @@ class Plugins:
self._plugin_collection = []
- def launch_plugins(self):
+ def launch_plugins(self) -> None:
self._set_plugins_watcher()
self.load_plugins()
- def _set_plugins_watcher(self):
+ def _set_plugins_watcher(self) -> None:
self._plugins_dir_watcher = Gio.File.new_for_path(self._plugins_path) \
.monitor_directory(Gio.FileMonitorFlags.WATCH_MOVES, Gio.Cancellable())
self._plugins_dir_watcher.connect("changed", self._on_plugins_changed, ())
@@ -43,7 +43,7 @@ class Plugins:
self.reload_plugins(file)
# @threaded
- def load_plugins(self, file=None):
+ def load_plugins(self, file: str = None) -> None:
print(f"Loading plugins...")
parent_path = os.getcwd()
@@ -72,12 +72,12 @@ class Plugins:
os.chdir(parent_path)
- def reload_plugins(self, file=None):
+ def reload_plugins(self, file: str = None) -> None:
print(f"Reloading plugins... stub.")
- def send_message_to_plugin(self, type, data):
+ def send_message_to_plugin(self, target: str , data: type) -> None:
print("Trying to send message to plugin...")
for plugin in self._plugin_collection:
- if type in plugin.name:
+ if target in plugin.name:
print('Found plugin; posting message...')
plugin.reference.set_message(data)
diff --git a/src/versions/solarfm-0.0.1/SolarFM/solarfm/shellfm/windows/tabs/utils/settings.py b/src/versions/solarfm-0.0.1/SolarFM/solarfm/shellfm/windows/tabs/utils/settings.py
index e4d9323..fb982af 100644
--- a/src/versions/solarfm-0.0.1/SolarFM/solarfm/shellfm/windows/tabs/utils/settings.py
+++ b/src/versions/solarfm-0.0.1/SolarFM/solarfm/shellfm/windows/tabs/utils/settings.py
@@ -59,7 +59,7 @@ class Settings:
subpath = settings["base_of_home"]
HIDE_HIDDEN_FILES = True if settings["hide_hidden_files"] == "true" else False
FFMPG_THUMBNLR = FFMPG_THUMBNLR if settings["thumbnailer_path"] == "" else settings["thumbnailer_path"]
- go_past_home = True if settings["go_past_home"] == "" else settings["go_past_home"]
+ go_past_home = True if settings["go_past_home"] == "" else settings["go_past_home"]
lock_folder = True if settings["lock_folder"] == "true" else False
locked_folders = settings["locked_folders"].split("::::")
mplayer_options = settings["mplayer_options"].split()
@@ -76,7 +76,7 @@ class Settings:
# Filters
fvideos = ('.mkv', '.avi', '.flv', '.mov', '.m4v', '.mpg', '.wmv', '.mpeg', '.mp4', '.webm')
foffice = ('.doc', '.docx', '.xls', '.xlsx', '.xlt', '.xltx', '.xlm', '.ppt', 'pptx', '.pps', '.ppsx', '.odt', '.rtf')
- fimages = ('.png', '.jpg', '.jpeg', '.gif', '.ico', '.tga')
+ fimages = ('.png', '.jpg', '.jpeg', '.gif', '.ico', '.tga', '.webp')
ftext = ('.txt', '.text', '.sh', '.cfg', '.conf')
fmusic = ('.psf', '.mp3', '.ogg', '.flac', '.m4a')
fpdf = ('.pdf')
diff --git a/src/versions/solarfm-0.0.1/SolarFM/solarfm/utils/ipc_server.py b/src/versions/solarfm-0.0.1/SolarFM/solarfm/utils/ipc_server.py
index 0972d86..27a0095 100644
--- a/src/versions/solarfm-0.0.1/SolarFM/solarfm/utils/ipc_server.py
+++ b/src/versions/solarfm-0.0.1/SolarFM/solarfm/utils/ipc_server.py
@@ -17,7 +17,7 @@ def threaded(fn):
class IPCServer:
""" Create a listener so that other SolarFM instances send requests back to existing instance. """
- def __init__(self, conn_type="socket"):
+ def __init__(self, conn_type: str = "socket"):
self.is_ipc_alive = False
self._conn_type = conn_type
self.ipc_authkey = b'solarfm-ipc'
@@ -31,7 +31,7 @@ class IPCServer:
@threaded
- def create_ipc_server(self):
+ def create_ipc_server(self) -> None:
if self._conn_type == "socket":
if os.path.exists(self.ipc_address):
return
@@ -44,7 +44,7 @@ class IPCServer:
self.is_ipc_alive = True
while True:
conn = listener.accept()
- start_time = time.time()
+ start_time = time.perf_counter()
print(f"New Connection: {listener.last_accepted}")
while True:
@@ -69,14 +69,14 @@ class IPCServer:
break
# NOTE: Not perfect but insures we don't lock up the connection for too long.
- end_time = time.time()
+ end_time = time.perf_counter()
if (end - start) > self.ipc_timeout:
conn.close()
listener.close()
- def send_ipc_message(self, message="Empty Data..."):
+ def send_ipc_message(self, message: str = "Empty Data...") -> None:
try:
if self._conn_type == "socket":
conn = Client(address=self.ipc_address, family="AF_UNIX", authkey=self.ipc_authkey)
@@ -86,5 +86,6 @@ class IPCServer:
conn.send(message)
conn.send('close connection')
+ conn.close()
except Exception as e:
print(repr(e))
diff --git a/src/versions/solarfm-0.0.1/SolarFM/solarfm/utils/logger.py b/src/versions/solarfm-0.0.1/SolarFM/solarfm/utils/logger.py
index 06eed47..63db6e2 100644
--- a/src/versions/solarfm-0.0.1/SolarFM/solarfm/utils/logger.py
+++ b/src/versions/solarfm-0.0.1/SolarFM/solarfm/utils/logger.py
@@ -5,10 +5,10 @@ import os, logging
class Logger:
- def __init__(self, config_path):
+ def __init__(self, config_path: str):
self._CONFIG_PATH = config_path
- def get_logger(self, loggerName = "NO_LOGGER_NAME_PASSED", createFile = True):
+ def get_logger(self, loggerName: str = "NO_LOGGER_NAME_PASSED", createFile: bool = True) -> logging.Logger:
"""
Create a new logging object and return it.
:note:
diff --git a/src/versions/solarfm-0.0.1/SolarFM/solarfm/utils/settings.py b/src/versions/solarfm-0.0.1/SolarFM/solarfm/utils/settings.py
index 0750213..6d93e77 100644
--- a/src/versions/solarfm-0.0.1/SolarFM/solarfm/utils/settings.py
+++ b/src/versions/solarfm-0.0.1/SolarFM/solarfm/utils/settings.py
@@ -31,6 +31,7 @@ class Settings:
self._KEY_BINDINGS = f"{self._CONFIG_PATH}/key-bindings.json"
self._DEFAULT_ICONS = f"{self._CONFIG_PATH}/icons"
self._WINDOW_ICON = f"{self._DEFAULT_ICONS}/{app_name.lower()}.png"
+ self._ICON_THEME = Gtk.IconTheme.get_default()
if not os.path.exists(self._CONFIG_PATH):
os.mkdir(self._CONFIG_PATH)
@@ -63,12 +64,12 @@ class Settings:
self._builder.add_from_file(self._GLADE_FILE)
- def create_window(self):
+ def create_window(self) -> None:
# Get window and connect signals
self._main_window = self._builder.get_object("Main_Window")
self._set_window_data()
- def _set_window_data(self):
+ def _set_window_data(self) -> None:
self._main_window.set_icon_from_file(self._WINDOW_ICON)
screen = self._main_window.get_screen()
visual = screen.get_rgba_visual()
@@ -85,29 +86,28 @@ class Settings:
styleContext = Gtk.StyleContext()
styleContext.add_provider_for_screen(screen, cssProvider, Gtk.STYLE_PROVIDER_PRIORITY_USER)
- def _area_draw(self, widget, cr):
+ def _area_draw(self, widget: Gtk.ApplicationWindow, cr: cairo.Context) -> None:
cr.set_source_rgba(0, 0, 0, 0.54)
cr.set_operator(cairo.OPERATOR_SOURCE)
cr.paint()
cr.set_operator(cairo.OPERATOR_OVER)
- def get_monitor_data(self):
+ def get_monitor_data(self) -> list:
screen = self._builder.get_object("Main_Window").get_screen()
monitors = []
for m in range(screen.get_n_monitors()):
monitors.append(screen.get_monitor_geometry(m))
-
- for monitor in monitors:
print("{}x{}+{}+{}".format(monitor.width, monitor.height, monitor.x, monitor.y))
return monitors
- def get_builder(self): return self._builder
- def get_logger(self): return self._logger
- def get_keybindings(self): return self._keybindings
- def get_main_window(self): return self._main_window
- def get_plugins_path(self): return self._PLUGINS_PATH
+ def get_main_window(self) -> Gtk.ApplicationWindow: return self._main_window
+ def get_builder(self) -> Gtk.Builder: return self._builder
+ def get_logger(self) -> Logger: return self._logger
+ def get_keybindings(self) -> Keybindings: return self._keybindings
+ def get_plugins_path(self) -> str: return self._PLUGINS_PATH
+ def get_icon_theme(self) -> str: return self._ICON_THEME
- def get_success_color(self): return self._success_color
- def get_warning_color(self): return self._warning_color
- def get_error_color(self): return self._error_color
+ def get_success_color(self) -> str: return self._success_color
+ def get_warning_color(self) -> str: return self._warning_color
+ def get_error_color(self) -> str: return self._error_color
diff --git a/user_config/usr/share/solarfm/Main_Window.glade b/user_config/usr/share/solarfm/Main_Window.glade
index bd83627..065cf65 100644
--- a/user_config/usr/share/solarfm/Main_Window.glade
+++ b/user_config/usr/share/solarfm/Main_Window.glade
@@ -621,519 +621,11 @@ SolarFM is developed on Atom, git, and using Python 3+ with Gtk GObject introspe
False
gtk-new
-
-
True
False
@@ -1241,162 +733,6 @@ SolarFM is developed on Atom, git, and using Python 3+ with Gtk GObject introspe
False
gtk-media-forward
-
True
False
@@ -2128,6 +1464,496 @@ SolarFM is developed on Atom, git, and using Python 3+ with Gtk GObject introspe
+
+
+ 120
+ False
+ False
+ True
+ center-always
+ True
+ normal
+ True
+ True
+ True
+ False
+ False
+ center
+ Main_Window
+
+
+ False
+ 5
+ 5
+ 5
+ 5
+ vertical
+ 2
+
+
+ False
+ end
+
+
+ Overwrite
+ True
+ True
+ True
+
+
+ True
+ True
+ 0
+
+
+
+
+ Overwrite (All)
+ True
+ True
+ True
+
+
+ True
+ True
+ 1
+
+
+
+
+ Skip
+ True
+ True
+ True
+
+
+ True
+ True
+ 2
+
+
+
+
+ Skip (All)
+ True
+ True
+ True
+
+
+ True
+ True
+ 3
+
+
+
+
+ False
+ False
+ 0
+
+
+
+
+ True
+ False
+ vertical
+
+
+ True
+ False
+ Filename already exists. Please rename or select an action.
+ 0.10000000149011612
+
+
+
+
+
+ False
+ True
+ 0
+
+
+
+
+ True
+ False
+ 15
+ 10
+
+
+ True
+ False
+ Moving From:
+
+
+ False
+ True
+ 0
+
+
+
+
+ True
+ False
+
+
+ True
+ True
+ 1
+
+
+
+
+ False
+ True
+ 1
+
+
+
+
+ True
+ False
+ 0
+
+
+ True
+ True
+ 2
+
+
+
+
+ True
+ False
+ 20
+ 10
+
+
+ True
+ False
+ Moving To:
+
+
+ False
+ True
+ 0
+
+
+
+
+ True
+ False
+
+
+ True
+ True
+ 1
+
+
+
+
+ False
+ True
+ 3
+
+
+
+
+ True
+ False
+ 0
+
+
+ True
+ True
+ 4
+
+
+
+
+ True
+ False
+ 20
+
+
+ True
+ False
+ Filename:
+
+
+ False
+ True
+ 0
+
+
+
+
+ True
+ False
+
+
+ True
+ True
+ 1
+
+
+
+
+ False
+ True
+ 5
+
+
+
+
+ True
+ True
+
+
+
+ False
+ True
+ 6
+
+
+
+
+ True
+ False
+ 20
+ top
+ start
+
+
+
+
+
+ Rename
+ True
+ False
+ True
+ True
+
+
+
+ True
+ True
+ 1
+ True
+
+
+
+
+ Auto Rename
+ True
+ True
+ True
+
+
+
+ True
+ True
+ 2
+ True
+
+
+
+
+ Auto Rename All
+ True
+ True
+ True
+
+
+
+ True
+ True
+ 3
+ True
+
+
+
+
+ False
+ True
+ 7
+
+
+
+
+ True
+ True
+ 1
+
+
+
+
+
+ button5
+ button6
+ button7
+ button8
+
+
+
+