Das sind aber meiner Meinung nach alles Dinge, die man im Nachhinein ändern kann. Mit der prinzipiellen Funktion eines Plugin Systems hats ja nix zu tun. Ob ich die Module nun EINMALIG lade oder öfters. Würde erst mal priorisieren das so umzusetzen, dass der Code ausgelagert ist, und es funktioniert.
Dann kann man über den "produktiv" Feinschliff nachdenken, oder hast du da eine andere Meinung?
Gruß
Nein, ich hätte ja noch kleiner mit Funktionen angefangen, bevor ich die Funktionen in Module ausgelagert hätte. Deswegen habe ich nichts gegen schrittweise Vorgehen.
config.ini
Pflicht für Plugin-Name: MySQLCode:useMySQL = 1
Plugins ausführen:
Edit: Fehler im Code bereinigtCode:for i in pluginloader.getPlugins(): if int(config.get("Modules", "use"+i["name"])) print("Loading plugin " + i["name"]) plugin = pluginloader.loadPlugin(i) plugin.run()
Wäre die minimale Anpassung config.ini um eine neue Zeile ergänzen.
Geändert von JHC (18.05.2015 um 09:40 Uhr)
Oke das würde ich so kaufen :-D Die Idee ist gut. Ich mach mich später mal dran, das Grundlegende einzubauen.
Naja wir machen jetzt ja nichts anderes, als die Dinge in eine Funktion zu packen. Nur das die Funktionen jetzt eben driekt in eigenen Dateien liegen :-) Und bis auf die paar Zeilen loader Srcipt ist es ja kein Unterschied...
Würde das wohl reichen, jedem Plugin folgende 6 Daten zu übergeben, oder hab ich was wichtiges vergessen?
Code:ZVEI: ===== typ = zvei time = datetime frequenz= empfangsfrequenz data1 = zvei code data2 = data3 = FMS: ==== typ = fms time = datetime frequenz= empfangsfrequenz data1 = fms kennung data2 = status data3 = richtung POCSAG 1200: ============ typ = poc1200 time = datetime frequenz= empfangsfrequenz data1 = ric data2 = sub_ric data3 = text
Moin, moin,
1.) Warum die Zeit übergeben? Wird ja nicht "über Funk" übertragen. Ermittlung wenn nötig im Modul, bzw. bei MySQL die DB machen lassen.
2.) Ist später eine Unterscheidung in POCSAG 512/1024/2048 nötig?
Wird doch nur für die Stringzerlegung benötigt.
Ich würde nicht data1-3 nennen, das finde ich zu unverbindlich.
Bisher werden im Script id, function/status, msg/richtung genutzt.
Wenn inhaltlich etwas anderes genutzt wird, müsste man in meinen Augen auch einen neuen Parameter definieren.
Grüße
Jens
1.) Macht Sinn, die zeit kann wirklich weg...
2.) Hab hier kein Pocsag, und kenn mich damit auch nicht aus. Keine Ahnung inwiefern eine Unterscheidung im nachhinein nötig ist.
Die Daten werden an die Plugins ja auch nur an eine Funktion übergeben. Also brauchen wir eine FEST definierte Anzahl an Parametern. Und wie die dann heißen ist eigentlich egal, das ändert sich ja auch nie mehr, denn dann müssten alle Plugins umgeschrieben werden.
Oder wie sollte ich sie denn sonst nennen, um die Daten an die Plugin.run() zu übergeben?
Geändert von Schrolli (18.05.2015 um 13:04 Uhr)
Aktive Benutzer in diesem Thema: 5 (Registrierte Benutzer: 0, Gäste: 5)