Entwicklung - Hinweise für Plugin Entwickler

Aus VDR Wiki
(Unterschied zwischen Versionen)
Wechseln zu: Navigation, Suche
K (Debugging: + Kategorie:Entwicklung)
K
Zeile 1: Zeile 1:
===Plugins ''packen''===
+
==Beschreibung==
 +
 
 +
==Plugins ''packen''==
 
Sinngemäß entsprechend '''../VDR/PLUGINS.html''':
 
Sinngemäß entsprechend '''../VDR/PLUGINS.html''':
  
Zeile 19: Zeile 21:
 
und 0.0.1 durch die Versionsnummer des Plugins.
 
und 0.0.1 durch die Versionsnummer des Plugins.
  
===Übersetzungen / Internationalization===
+
==Übersetzungen / Internationalization==
 
* Finnisch -> http://www.saunalahti.fi/~rahrenbe/vdr/patches
 
* Finnisch -> http://www.saunalahti.fi/~rahrenbe/vdr/patches
 
* Französisch -> http://vdrbox.free.fr/fichiers/traduction
 
* Französisch -> http://vdrbox.free.fr/fichiers/traduction
Zeile 25: Zeile 27:
 
** http://gentoo.fh-luh.de/files/internationalization
 
** http://gentoo.fh-luh.de/files/internationalization
  
===Wünschenswert===
+
==Wünschenswert==
 
Wie in der [[Struktur]] zu sehen ist, wird das '''$VDRCONFIG/plugins''' Verzeichnis mit der Anzahl der [[Plugins]] ''unübersichtlich''.
 
Wie in der [[Struktur]] zu sehen ist, wird das '''$VDRCONFIG/plugins''' Verzeichnis mit der Anzahl der [[Plugins]] ''unübersichtlich''.
  
Zeile 58: Zeile 60:
 
Zum anderen dient es sicher der Übersichtlichkeit.
 
Zum anderen dient es sicher der Übersichtlichkeit.
  
===''Intelligenz'' einiger Plugins===
+
==''Intelligenz'' einiger Plugins==
 
Warum steigen einige Plugins aus, mit der message '''"configfile not found..."''', könnte man nicht ein wenig ''Intelligenz'' von einem Plugin erwarten?
 
Warum steigen einige Plugins aus, mit der message '''"configfile not found..."''', könnte man nicht ein wenig ''Intelligenz'' von einem Plugin erwarten?
  
Zeile 65: Zeile 67:
 
Glaube im [[eggtimer-plugin]] solch eine Routine gesehen zu haben.
 
Glaube im [[eggtimer-plugin]] solch eine Routine gesehen zu haben.
  
===Debugging===
+
==Debugging==
 
Viele nutzen.
 
Viele nutzen.
  
Zeile 81: Zeile 83:
  
 
Wäre nicht schlecht, wenn das die anderen Plugins ebenso halten könnten.
 
Wäre nicht schlecht, wenn das die anderen Plugins ebenso halten könnten.
 +
 +
==Links==
  
 
[[Kategorie:Entwicklung]]
 
[[Kategorie:Entwicklung]]

Version vom 25. April 2006, 10:59 Uhr

Inhaltsverzeichnis

Beschreibung

Plugins packen

Sinngemäß entsprechend ../VDR/PLUGINS.html:

Erstellen eines Plugin-Pakets

Wenn man als Entwickler sein Plugin anderen VDR-Nutzern verfügbar machen möchte, muss man ein Quellcode-Paket erstellen. Das Makefile welches beim Aufruf von newplugin erstellt wurde verfügt über das make Ziel dist, welches diese Funktion übernimmt.

In das Plugin Verzeichnis wechseln und make dist ausführen, hier am Beispiel von hello:

cd VDR/PLUGINS/src/hello
make dist

Anschließend sollte ein neu erstelltes Quellcode-Tarball

vdr-hello-0.0.1.tgz

im Quellcodeverzeichnis erstellt worden sein, wobei hello durch den aktuellen Plugin-Namen ersetzt wird und 0.0.1 durch die Versionsnummer des Plugins.

Übersetzungen / Internationalization

Wünschenswert

Wie in der Struktur zu sehen ist, wird das $VDRCONFIG/plugins Verzeichnis mit der Anzahl der Plugins unübersichtlich.

Wäre schön, wenn wie bei einiegen Plugins schon geschehen, der Ort für Konfigurationsdateien mit einem neuen Verzeichnis eine ebene tiefer gesetzt wird.

- VDRCONFIG/plugins
+ VDRCONFIG/plugins/<PLUGIN>

Oder zwecks abwärtskompatibilität, eine entsprechende Option bereit zu stellen. (siehe image-plugin / loadepg-plugin)

-c <PATH>
--config=<PATH>

PATH ist relativ zum VDR Plugin Konfigurationsverzeichnis, Bsp.

-c test

Entspricht.

$VDRCONFIG/plugins/test

So wäre in Zukunft sicher gestellt, das Konfigurations-Dateien nicht mit einnander kolidieren, wie es zbs. schon beim mp3-plugin + mediamvp-plugin der Fall ist (explizit, nutzen beide Plugins die mp3sources.conf, in ein und dem selben verzeichnis, so das hier ein sepereates zuweisen von verschiedenen Quellen, nicht mehr möglich ist).

Das wäre mit ... nicht passiert.

+-- Folder.png /plugins
    +-- Folder.png /mediamvp
        |--+ mp3sources.conf
    +-- Folder.png /mp3
        |--+ mp3sources.conf

Zum anderen dient es sicher der Übersichtlichkeit.

Intelligenz einiger Plugins

Warum steigen einige Plugins aus, mit der message "configfile not found...", könnte man nicht ein wenig Intelligenz von einem Plugin erwarten?

Zbs, wenn eine Konfigurations-Datei nicht vorhanden ist, das diese dann vom Plugin am passenden Ort erstellt wird?

Glaube im eggtimer-plugin solch eine Routine gesehen zu haben.

Debugging

Viele nutzen.

DEBUG = 1

In den Makefiles, Problem.

make DEBUG=1 all plugins

Und alles würde mit Debug übersetzt, obwohl man explizit nur ein Plugin in diesen Modus haben möchte.

Das femon-plugin macht es richtig. (<NAME DES PLUGINS>_DEBUG)

FEMON_DEBUG = 1

Wäre nicht schlecht, wenn das die anderen Plugins ebenso halten könnten.

Links