summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGnapheus <solevita50@googlemail.com>2010-08-06 18:54:24 +0200
committerGnapheus <solevita50@googlemail.com>2010-08-06 18:54:24 +0200
commite3ff5a742f962a4da4d7afdeaf173b02d87e8ca4 (patch)
tree8bdd2b2ab13c4d8b7052b761455be091dc51c81d
downloadvdr-plugin-zappilot-e3ff5a742f962a4da4d7afdeaf173b02d87e8ca4.tar.gz
vdr-plugin-zappilot-e3ff5a742f962a4da4d7afdeaf173b02d87e8ca4.tar.bz2
Initial commit
-rw-r--r--COPYING340
-rw-r--r--HISTORY25
-rw-r--r--Makefile119
-rw-r--r--README78
-rw-r--r--config.h14
-rw-r--r--po/de_DE.po38
-rw-r--r--po/es_ES.po37
-rw-r--r--po/fi_FI.po40
-rw-r--r--po/fr_FR.po41
-rw-r--r--zappilot.c119
-rw-r--r--zappilotosd.c657
-rw-r--r--zappilotosd.h62
-rw-r--r--zappilotsetup.c30
-rw-r--r--zappilotsetup.h17
14 files changed, 1617 insertions, 0 deletions
diff --git a/COPYING b/COPYING
new file mode 100644
index 0000000..f90922e
--- /dev/null
+++ b/COPYING
@@ -0,0 +1,340 @@
+ GNU GENERAL PUBLIC LICENSE
+ Version 2, June 1991
+
+ Copyright (C) 1989, 1991 Free Software Foundation, Inc.
+ 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+ Everyone is permitted to copy and distribute verbatim copies
+ of this license document, but changing it is not allowed.
+
+ Preamble
+
+ The licenses for most software are designed to take away your
+freedom to share and change it. By contrast, the GNU General Public
+License is intended to guarantee your freedom to share and change free
+software--to make sure the software is free for all its users. This
+General Public License applies to most of the Free Software
+Foundation's software and to any other program whose authors commit to
+using it. (Some other Free Software Foundation software is covered by
+the GNU Lesser General Public License instead.) You can apply it to
+your programs, too.
+
+ When we speak of free software, we are referring to freedom, not
+price. Our General Public Licenses are designed to make sure that you
+have the freedom to distribute copies of free software (and charge for
+this service if you wish), that you receive source code or can get it
+if you want it, that you can change the software or use pieces of it
+in new free programs; and that you know you can do these things.
+
+ To protect your rights, we need to make restrictions that forbid
+anyone to deny you these rights or to ask you to surrender the rights.
+These restrictions translate to certain responsibilities for you if you
+distribute copies of the software, or if you modify it.
+
+ For example, if you distribute copies of such a program, whether
+gratis or for a fee, you must give the recipients all the rights that
+you have. You must make sure that they, too, receive or can get the
+source code. And you must show them these terms so they know their
+rights.
+
+ We protect your rights with two steps: (1) copyright the software, and
+(2) offer you this license which gives you legal permission to copy,
+distribute and/or modify the software.
+
+ Also, for each author's protection and ours, we want to make certain
+that everyone understands that there is no warranty for this free
+software. If the software is modified by someone else and passed on, we
+want its recipients to know that what they have is not the original, so
+that any problems introduced by others will not reflect on the original
+authors' reputations.
+
+ Finally, any free program is threatened constantly by software
+patents. We wish to avoid the danger that redistributors of a free
+program will individually obtain patent licenses, in effect making the
+program proprietary. To prevent this, we have made it clear that any
+patent must be licensed for everyone's free use or not licensed at all.
+
+ The precise terms and conditions for copying, distribution and
+modification follow.
+
+ GNU GENERAL PUBLIC LICENSE
+ TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
+
+ 0. This License applies to any program or other work which contains
+a notice placed by the copyright holder saying it may be distributed
+under the terms of this General Public License. The "Program", below,
+refers to any such program or work, and a "work based on the Program"
+means either the Program or any derivative work under copyright law:
+that is to say, a work containing the Program or a portion of it,
+either verbatim or with modifications and/or translated into another
+language. (Hereinafter, translation is included without limitation in
+the term "modification".) Each licensee is addressed as "you".
+
+Activities other than copying, distribution and modification are not
+covered by this License; they are outside its scope. The act of
+running the Program is not restricted, and the output from the Program
+is covered only if its contents constitute a work based on the
+Program (independent of having been made by running the Program).
+Whether that is true depends on what the Program does.
+
+ 1. You may copy and distribute verbatim copies of the Program's
+source code as you receive it, in any medium, provided that you
+conspicuously and appropriately publish on each copy an appropriate
+copyright notice and disclaimer of warranty; keep intact all the
+notices that refer to this License and to the absence of any warranty;
+and give any other recipients of the Program a copy of this License
+along with the Program.
+
+You may charge a fee for the physical act of transferring a copy, and
+you may at your option offer warranty protection in exchange for a fee.
+
+ 2. You may modify your copy or copies of the Program or any portion
+of it, thus forming a work based on the Program, and copy and
+distribute such modifications or work under the terms of Section 1
+above, provided that you also meet all of these conditions:
+
+ a) You must cause the modified files to carry prominent notices
+ stating that you changed the files and the date of any change.
+
+ b) You must cause any work that you distribute or publish, that in
+ whole or in part contains or is derived from the Program or any
+ part thereof, to be licensed as a whole at no charge to all third
+ parties under the terms of this License.
+
+ c) If the modified program normally reads commands interactively
+ when run, you must cause it, when started running for such
+ interactive use in the most ordinary way, to print or display an
+ announcement including an appropriate copyright notice and a
+ notice that there is no warranty (or else, saying that you provide
+ a warranty) and that users may redistribute the program under
+ these conditions, and telling the user how to view a copy of this
+ License. (Exception: if the Program itself is interactive but
+ does not normally print such an announcement, your work based on
+ the Program is not required to print an announcement.)
+
+These requirements apply to the modified work as a whole. If
+identifiable sections of that work are not derived from the Program,
+and can be reasonably considered independent and separate works in
+themselves, then this License, and its terms, do not apply to those
+sections when you distribute them as separate works. But when you
+distribute the same sections as part of a whole which is a work based
+on the Program, the distribution of the whole must be on the terms of
+this License, whose permissions for other licensees extend to the
+entire whole, and thus to each and every part regardless of who wrote it.
+
+Thus, it is not the intent of this section to claim rights or contest
+your rights to work written entirely by you; rather, the intent is to
+exercise the right to control the distribution of derivative or
+collective works based on the Program.
+
+In addition, mere aggregation of another work not based on the Program
+with the Program (or with a work based on the Program) on a volume of
+a storage or distribution medium does not bring the other work under
+the scope of this License.
+
+ 3. You may copy and distribute the Program (or a work based on it,
+under Section 2) in object code or executable form under the terms of
+Sections 1 and 2 above provided that you also do one of the following:
+
+ a) Accompany it with the complete corresponding machine-readable
+ source code, which must be distributed under the terms of Sections
+ 1 and 2 above on a medium customarily used for software interchange; or,
+
+ b) Accompany it with a written offer, valid for at least three
+ years, to give any third party, for a charge no more than your
+ cost of physically performing source distribution, a complete
+ machine-readable copy of the corresponding source code, to be
+ distributed under the terms of Sections 1 and 2 above on a medium
+ customarily used for software interchange; or,
+
+ c) Accompany it with the information you received as to the offer
+ to distribute corresponding source code. (This alternative is
+ allowed only for noncommercial distribution and only if you
+ received the program in object code or executable form with such
+ an offer, in accord with Subsection b above.)
+
+The source code for a work means the preferred form of the work for
+making modifications to it. For an executable work, complete source
+code means all the source code for all modules it contains, plus any
+associated interface definition files, plus the scripts used to
+control compilation and installation of the executable. However, as a
+special exception, the source code distributed need not include
+anything that is normally distributed (in either source or binary
+form) with the major components (compiler, kernel, and so on) of the
+operating system on which the executable runs, unless that component
+itself accompanies the executable.
+
+If distribution of executable or object code is made by offering
+access to copy from a designated place, then offering equivalent
+access to copy the source code from the same place counts as
+distribution of the source code, even though third parties are not
+compelled to copy the source along with the object code.
+
+ 4. You may not copy, modify, sublicense, or distribute the Program
+except as expressly provided under this License. Any attempt
+otherwise to copy, modify, sublicense or distribute the Program is
+void, and will automatically terminate your rights under this License.
+However, parties who have received copies, or rights, from you under
+this License will not have their licenses terminated so long as such
+parties remain in full compliance.
+
+ 5. You are not required to accept this License, since you have not
+signed it. However, nothing else grants you permission to modify or
+distribute the Program or its derivative works. These actions are
+prohibited by law if you do not accept this License. Therefore, by
+modifying or distributing the Program (or any work based on the
+Program), you indicate your acceptance of this License to do so, and
+all its terms and conditions for copying, distributing or modifying
+the Program or works based on it.
+
+ 6. Each time you redistribute the Program (or any work based on the
+Program), the recipient automatically receives a license from the
+original licensor to copy, distribute or modify the Program subject to
+these terms and conditions. You may not impose any further
+restrictions on the recipients' exercise of the rights granted herein.
+You are not responsible for enforcing compliance by third parties to
+this License.
+
+ 7. If, as a consequence of a court judgment or allegation of patent
+infringement or for any other reason (not limited to patent issues),
+conditions are imposed on you (whether by court order, agreement or
+otherwise) that contradict the conditions of this License, they do not
+excuse you from the conditions of this License. If you cannot
+distribute so as to satisfy simultaneously your obligations under this
+License and any other pertinent obligations, then as a consequence you
+may not distribute the Program at all. For example, if a patent
+license would not permit royalty-free redistribution of the Program by
+all those who receive copies directly or indirectly through you, then
+the only way you could satisfy both it and this License would be to
+refrain entirely from distribution of the Program.
+
+If any portion of this section is held invalid or unenforceable under
+any particular circumstance, the balance of the section is intended to
+apply and the section as a whole is intended to apply in other
+circumstances.
+
+It is not the purpose of this section to induce you to infringe any
+patents or other property right claims or to contest validity of any
+such claims; this section has the sole purpose of protecting the
+integrity of the free software distribution system, which is
+implemented by public license practices. Many people have made
+generous contributions to the wide range of software distributed
+through that system in reliance on consistent application of that
+system; it is up to the author/donor to decide if he or she is willing
+to distribute software through any other system and a licensee cannot
+impose that choice.
+
+This section is intended to make thoroughly clear what is believed to
+be a consequence of the rest of this License.
+
+ 8. If the distribution and/or use of the Program is restricted in
+certain countries either by patents or by copyrighted interfaces, the
+original copyright holder who places the Program under this License
+may add an explicit geographical distribution limitation excluding
+those countries, so that distribution is permitted only in or among
+countries not thus excluded. In such case, this License incorporates
+the limitation as if written in the body of this License.
+
+ 9. The Free Software Foundation may publish revised and/or new versions
+of the General Public License from time to time. Such new versions will
+be similar in spirit to the present version, but may differ in detail to
+address new problems or concerns.
+
+Each version is given a distinguishing version number. If the Program
+specifies a version number of this License which applies to it and "any
+later version", you have the option of following the terms and conditions
+either of that version or of any later version published by the Free
+Software Foundation. If the Program does not specify a version number of
+this License, you may choose any version ever published by the Free Software
+Foundation.
+
+ 10. If you wish to incorporate parts of the Program into other free
+programs whose distribution conditions are different, write to the author
+to ask for permission. For software which is copyrighted by the Free
+Software Foundation, write to the Free Software Foundation; we sometimes
+make exceptions for this. Our decision will be guided by the two goals
+of preserving the free status of all derivatives of our free software and
+of promoting the sharing and reuse of software generally.
+
+ NO WARRANTY
+
+ 11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY
+FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN
+OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES
+PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED
+OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS
+TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE
+PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING,
+REPAIR OR CORRECTION.
+
+ 12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
+WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR
+REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES,
+INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING
+OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED
+TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY
+YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER
+PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE
+POSSIBILITY OF SUCH DAMAGES.
+
+ END OF TERMS AND CONDITIONS
+
+ How to Apply These Terms to Your New Programs
+
+ If you develop a new program, and you want it to be of the greatest
+possible use to the public, the best way to achieve this is to make it
+free software which everyone can redistribute and change under these terms.
+
+ To do so, attach the following notices to the program. It is safest
+to attach them to the start of each source file to most effectively
+convey the exclusion of warranty; and each file should have at least
+the "copyright" line and a pointer to where the full notice is found.
+
+ <one line to give the program's name and a brief idea of what it does.>
+ Copyright (C) <year> <name of author>
+
+ This program is free software; you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation; either version 2 of the License, or
+ (at your option) any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with this program; if not, write to the Free Software
+ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+
+
+Also add information on how to contact you by electronic and paper mail.
+
+If the program is interactive, make it output a short notice like this
+when it starts in an interactive mode:
+
+ Gnomovision version 69, Copyright (C) year name of author
+ Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
+ This is free software, and you are welcome to redistribute it
+ under certain conditions; type `show c' for details.
+
+The hypothetical commands `show w' and `show c' should show the appropriate
+parts of the General Public License. Of course, the commands you use may
+be called something other than `show w' and `show c'; they could even be
+mouse-clicks or menu items--whatever suits your program.
+
+You should also get your employer (if you work as a programmer) or your
+school, if any, to sign a "copyright disclaimer" for the program, if
+necessary. Here is a sample; alter the names:
+
+ Yoyodyne, Inc., hereby disclaims all copyright interest in the program
+ `Gnomovision' (which makes passes at compilers) written by James Hacker.
+
+ <signature of Ty Coon>, 1 April 1989
+ Ty Coon, President of Vice
+
+This General Public License does not permit incorporating your program into
+proprietary programs. If your program is a subroutine library, you may
+consider it more useful to permit linking proprietary applications with the
+library. If this is what you want to do, use the GNU Lesser General
+Public License instead of this License.
diff --git a/HISTORY b/HISTORY
new file mode 100644
index 0000000..d85631f
--- /dev/null
+++ b/HISTORY
@@ -0,0 +1,25 @@
+VDR Plugin 'zappilot' Revision History
+-----------------------------------
+2010-08-06:Version 0.0.4
+ - Renamed plugin to zappilot
+ - Added fast browse
+ - Moved homepage to http://projects.vdr-developer.org/projects/show/plg-zappilot
+
+2007-08-21: Version 0.0.3
+ - Added support for gettext (VDR >= 1.5.7)
+ - Clean the code, correct minors bugs
+
+2006-04-30: Version 0.0.2
+ - plugin is accessible from Main Menu
+ - VDR's new APIVERSION feature
+ - Maintenance release for vdr-1.4+
+
+2006-03-28: Version 0.0.1alpha2
+ - Add an option to Hide the Main Menu entry
+ - Clean the Setup Menu
+
+2006-02-21: Version 0.0.1alpha1
+ - Initial Version
+ - Based on pilot Version 0.0.8
+ - Maintenance release for vdr-1.3.18 (and up?)
+ Provided by free-x and Thomas Gunther
diff --git a/Makefile b/Makefile
new file mode 100644
index 0000000..265cc33
--- /dev/null
+++ b/Makefile
@@ -0,0 +1,119 @@
+#
+# Makefile for a Video Disk Recorder plugin
+#
+# $Id$
+
+# The official name of this plugin.
+# This name will be used in the '-P...' option of VDR to load the plugin.
+# By default the main source file also carries this name.
+# IMPORTANT: the presence of this macro is important for the Make.config
+# file. So it must be defined, even if it is not used here!
+#
+PLUGIN = zappilot
+
+### The version number of this plugin (taken from the main source file):
+
+VERSION = $(shell grep 'static const char \*VERSION *=' $(PLUGIN).c | awk '{ print $$6 }' | sed -e 's/[";]//g')
+
+### The C++ compiler and options:
+
+CXX ?= g++
+CXXFLAGS ?= -g -O2 -Wall -Woverloaded-virtual -Wno-parentheses
+
+### The directory environment:
+
+VDRDIR = ../../..
+LIBDIR = ../../lib
+TMPDIR = /tmp
+
+### Make sure that necessary options are included:
+
+ ### For backward compatibility vdr-1.6.0:
+ CFLAGS += -fPIC
+ CXXFLAGS += -fPIC
+ DEFINES += -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE -D_LARGEFILE64_SOURCE
+
+-include $(VDRDIR)/Make.global
+
+### Allow user defined options to overwrite defaults:
+
+-include $(VDRDIR)/Make.config
+
+### The version number of VDR's plugin API (taken from VDR's "config.h"):
+
+APIVERSION = $(shell sed -ne '/define APIVERSION/s/^.*"\(.*\)".*$$/\1/p' $(VDRDIR)/config.h)
+
+### The name of the distribution archive:
+
+ARCHIVE = $(PLUGIN)-$(VERSION)
+PACKAGE = vdr-$(ARCHIVE)
+
+### Includes and Defines (add further entries here):
+
+INCLUDES += -I$(VDRDIR)/include
+
+DEFINES += -D_GNU_SOURCE -DPLUGIN_NAME_I18N='"$(PLUGIN)"'
+
+### The object files (add further files here):
+
+OBJS = $(PLUGIN).o zappilotosd.o zappilotsetup.o
+
+### The main target:
+
+all: libvdr-$(PLUGIN).so i18n
+
+### Implicit rules:
+
+%.o: %.c
+ $(CXX) $(CXXFLAGS) -c $(DEFINES) $(INCLUDES) $<
+
+### Dependencies:
+
+MAKEDEP = $(CXX) -MM -MG
+DEPFILE = .dependencies
+$(DEPFILE): Makefile
+ @$(MAKEDEP) $(DEFINES) $(INCLUDES) $(OBJS:%.o=%.c) > $@
+
+-include $(DEPFILE)
+
+### Internationalization (I18N):
+
+PODIR = po
+LOCALEDIR = $(VDRDIR)/locale
+I18Npo = $(wildcard $(PODIR)/*.po)
+I18Nmsgs = $(addprefix $(LOCALEDIR)/, $(addsuffix /LC_MESSAGES/vdr-$(PLUGIN).mo, $(notdir $(foreach file, $(I18Npo), $(basename $(file))))))
+I18Npot = $(PODIR)/$(PLUGIN).pot
+
+%.mo: %.po
+ msgfmt -c -o $@ $<
+
+$(I18Npot): $(wildcard *.c)
+ xgettext -C -cTRANSLATORS --no-wrap --no-location -k -ktr -ktrNOOP --msgid-bugs-address='<see README>' -o $@ $^
+
+%.po: $(I18Npot)
+ msgmerge -U --no-wrap --no-location --backup=none -q $@ $<
+ @touch $@
+
+$(I18Nmsgs): $(LOCALEDIR)/%/LC_MESSAGES/vdr-$(PLUGIN).mo: $(PODIR)/%.mo
+ @mkdir -p $(dir $@)
+ cp $< $@
+
+.PHONY: i18n
+i18n: $(I18Nmsgs) $(I18Npot)
+
+### Targets:
+
+libvdr-$(PLUGIN).so: $(OBJS)
+ $(CXX) $(CXXFLAGS) -shared $(OBJS) -o $@
+ @cp --remove-destination $@ $(LIBDIR)/$@.$(APIVERSION)
+
+dist: clean
+ @-rm -rf $(TMPDIR)/$(ARCHIVE)
+ @mkdir $(TMPDIR)/$(ARCHIVE)
+ @cp -a * $(TMPDIR)/$(ARCHIVE)
+ @tar czf $(PACKAGE).tgz -C $(TMPDIR) $(ARCHIVE)
+ @-rm -rf $(TMPDIR)/$(ARCHIVE)
+ @echo Distribution package created as $(PACKAGE).tgz
+
+clean:
+ @-rm -f $(OBJS) $(DEPFILE) *.so *.tgz core* *~ $(PODIR)/*.mo $(PODIR)/*.pot
diff --git a/README b/README
new file mode 100644
index 0000000..97d7957
--- /dev/null
+++ b/README
@@ -0,0 +1,78 @@
+This is a "plugin" for the Video Disk Recorder (VDR).
+
+Written by: Christophe Nouhet, Gnapheus
+
+Project's homepage: http://projects.vdr-developer.org/projects/show/plg-zappilot
+
+Latest version available at: http://projects.vdr-developer.org/projects/show/plg-zappilot
+
+This program is free software; you can redistribute it and/or modify
+it under the terms of the GNU General Public License as published by
+the Free Software Foundation; either version 2 of the License, or
+(at your option) any later version.
+See the file COPYING for more information.
+
+Description:
+-----------
+Zappilot is a plugin for VDR forked from the plugin pilotskin created by
+Christophe Nouhet (original idea Olivier Jacques). It brings the ability
+to fastly browse the EPG information without being forced to switch to a
+channel. It makes it easy to see what is going on on other channels while
+still watching the current channel. The plugin adds the possibility of
+having detailed information of the event and launching timers
+
+Installation:
+------------
+- Type "make plugins" at VDR directory level
+- Edit the keymacros.conf
+ cd "VDR_CONFIG_DIR"
+ vi keymacros.conf
+----------------keymacros.conf
+Blue Timers
+User1 @zappilot
+----------------
+ Please check VDR manual (man 5 vdr) for more informations on keymacros.conf
+
+Customization:
+-------------
+Pilot plugin can be tuned to your own preferences.
+Go to Configuration/Plugins/zappilot to access the setup menu.
+Hide main menu entry : Hide the plugin entry in the main menu
+Close on OK : Close the Pilot plugin when pressing OK button
+ (in addition to switch to the selected channel).
+ Otherwise, switch to the channel but keep
+ the pilot opened.
+Fast browse : Changes keys for faster EPG browsing
+
+Usage normal:
+-------------
+
+UP : go one channel up
+DOWN : go one channel down
+LEFT : go prev group
+RIGHT : go next group
+OK : switch to the selected channel
+BACK : exit Pilotskin plugin
+RED : edit a timer
+GREEN : Show extra infos
+YELLOW : previous event
+BLUE : next event
+
+Usage fast browse:
+-----------------
+UP : previous event
+DOWN : next event
+LEFT : prev channel
+RIGHT : next channel up go next group
+OK : switch to the selected channel
+BACK : exit Pilotskin plugin
+RED : edit a timer
+GREEN : Show extra infos
+YELLOW : previous event
+BLUE : next event
+
+
+
+To do:
+-----
+
diff --git a/config.h b/config.h
new file mode 100644
index 0000000..06256f7
--- /dev/null
+++ b/config.h
@@ -0,0 +1,14 @@
+#ifndef __ZAPPILOTCONFIG_H
+#define __ZAPPILOTCONFIG_H
+
+struct sZappilotConfig
+{
+ int closeonswitch;
+ int hidemenu;
+ int fastbrowse;
+};
+
+extern sZappilotConfig config;
+
+// #define DEBUG
+#endif //__ZAPPILOTCONFIG_H
diff --git a/po/de_DE.po b/po/de_DE.po
new file mode 100644
index 0000000..4d38186
--- /dev/null
+++ b/po/de_DE.po
@@ -0,0 +1,38 @@
+# VDR plugin language source file.
+# Copyright (C) 2007 Klaus Schmidinger <kls@cadsoft.de>
+# This file is distributed under the same license as the VDR package.
+# Klaus Schmidinger <kls@cadsoft.de>, 2000
+#
+msgid ""
+msgstr ""
+"Project-Id-Version: VDR 1.5.7\n"
+"Report-Msgid-Bugs-To: <see README>\n"
+"POT-Creation-Date: 2010-08-04 22:06+0200\n"
+"PO-Revision-Date: 2007-08-21 23:24+0200\n"
+"Last-Translator: Klaus Schmidinger <kls@cadsoft.de>\n"
+"Language-Team: <vdr@linuxtv.org>\n"
+"MIME-Version: 1.0\n"
+"Content-Type: text/plain; charset=ISO-8859-15\n"
+"Content-Transfer-Encoding: 8bit\n"
+
+msgid "A zapping co-pilot"
+msgstr "Ein Zapping-Kopilot"
+
+msgid "Zappilot"
+msgstr ""
+
+msgid "Close on OK"
+msgstr "Schließen bei OK"
+
+msgid "Hide main menu entry"
+msgstr "Hauptmenüeintrag verstecken"
+
+msgid "no"
+msgstr "nein"
+
+msgid "yes"
+msgstr "ja"
+
+msgid "Fast browse"
+msgstr "Schnell navigieren"
+
diff --git a/po/es_ES.po b/po/es_ES.po
new file mode 100644
index 0000000..e8fa6ad
--- /dev/null
+++ b/po/es_ES.po
@@ -0,0 +1,37 @@
+# VDR plugin language source file.
+# Copyright (C) 2007 Klaus Schmidinger <kls@cadsoft.de>
+# This file is distributed under the same license as the VDR package.
+# Ruben Nunez Francisco <ruben.nunez@tang-it.com>, 2002
+#
+msgid ""
+msgstr ""
+"Project-Id-Version: VDR 1.5.7\n"
+"Report-Msgid-Bugs-To: <see README>\n"
+"POT-Creation-Date: 2010-08-04 22:06+0200\n"
+"PO-Revision-Date: 2007-08-21 23:24+0200\n"
+"Last-Translator: Ruben Nunez Francisco <ruben.nunez@tang-it.com>\n"
+"Language-Team: <vdr@linuxtv.org>\n"
+"MIME-Version: 1.0\n"
+"Content-Type: text/plain; charset=ISO-8859-15\n"
+"Content-Transfer-Encoding: 8bit\n"
+
+msgid "A zapping co-pilot"
+msgstr ""
+
+msgid "Zappilot"
+msgstr ""
+
+msgid "Close on OK"
+msgstr ""
+
+msgid "Hide main menu entry"
+msgstr "Ocultar en el menú principal"
+
+msgid "no"
+msgstr ""
+
+msgid "yes"
+msgstr ""
+
+msgid "Fast browse"
+msgstr ""
diff --git a/po/fi_FI.po b/po/fi_FI.po
new file mode 100644
index 0000000..a78a206
--- /dev/null
+++ b/po/fi_FI.po
@@ -0,0 +1,40 @@
+# VDR plugin language source file.
+# Copyright (C) 2007 Klaus Schmidinger <kls@cadsoft.de>
+# This file is distributed under the same license as the VDR package.
+# Hannu Savolainen <hannu@opensound.com>, 2002
+# Jaakko Hyvätti <jaakko@hyvatti.iki.fi>, 2002
+# Niko Tarnanen <niko.tarnanen@hut.fi>, 2003
+# Rolf Ahrenberg <rahrenbe@cc.hut.fi>, 2003
+#
+msgid ""
+msgstr ""
+"Project-Id-Version: VDR 1.5.7\n"
+"Report-Msgid-Bugs-To: <see README>\n"
+"POT-Creation-Date: 2010-08-04 22:06+0200\n"
+"PO-Revision-Date: 2007-08-21 23:24+0200\n"
+"Last-Translator: Rolf Ahrenberg <rahrenbe@cc.hut.fi>\n"
+"Language-Team: <vdr@linuxtv.org>\n"
+"MIME-Version: 1.0\n"
+"Content-Type: text/plain; charset=ISO-8859-15\n"
+"Content-Transfer-Encoding: 8bit\n"
+
+msgid "A zapping co-pilot"
+msgstr ""
+
+msgid "Zappilot"
+msgstr ""
+
+msgid "Close on OK"
+msgstr "Sulje painamalla OK"
+
+msgid "Hide main menu entry"
+msgstr "Piilota valinta päävalikosta"
+
+msgid "no"
+msgstr ""
+
+msgid "yes"
+msgstr ""
+
+msgid "Fast browse"
+msgstr ""
diff --git a/po/fr_FR.po b/po/fr_FR.po
new file mode 100644
index 0000000..c9dcb0f
--- /dev/null
+++ b/po/fr_FR.po
@@ -0,0 +1,41 @@
+# VDR plugin language source file.
+# Copyright (C) 2007 Klaus Schmidinger <kls@cadsoft.de>
+# This file is distributed under the same license as the VDR package.
+# Jean-Claude Repetto <jc@repetto.org>, 2001
+# Olivier Jacques <jacquesolivier@hotmail.com>, 2003
+# Gregoire Favre <greg@magma.unil.ch>, 2003
+# Nicolas Huillard <nhuillard@e-dition.fr>, 2005
+#
+msgid ""
+msgstr ""
+"Project-Id-Version: VDR 1.5.7\n"
+"Report-Msgid-Bugs-To: <see README>\n"
+"POT-Creation-Date: 2010-08-04 22:06+0200\n"
+"PO-Revision-Date: 2007-08-21 23:24+0200\n"
+"Last-Translator: Nicolas Huillard <nhuillard@e-dition.fr>\n"
+"Language-Team: <vdr@linuxtv.org>\n"
+"MIME-Version: 1.0\n"
+"Content-Type: text/plain; charset=ISO-8859-1\n"
+"Content-Transfer-Encoding: 8bit\n"
+
+msgid "A zapping co-pilot"
+msgstr "Co-pilote de zapping"
+
+msgid "Zappilot"
+msgstr ""
+
+msgid "Close on OK"
+msgstr "Fermer le menu sur OK"
+
+msgid "Hide main menu entry"
+msgstr "Masquer dans le menu principal"
+
+msgid "no"
+msgstr "non"
+
+msgid "yes"
+msgstr "oui"
+
+msgid "Fast browse"
+msgstr ""
+
diff --git a/zappilot.c b/zappilot.c
new file mode 100644
index 0000000..ba544f0
--- /dev/null
+++ b/zappilot.c
@@ -0,0 +1,119 @@
+/*
+ * zappilot.c: A plugin for the Video Disk Recorder
+ *
+ * See the README file for copyright information and how to reach the author.
+ *
+ * $Id$
+ */
+
+#include "config.h"
+#include "zappilotosd.h"
+#include "zappilotsetup.h"
+
+#include <vdr/plugin.h>
+
+static const char *VERSION = "0.0.4";
+static const char *DESCRIPTION = trNOOP("A zapping co-pilot");
+static const char *MAINMENUENTRY = trNOOP("Zappilot");
+
+class cPluginZappilot : public cPlugin
+{
+ private:
+ // Add any member variables or functions you may need here.
+ public:
+ cPluginZappilot(void);
+ virtual ~cPluginZappilot();
+ virtual const char *Version(void) { return VERSION; }
+ virtual const char *Description(void) { return tr(DESCRIPTION); }
+ virtual const char *CommandLineHelp(void);
+ virtual bool ProcessArgs(int argc, char *argv[]);
+ virtual bool Start(void);
+ virtual void Housekeeping(void);
+ virtual const char *MainMenuEntry(void)
+ {
+ return config.hidemenu ? NULL : tr(MAINMENUENTRY);
+ }
+ virtual cOsdObject *MainMenuAction(void);
+ virtual cMenuSetupPage *SetupMenu(void);
+ virtual bool SetupParse(const char *Name, const char *Value);
+};
+
+int PilotChannelNumber;
+
+cPluginZappilot::cPluginZappilot(void)
+{
+ // Initialize any member variables here.
+ // DON'T DO ANYTHING ELSE THAT MAY HAVE SIDE EFFECTS, REQUIRE GLOBAL
+ // VDR OBJECTS TO EXIST OR PRODUCE ANY OUTPUT!
+ config.closeonswitch=1;
+ config.hidemenu=0;
+ config.fastbrowse=0;
+
+}
+
+
+cPluginZappilot::~cPluginZappilot()
+{
+ // Clean up after yourself!
+}
+
+
+const char *cPluginZappilot::CommandLineHelp(void)
+{
+ // Return a string that describes all known command line options.
+ return NULL;
+}
+
+
+bool cPluginZappilot::ProcessArgs(int argc, char *argv[])
+{
+ // Implement command line argument processing here if applicable.
+ return true;
+}
+
+
+bool cPluginZappilot::Start(void)
+{
+ // Start any background activities the plugin shall perform.
+ // Default values for setup
+ return true;
+}
+
+
+void cPluginZappilot::Housekeeping(void)
+{
+ // Perform any cleanup or other regular tasks.
+}
+
+
+cOsdObject *cPluginZappilot::MainMenuAction(void)
+{
+ // Perform the action when selected from the main VDR menu.
+ return new cZappilotOsd;
+}
+
+
+cMenuSetupPage *cPluginZappilot::SetupMenu(void)
+{
+ // Return a setup menu in case the plugin supports one.
+ return new cZappilotSetup;
+}
+
+
+bool cPluginZappilot::SetupParse(const char *Name, const char *Value)
+{
+ // Parse your own setup parameters and store their values.
+ if (!strcasecmp(Name, "CloseOnSwitch")) config.closeonswitch = atoi(Value);
+ else if (!strcasecmp(Name, "HideMenu")) config.hidemenu = atoi(Value);
+ else if (!strcasecmp(Name, "FastBrowse")) config.fastbrowse = atoi(Value);
+ else
+ return false;
+
+ return true;
+}
+
+
+sZappilotConfig config;
+
+// Don't touch this!
+VDRPLUGINCREATOR(cPluginZappilot);
diff --git a/zappilotosd.c b/zappilotosd.c
new file mode 100644
index 0000000..20ccc9a
--- /dev/null
+++ b/zappilotosd.c
@@ -0,0 +1,657 @@
+/*
+ * zappilotosd.c: A plugin for the Video Disk Recorder
+ *
+ * See the README file for copyright information and how to reach the author.
+ *
+ * $Id$
+ */
+
+#include <vdr/device.h>
+#include <vdr/osdbase.h>
+#include "zappilotosd.h"
+#include "config.h"
+
+extern int PilotChannelNumber;
+
+cZappilotOsd::cZappilotOsd(void):cOsdObject(true)
+{
+ osd = cOsdProvider::NewOsd(0, 0);
+ //displayChannel = Skins.Current()->DisplayChannel(true);
+ displayChannel = NULL;
+ displayEvent = NULL;
+ displayTimer = NULL;
+ group = -1;
+ number = 0;
+ lastTime = cTimeMs::Now();
+ extraInfo = false;
+ offset = 0;
+ lines = 0;
+ Present = NULL;
+ Following = NULL;
+ pArray = NULL;
+ currentEvent = 0;
+}
+
+
+cZappilotOsd::~cZappilotOsd(void)
+{
+ if (displayChannel)
+ {
+ delete displayChannel;
+ displayChannel = NULL;
+ }
+ if (displayEvent)
+ {
+ delete displayEvent;
+ displayEvent = NULL;
+ }
+ if (displayTimer)
+ {
+ delete displayTimer;
+ displayTimer = NULL;
+ }
+ delete osd;
+}
+
+
+void cZappilotOsd::DisplayChannel(const cChannel *Channel)
+{
+ int BufSize = 255;
+ if (Channel)
+ {
+ if (Channel->GroupSep())
+ snprintf(ChanName, BufSize, "* %s *", Channel->Name());
+ else
+ {
+ snprintf(ChanNumber, BufSize, "%d%s", Channel->Number(), number ? "-" : "");
+ snprintf(ChanName, BufSize, "%s", Channel->Name());
+ }
+
+ }
+ DrawMenu(0,0);
+ DisplayBitmap();
+}
+
+
+static int CompareEventTime(const void *p1, const void *p2)
+{
+ return (int)((*(cEvent **)p1)->StartTime() - (*(cEvent **)p2)->StartTime());
+}
+
+
+void cZappilotOsd::UpdateEPGInfo(int NowNextPrev)
+{
+ // Start to reset all previous info
+ textPresentInfo = NULL;
+ textFollowingInfo = NULL;
+ titlePresentInfo = NULL;
+ titleFollowingInfo = NULL;
+ subtitlePresentInfo = NULL;
+ subtitleFollowingInfo = NULL;
+ cSchedulesLock SchedulesLock;
+ const cSchedules *Schedules = cSchedules::Schedules(SchedulesLock);
+ if (Schedules)
+ {
+ const cSchedule *Schedule = Schedules->GetSchedule(Channels.GetByNumber(PilotChannelNumber)->GetChannelID());
+ if (Schedule)
+ {
+ // Get Present event
+ time_t now = time(NULL);
+ int a=0;
+ int num = ( Schedule->Events() )->Count();
+ switch (NowNextPrev)
+ {
+ case 1: // Now
+ // Free previous Array
+ Present = NULL;
+ Following = NULL;
+ if (pArray)
+ {
+ free(pArray);
+ pArray = NULL;
+ }
+ pArray = MALLOC(const cEvent *, num);
+ if (pArray)
+ {
+ int numreal = 0;
+ for (int a = 0; a < num; a++)
+ {
+ const cEvent *EventInfo = ( Schedule->Events() )->Get(a);
+ // if (EventInfo->GetTime() + EventInfo->GetDuration() > now)
+ pArray[numreal++] = EventInfo;
+ }
+ qsort(pArray, numreal, sizeof(cEvent *), CompareEventTime);
+ }
+ // Find the current event
+ while ( (a < num) && ( (pArray[a])->StartTime() + (pArray[a])->Duration() < now ) )
+ {
+ a++;
+ }
+ currentEvent = a;
+ if (a<num)
+ {
+ Present = pArray[currentEvent];
+ if (currentEvent + 1 < num)
+ Following = pArray[currentEvent + 1];
+ }
+ break;
+ case 2: // Next
+ if (currentEvent + 1 < num)
+ {
+ Present = NULL;
+ Following = NULL;
+ currentEvent++;
+ Present = pArray[currentEvent];
+ if (currentEvent + 1 < num)
+ Following = pArray[currentEvent + 1];
+ }
+ break;
+ case 3: // Prev
+ if (currentEvent != 0)
+ {
+ Following = Present;
+ if (currentEvent > 0)
+ {
+ currentEvent--;
+ Present = pArray[currentEvent];
+ }
+ }
+ break;
+ }
+ // Get Event details
+ if (Present)
+ {
+ // printf("[%d] PRESENT:", currentEvent);
+ titlePresentInfo = Present->Title();
+ subtitlePresentInfo = Present->ShortText();
+ textPresentInfo = Present->Description();
+ }
+ // Get Following event
+ if (Following)
+ {
+ // printf("[%d] FOLLOWING:", currentEvent+1);
+ titleFollowingInfo = Following->Title();
+ subtitleFollowingInfo = Following->ShortText();
+ textFollowingInfo = Following->Description();
+ // printf(" --->%s\n", Following->GetTitle());
+ }
+ }
+ }
+}
+
+
+void cZappilotOsd::Show()
+{
+ // find the actual current
+ cChannel *Channel = Channels.GetByNumber(cDevice::PrimaryDevice()->CurrentChannel());
+
+ if (Channel)
+ {
+ PilotChannelNumber = Channel->Number();
+ }
+ UpdateEPGInfo(1);
+ DrawMenu(0,0);
+ DisplayBitmap();
+}
+
+
+eOSState cZappilotOsd::ProcessKey(eKeys Key)
+{
+ eOSState state;
+ if (displayTimer)
+ {
+ state=displayTimer->ProcessKey(Key);
+ if (state==osBack)
+ {
+ extraInfo = false;
+ DisplayBitmap();
+ DrawMenu(0,0);
+ DisplayBitmap();
+ return osContinue;
+ }
+ else if (state == osUnknown)
+ {
+ switch (Key & ~k_Repeat)
+ {
+ case kOk:
+ case kBack:
+ case kRed:
+ extraInfo = false;
+ DisplayBitmap();
+ DrawMenu(0,0);
+ DisplayBitmap();
+ break;
+ }
+ }
+ return osContinue;
+ }
+ else if (displayChannel )
+ {
+ switch (Key)
+ {
+ case kUser1 ... kUser9:
+ {
+ return osEnd;
+ }
+ case kBack:
+ {
+ return osEnd;
+ }
+ case k0:
+ if (number == 0)
+ {
+ // keep the "Toggle channels" function working
+ //cRemote::Put(Key);
+ return osContinue;
+ }
+ case k1 ... k9:
+ if (number >= 0)
+ {
+ if (number > Channels.MaxNumber())
+ number = Key - k0;
+ else
+ number = number * 10 + Key - k0;
+ if (number > 0)
+ {
+ cChannel *channel = Channels.GetByNumber(number);
+ if (channel)
+ {
+ PilotChannelNumber = channel->Number();
+ UpdateEPGInfo(1);
+ displayChannel->SetChannel(channel, number);
+ displayChannel->SetEvents(NULL, NULL);
+ displayChannel->Flush();
+ }
+ else
+ {
+ displayChannel->SetChannel(channel, number);
+ displayChannel->SetEvents(NULL, NULL);
+ displayChannel->Flush();
+ }
+ lastTime = cTimeMs::Now();
+ }
+ }
+ break;
+ case kLeft|k_Repeat:
+ case kLeft:
+ if (config.fastbrowse)
+ {
+ CursorDown();
+ cChannel *channel = Channels.GetByNumber(PilotChannelNumber);
+ if (channel)
+ group = channel->Index()-1;
+ break;
+ }
+ case kRight|k_Repeat:
+ case kRight:
+ if (config.fastbrowse)
+ {
+ CursorUp();
+ cChannel *channel = Channels.GetByNumber(PilotChannelNumber);
+ if (channel)
+ group = channel->Index()-1;
+ break;
+ }
+ else
+ {
+ if (group < 0)
+ {
+ cChannel *channel = Channels.GetByNumber(PilotChannelNumber);
+ if (channel)
+ group = channel->Index();
+ }
+ if (group >= 0)
+ {
+ int SaveGroup = group;
+ if (NORMALKEY(Key) == kRight)
+ {
+ group = Channels.GetNextGroup(group);
+ }
+ else
+ {
+ group = Channels.GetPrevGroup(group < 1 ? 1 : group);
+ }
+ if (group < 0)
+ group = SaveGroup;
+ cChannel *channel = Channels.Get(group);
+ if (channel)
+ {
+ //DisplayChannel(channel);
+ if (!channel->GroupSep())
+ group = -1;
+ else
+ {
+ const char *groupName;
+ groupName = channel->Name();
+ channel = (cChannel *)channel->Next();
+ while (channel->GroupSep())
+ {
+ channel = (cChannel *)channel->Next();
+ }
+ PilotChannelNumber = channel->Number();
+ UpdateEPGInfo(1);
+ DrawMenu(-16,1);
+ }
+ }
+ }
+ lastTime = cTimeMs::Now();
+ break;
+ }
+ case kUp|k_Repeat:
+ case kUp:
+ if (config.fastbrowse)
+ {
+ // Scroll back in time
+ UpdateEPGInfo(3);
+ DrawMenu(0,0);
+ return osContinue;
+ }
+ else
+ {
+ CursorUp();
+ cChannel *channel = Channels.GetByNumber(PilotChannelNumber);
+ if (channel)
+ group = channel->Index()-1;
+ break;
+ }
+ case kDown|k_Repeat:
+ case kDown:
+ if (config.fastbrowse)
+ {
+ // Scroll forward in time
+ UpdateEPGInfo(2);
+ DrawMenu(0,0);
+ return osContinue;
+ }
+ else
+ {
+ CursorDown();
+ cChannel *channel = Channels.GetByNumber(PilotChannelNumber);
+ if (channel)
+ group = channel->Index()-1;
+ break;
+ }
+ case kNone:
+ if (number && (int)cTimeMs::Now() - lastTime > 1000)
+ {
+ if (Channels.GetByNumber(number))
+ {
+ PilotChannelNumber = number;
+ lastTime = cTimeMs::Now();
+ number = 0;
+ cChannel *channel = Channels.GetByNumber(PilotChannelNumber);
+ if (channel)
+ group = channel->Index()-1;
+ }
+ else
+ {
+ number = 0;
+ lastTime = cTimeMs::Now();
+ return osContinue;
+ }
+ UpdateEPGInfo(1);
+ DrawMenu(0,0);
+ return osContinue;
+ }
+ break;
+ case kOk:
+ {
+ // cn if (group>=-1) {
+ // number = 0;
+ // PilotChannelNumber = Channels.Get(Channels.GetNextNormal(group))->Number();
+ CursorOK();
+ if (config.closeonswitch) return osEnd;
+ else break;
+ }
+ case kRed:
+ {
+ if (Present)
+ {
+ extraInfo = true;
+ DisplayTimer();
+ }
+ return osContinue;
+ }
+ break;
+ case kInfo:
+ case kGreen:
+ {
+ if (Present)
+ {
+ // Display extra infos
+ extraInfo = true;
+ offset = 0;
+ type = 2; // PRESENT
+ DisplayExtraInfo();
+ return osContinue;
+ }
+ }
+ break;
+ case kYellow|k_Repeat:
+ case kYellow:
+ {
+ // Scroll back in time
+ UpdateEPGInfo(3);
+ DrawMenu(0,0);
+ return osContinue;
+ }
+ break;
+ case kBlue|k_Repeat:
+ case kBlue:
+ {
+ // Scroll back in time
+ UpdateEPGInfo(2);
+ DrawMenu(0,0);
+ return osContinue;
+ }
+ break;
+ default:
+ return state;
+ };
+ if ((int)cTimeMs::Now() - lastTime < 5000)
+ {
+ DrawMenu(0,0);
+ return osContinue;
+ }
+ }
+ else if (displayEvent)
+ {
+ switch (Key)
+ {
+ case kUser1 ... kUser9:
+ {
+ return osEnd;
+ }
+ case kBack:
+ {
+ // Display normal info
+ extraInfo = false;
+ DisplayBitmap();
+ DrawMenu(0,0);
+ DisplayBitmap();
+ return osContinue;
+ }
+ case kOk:
+ {
+ extraInfo = false;
+ CursorOK();
+ if (config.closeonswitch) return osEnd;
+ else break;
+ }
+ case kRed:
+ {
+ if (Present)
+ {
+ extraInfo = true;
+ DisplayTimer();
+ }
+ return osContinue;
+ break;
+ }
+ case kInfo:
+ case kGreen:
+ {
+ if (Present)
+ {
+ // Display normal info
+ extraInfo = false;
+ DisplayBitmap();
+ DrawMenu(0,0);
+ DisplayBitmap();
+ return osContinue;
+ }
+ break;
+ }
+ default:
+ state = displayEvent->ProcessKey(Key);
+ return state;
+ };
+ }
+ return osContinue;
+}
+
+
+void cZappilotOsd::CursorUp()
+{
+ int n = PilotChannelNumber + 1;
+ cChannel *channel;
+ channel = Channels.GetByNumber(n, 1);
+ if (channel)
+ {
+ n = channel->Number();
+ PilotChannelNumber = n;
+ UpdateEPGInfo(1);
+ DrawMenu(-16,1);
+ }
+}
+
+
+void cZappilotOsd::CursorDown()
+{
+ int n = PilotChannelNumber - 1;
+ cChannel *channel;
+ channel = Channels.GetByNumber(n, -1);
+ if (channel)
+ {
+ n = channel->Number();
+ PilotChannelNumber = n;
+ UpdateEPGInfo(1);
+ DrawMenu(+16,1);
+ }
+}
+
+
+void cZappilotOsd::CursorOK()
+{
+ DrawMenu(0,2);
+ cChannel *Channel = Channels.GetByNumber(PilotChannelNumber);
+ if (Channel)
+ {
+ cDevice::PrimaryDevice()->SwitchChannel(Channel, true);
+ }
+}
+
+
+void cZappilotOsd::DrawMenu(int delta, int highlight)
+{
+ DisplayInfo(delta);
+}
+
+
+void cZappilotOsd::DisplayBitmap()
+{
+ // osd->Flush();
+ if (displayChannel)
+ {
+ displayChannel->Flush();
+ }
+ else if (displayEvent)
+ {
+ displayEvent->Display();
+ }
+ else if (displayTimer)
+ {
+ displayTimer->Display();
+ }
+}
+
+
+// to display channel Infos ...
+void cZappilotOsd::DisplayInfo(int delta)
+{
+ if (osd)
+ {
+ delete osd;
+ osd = NULL;
+ displayChannel = Skins.Current()->DisplayChannel(true);
+ }
+
+ if (displayEvent)
+ {
+ delete displayEvent;
+ displayEvent = NULL;
+ displayChannel = Skins.Current()->DisplayChannel(true);
+ }
+ else if (displayTimer)
+ {
+ delete displayTimer;
+ displayTimer = NULL;
+ displayChannel = Skins.Current()->DisplayChannel(true);
+ }
+ cChannel *channel = Channels.GetByNumber(PilotChannelNumber);
+
+ if (!isempty(titlePresentInfo))
+ {
+ displayChannel->SetChannel(channel, 0);
+ displayChannel->SetEvents(Present, Following);
+ }
+ else
+ {
+ displayChannel->SetChannel(channel, 0);
+ displayChannel->SetEvents(NULL, NULL);
+ }
+}
+
+
+void cZappilotOsd::DisplayExtraInfo()
+{
+ if (displayChannel)
+ {
+ delete displayChannel;
+ displayChannel = NULL;
+ }
+ else if (displayEvent)
+ {
+ delete displayEvent;
+ displayEvent = NULL;
+ }
+
+ displayEvent = new cMenuEvent(Present,false,true);
+ displayEvent->Display();
+}
+
+
+void cZappilotOsd::DisplayTimer()
+{
+
+ if (displayChannel)
+ {
+ delete displayChannel;
+ displayChannel = NULL;
+ }
+ else if (displayEvent)
+ {
+ delete displayEvent;
+ displayEvent = NULL;
+ }
+
+ cTimer *timer = new cTimer(Present);
+ cTimer *t = Timers.GetTimer(timer);
+ if (t)
+ {
+ delete timer;
+ timer = t;
+ }
+ displayTimer=new cMenuEditTimer(timer, !t);
+ displayTimer->Display();
+}
diff --git a/zappilotosd.h b/zappilotosd.h
new file mode 100644
index 0000000..4b4fe89
--- /dev/null
+++ b/zappilotosd.h
@@ -0,0 +1,62 @@
+#ifndef __ZAPPILOTOSD_H
+#define __ZAPPILOTOSD_H
+
+#include <vdr/osd.h>
+#include <vdr/menuitems.h>
+#include <vdr/menu.h>
+#include <vdr/skins.h>
+#include <ctype.h>
+
+#include <vdr/plugin.h>
+#include <vdr/menu.h>
+#include <time.h>
+#include "config.h"
+
+class cZappilotOsd : public cOsdObject
+{
+ private:
+
+ cOsd *osd;
+ cSkinDisplayChannel *displayChannel;
+ class cMenuEvent *displayEvent;
+ class cMenuEditTimer *displayTimer;
+ int lastTime;
+ int number;
+ int group;
+ char ChanName[255];
+ char ChanNumber[255];
+ int extraInfo;
+ const cEvent *Present;
+ const cEvent *Following;
+ const cEvent **pArray;
+ const char *textPresentInfo;
+ const char *textFollowingInfo;
+ const char *titlePresentInfo;
+ const char *titleFollowingInfo;
+ const char *subtitlePresentInfo;
+ const char *subtitleFollowingInfo;
+ int currentEvent;
+ int offset;
+ int lines;
+ int type;
+
+ public:
+ cZappilotOsd(void);
+ ~cZappilotOsd();
+ virtual void Show(void);
+ virtual eOSState ProcessKey(eKeys Key);
+
+ void CursorUp();
+ void CursorDown();
+ void CursorOK();
+
+ void UpdateEPGInfo(int NowPrevNext);
+ void DrawMenu(int delta, int highlight);
+ void DisplayBitmap(void);
+ void DisplayInfo(int delta);
+ void DisplayExtraInfo(void);
+ void DisplayTimer(void);
+ void DisplayChannel(const cChannel *Channel);
+};
+
+#endif //__ZAPPILOTOSD_H
diff --git a/zappilotsetup.c b/zappilotsetup.c
new file mode 100644
index 0000000..e0cb11c
--- /dev/null
+++ b/zappilotsetup.c
@@ -0,0 +1,30 @@
+/*
+ * zappilotsetup.c: A plugin for the Video Disk Recorder
+ *
+ * See the README file for copyright information and how to reach the author.
+ *
+ * $Id$
+ */
+
+#include "zappilotsetup.h"
+#include "config.h"
+
+cZappilotSetup::cZappilotSetup(void)
+{
+
+ CloseOnSwitch = config.closeonswitch;
+ Hidemenu = config.hidemenu;
+ FastBrowse = config.fastbrowse;
+
+ Add(new cMenuEditBoolItem(tr("Close on OK"), &CloseOnSwitch));
+ Add(new cMenuEditBoolItem( tr("Hide main menu entry"), &Hidemenu, tr("no"), tr("yes")));
+ Add(new cMenuEditBoolItem( tr("Fast browse"), &FastBrowse, tr("no"), tr("yes")));
+}
+
+
+void cZappilotSetup::Store(void)
+{
+ SetupStore("CloseOnSwitch", config.closeonswitch = CloseOnSwitch);
+ SetupStore("Hidemenu", config.hidemenu = Hidemenu);
+ SetupStore("FastBrowse", config.fastbrowse = FastBrowse);
+}
diff --git a/zappilotsetup.h b/zappilotsetup.h
new file mode 100644
index 0000000..422ae18
--- /dev/null
+++ b/zappilotsetup.h
@@ -0,0 +1,17 @@
+#ifndef __ZAPPILOTSETUP_H
+#define __ZAPPILOTSETUP_H
+
+#include <vdr/plugin.h>
+
+class cZappilotSetup : public cMenuSetupPage
+{
+ private:
+ int CloseOnSwitch;
+ int Hidemenu;
+ int FastBrowse;
+ protected:
+ virtual void Store(void);
+ public:
+ cZappilotSetup(void);
+};
+#endif //__ZAPPILOTSETUP_H