20 Commits

Author SHA1 Message Date
Lerking 34c7927601 Merge pull request '0.3.0' (#33) from 0.3.0 into main
Reviewed-on: https://gitea.com/Lerking/XtendR/pulls/33
2025-03-28 17:23:38 +00:00
Lerking ebf31756b5 #31 Done. /JL 2025-03-28 18:22:16 +01:00
Lerking 406c1b77ed #31 - Creating thread with callback, on pre_load(). /JL 2025-03-28 17:26:58 +01:00
Lerking 1be429c5cd Update xtendr/xtendrsystem.py 2025-03-27 20:33:19 +00:00
Lerking a093b3f56c Update plugins/example_plugin/example_plugin.py 2025-03-27 20:31:12 +00:00
Lerking 1dc0c81d84 Update plugins/example_plugin/example_plugin.py 2025-03-27 20:30:23 +00:00
Lerking 3e38cabf81 Update xtendr/xtendrsystem.py 2025-03-27 20:25:12 +00:00
Lerking 63f649af25 #31 Added **self.use_pre_load:bool = False** and pre_load() method. 2025-03-27 19:30:41 +00:00
Lerking b6efe1b1df Update xtendr/xtendrbase.py
#31 Added pre_load() method
2025-03-27 19:23:59 +00:00
Lerking c5ee073d65 Update setup.py 2025-03-27 19:20:30 +00:00
Lerking 3bcf01dc26 Merge pull request '0.2.1 Updated to include keyword arguments in run() method. /JL' (#30) from 0.2.1 into main
Reviewed-on: https://gitea.com/Lerking/XtendR/pulls/30
2025-03-27 09:47:53 +00:00
Jan Lerking dd5904c273 0.2.1 Updated to include keyword arguments in run() method. /JL 2025-03-27 10:46:05 +01:00
Lerking b763308aa9 Merge pull request 'Added plugin.run() with arguments. /JL' (#29) from 0.2.0 into main
Reviewed-on: https://gitea.com/Lerking/XtendR/pulls/29
2025-03-27 08:57:26 +00:00
Jan Lerking 34ba757bc6 Added plugin.run() with arguments. /JL 2025-03-27 09:35:29 +01:00
Lerking b5d2e1b0be Merge pull request '0.1.3 #26 bug-fix corrected variable name. /JL' (#28) from 0.1.3 into main
Reviewed-on: https://gitea.com/Lerking/XtendR/pulls/28
2025-03-09 14:28:53 +00:00
Lerking d3031952bf 0.1.3 #26 bug-fix corrected variable name. /JL 2025-03-09 15:21:08 +01:00
Lerking 3312f2da28 Merge pull request '0.1.2 #26 Added possibility to choose your own plugins folder. /JL' (#27) from 0.1.2 into main
Reviewed-on: https://gitea.com/Lerking/XtendR/pulls/27
2025-03-09 14:14:37 +00:00
Lerking a21122671d 0.1.2 #26 Added possibility to choose your own plugins folder. /JL 2025-03-09 15:06:32 +01:00
Lerking 9effa4be3e Merge pull request '0.1.1 Updated doctest. /JL' (#25) from 0.1.1 into main
Reviewed-on: https://gitea.com/Lerking/XtendR/pulls/25
2025-03-08 17:34:52 +00:00
Lerking 217038b863 0.1.1 Updated doctest. /JL 2025-03-08 18:34:04 +01:00
5 changed files with 54 additions and 11 deletions
+13 -2
View File
@@ -1,5 +1,9 @@
import time
from xtendr.xtendrsystem import XtendRSystem
def my_callback():
print("'example_plugin is finished pre-loading")
if __name__ == "__main__":
"""Example usage of the PluginSystem.
@@ -15,7 +19,14 @@ if __name__ == "__main__":
Detached plugin 'example_plugin'.
"""
system = XtendRSystem()
system.attach("example_plugin") # Assuming 'example_plugin/plugin_info.json' exists
system.run("example_plugin")
system.attach("example_plugin", my_callback) # Assuming 'example_plugin/plugin_info.json' exists
for i in range(3):
print(f"Main program is running iteration {i+1}...")
time.sleep(2)
system.run("example_plugin", test="Hello!")
system.stop("example_plugin")
system.run("example_plugin", 25)
system.stop("example_plugin")
system.run("example_plugin", "Hello!", 25)
system.stop("example_plugin")
system.detach("example_plugin")
+24 -2
View File
@@ -1,3 +1,5 @@
import threading
import time
from xtendr.xtendrbase import XtendRBase
class ExamplePlugin(XtendRBase):
@@ -5,13 +7,33 @@ class ExamplePlugin(XtendRBase):
Example:
>>> plugin = ExamplePlugin()
>>> plugin.run()
>>> plugin.run("Hello!", 25)
Passed arguments 2:
Argument 0: Hello!
Argument 1: 25
ExamplePlugin is running!
>>> plugin.stop()
ExamplePlugin has stopped!
"""
def run(self):
def run(self, *args, **kwargs):
arglen = len(args)
keylen = len(kwargs)
if arglen > 0:
print(f"Passed arguments {arglen}:")
for idx, a in enumerate(args):
print(f"Argument {idx}: {a}")
if keylen > 0:
print(f"Keyword arguments passed {keylen}")
if not "test" in kwargs:
raise ValueError("Didn't get expected 'test' keyword!")
for kw in kwargs:
print(f"Argument {kw}: {kwargs[kw]}")
print("ExamplePlugin is running!")
def stop(self):
print("ExamplePlugin has stopped!")
def pre_load(self, callback):
time.sleep(5) # Indicate long running pre-load.
callback()
+1 -1
View File
@@ -3,7 +3,7 @@ if __name__ == "__main__":
setup(
name="XtendR",
version="0.0.9",
version="0.3.2",
packages=find_packages(),
install_requires=[],
author="Jan Lerking",
+6 -1
View File
@@ -17,9 +17,14 @@ class XtendRBase(ABC):
Stopping TestPlugin
"""
@abstractmethod
def run(self):
def run(self, *args, **kwargs):
pass
@abstractmethod
def stop(self):
pass
@abstractmethod
def pre_load(self, *args):
pass
+10 -5
View File
@@ -2,9 +2,10 @@ import importlib
import sys
import os
import json
import threading
from xtendr.xtendrbase import XtendRBase
__version__ = "0.1.0"
__version__ = "0.3.2"
class XtendRSystem:
"""Plugin system to manage plugins.
@@ -12,7 +13,7 @@ class XtendRSystem:
Example:
>>> system = XtendRSystem()
>>> system.version()
XtendR v0.1.0
XtendR v0.1.3
>>> system.attach("example_plugin") # Assuming 'example_plugin/example_plugin.json' exists
>>> system.run("example_plugin")
ExamplePlugin is running!
@@ -21,19 +22,20 @@ class XtendRSystem:
>>> system.detach("example_plugin")
Detached plugin 'example_plugin'.
"""
def __init__(self):
def __init__(self, pluginpath = "plugins"):
self.pluginspath = pluginpath
self.plugins = {}
def version(self) -> str:
return "XtendR v" + __version__
def attach(self, name: str) -> None:
def attach(self, name: str, callback) -> None:
"""Dynamically load a plugin from its folder."""
if name in self.plugins:
print(f"Plugin '{name}' is already attached.")
return
plugin_path = os.path.join(os.getcwd(), "plugins", name)
plugin_path = os.path.join(os.getcwd(), self.pluginspath, name)
info_path = os.path.join(plugin_path, name + ".json")
print(plugin_path + "\n" + info_path)
@@ -66,6 +68,9 @@ class XtendRSystem:
'autorun': False
}
print(f"Attached plugin '{name}'.")
print(f"Running pre-load on '{name}'.")
thread = threading.Thread(target=self.plugins[name]['instance'].pre_load, args=(callback,))
thread.start()
except (ModuleNotFoundError, json.JSONDecodeError, AttributeError) as e:
print(f"Failed to attach plugin '{name}': {e}")