From 56e5836b54ab1a7f5ad5b067e867a0c9392c5e5b Mon Sep 17 00:00:00 2001 From: Klaus Schmidinger Date: Fri, 28 Apr 2006 18:00:00 +0200 Subject: =?UTF-8?q?Version=201.3.49=20-=20Fixed=20initializing=20'noapiv'?= =?UTF-8?q?=20in=20the=20Makefile=20(reported=20by=20Ronny=20Kornexl).=20-?= =?UTF-8?q?=20Fixed=20extracting=20APIVERSION=20to=20work=20with=20older?= =?UTF-8?q?=20versions=20of=20'sed'=20(reported=20by=20=20=20Oliver=20Endr?= =?UTF-8?q?iss;=20thanks=20also=20to=20Udo=20Richter=20for=20a=20shorter?= =?UTF-8?q?=20version=20of=20the=20'sed'=20=20=20expression).=20-=20Fixed?= =?UTF-8?q?=20broken=20APIVERSION=20extraction=20line=20in=20'newplugin'?= =?UTF-8?q?=20(thanks=20to=20Oliver=20Endriss).=20-=20Fixed=20entering=20'?= =?UTF-8?q?0'=20in=20a=20cMenuEditIntItem=20(reported=20by=20Mirko=20D?= =?UTF-8?q?=C3=B6lle).=20-=20Updated=20the=20Italian=20OSD=20texts=20(than?= =?UTF-8?q?ks=20to=20Nino=20Gerbino).=20-=20Added=20a=20note=20about=20add?= =?UTF-8?q?ing=20'INCLUDES=20+=3D=20-I$(DVBDIR)/include'=20to=20an=20exist?= =?UTF-8?q?ing=20=20=20Make.config=20(problem=20reported=20by=20Markus=20E?= =?UTF-8?q?hrnsperger).=20-=20Fixed=20handling=20the=20cPluginManager::Act?= =?UTF-8?q?ive()=20result=20when=20pressing=20the=20"Power"=20key=20=20=20?= =?UTF-8?q?(reported=20by=20Werner=20F=C3=A4rber).=20-=20Added=20a=20hint?= =?UTF-8?q?=20about=20commenting=20out=20the=20line=20'#define=20USE=5FFAD?= =?UTF-8?q?VISE'=20in=20tools.c=20in=20=20=20case=20of=20problems=20with?= =?UTF-8?q?=20replaying=20in=20fast=20forward=20mode=20if=20the=20video=20?= =?UTF-8?q?directory=20is=20=20=20mounted=20via=20a=20Samba=20share=20(rep?= =?UTF-8?q?orted=20by=20Andy=20Grobb).=20-=20Changed=20the=20"Really=20res?= =?UTF-8?q?tart=3F"=20prompt=20in=20the=20call=20to=20cPluginManager::Acti?= =?UTF-8?q?ve()=20in=20=20=20menu.c=20to=20"restart=20anyway=3F"=20(sugges?= =?UTF-8?q?ted=20by=20Rolf=20Ahrenberg).=20-=20Removed=20the=20obsolete=20?= =?UTF-8?q?"'1'=20for=20encrypted=20radio=20channels"=20part=20from=20the?= =?UTF-8?q?=20description=20=20=20of=20the=20VPID=20in=20vdr.5=20(reported?= =?UTF-8?q?=20by=20Alexander=20Hans).=20-=20Fixed=20tuning=20to=20the=20ch?= =?UTF-8?q?annel=20of=20a=20VPS=20timer=20if=20the=20device=20is=20the=20a?= =?UTF-8?q?ctual=20device.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- PLUGINS.html | 32 +------------------------------- 1 file changed, 1 insertion(+), 31 deletions(-) (limited to 'PLUGINS.html') diff --git a/PLUGINS.html b/PLUGINS.html index 491399c..0869c38 100644 --- a/PLUGINS.html +++ b/PLUGINS.html @@ -6,7 +6,7 @@

The VDR Plugin System

-
Version 1.3
+
Version 1.4

Copyright © 2006 Klaus Schmidinger
@@ -14,19 +14,6 @@ Copyright © 2006 Klaus Schmidinger
www.cadsoft.de/vdr

-
  -Important modifications introduced in version 1.3.31 are marked like this. -
-
  -Important modifications introduced in version 1.3.37 are marked like this. -
-
  -Important modifications introduced in version 1.3.38 are marked like this. -
-
  -Important modifications introduced in version 1.3.46 are marked like this. -
-

VDR provides an easy to use plugin interface that allows additional functionality to be added to the program by implementing a dynamically loadable library file. This interface allows programmers to develop additional functionality for VDR completely @@ -62,18 +49,14 @@ structures and allows it to hook itself into specific areas to perform special a

  • Main menu entry
  • User interaction
  • Housekeeping -
     
  • Main thread hook
  • Activity -
  • Setup parameters
  • The Setup menu
  • Configuration files
  • Internationalization
  • Custom services -
     
  • SVDRP commands -
  • Loading plugins into VDR
  • Building the distribution package @@ -166,7 +149,6 @@ loadable library file for that plugin (we'll get to the details later). The lib directory contains the dynamically loadable libraries of all available plugins. Note that the names of these files are created by concatenating

    -
      @@ -178,7 +160,6 @@ of VDR as long as their plugin API version number is still the same as that of the current VDR version. That way minor fixes to VDR, that don't require changes to the VDR header files, can be made without requiring all plugins to be recompiled. -
    libvdr-hello.so.1.1.0
    VDR plugin
    library prefix
    name of
    the plugin
    shared object
    indicator
    API version number
    this plugin was
    compiled for

    The plugin library files can be stored in any directory. If the default organization is not used, the path to the plugin directory has be be given to VDR through the @@ -620,7 +601,6 @@ interaction is possible. If a specific action takes longer than a few seconds, the plugin should launch a separate thread to do this. -
     

    Main thread hook

    Pushing in...

    @@ -677,7 +657,6 @@ the prompt by pressing the "Ok" button, the rest of the plugins will also be queried, and further prompts may show up. If all prompts have been confirmed, the shutdown will take place. As soon as one prompt is not confirmed, no further plugins will be queried and no shutdown will be done. -


    Setup parameters

    @@ -1002,7 +981,6 @@ To send a message to all plugins, a plugin can call the function cPluginManager::CallAllServices(). This function returns true if any plugin handled the request, or false if no plugin handled the request. -
     

    SVDRP commands

    Infinite Diversity in Infinite Combinations

    @@ -1094,8 +1072,6 @@ The returned string may consist of several lines, separated by the newline chara when presenting them to the caller, and the continuation character ('-') will be set for all but the last one. -

    -

    Loading plugins into VDR

    Saddling up!

    @@ -1329,9 +1305,7 @@ public: cMyControl(void); virtual ~cMyControl(); virtual void Hide(void); -
      virtual cOsdObject *GetInfo(void); -
    virtual eOSState ProcessKey(eKeys Key); };

    @@ -1361,13 +1335,11 @@ A derived cControl must implement the Hide() function, it has to hide itself from the OSD, in case it uses it. Hide() may be called at any time, and it may be called even if the cControl is not visible at the moment.

    -
      The GetInfo() function is called when the user presses the Info button, and shall return a pointer to a cOsdObject that contains information about the currently played programme. The caller takes ownership of the returned pointer and will delete it when it is no longer used. If no information is available, NULL shall be returned. -

    Finally, to get things going, a plugin that implements a player (and the surrounding infrastructure like displaying a list of playable stuff etc) simply has to call the @@ -1589,7 +1561,6 @@ with the full required resolution. Only if this fails shall it use alternate areas. Drawing areas are always rectangular and may not overlap (but do not need to be adjacent). -
     

    Directly accessing the OSD is only allowed from the foreground thread, which restricts this to a cOsdObject returned from the plugin's MainMenuAction() @@ -1603,7 +1574,6 @@ int cSkins::QueueMessage(eMessageType Type, const char *s, int Seconds = 0, int

    to queue that message for display. See VDR/skins.h for details. -


    Skins

    -- cgit v1.2.3