mirror of
https://github.com/vdr-projects/vdr.git
synced 2025-03-01 10:50:46 +00:00
Version 1.3.32
- Added some missing braces in remux.c (thanks to Wayne Keer for reporting this one). - Removed unused MAINMENUENTRY from svdrpdemo.c (thanks to Udo Richter for reporting this one). - Fixed appending sequence end code in cDvbPlayer::Goto() (thanks to Reinhard Nissl). - Fixed syncing in cRepacker (thanks to Reinhard Nissl). - Now always using stream id 0xE0 for the video stream, to avoid problems with post processing tools that choke on different ids (suggested by Reinhard Nissl). - Updated the Estonian OSD texts (thanks to Arthur Konovalov). - Fixed cDvbPlayer::SkipFrames() to properly handle radio recordings (thanks to Reinhard Nissl). - Updated the Swedish OSD texts (thanks to Tomas Prybil). - Updated the Slovenian OSD texts (thanks to Matjaz Thaler). - Updated the Danish OSD texts (thanks to Mogens Elneff). - Made LIRC command parsing more robust (thanks to Ville Skyttä). - Introduced a separate 'plugins-install' target in the Makefile (thanks to Daniel Thompson). - Re-introduced the code that waits for a tuner lock in VDR/device.c, since apparently some users actually need it. It's not active by default, you'll have to define the WAIT_FOR_TUNER_LOCK macro in that file if you need it (suggested by Malcolm Caldwell). - Adjusted the Makefile to the dvb-kernel driver on kernel 2.6 and up (thanks to Lauri Tischler). - Repeat keys are now ignored when waiting for a keypress to cancel an operation (thanks to Marko Mäkelä). - The main menu function of a plugin can now be activated through a key macro of the form "@plugin" even if that plugin doesn't have a main menu entry (using part of a patch by Hardy Flor, which originally implemented calling plugins from SVDRP). - The menu timeout handling is now done centrally in the main program loop. - Added missing help for the 'help' keyword in the SVDRP command PLUG. - The main menu function of a plugin can now be called programmatically through the static function cRemote::CallPlugin(). - The SVDRP command PLUG now has a new option 'main' which can be used to initiate a call to the main menu function of a plugin (using part of a patch by Hardy Flor). - The new command line option '--vfat' can be used to make VDR encode special characters in recording file names, even if it wasn't compiled with VFAT=1 (suggested by Peter Bieringer). The compile time option VFAT still exists and creates a VDR that always behaves as if it were called with '--vfat'. - Replaced the ':' delimiter between hour and minute in recording file names with a '.' under Linux, too. Existing recordings with ':' as delimiter will still work. - Implemented the SVDRP command MOVC (thanks to Andreas Brachold). - Added support for multiple audio language codes in ISO639LanguageDescriptors to 'libsi' (thanks to Marcel Wiesweg). - Changed the audio PID language codes to hold up to two 3 letter codes, separated by '+', to store separate languages broadcast in two channel audio mode. - If the preferred audio language is broadcast on a PID that has two different languages in the two stereo channels, the audio channel is now properly set when switching to such a channel (thanks to Mogens Elneff for his help in testing this). - Fixed some typos in MANUAL (thanks to Ville Skyttä). - Fixed the default value for "Setup/EPG bugfix level" (thanks to Ville Skyttä for reporting this one). - Fixed defining timers that only differ in the day of week (thanks to Patrick Rother for reporting this one). - Fixed converting summary.vdr files that would result in a very long 'short text' (thanks to Carsten Koch). - Implemented a hash for the channels to reduce the system load in the EIT scanning thread (based on a patch by Georg Acher).
This commit is contained in:
parent
ad40eaa28e
commit
d5c85f5ff8
23
CONTRIBUTORS
23
CONTRIBUTORS
@ -13,6 +13,7 @@ Carsten Koch <Carsten.Koch@icem.de>
|
|||||||
for suggesting that the "Back" button in replay mode should bring up the "Recordings" menu
|
for suggesting that the "Back" button in replay mode should bring up the "Recordings" menu
|
||||||
for fixing the watchdog timer if the program hangs in OSD activities
|
for fixing the watchdog timer if the program hangs in OSD activities
|
||||||
for his support in keeping the Premiere World channels up to date in 'channels.conf'
|
for his support in keeping the Premiere World channels up to date in 'channels.conf'
|
||||||
|
for fixing converting summary.vdr files that would result in a very long 'short text'
|
||||||
|
|
||||||
Plamen Ganev <pganev@com-it.net>
|
Plamen Ganev <pganev@com-it.net>
|
||||||
for fixing the frequency offset for Hotbird channels
|
for fixing the frequency offset for Hotbird channels
|
||||||
@ -588,6 +589,7 @@ Lauri Tischler <lauri.tischler@efore.fi>
|
|||||||
unavailable due to a recording on a different transponder
|
unavailable due to a recording on a different transponder
|
||||||
for reporting a compiler warning about virtual cConfig::Load() functions
|
for reporting a compiler warning about virtual cConfig::Load() functions
|
||||||
for reporting a warning about character comparison in libsi/si.c
|
for reporting a warning about character comparison in libsi/si.c
|
||||||
|
for adjusting the Makefile to the dvb-kernel driver on kernel 2.6 and up
|
||||||
|
|
||||||
Andy Carter <fruit@ukgateway.net>
|
Andy Carter <fruit@ukgateway.net>
|
||||||
for helping to test new DVB-T handling
|
for helping to test new DVB-T handling
|
||||||
@ -791,6 +793,7 @@ Malcolm Caldwell <malcolm.caldwell@ntu.edu.au>
|
|||||||
for modifying LOF handling to allow for C-band reception
|
for modifying LOF handling to allow for C-band reception
|
||||||
for reporting a crash in creating a new timer in case there is no device in the
|
for reporting a crash in creating a new timer in case there is no device in the
|
||||||
system that can actually receive any channel
|
system that can actually receive any channel
|
||||||
|
for suggesting to re-introduced the code that waits for a tuner lock in VDR/device.c
|
||||||
|
|
||||||
Ludwig Nussel <ludwig.nussel@web.de>
|
Ludwig Nussel <ludwig.nussel@web.de>
|
||||||
for making the LIRC thread avoid high CPU load in case the connection to LIRC gets lost
|
for making the LIRC thread avoid high CPU load in case the connection to LIRC gets lost
|
||||||
@ -828,6 +831,7 @@ Andreas Brachold <vdr04@deltab.de>
|
|||||||
umask settings
|
umask settings
|
||||||
for reporting that there are empty info.vdr files created if there is no EPG
|
for reporting that there are empty info.vdr files created if there is no EPG
|
||||||
info available
|
info available
|
||||||
|
for implementing the SVDRP command MOVC
|
||||||
|
|
||||||
Manuel Hartl <icecep@gmx.net>
|
Manuel Hartl <icecep@gmx.net>
|
||||||
for suggesting to extend the logging info when starting/stopping timers
|
for suggesting to extend the logging info when starting/stopping timers
|
||||||
@ -908,6 +912,7 @@ Hermann Gausterer <mrq1@gmx.net>
|
|||||||
|
|
||||||
Peter Bieringer <pb@bieringer.de>
|
Peter Bieringer <pb@bieringer.de>
|
||||||
for reporting a problem with duplicate recordings with the same file name
|
for reporting a problem with duplicate recordings with the same file name
|
||||||
|
for suggesting to implement the command line option '--vfat'
|
||||||
|
|
||||||
Alexander Damhuis <ad@phonedation.de>
|
Alexander Damhuis <ad@phonedation.de>
|
||||||
for reporting problems when deleting a timer that is currently recording
|
for reporting problems when deleting a timer that is currently recording
|
||||||
@ -978,6 +983,9 @@ Reinhard Nissl <rnissl@gmx.de>
|
|||||||
for fixing cDvbSpuBitmap::putPixel()
|
for fixing cDvbSpuBitmap::putPixel()
|
||||||
for implementing cAudioRepacker in remux.c
|
for implementing cAudioRepacker in remux.c
|
||||||
for modifying handling of audio packets for radio channels in remux.c
|
for modifying handling of audio packets for radio channels in remux.c
|
||||||
|
for suggesting to always use stream id 0xE0 for the video stream, to avoid problems
|
||||||
|
with post processing tools that choke on different ids
|
||||||
|
for fixing cDvbPlayer::SkipFrames() to properly handle radio recordings
|
||||||
|
|
||||||
Richard Robson <richard_robson@beeb.net>
|
Richard Robson <richard_robson@beeb.net>
|
||||||
for reporting freezing replay if a timer starts while in Transfer Mode from the
|
for reporting freezing replay if a timer starts while in Transfer Mode from the
|
||||||
@ -1153,6 +1161,7 @@ Wayne Keer <syphir@syphir.sytes.net>
|
|||||||
for reporting an unused variable from cTimer::GetWDayFromMDay()
|
for reporting an unused variable from cTimer::GetWDayFromMDay()
|
||||||
for reporting a spelling error in 'canceling'
|
for reporting a spelling error in 'canceling'
|
||||||
for adding some 'mkdir -p' to the Makefile's 'install' target
|
for adding some 'mkdir -p' to the Makefile's 'install' target
|
||||||
|
for reporting some missing braces in remux.c
|
||||||
|
|
||||||
Marco Schlüßler <marco@lordzodiac.de>
|
Marco Schlüßler <marco@lordzodiac.de>
|
||||||
for fixing handling colors in cDvbSpuPalette::yuv2rgb()
|
for fixing handling colors in cDvbSpuPalette::yuv2rgb()
|
||||||
@ -1266,6 +1275,7 @@ Udo Richter <udo_richter@gmx.de>
|
|||||||
for suggesting a fix for an out-of-bounds memory access with audio language ids
|
for suggesting a fix for an out-of-bounds memory access with audio language ids
|
||||||
for reporting a problem with cRemux in a single thread
|
for reporting a problem with cRemux in a single thread
|
||||||
for adding 'Service' functions to the plugin interface
|
for adding 'Service' functions to the plugin interface
|
||||||
|
for reporting an unused MAINMENUENTRY in svdrpdemo.c
|
||||||
|
|
||||||
Sven Kreiensen <svenk@kammer.uni-hannover.de>
|
Sven Kreiensen <svenk@kammer.uni-hannover.de>
|
||||||
for his help in keeping 'channels.conf.terr' up to date
|
for his help in keeping 'channels.conf.terr' up to date
|
||||||
@ -1287,6 +1297,8 @@ Uwe Hanke <uhanke@gmx.de>
|
|||||||
|
|
||||||
Mogens Elneff <mogens@elneff.dk>
|
Mogens Elneff <mogens@elneff.dk>
|
||||||
for translating OSD texts to the Danish language
|
for translating OSD texts to the Danish language
|
||||||
|
for his help in testing automatically selecting the proper audio channel when
|
||||||
|
switching to a channel with two different languages on the same PID
|
||||||
|
|
||||||
Joachim Wilke <vdr@joachim-wilke.de>
|
Joachim Wilke <vdr@joachim-wilke.de>
|
||||||
for reporting missing calls to cStatus::MsgOsdClear() in cSkins::Message()
|
for reporting missing calls to cStatus::MsgOsdClear() in cSkins::Message()
|
||||||
@ -1382,6 +1394,9 @@ Roman Krenick
|
|||||||
Ville Skyttä <ville.skytta@iki.fi>
|
Ville Skyttä <ville.skytta@iki.fi>
|
||||||
for reporting several compiler warnings in gcc 4.0
|
for reporting several compiler warnings in gcc 4.0
|
||||||
for including the optional user defined Make.config from the 'libsi' Makefile
|
for including the optional user defined Make.config from the 'libsi' Makefile
|
||||||
|
for making LIRC command parsing more robust
|
||||||
|
for fixing some typos in MANUAL
|
||||||
|
for reporting that the default value for "Setup/EPG bugfix level" was wrong
|
||||||
|
|
||||||
Steffen Beyer <cpunk@reactor.de>
|
Steffen Beyer <cpunk@reactor.de>
|
||||||
for fixing setting the colored button help after deleting a recording in case the next
|
for fixing setting the colored button help after deleting a recording in case the next
|
||||||
@ -1389,6 +1404,7 @@ Steffen Beyer <cpunk@reactor.de>
|
|||||||
|
|
||||||
Daniel Thompson <daniel.thompson@st.com>
|
Daniel Thompson <daniel.thompson@st.com>
|
||||||
for fixing a memory leak in tComponent
|
for fixing a memory leak in tComponent
|
||||||
|
for introducing a separate 'plugins-install' target in the Makefile
|
||||||
|
|
||||||
Matthias Lötzke <Matthias@Loetzke.de>
|
Matthias Lötzke <Matthias@Loetzke.de>
|
||||||
for adding missing text internationalization for "Starting EPG scan"
|
for adding missing text internationalization for "Starting EPG scan"
|
||||||
@ -1414,6 +1430,7 @@ Georg Acher <acher@baycom.de>
|
|||||||
for avoiding unnecessary calls to getLength() in libsi/si.c, and avoiding the
|
for avoiding unnecessary calls to getLength() in libsi/si.c, and avoiding the
|
||||||
'& 0xff' in CRC32::crc32() of libsi/util.c
|
'& 0xff' in CRC32::crc32() of libsi/util.c
|
||||||
for suggesting to reduce the priority of the section handler threads
|
for suggesting to reduce the priority of the section handler threads
|
||||||
|
for a patch that was used to implement a hash for the channels
|
||||||
|
|
||||||
Henrik Niehaus <henrik.niehaus@gmx.de>
|
Henrik Niehaus <henrik.niehaus@gmx.de>
|
||||||
for reporting a problem with timers with a day given as MTWTF--@6, i.e. a repeating
|
for reporting a problem with timers with a day given as MTWTF--@6, i.e. a repeating
|
||||||
@ -1456,3 +1473,9 @@ Hardy Flor <HFlor@web.de>
|
|||||||
|
|
||||||
Harald Milz <hm@seneca.muc.de>
|
Harald Milz <hm@seneca.muc.de>
|
||||||
for his CUTR patch, which was used as a base to implement the SVDRP command EDIT
|
for his CUTR patch, which was used as a base to implement the SVDRP command EDIT
|
||||||
|
|
||||||
|
Marko Mäkelä <marko.makela@hut.fi>
|
||||||
|
for making repeat keys be ignored when waiting for a keypress to cancel an operation
|
||||||
|
|
||||||
|
Patrick Rother <krd-vdr@gulu.net>
|
||||||
|
for reporting a bug in defining timers that only differ in the day of week
|
||||||
|
62
HISTORY
62
HISTORY
@ -1114,7 +1114,7 @@ Video Disk Recorder Revision History
|
|||||||
Please check if your system provides 'killall' - if it doesn't, please change
|
Please check if your system provides 'killall' - if it doesn't, please change
|
||||||
this back in 'runvdr' and report this (thanks to Achim Lange).
|
this back in 'runvdr' and report this (thanks to Achim Lange).
|
||||||
- The "Commands" menu now automatically assigns number keys as hotkeys to the
|
- The "Commands" menu now automatically assigns number keys as hotkeys to the
|
||||||
commands. If you have preceeded your commands with digits you may want to
|
commands. If you have preceded your commands with digits you may want to
|
||||||
remove these from your 'commands.conf' file.
|
remove these from your 'commands.conf' file.
|
||||||
- The new Setup item "Restart" can be used to force a complete restart of VDR,
|
- The new Setup item "Restart" can be used to force a complete restart of VDR,
|
||||||
including reloading the driver. Note that this can only work if VDR and the
|
including reloading the driver. Note that this can only work if VDR and the
|
||||||
@ -3746,3 +3746,63 @@ Video Disk Recorder Revision History
|
|||||||
Hardy Flor).
|
Hardy Flor).
|
||||||
- The new SVDRP command EDIT can be used to start the editing process of a recording
|
- The new SVDRP command EDIT can be used to start the editing process of a recording
|
||||||
(based on the CUTR patch by Harald Milz).
|
(based on the CUTR patch by Harald Milz).
|
||||||
|
|
||||||
|
2005-09-11: Version 1.3.32
|
||||||
|
|
||||||
|
- Added some missing braces in remux.c (thanks to Wayne Keer for reporting this one).
|
||||||
|
- Removed unused MAINMENUENTRY from svdrpdemo.c (thanks to Udo Richter for reporting
|
||||||
|
this one).
|
||||||
|
- Fixed appending sequence end code in cDvbPlayer::Goto() (thanks to Reinhard Nissl).
|
||||||
|
- Fixed syncing in cRepacker (thanks to Reinhard Nissl).
|
||||||
|
- Now always using stream id 0xE0 for the video stream, to avoid problems with
|
||||||
|
post processing tools that choke on different ids (suggested by Reinhard Nissl).
|
||||||
|
- Updated the Estonian OSD texts (thanks to Arthur Konovalov).
|
||||||
|
- Fixed cDvbPlayer::SkipFrames() to properly handle radio recordings (thanks to
|
||||||
|
Reinhard Nissl).
|
||||||
|
- Updated the Swedish OSD texts (thanks to Tomas Prybil).
|
||||||
|
- Updated the Slovenian OSD texts (thanks to Matjaz Thaler).
|
||||||
|
- Updated the Danish OSD texts (thanks to Mogens Elneff).
|
||||||
|
- Made LIRC command parsing more robust (thanks to Ville Skyttä).
|
||||||
|
- Introduced a separate 'plugins-install' target in the Makefile (thanks to Daniel
|
||||||
|
Thompson).
|
||||||
|
- Re-introduced the code that waits for a tuner lock in VDR/device.c, since
|
||||||
|
apparently some users actually need it. It's not active by default, you'll have
|
||||||
|
to define the WAIT_FOR_TUNER_LOCK macro in that file if you need it (suggested
|
||||||
|
by Malcolm Caldwell).
|
||||||
|
- Adjusted the Makefile to the dvb-kernel driver on kernel 2.6 and up (thanks to
|
||||||
|
Lauri Tischler).
|
||||||
|
- Repeat keys are now ignored when waiting for a keypress to cancel an operation
|
||||||
|
(thanks to Marko Mäkelä).
|
||||||
|
- The main menu function of a plugin can now be activated through a key macro of
|
||||||
|
the form "@plugin" even if that plugin doesn't have a main menu entry (using
|
||||||
|
part of a patch by Hardy Flor, which originally implemented calling plugins from
|
||||||
|
SVDRP).
|
||||||
|
- The menu timeout handling is now done centrally in the main program loop.
|
||||||
|
- Added missing help for the 'help' keyword in the SVDRP command PLUG.
|
||||||
|
- The main menu function of a plugin can now be called programmatically through
|
||||||
|
the static function cRemote::CallPlugin().
|
||||||
|
- The SVDRP command PLUG now has a new option 'main' which can be used to initiate
|
||||||
|
a call to the main menu function of a plugin (using part of a patch by Hardy Flor).
|
||||||
|
- The new command line option '--vfat' can be used to make VDR encode special
|
||||||
|
characters in recording file names, even if it wasn't compiled with VFAT=1
|
||||||
|
(suggested by Peter Bieringer). The compile time option VFAT still exists and
|
||||||
|
creates a VDR that always behaves as if it were called with '--vfat'.
|
||||||
|
- Replaced the ':' delimiter between hour and minute in recording file names with
|
||||||
|
a '.' under Linux, too. Existing recordings with ':' as delimiter will still work.
|
||||||
|
- Implemented the SVDRP command MOVC (thanks to Andreas Brachold).
|
||||||
|
- Added support for multiple audio language codes in ISO639LanguageDescriptors to
|
||||||
|
'libsi' (thanks to Marcel Wiesweg).
|
||||||
|
- Changed the audio PID language codes to hold up to two 3 letter codes, separated
|
||||||
|
by '+', to store separate languages broadcast in two channel audio mode.
|
||||||
|
- If the preferred audio language is broadcast on a PID that has two different
|
||||||
|
languages in the two stereo channels, the audio channel is now properly set when
|
||||||
|
switching to such a channel (thanks to Mogens Elneff for his help in testing this).
|
||||||
|
- Fixed some typos in MANUAL (thanks to Ville Skyttä).
|
||||||
|
- Fixed the default value for "Setup/EPG bugfix level" (thanks to Ville Skyttä for
|
||||||
|
reporting this one).
|
||||||
|
- Fixed defining timers that only differ in the day of week (thanks to Patrick
|
||||||
|
Rother for reporting this one).
|
||||||
|
- Fixed converting summary.vdr files that would result in a very long 'short text'
|
||||||
|
(thanks to Carsten Koch).
|
||||||
|
- Implemented a hash for the channels to reduce the system load in the EIT scanning
|
||||||
|
thread (based on a patch by Georg Acher).
|
||||||
|
26
INSTALL
26
INSTALL
@ -23,18 +23,21 @@ mode you want.
|
|||||||
Compiling and running the program:
|
Compiling and running the program:
|
||||||
----------------------------------
|
----------------------------------
|
||||||
|
|
||||||
Make sure the files from this package are located in a
|
VDR requires the Linux-DVB driver header files to compile.
|
||||||
directory that is "parallel" to the DVB directory of the
|
As of kernel 2.6 these are part of the official Linux kernel
|
||||||
driver source for the Siemens DVB-S PCI card (refer to
|
distribution, and VDR's Makefile will automatically locate
|
||||||
http://linuxtv.org/dvb/siemens_dvb.html for more information
|
them. If you are using kernel 2.4 or earlier, you should
|
||||||
about that driver). For example, if the DVB driver was
|
install the files from this package in a directory that is
|
||||||
extracted into the directory /home/kls/vdr/DVB, then this
|
"parallel" to the DVB directory of the driver source (refer to
|
||||||
package should be extracted into /home/kls/vdr/VDR.
|
http://linuxtv.org for more information about that driver).
|
||||||
|
For example, if the DVB driver was extracted into the directory
|
||||||
|
/home/kls/vdr/DVB, then this package should be extracted into
|
||||||
|
/home/kls/vdr/VDR.
|
||||||
If you have the DVB driver source in a different location
|
If you have the DVB driver source in a different location
|
||||||
you will have to change the definition of DVBDIR in the
|
you can rename the file Make.config.template to Make.config and
|
||||||
Makefile (see the file Make.config.template).
|
adjust the definition of DVBDIR in that file.
|
||||||
|
|
||||||
VDR requires the Linux-DVB card driver version dated 2003-08-23 or higher
|
VDR requires the Linux-DVB driver version dated 2003-08-23 or higher
|
||||||
to work properly.
|
to work properly.
|
||||||
|
|
||||||
After extracting the package, change into the VDR directory
|
After extracting the package, change into the VDR directory
|
||||||
@ -68,7 +71,8 @@ time switch
|
|||||||
|
|
||||||
VFAT=1
|
VFAT=1
|
||||||
|
|
||||||
to the 'make' command.
|
to the 'make' command. Alternatively, you can call VDR with the command
|
||||||
|
line option '--vfat'.
|
||||||
|
|
||||||
When running, the 'vdr' program writes status information into the
|
When running, the 'vdr' program writes status information into the
|
||||||
system log file (/var/log/messages). You may want to watch these
|
system log file (/var/log/messages). You may want to watch these
|
||||||
|
12
MANUAL
12
MANUAL
@ -77,7 +77,7 @@ Version 1.2
|
|||||||
"by name" and "by provider".
|
"by name" and "by provider".
|
||||||
(4) In the "Timers" menu, when on the "Day" item, the '0' key toggles between
|
(4) In the "Timers" menu, when on the "Day" item, the '0' key toggles between
|
||||||
a single shot and a repeating timer. If "Day" indicates a repeating timer,
|
a single shot and a repeating timer. If "Day" indicates a repeating timer,
|
||||||
the keys '1'...'7' can be used to toggle the individual days ('1' is monday).
|
the keys '1'...'7' can be used to toggle the individual days ('1' is Monday).
|
||||||
|
|
||||||
* Navigating through the On Screen Menus
|
* Navigating through the On Screen Menus
|
||||||
|
|
||||||
@ -342,7 +342,7 @@ Version 1.2
|
|||||||
mark, and a triangle at the bottom means that this is an "end" mark.
|
mark, and a triangle at the bottom means that this is an "end" mark.
|
||||||
The cutting process will save all video data between "start" and "end" marks
|
The cutting process will save all video data between "start" and "end" marks
|
||||||
into a new file (the original recording remains untouched). The new file will
|
into a new file (the original recording remains untouched). The new file will
|
||||||
have the same name as the original recording, preceeded with a '%' character
|
have the same name as the original recording, preceded with a '%' character
|
||||||
(imagine the '%' somehow looking like a pair of scissors ;-). Red bars in the
|
(imagine the '%' somehow looking like a pair of scissors ;-). Red bars in the
|
||||||
progress display indicate which video sequences will be saved by the cutting
|
progress display indicate which video sequences will be saved by the cutting
|
||||||
process.
|
process.
|
||||||
@ -376,7 +376,7 @@ Version 1.2
|
|||||||
The parameters in the "Edit Timer" menu have the following meanings:
|
The parameters in the "Edit Timer" menu have the following meanings:
|
||||||
|
|
||||||
Active: Defines whether the timer will be processed (set it to 'no' to
|
Active: Defines whether the timer will be processed (set it to 'no' to
|
||||||
temporarily desable a timer).
|
temporarily disable a timer).
|
||||||
Channel: The channel to be recorded (as defined in the "Channels" list).
|
Channel: The channel to be recorded (as defined in the "Channels" list).
|
||||||
Any changes made in the "Channels" list (like renaming or
|
Any changes made in the "Channels" list (like renaming or
|
||||||
reordering channels) will be automatically reflected in the
|
reordering channels) will be automatically reflected in the
|
||||||
@ -386,11 +386,11 @@ Version 1.2
|
|||||||
timer that hits once and is deleted after it ends.
|
timer that hits once and is deleted after it ends.
|
||||||
Another option here are "repeating timers" which are defined
|
Another option here are "repeating timers" which are defined
|
||||||
by listing the days of the week on which they shall record.
|
by listing the days of the week on which they shall record.
|
||||||
For example, a timer that shall record every monday and wednesday
|
For example, a timer that shall record every Monday and Wednesday
|
||||||
would have a Day setting of "M-W----".
|
would have a Day setting of "M-W----".
|
||||||
The '0' key toggles between a single shot and a repeating timer.
|
The '0' key toggles between a single shot and a repeating timer.
|
||||||
If "Day" indicates a repeating timer, the keys '1'...'7' can be
|
If "Day" indicates a repeating timer, the keys '1'...'7' can be
|
||||||
used to toggle the individual days ('1' is monday).
|
used to toggle the individual days ('1' is Monday).
|
||||||
You can also switch to a set of predefined repeating timer settings
|
You can also switch to a set of predefined repeating timer settings
|
||||||
by pressing the "Left" key when the day is the present day. To return
|
by pressing the "Left" key when the day is the present day. To return
|
||||||
to the single shot mode just press "Right" until a date is displayed.
|
to the single shot mode just press "Right" until a date is displayed.
|
||||||
@ -545,7 +545,7 @@ Version 1.2
|
|||||||
Set system time = no Defines whether the system time will be set according to
|
Set system time = no Defines whether the system time will be set according to
|
||||||
the time received from the DVB data stream.
|
the time received from the DVB data stream.
|
||||||
Note that this works only if VDR is running under a user
|
Note that this works only if VDR is running under a user
|
||||||
id that has permisson to set the system time. You also
|
id that has permission to set the system time. You also
|
||||||
need to set the option "Use time from transponder" to a
|
need to set the option "Use time from transponder" to a
|
||||||
channel that you trust to transmit a reliable time base
|
channel that you trust to transmit a reliable time base
|
||||||
(not all channels seem to have access to a correct time
|
(not all channels seem to have access to a correct time
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
# See the main source file 'vdr.c' for copyright information and
|
# See the main source file 'vdr.c' for copyright information and
|
||||||
# how to reach the author.
|
# how to reach the author.
|
||||||
#
|
#
|
||||||
# $Id: Make.config.template 1.5 2005/07/31 11:35:28 kls Exp $
|
# $Id: Make.config.template 1.6 2005/09/02 14:24:31 kls Exp $
|
||||||
|
|
||||||
### The C compiler and options:
|
### The C compiler and options:
|
||||||
|
|
||||||
@ -18,7 +18,7 @@ CXXFLAGS = -fPIC -g -O2 -Wall -Woverloaded-virtual
|
|||||||
|
|
||||||
### The directory environment:
|
### The directory environment:
|
||||||
|
|
||||||
DVBDIR = ../DVB
|
#DVBDIR = ../DVB
|
||||||
MANDIR = /usr/local/man
|
MANDIR = /usr/local/man
|
||||||
BINDIR = /usr/local/bin
|
BINDIR = /usr/local/bin
|
||||||
|
|
||||||
|
17
Makefile
17
Makefile
@ -4,7 +4,7 @@
|
|||||||
# See the main source file 'vdr.c' for copyright information and
|
# See the main source file 'vdr.c' for copyright information and
|
||||||
# how to reach the author.
|
# how to reach the author.
|
||||||
#
|
#
|
||||||
# $Id: Makefile 1.77 2005/08/14 11:42:20 kls Exp $
|
# $Id: Makefile 1.79 2005/09/02 14:23:38 kls Exp $
|
||||||
|
|
||||||
.DELETE_ON_ERROR:
|
.DELETE_ON_ERROR:
|
||||||
|
|
||||||
@ -14,7 +14,16 @@ CFLAGS ?= -O2
|
|||||||
CXX ?= g++
|
CXX ?= g++
|
||||||
CXXFLAGS ?= -fPIC -g -O2 -Wall -Woverloaded-virtual
|
CXXFLAGS ?= -fPIC -g -O2 -Wall -Woverloaded-virtual
|
||||||
|
|
||||||
|
LINUX_VERSION := $(shell uname -r | cut -c-3)
|
||||||
|
LINUX := $(shell uname -r)
|
||||||
|
DVBDIR := /lib/modules/$(LINUX)/build
|
||||||
|
ifeq ($(LINUX_VERSION), 2.4)
|
||||||
DVBDIR = ../DVB
|
DVBDIR = ../DVB
|
||||||
|
endif
|
||||||
|
ifeq ($(LINUX_VERSION), 2.2)
|
||||||
|
DVBDIR = ../DVB
|
||||||
|
endif
|
||||||
|
|
||||||
LSIDIR = ./libsi
|
LSIDIR = ./libsi
|
||||||
MANDIR = /usr/local/man
|
MANDIR = /usr/local/man
|
||||||
BINDIR = /usr/local/bin
|
BINDIR = /usr/local/bin
|
||||||
@ -185,8 +194,6 @@ plugins-clean:
|
|||||||
install:
|
install:
|
||||||
@mkdir -p $(BINDIR)
|
@mkdir -p $(BINDIR)
|
||||||
@cp vdr runvdr $(BINDIR)
|
@cp vdr runvdr $(BINDIR)
|
||||||
@mkdir -p $(BINDIR)/$(PLUGINLIBDIR)
|
|
||||||
@cp $(PLUGINLIBDIR)/* $(BINDIR)/$(PLUGINLIBDIR)
|
|
||||||
@mkdir -p $(MANDIR)/man1
|
@mkdir -p $(MANDIR)/man1
|
||||||
@mkdir -p $(MANDIR)/man5
|
@mkdir -p $(MANDIR)/man5
|
||||||
@gzip -c vdr.1 > $(MANDIR)/man1/vdr.1.gz
|
@gzip -c vdr.1 > $(MANDIR)/man1/vdr.1.gz
|
||||||
@ -196,6 +203,10 @@ install:
|
|||||||
cp *.conf $(VIDEODIR);\
|
cp *.conf $(VIDEODIR);\
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
plugins-install:
|
||||||
|
@mkdir -p $(BINDIR)/$(PLUGINLIBDIR)
|
||||||
|
@cp $(PLUGINLIBDIR)/* $(BINDIR)/$(PLUGINLIBDIR)
|
||||||
|
|
||||||
# Source documentation:
|
# Source documentation:
|
||||||
|
|
||||||
srcdoc:
|
srcdoc:
|
||||||
|
@ -273,7 +273,7 @@ file (or rather its contents, to be precise) from being included more than once,
|
|||||||
|
|
||||||
The example shown here is the way VDR does this in its core source files.
|
The example shown here is the way VDR does this in its core source files.
|
||||||
It takes the header file's name, converts it to all uppercase, replaces the
|
It takes the header file's name, converts it to all uppercase, replaces the
|
||||||
dot with an underline and preceedes the whole thing with two underlines.
|
dot with an underline and precedes the whole thing with two underlines.
|
||||||
The GNU library header files do this pretty much the same way, except that they
|
The GNU library header files do this pretty much the same way, except that they
|
||||||
usually precede the name with only one underline (there are exceptions, though).
|
usually precede the name with only one underline (there are exceptions, though).
|
||||||
<p>
|
<p>
|
||||||
@ -655,7 +655,7 @@ used in the <a href="#The Setup menu"><i>Setup</i> menu</a>'s <tt>Store()</tt> f
|
|||||||
<p>
|
<p>
|
||||||
The plugin's setup parameters are stored in the same file as VDR's parameters.
|
The plugin's setup parameters are stored in the same file as VDR's parameters.
|
||||||
In order to allow each plugin (and VDR itself) to have its own set of parameters,
|
In order to allow each plugin (and VDR itself) to have its own set of parameters,
|
||||||
the <tt>Name</tt> of each parameter will be preceeded with the plugin's
|
the <tt>Name</tt> of each parameter will be preceded with the plugin's
|
||||||
name, as in
|
name, as in
|
||||||
<p>
|
<p>
|
||||||
<tt>hello.GreetingTime = 3</tt>
|
<tt>hello.GreetingTime = 3</tt>
|
||||||
@ -1031,7 +1031,7 @@ plugin was called, and will therefore process the values according to the
|
|||||||
particular plugin's definitions.
|
particular plugin's definitions.
|
||||||
<p>
|
<p>
|
||||||
The returned string may consist of several lines, separated by the newline character
|
The returned string may consist of several lines, separated by the newline character
|
||||||
('<tt>\n</tt>'). Each of these lines will be preceeded with the <tt>ReplyCode</tt>
|
('<tt>\n</tt>'). Each of these lines will be preceded with the <tt>ReplyCode</tt>
|
||||||
when presenting them to the caller, and the continuation character ('<tt>-</tt>')
|
when presenting them to the caller, and the continuation character ('<tt>-</tt>')
|
||||||
will be set for all but the last one.
|
will be set for all but the last one.
|
||||||
|
|
||||||
|
@ -4,3 +4,7 @@ VDR Plugin 'svdrpdemo' Revision History
|
|||||||
2005-08-27: Version 0.0.1
|
2005-08-27: Version 0.0.1
|
||||||
|
|
||||||
- Initial revision.
|
- Initial revision.
|
||||||
|
|
||||||
|
2005-08-28: Version 0.0.2
|
||||||
|
|
||||||
|
- Removed unused MAINMENUENTRY.
|
||||||
|
@ -3,14 +3,13 @@
|
|||||||
*
|
*
|
||||||
* See the README file for copyright information and how to reach the author.
|
* See the README file for copyright information and how to reach the author.
|
||||||
*
|
*
|
||||||
* $Id: svdrpdemo.c 1.1 2005/08/27 16:28:58 kls Exp $
|
* $Id: svdrpdemo.c 1.2 2005/08/28 21:11:14 kls Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <vdr/plugin.h>
|
#include <vdr/plugin.h>
|
||||||
|
|
||||||
static const char *VERSION = "0.0.1";
|
static const char *VERSION = "0.0.2";
|
||||||
static const char *DESCRIPTION = "How to add SVDRP support to a plugin";
|
static const char *DESCRIPTION = "How to add SVDRP support to a plugin";
|
||||||
static const char *MAINMENUENTRY = NULL;
|
|
||||||
|
|
||||||
class cPluginSvdrpdemo : public cPlugin {
|
class cPluginSvdrpdemo : public cPlugin {
|
||||||
private:
|
private:
|
||||||
|
67
channels.c
67
channels.c
@ -4,12 +4,13 @@
|
|||||||
* See the main source file 'vdr.c' for copyright information and
|
* See the main source file 'vdr.c' for copyright information and
|
||||||
* how to reach the author.
|
* how to reach the author.
|
||||||
*
|
*
|
||||||
* $Id: channels.c 1.44 2005/08/06 12:22:41 kls Exp $
|
* $Id: channels.c 1.46 2005/09/11 14:22:24 kls Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "channels.h"
|
#include "channels.h"
|
||||||
#include <linux/dvb/frontend.h>
|
#include <linux/dvb/frontend.h>
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
|
#include "device.h"
|
||||||
|
|
||||||
// IMPORTANT NOTE: in the 'sscanf()' calls there is a blank after the '%d'
|
// IMPORTANT NOTE: in the 'sscanf()' calls there is a blank after the '%d'
|
||||||
// format characters in order to allow any number of blanks after a numeric
|
// format characters in order to allow any number of blanks after a numeric
|
||||||
@ -341,11 +342,14 @@ void cChannel::SetId(int Nid, int Tid, int Sid, int Rid)
|
|||||||
dsyslog("changing id of channel %d from %d-%d-%d-%d to %d-%d-%d-%d", Number(), nid, tid, sid, rid, Nid, Tid, Sid, Rid);
|
dsyslog("changing id of channel %d from %d-%d-%d-%d to %d-%d-%d-%d", Number(), nid, tid, sid, rid, Nid, Tid, Sid, Rid);
|
||||||
modification |= CHANNELMOD_ID;
|
modification |= CHANNELMOD_ID;
|
||||||
Channels.SetModified();
|
Channels.SetModified();
|
||||||
|
Channels.UnhashChannel(this);
|
||||||
}
|
}
|
||||||
nid = Nid;
|
nid = Nid;
|
||||||
tid = Tid;
|
tid = Tid;
|
||||||
sid = Sid;
|
sid = Sid;
|
||||||
rid = Rid;
|
rid = Rid;
|
||||||
|
if (Number())
|
||||||
|
Channels.HashChannel(this);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -386,7 +390,7 @@ void cChannel::SetPortalName(const char *PortalName)
|
|||||||
#define STRDIFF 0x01
|
#define STRDIFF 0x01
|
||||||
#define VALDIFF 0x02
|
#define VALDIFF 0x02
|
||||||
|
|
||||||
static int IntArraysDiffer(const int *a, const int *b, const char na[][4] = NULL, const char nb[][4] = NULL)
|
static int IntArraysDiffer(const int *a, const int *b, const char na[][MAXLANGCODE2] = NULL, const char nb[][MAXLANGCODE2] = NULL)
|
||||||
{
|
{
|
||||||
int result = 0;
|
int result = 0;
|
||||||
for (int i = 0; a[i] || b[i]; i++) {
|
for (int i = 0; a[i] || b[i]; i++) {
|
||||||
@ -400,7 +404,7 @@ static int IntArraysDiffer(const int *a, const int *b, const char na[][4] = NULL
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int IntArrayToString(char *s, const int *a, int Base = 10, const char n[][4] = NULL)
|
static int IntArrayToString(char *s, const int *a, int Base = 10, const char n[][MAXLANGCODE2] = NULL)
|
||||||
{
|
{
|
||||||
char *q = s;
|
char *q = s;
|
||||||
int i = 0;
|
int i = 0;
|
||||||
@ -416,7 +420,7 @@ static int IntArrayToString(char *s, const int *a, int Base = 10, const char n[]
|
|||||||
return q - s;
|
return q - s;
|
||||||
}
|
}
|
||||||
|
|
||||||
void cChannel::SetPids(int Vpid, int Ppid, int *Apids, char ALangs[][4], int *Dpids, char DLangs[][4], int Tpid)
|
void cChannel::SetPids(int Vpid, int Ppid, int *Apids, char ALangs[][MAXLANGCODE2], int *Dpids, char DLangs[][MAXLANGCODE2], int Tpid)
|
||||||
{
|
{
|
||||||
int mod = CHANNELMOD_NONE;
|
int mod = CHANNELMOD_NONE;
|
||||||
if (vpid != Vpid || ppid != Ppid || tpid != Tpid)
|
if (vpid != Vpid || ppid != Ppid || tpid != Tpid)
|
||||||
@ -427,8 +431,9 @@ void cChannel::SetPids(int Vpid, int Ppid, int *Apids, char ALangs[][4], int *Dp
|
|||||||
if (m & VALDIFF)
|
if (m & VALDIFF)
|
||||||
mod |= CHANNELMOD_PIDS;
|
mod |= CHANNELMOD_PIDS;
|
||||||
if (mod) {
|
if (mod) {
|
||||||
char OldApidsBuf[(MAXAPIDS + MAXDPIDS) * 10 + 10]; // 10: 5 digits plus delimiting ',' or ';' plus optional '=cod', +10: paranoia
|
const int BufferSize = (MAXAPIDS + MAXDPIDS) * (5 + 1 + MAXLANGCODE2) + 10; // 5 digits plus delimiting ',' or ';' plus optional '=cod+cod', +10: paranoia
|
||||||
char NewApidsBuf[(MAXAPIDS + MAXDPIDS) * 10 + 10];
|
char OldApidsBuf[BufferSize];
|
||||||
|
char NewApidsBuf[BufferSize];
|
||||||
char *q = OldApidsBuf;
|
char *q = OldApidsBuf;
|
||||||
q += IntArrayToString(q, apids, 10, alangs);
|
q += IntArrayToString(q, apids, 10, alangs);
|
||||||
if (dpids[0]) {
|
if (dpids[0]) {
|
||||||
@ -448,12 +453,12 @@ void cChannel::SetPids(int Vpid, int Ppid, int *Apids, char ALangs[][4], int *Dp
|
|||||||
ppid = Ppid;
|
ppid = Ppid;
|
||||||
for (int i = 0; i < MAXAPIDS; i++) {
|
for (int i = 0; i < MAXAPIDS; i++) {
|
||||||
apids[i] = Apids[i];
|
apids[i] = Apids[i];
|
||||||
strn0cpy(alangs[i], ALangs[i], 4);
|
strn0cpy(alangs[i], ALangs[i], MAXLANGCODE2);
|
||||||
}
|
}
|
||||||
apids[MAXAPIDS] = 0;
|
apids[MAXAPIDS] = 0;
|
||||||
for (int i = 0; i < MAXDPIDS; i++) {
|
for (int i = 0; i < MAXDPIDS; i++) {
|
||||||
dpids[i] = Dpids[i];
|
dpids[i] = Dpids[i];
|
||||||
strn0cpy(dlangs[i], DLangs[i], 4);
|
strn0cpy(dlangs[i], DLangs[i], MAXLANGCODE2);
|
||||||
}
|
}
|
||||||
dpids[MAXDPIDS] = 0;
|
dpids[MAXDPIDS] = 0;
|
||||||
tpid = Tpid;
|
tpid = Tpid;
|
||||||
@ -633,7 +638,8 @@ cString cChannel::ToText(const cChannel *Channel)
|
|||||||
if (Channel->ppid && Channel->ppid != Channel->vpid)
|
if (Channel->ppid && Channel->ppid != Channel->vpid)
|
||||||
q += snprintf(q, sizeof(vpidbuf) - (q - vpidbuf), "+%d", Channel->ppid);
|
q += snprintf(q, sizeof(vpidbuf) - (q - vpidbuf), "+%d", Channel->ppid);
|
||||||
*q = 0;
|
*q = 0;
|
||||||
char apidbuf[(MAXAPIDS + MAXDPIDS) * 10 + 10]; // 10: 5 digits plus delimiting ',' or ';' plus optional '=cod', +10: paranoia
|
const int BufferSize = (MAXAPIDS + MAXDPIDS) * (5 + 1 + MAXLANGCODE2) + 10; // 5 digits plus delimiting ',' or ';' plus optional '=cod+cod', +10: paranoia
|
||||||
|
char apidbuf[BufferSize];
|
||||||
q = apidbuf;
|
q = apidbuf;
|
||||||
q += IntArrayToString(q, Channel->apids, 10, Channel->alangs);
|
q += IntArrayToString(q, Channel->apids, 10, Channel->alangs);
|
||||||
if (Channel->dpids[0]) {
|
if (Channel->dpids[0]) {
|
||||||
@ -722,7 +728,7 @@ bool cChannel::Parse(const char *s)
|
|||||||
char *l = strchr(q, '=');
|
char *l = strchr(q, '=');
|
||||||
if (l) {
|
if (l) {
|
||||||
*l++ = 0;
|
*l++ = 0;
|
||||||
strn0cpy(alangs[NumApids], l, 4);
|
strn0cpy(alangs[NumApids], l, MAXLANGCODE2);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
*alangs[NumApids] = 0;
|
*alangs[NumApids] = 0;
|
||||||
@ -743,7 +749,7 @@ bool cChannel::Parse(const char *s)
|
|||||||
char *l = strchr(q, '=');
|
char *l = strchr(q, '=');
|
||||||
if (l) {
|
if (l) {
|
||||||
*l++ = 0;
|
*l++ = 0;
|
||||||
strn0cpy(dlangs[NumDpids], l, 4);
|
strn0cpy(dlangs[NumDpids], l, MAXLANGCODE2);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
*dlangs[NumDpids] = 0;
|
*dlangs[NumDpids] = 0;
|
||||||
@ -865,6 +871,16 @@ bool cChannels::Load(const char *FileName, bool AllowComments, bool MustExist)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void cChannels::HashChannel(cChannel *Channel)
|
||||||
|
{
|
||||||
|
channelsHashSid.Add(Channel, Channel->Sid());
|
||||||
|
}
|
||||||
|
|
||||||
|
void cChannels::UnhashChannel(cChannel *Channel)
|
||||||
|
{
|
||||||
|
channelsHashSid.Del(Channel, Channel->Sid());
|
||||||
|
}
|
||||||
|
|
||||||
int cChannels::GetNextGroup(int Idx)
|
int cChannels::GetNextGroup(int Idx)
|
||||||
{
|
{
|
||||||
cChannel *channel = Get(++Idx);
|
cChannel *channel = Get(++Idx);
|
||||||
@ -891,6 +907,7 @@ int cChannels::GetNextNormal(int Idx)
|
|||||||
|
|
||||||
void cChannels::ReNumber( void )
|
void cChannels::ReNumber( void )
|
||||||
{
|
{
|
||||||
|
channelsHashSid.Clear();
|
||||||
int Number = 1;
|
int Number = 1;
|
||||||
for (cChannel *channel = First(); channel; channel = Next(channel)) {
|
for (cChannel *channel = First(); channel; channel = Next(channel)) {
|
||||||
if (channel->GroupSep()) {
|
if (channel->GroupSep()) {
|
||||||
@ -898,6 +915,7 @@ void cChannels::ReNumber( void )
|
|||||||
Number = channel->Number();
|
Number = channel->Number();
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
HashChannel(channel);
|
||||||
maxNumber = Number;
|
maxNumber = Number;
|
||||||
channel->SetNumber(Number++);
|
channel->SetNumber(Number++);
|
||||||
}
|
}
|
||||||
@ -921,33 +939,44 @@ cChannel *cChannels::GetByNumber(int Number, int SkipGap)
|
|||||||
|
|
||||||
cChannel *cChannels::GetByServiceID(int Source, int Transponder, unsigned short ServiceID)
|
cChannel *cChannels::GetByServiceID(int Source, int Transponder, unsigned short ServiceID)
|
||||||
{
|
{
|
||||||
for (cChannel *channel = First(); channel; channel = Next(channel)) {
|
cList<cHashObject> *list = channelsHashSid.GetList(ServiceID);
|
||||||
if (!channel->GroupSep() && channel->Source() == Source && ISTRANSPONDER(channel->Transponder(), Transponder) && channel->Sid() == ServiceID)
|
if (list) {
|
||||||
|
for (cHashObject *hobj = list->First(); hobj; hobj = list->Next(hobj)) {
|
||||||
|
cChannel *channel = (cChannel *)hobj->Object();
|
||||||
|
if (channel->Sid() == ServiceID && channel->Source() == Source && ISTRANSPONDER(channel->Transponder(), Transponder))
|
||||||
return channel;
|
return channel;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
cChannel *cChannels::GetByChannelID(tChannelID ChannelID, bool TryWithoutRid, bool TryWithoutPolarization)
|
cChannel *cChannels::GetByChannelID(tChannelID ChannelID, bool TryWithoutRid, bool TryWithoutPolarization)
|
||||||
{
|
{
|
||||||
for (cChannel *channel = First(); channel; channel = Next(channel)) {
|
int sid = ChannelID.Sid();
|
||||||
if (!channel->GroupSep() && channel->GetChannelID() == ChannelID)
|
cList<cHashObject> *list = channelsHashSid.GetList(sid);
|
||||||
|
if (list) {
|
||||||
|
for (cHashObject *hobj = list->First(); hobj; hobj = list->Next(hobj)) {
|
||||||
|
cChannel *channel = (cChannel *)hobj->Object();
|
||||||
|
if (channel->Sid() == sid && channel->GetChannelID() == ChannelID)
|
||||||
return channel;
|
return channel;
|
||||||
}
|
}
|
||||||
if (TryWithoutRid) {
|
if (TryWithoutRid) {
|
||||||
ChannelID.ClrRid();
|
ChannelID.ClrRid();
|
||||||
for (cChannel *channel = First(); channel; channel = Next(channel)) {
|
for (cHashObject *hobj = list->First(); hobj; hobj = list->Next(hobj)) {
|
||||||
if (!channel->GroupSep() && channel->GetChannelID().ClrRid() == ChannelID)
|
cChannel *channel = (cChannel *)hobj->Object();
|
||||||
|
if (channel->Sid() == sid && channel->GetChannelID().ClrRid() == ChannelID)
|
||||||
return channel;
|
return channel;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (TryWithoutPolarization) {
|
if (TryWithoutPolarization) {
|
||||||
ChannelID.ClrPolarization();
|
ChannelID.ClrPolarization();
|
||||||
for (cChannel *channel = First(); channel; channel = Next(channel)) {
|
for (cHashObject *hobj = list->First(); hobj; hobj = list->Next(hobj)) {
|
||||||
if (!channel->GroupSep() && channel->GetChannelID().ClrPolarization() == ChannelID)
|
cChannel *channel = (cChannel *)hobj->Object();
|
||||||
|
if (channel->Sid() == sid && channel->GetChannelID().ClrPolarization() == ChannelID)
|
||||||
return channel;
|
return channel;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,12 +1,12 @@
|
|||||||
RTL Television,RTL;RTL World:12187:hC34:S19.2E:27500:163:104=deu:105:0:12003:1:1089:0
|
RTL Television,RTL;RTL World:12187:hC34:S19.2E:27500:163:104=deu:105:0:12003:1:1089:0
|
||||||
SAT.1;ProSiebenSat.1:12480:vC34:S19.2E:27500:1791:1792=deu;1795=deu:34:0:46:133:33:0
|
SAT.1;ProSiebenSat.1:12480:vC34:S19.2E:27500:1791:1792=deu;1795=deu:34:0:46:133:33:0
|
||||||
ProSieben;ProSiebenSat.1:12480:vC34:S19.2E:27500:255:256=deu;257=deu:32:0:898:133:33:0
|
ProSieben;ProSiebenSat.1:12480:vC34:S19.2E:27500:0:0:0:0:898:133:33:0
|
||||||
RTL2;RTL World:12187:hC34:S19.2E:27500:166:128=deu:68:0:12020:1:1089:0
|
RTL2;RTL World:12187:hC34:S19.2E:27500:166:128=deu:68:0:12020:1:1089:0
|
||||||
Das Erste;ARD:11836:hC34:S19.2E:27500:101:102=deu:104:0:28106:1:1101:0
|
Das Erste;ARD:11836:hC34:S19.2E:27500:101:102=deu:104:0:28106:1:1101:0
|
||||||
Bayerisches FS;ARD:11836:hC34:S19.2E:27500:201:202=deu:204:0:28107:1:1101:0
|
Bayerisches FS;ARD:11836:hC34:S19.2E:27500:201:202=deu:204:0:28107:1:1101:0
|
||||||
hr-fernsehen;ARD:11836:hC34:S19.2E:27500:301:302=deu:304:0:28108:1:1101:0
|
hr-fernsehen;ARD:11836:hC34:S19.2E:27500:301:302=deu:304:0:28108:1:1101:0
|
||||||
NDR FS MV;ARD:12109:hC34:S19.2E:27500:301:302=deu:2404:0:28224:1:1073:0
|
NDR FS MV;ARD:12109:hC34:S19.2E:27500:2401:2402=deu:2404:0:28224:1:1073:0
|
||||||
SR SÜDWEST Ferns.;ARD:11836:hC34:S19.2E:27500:501:502=deu:504:0:28110:1:1101:0
|
SR SÜDWEST Fernsehen;ARD:12265:hC34:S19.2E:27500:1301:1302=deu:1304:0:28486:1:1093:0
|
||||||
WDR Köln;ARD:11836:hC34:S19.2E:27500:601:602=deu:604:0:28111:1:1101:0
|
WDR Köln;ARD:11836:hC34:S19.2E:27500:601:602=deu:604:0:28111:1:1101:0
|
||||||
BR-alpha;ARD:11836:hC34:S19.2E:27500:701:702=deu:704:0:28112:1:1101:0
|
BR-alpha;ARD:11836:hC34:S19.2E:27500:701:702=deu:704:0:28112:1:1101:0
|
||||||
SÜDWEST Ferns. BW;ARD:11836:hC34:S19.2E:27500:801:802=deu:804:0:28113:1:1101:0
|
SÜDWEST Ferns. BW;ARD:11836:hC34:S19.2E:27500:801:802=deu:804:0:28113:1:1101:0
|
||||||
@ -15,7 +15,7 @@ ZDF;ZDFvision:11953:hC34:S19.2E:27500:110:120=deu,121=2ch;125=dd:130:0:28006:1:1
|
|||||||
3sat;ZDFvision:11953:hC34:S19.2E:27500:210:220=deu,221=2ch;225=dd:230:0:28007:1:1079:0
|
3sat;ZDFvision:11953:hC34:S19.2E:27500:210:220=deu,221=2ch;225=dd:230:0:28007:1:1079:0
|
||||||
KiKa;ZDFvision:11953:hC34:S19.2E:27500:310:320=deu:330:0:28008:1:1079:0
|
KiKa;ZDFvision:11953:hC34:S19.2E:27500:310:320=deu:330:0:28008:1:1079:0
|
||||||
arte;ARD:11836:hC34:S19.2E:27500:401:402=deu,403=fra:404:0:28109:1:1101:0
|
arte;ARD:11836:hC34:S19.2E:27500:401:402=deu,403=fra:404:0:28109:1:1101:0
|
||||||
ORF1;ORF:12692:hC56:S19.2E:22000:160:161=deu;163=deu:165:3:13001:1:1117:0
|
ORF1;ORF:12692:hC56:S19.2E:22000:160:161=deu;163=deu:165:1762,D05,1702,1801:13001:1:1117:0
|
||||||
ORF2;ORF:12692:hC56:S19.2E:22000:500:501=deu;503=deu:505:3:13002:1:1117:0
|
ORF2;ORF:12692:hC56:S19.2E:22000:500:501=deu;503=deu:505:3:13002:1:1117:0
|
||||||
ZDFinfokanal;ZDFvision:11953:hC34:S19.2E:27500:610:620=deu:130:0:28011:1:1079:0
|
ZDFinfokanal;ZDFvision:11953:hC34:S19.2E:27500:610:620=deu:130:0:28011:1:1079:0
|
||||||
CNN Int.;CNN:11778:vC34:S19.2E:27500:165:100=eng:47:0:28522:1:1068:0
|
CNN Int.;CNN:11778:vC34:S19.2E:27500:165:100=eng:47:0:28522:1:1068:0
|
||||||
@ -27,7 +27,7 @@ DSF;BetaDigital:12480:vC34:S19.2E:27500:1023:1024=deu:39:0:900:133:33:0
|
|||||||
HSE24,HSE24;BetaDigital:12480:vC34:S19.2E:27500:1279:1280=deu:37:0:40:133:33:0
|
HSE24,HSE24;BetaDigital:12480:vC34:S19.2E:27500:1279:1280=deu:37:0:40:133:33:0
|
||||||
Bloomberg TV Germany;Bloomberg:12551:vC56:S19.2E:22000:162:99=deu:0:0:12160:1:1108:0
|
Bloomberg TV Germany;Bloomberg:12551:vC56:S19.2E:22000:162:99=deu:0:0:12160:1:1108:0
|
||||||
EURONEWS;CSAT:11817:vC34:S19.2E:27500:163:92=fra,93=eng,94=ita,95=esl,91=rus,98=por,99=deu:0:0:8004:1:1070:0
|
EURONEWS;CSAT:11817:vC34:S19.2E:27500:163:92=fra,93=eng,94=ita,95=esl,91=rus,98=por,99=deu:0:0:8004:1:1070:0
|
||||||
rbb Brandenburg;ARD:12109:hC34:S19.2E:27500:501:502=deu:504:0:28205:1:1073:0
|
rbb Brandenburg;ARD:12109:hC34:S19.2E:27500:601:602=deu:604:0:28205:1:1073:0
|
||||||
Sky News:11597:vC56:S19.2E:22000:305+131:306=eng:0:0:28707:1:1026:0
|
Sky News:11597:vC56:S19.2E:22000:305+131:306=eng:0:0:28707:1:1026:0
|
||||||
Veronica/JETIX;CANALDIGITAAL:12574:hC56:S19.2E:22000:518+8190:92=dut:38:622,100:5020:53:1109:0
|
Veronica/JETIX;CANALDIGITAAL:12574:hC56:S19.2E:22000:518+8190:92=dut:38:622,100:5020:53:1109:0
|
||||||
BVN;CANALDIGITAAL:12574:hC56:S19.2E:22000:515+8190:96=dut:36:0:5025:53:1109:0
|
BVN;CANALDIGITAAL:12574:hC56:S19.2E:22000:515+8190:96=dut:36:0:5025:53:1109:0
|
||||||
@ -45,9 +45,9 @@ rbb Berlin;ARD:12109:hC34:S19.2E:27500:601:602=deu:604:0:28206:1:1073:0
|
|||||||
:Premiere World
|
:Premiere World
|
||||||
PREMIERE START,START;PREMIERE:11797:hC34:S19.2E:27500:255:256=deu:32:1:8:133:2:0
|
PREMIERE START,START;PREMIERE:11797:hC34:S19.2E:27500:255:256=deu:32:1:8:133:2:0
|
||||||
PREMIERE 1,PREM 1;PREMIERE:11797:hC34:S19.2E:27500:511:512=deu,513=deu;515=deu:32:1:10:133:2:0
|
PREMIERE 1,PREM 1;PREMIERE:11797:hC34:S19.2E:27500:511:512=deu,513=deu;515=deu:32:1:10:133:2:0
|
||||||
PREMIERE 2,PREM 2;PREMIERE:11797:hC34:S19.2E:27500:1791:1792=deu,1793=deu;1795=deu:32:1801,1722,1702:11:133:2:0
|
PREMIERE 2,PREM 2;PREMIERE:11797:hC34:S19.2E:27500:1791:1792=deu,1793=deu;1795=deu:32:1:11:133:2:0
|
||||||
PREMIERE 3,PREM 3;PREMIERE:11797:hC34:S19.2E:27500:2303:2304=deu,2305=deu:32:1722,1801,1702:43:133:2:0
|
PREMIERE 3,PREM 3;PREMIERE:11797:hC34:S19.2E:27500:2303:2304=deu,2305=deu:32:1722,1801,1702:43:133:2:0
|
||||||
PREMIERE 4,PREM 4;PREMIERE:11797:hC34:S19.2E:27500:767:768=deu:32:1801,1722,1702:9:133:2:0
|
PREMIERE 4,PREM 4;PREMIERE:11797:hC34:S19.2E:27500:767:768=deu,769=deu:32:1801,1722,1702:9:133:2:0
|
||||||
PREMIERE 5,PREM 5;PREMIERE:11797:hC34:S19.2E:27500:1279:1280=deu:32:1722,1801,1702:29:133:2:0
|
PREMIERE 5,PREM 5;PREMIERE:11797:hC34:S19.2E:27500:1279:1280=deu:32:1722,1801,1702:29:133:2:0
|
||||||
PREMIERE 6,PREM 6;PREMIERE:11797:hC34:S19.2E:27500:1535:1536=deu:32:1702,1801,1722:41:133:2:0
|
PREMIERE 6,PREM 6;PREMIERE:11797:hC34:S19.2E:27500:1535:1536=deu:32:1702,1801,1722:41:133:2:0
|
||||||
PREMIERE 7,PREM 7;PREMIERE:11797:hC34:S19.2E:27500:1023:1024=deu:32:1801,1722,1702:20:133:2:0
|
PREMIERE 7,PREM 7;PREMIERE:11797:hC34:S19.2E:27500:1023:1024=deu:32:1801,1722,1702:20:133:2:0
|
||||||
@ -56,7 +56,7 @@ DISNEY CHANNEL,DISNEY;PREMIERE:11758:hC34:S19.2E:27500:2559:2560=deu:32:1722,180
|
|||||||
PREMIERE DIREKT,DIREKT;PREMIERE:12031:hC34:S19.2E:27500:2815:2816=deu,2817=deu;2819=deu:0:0:18:133:4:0
|
PREMIERE DIREKT,DIREKT;PREMIERE:12031:hC34:S19.2E:27500:2815:2816=deu,2817=deu;2819=deu:0:0:18:133:4:0
|
||||||
:PW Erotic
|
:PW Erotic
|
||||||
BEATE-UHSE.TV,B-UHSE;PREMIERE:11758:hC34:S19.2E:27500:1791:1792=deu:32:1801,1722,1702:21:133:17:0
|
BEATE-UHSE.TV,B-UHSE;PREMIERE:11758:hC34:S19.2E:27500:1791:1792=deu:32:1801,1722,1702:21:133:17:0
|
||||||
DIREKT EROTIK,EROTIK;PREMIERE:12031:hC34:S19.2E:27500:1279:0:0:1722,1801,1702:513:133:4:0
|
DIREKT EROTIK,EROTIK;PREMIERE:12031:hC34:S19.2E:27500:1279:1280=deu:0:1722,1801,1702:513:133:4:0
|
||||||
:Sportsworld
|
:Sportsworld
|
||||||
PREMIERE SPORT PORTAL,SPORT PORTAL;PREMIERE:11719:hC34:S19.2E:27500:255:256=deu,257=deu:32:1702,1801,1722:17:133:3:0
|
PREMIERE SPORT PORTAL,SPORT PORTAL;PREMIERE:11719:hC34:S19.2E:27500:255:256=deu,257=deu:32:1702,1801,1722:17:133:3:0
|
||||||
PREMIERE WIN,WIN;PREMIERE:12031:hC34:S19.2E:27500:3839:3840=deu:32:1722,1801,1702:27:133:4:0
|
PREMIERE WIN,WIN;PREMIERE:12031:hC34:S19.2E:27500:3839:3840=deu:32:1722,1801,1702:27:133:4:0
|
||||||
@ -79,8 +79,8 @@ ASTRA-Mosaic 4;SES ASTRA:12551:vC56:S19.2E:22000:185:170=fra:0:0:3985:1:1108:0
|
|||||||
ASTRA-Mosaic 5;SES ASTRA:12551:vC56:S19.2E:22000:163:164:0:0:3984:1:1108:0
|
ASTRA-Mosaic 5;SES ASTRA:12551:vC56:S19.2E:22000:163:164:0:0:3984:1:1108:0
|
||||||
Chamber TV;Chambre des Députées:12551:vC56:S19.2E:22000:55:56=ltz:0:0:12180:1:1108:0
|
Chamber TV;Chambre des Députées:12551:vC56:S19.2E:22000:55:56=ltz:0:0:12180:1:1108:0
|
||||||
RTL TELE Letzebuerg:12551:vC56:S19.2E:22000:168:144=eng,146=fra,151=ltz:74:0:3994:1:1108:0
|
RTL TELE Letzebuerg:12551:vC56:S19.2E:22000:168:144=eng,146=fra,151=ltz:74:0:3994:1:1108:0
|
||||||
RTL7.;CANALDIGITAAL:12574:hC56:S19.2E:22000:512+8190:84=dut:33:622,100:5010:53:1109:0
|
Test;CANALDIGITAAL:12574:hC56:S19.2E:22000:512+8190:84=dut:33:622,100:5010:53:1109:0
|
||||||
MTV2 Pop Channel;MTV Networks:12226:hC34:S19.2E:27500:513+8190:661=deu:577:0:28640:1:1091:0
|
Nickelodeon;MTV Networks:12226:hC34:S19.2E:27500:513+8190:661=deu:577:0:28640:1:1091:0
|
||||||
MTV Central;MTV Networks:11739:vC34:S19.2E:27500:3031:3032:3034:0:28653:1:1066:0
|
MTV Central;MTV Networks:11739:vC34:S19.2E:27500:3031:3032:3034:0:28653:1:1066:0
|
||||||
VIVA;VIVA Fernsehen GmbH & Co. KG:12669:vC56:S19.2E:22000:309:310=deu:311:0:12732:1:1116:0
|
VIVA;VIVA Fernsehen GmbH & Co. KG:12669:vC56:S19.2E:22000:309:310=deu:311:0:12732:1:1116:0
|
||||||
VIVA PLUS;VIVA Fernsehen GmbH & Co. KG:12551:vC56:S19.2E:22000:171:172=deu:173:0:12120:1:1108:0
|
VIVA PLUS;VIVA Fernsehen GmbH & Co. KG:12551:vC56:S19.2E:22000:171:172=deu:173:0:12120:1:1108:0
|
||||||
@ -108,12 +108,12 @@ Sky Cinema 1;BSkyB:12285:vC23:S28.2E:27500:519+8190:647=eng,667=NAR:583:960,961:
|
|||||||
Sky Cinema 2;BSkyB:12285:vC23:S28.2E:27500:517+8190:645=eng,665=NAR:581:960,961:4802:2:2030:0
|
Sky Cinema 2;BSkyB:12285:vC23:S28.2E:27500:517+8190:645=eng,665=NAR:581:960,961:4802:2:2030:0
|
||||||
:@900 Some 'seed' channels
|
:@900 Some 'seed' channels
|
||||||
Chelsea TV;BskyB:11778:vC23:S28.2E:27500:2308+2304:2309=eng:0:960,961:9307:2:2004:0
|
Chelsea TV;BskyB:11778:vC23:S28.2E:27500:2308+2304:2309=eng:0:960,961:9307:2:2004:0
|
||||||
WDR Münster;ARD:12421:hC34:S19.2E:27500:701:702=deu:104:0:28310:1:1201:0
|
WDR Münster;ARD:12421:hC34:S19.2E:27500:101:102=deu:104:0:28310:1:1201:0
|
||||||
Animal Plnt+;BSkyB:12070:hC23:S28.2E:27500:2314+2307:2315=eng:0:960,961:50002:2:2019:0
|
Animal Plnt+;BSkyB:12070:hC23:S28.2E:27500:2314+2307:2315=eng:0:960,961:50002:2:2019:0
|
||||||
S1T;BSkyB:12285:vC23:S28.2E:27500:513+8190:641=eng,661=NAR:577:960,961:4409:2:2030:0
|
S1T;BSkyB:12285:vC23:S28.2E:27500:513+8190:641=eng,661=NAR:577:960,961:4409:2:2030:0
|
||||||
CNN;BSkyB:12051:vC23:S28.2E:27500:2313:2315=eng:2314:0:7140:2:2018:0
|
CNN;BSkyB:12051:vC23:S28.2E:27500:2313:2315=eng:2314:0:7140:2:2018:0
|
||||||
BBC PARL'MNT;BSkyB:10847:vC56:S28.2E:22000:2327:2328=eng:2331:0:6902:2:2050:0
|
BBC PARL'MNT;BSkyB:10847:vC56:S28.2E:22000:2327:2328=eng:2331:0:6902:2:2050:0
|
||||||
Bethel TV;T-Systems/MTI:11200:vC56:S13.0E:27500:413:414:0:0:4733:318:13400:0
|
JGLESIA MME;T-Systems/MTI:11200:vC56:S13.0E:27500:413:414:0:0:4733:318:13400:0
|
||||||
Euro1080;EURO1080:12168:vC34:S19.2E:27500:308:256:0:FF:21100:1:1088:0
|
Euro1080;EURO1080:12168:vC34:S19.2E:27500:308:256:0:FF:21100:1:1088:0
|
||||||
Astra HD:12441:vC34:S19.2E:27500:133+80:134=eng:0:FF:29700:0:0:0
|
Astra HD:12441:vC34:S19.2E:27500:133+80:134=eng:0:FF:29700:0:0:0
|
||||||
eng-WRN-multi;WRN:12597:vC34:S13.0E:27500:0:2132:0:0:8230:318:9400:0
|
eng-WRN-multi;WRN:12597:vC34:S13.0E:27500:0:2132:0:0:8230:318:9400:0
|
||||||
|
21
channels.h
21
channels.h
@ -4,7 +4,7 @@
|
|||||||
* See the main source file 'vdr.c' for copyright information and
|
* See the main source file 'vdr.c' for copyright information and
|
||||||
* how to reach the author.
|
* how to reach the author.
|
||||||
*
|
*
|
||||||
* $Id: channels.h 1.33 2005/08/06 11:23:32 kls Exp $
|
* $Id: channels.h 1.35 2005/09/11 11:17:19 kls Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __CHANNELS_H
|
#ifndef __CHANNELS_H
|
||||||
@ -36,6 +36,9 @@
|
|||||||
#define MAXSPIDS 8 // subtitles
|
#define MAXSPIDS 8 // subtitles
|
||||||
#define MAXCAIDS 8 // conditional access
|
#define MAXCAIDS 8 // conditional access
|
||||||
|
|
||||||
|
#define MAXLANGCODE1 4 // a 3 letter language code, zero terminated
|
||||||
|
#define MAXLANGCODE2 8 // up to two 3 letter language codes, separated by '+' and zero terminated
|
||||||
|
|
||||||
struct tChannelParameterMap {
|
struct tChannelParameterMap {
|
||||||
int userValue;
|
int userValue;
|
||||||
int driverValue;
|
int driverValue;
|
||||||
@ -69,6 +72,11 @@ public:
|
|||||||
bool Valid(void) const { return (nid || tid) && sid; } // rid is optional and source may be 0//XXX source may not be 0???
|
bool Valid(void) const { return (nid || tid) && sid; } // rid is optional and source may be 0//XXX source may not be 0???
|
||||||
tChannelID &ClrRid(void) { rid = 0; return *this; }
|
tChannelID &ClrRid(void) { rid = 0; return *this; }
|
||||||
tChannelID &ClrPolarization(void);
|
tChannelID &ClrPolarization(void);
|
||||||
|
int Source(void) { return source; }
|
||||||
|
int Nid(void) { return nid; }
|
||||||
|
int Tid(void) { return tid; }
|
||||||
|
int Sid(void) { return sid; }
|
||||||
|
int Rid(void) { return rid; }
|
||||||
static tChannelID FromString(const char *s);
|
static tChannelID FromString(const char *s);
|
||||||
cString ToString(void) const;
|
cString ToString(void) const;
|
||||||
static const tChannelID InvalidID;
|
static const tChannelID InvalidID;
|
||||||
@ -102,11 +110,11 @@ private:
|
|||||||
int vpid;
|
int vpid;
|
||||||
int ppid;
|
int ppid;
|
||||||
int apids[MAXAPIDS + 1]; // list is zero-terminated
|
int apids[MAXAPIDS + 1]; // list is zero-terminated
|
||||||
char alangs[MAXAPIDS][4];
|
char alangs[MAXAPIDS][MAXLANGCODE2];
|
||||||
int dpids[MAXDPIDS + 1]; // list is zero-terminated
|
int dpids[MAXDPIDS + 1]; // list is zero-terminated
|
||||||
char dlangs[MAXDPIDS][4];
|
char dlangs[MAXDPIDS][MAXLANGCODE2];
|
||||||
int spids[MAXSPIDS + 1]; // list is zero-terminated
|
int spids[MAXSPIDS + 1]; // list is zero-terminated
|
||||||
char slangs[MAXSPIDS][4];
|
char slangs[MAXSPIDS][MAXLANGCODE2];
|
||||||
int tpid;
|
int tpid;
|
||||||
int caids[MAXCAIDS + 1]; // list is zero-terminated
|
int caids[MAXCAIDS + 1]; // list is zero-terminated
|
||||||
int nid;
|
int nid;
|
||||||
@ -188,7 +196,7 @@ public:
|
|||||||
void SetId(int Nid, int Tid, int Sid, int Rid = 0);
|
void SetId(int Nid, int Tid, int Sid, int Rid = 0);
|
||||||
void SetName(const char *Name, const char *ShortName, const char *Provider);
|
void SetName(const char *Name, const char *ShortName, const char *Provider);
|
||||||
void SetPortalName(const char *PortalName);
|
void SetPortalName(const char *PortalName);
|
||||||
void SetPids(int Vpid, int Ppid, int *Apids, char ALangs[][4], int *Dpids, char DLangs[][4], int Tpid);
|
void SetPids(int Vpid, int Ppid, int *Apids, char ALangs[][MAXLANGCODE2], int *Dpids, char DLangs[][MAXLANGCODE2], int Tpid);
|
||||||
void SetCaIds(const int *CaIds); // list must be zero-terminated
|
void SetCaIds(const int *CaIds); // list must be zero-terminated
|
||||||
void SetCaDescriptors(int Level);
|
void SetCaDescriptors(int Level);
|
||||||
void SetLinkChannels(cLinkChannels *LinkChannels);
|
void SetLinkChannels(cLinkChannels *LinkChannels);
|
||||||
@ -200,10 +208,13 @@ private:
|
|||||||
int maxNumber;
|
int maxNumber;
|
||||||
int modified;
|
int modified;
|
||||||
int beingEdited;
|
int beingEdited;
|
||||||
|
cHash<cChannel> channelsHashSid;
|
||||||
void DeleteDuplicateChannels(void);
|
void DeleteDuplicateChannels(void);
|
||||||
public:
|
public:
|
||||||
cChannels(void);
|
cChannels(void);
|
||||||
bool Load(const char *FileName, bool AllowComments = false, bool MustExist = false);
|
bool Load(const char *FileName, bool AllowComments = false, bool MustExist = false);
|
||||||
|
void HashChannel(cChannel *Channel);
|
||||||
|
void UnhashChannel(cChannel *Channel);
|
||||||
int GetNextGroup(int Idx); // Get next channel group
|
int GetNextGroup(int Idx); // Get next channel group
|
||||||
int GetPrevGroup(int Idx); // Get previous channel group
|
int GetPrevGroup(int Idx); // Get previous channel group
|
||||||
int GetNextNormal(int Idx); // Get next normal channel (not group)
|
int GetNextNormal(int Idx); // Get next normal channel (not group)
|
||||||
|
5
config.c
5
config.c
@ -4,12 +4,13 @@
|
|||||||
* See the main source file 'vdr.c' for copyright information and
|
* See the main source file 'vdr.c' for copyright information and
|
||||||
* how to reach the author.
|
* how to reach the author.
|
||||||
*
|
*
|
||||||
* $Id: config.c 1.136 2005/08/13 13:47:08 kls Exp $
|
* $Id: config.c 1.138 2005/09/09 15:08:59 kls Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
#include "device.h"
|
||||||
#include "i18n.h"
|
#include "i18n.h"
|
||||||
#include "interface.h"
|
#include "interface.h"
|
||||||
#include "plugin.h"
|
#include "plugin.h"
|
||||||
@ -266,7 +267,7 @@ cSetup::cSetup(void)
|
|||||||
AudioLanguages[0] = -1;
|
AudioLanguages[0] = -1;
|
||||||
EPGLanguages[0] = -1;
|
EPGLanguages[0] = -1;
|
||||||
EPGScanTimeout = 5;
|
EPGScanTimeout = 5;
|
||||||
EPGBugfixLevel = 2;
|
EPGBugfixLevel = 3;
|
||||||
EPGLinger = 0;
|
EPGLinger = 0;
|
||||||
SVDRPTimeout = 300;
|
SVDRPTimeout = 300;
|
||||||
ZapTimeout = 3;
|
ZapTimeout = 3;
|
||||||
|
7
config.h
7
config.h
@ -4,7 +4,7 @@
|
|||||||
* See the main source file 'vdr.c' for copyright information and
|
* See the main source file 'vdr.c' for copyright information and
|
||||||
* how to reach the author.
|
* how to reach the author.
|
||||||
*
|
*
|
||||||
* $Id: config.h 1.225 2005/08/26 12:28:40 kls Exp $
|
* $Id: config.h 1.227 2005/09/04 10:49:24 kls Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __CONFIG_H
|
#ifndef __CONFIG_H
|
||||||
@ -16,12 +16,11 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include "device.h"
|
|
||||||
#include "i18n.h"
|
#include "i18n.h"
|
||||||
#include "tools.h"
|
#include "tools.h"
|
||||||
|
|
||||||
#define VDRVERSION "1.3.31"
|
#define VDRVERSION "1.3.32"
|
||||||
#define VDRVERSNUM 10331 // Version * 10000 + Major * 100 + Minor
|
#define VDRVERSNUM 10332 // Version * 10000 + Major * 100 + Minor
|
||||||
|
|
||||||
#define MAXPRIORITY 99
|
#define MAXPRIORITY 99
|
||||||
#define MAXLIFETIME 99
|
#define MAXLIFETIME 99
|
||||||
|
20
device.c
20
device.c
@ -4,7 +4,7 @@
|
|||||||
* See the main source file 'vdr.c' for copyright information and
|
* See the main source file 'vdr.c' for copyright information and
|
||||||
* how to reach the author.
|
* how to reach the author.
|
||||||
*
|
*
|
||||||
* $Id: device.c 1.107 2005/08/27 09:01:09 kls Exp $
|
* $Id: device.c 1.109 2005/09/04 14:28:16 kls Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "device.h"
|
#include "device.h"
|
||||||
@ -795,13 +795,17 @@ void cDevice::EnsureAudioTrack(bool Force)
|
|||||||
{
|
{
|
||||||
if (Force || !availableTracks[currentAudioTrack].id) {
|
if (Force || !availableTracks[currentAudioTrack].id) {
|
||||||
eTrackType PreferredTrack = ttAudioFirst;
|
eTrackType PreferredTrack = ttAudioFirst;
|
||||||
|
int PreferredAudioChannel = 0;
|
||||||
int LanguagePreference = -1;
|
int LanguagePreference = -1;
|
||||||
int StartCheck = Setup.CurrentDolby ? ttDolbyFirst : ttAudioFirst;
|
int StartCheck = Setup.CurrentDolby ? ttDolbyFirst : ttAudioFirst;
|
||||||
int EndCheck = ttDolbyLast;
|
int EndCheck = ttDolbyLast;
|
||||||
for (int i = StartCheck; i <= EndCheck; i++) {
|
for (int i = StartCheck; i <= EndCheck; i++) {
|
||||||
const tTrackId *TrackId = GetTrack(eTrackType(i));
|
const tTrackId *TrackId = GetTrack(eTrackType(i));
|
||||||
if (TrackId && TrackId->id && I18nIsPreferredLanguage(Setup.AudioLanguages, I18nLanguageIndex(TrackId->language), LanguagePreference))
|
int pos = 0;
|
||||||
|
if (TrackId && TrackId->id && I18nIsPreferredLanguage(Setup.AudioLanguages, TrackId->language, LanguagePreference, &pos)) {
|
||||||
PreferredTrack = eTrackType(i);
|
PreferredTrack = eTrackType(i);
|
||||||
|
PreferredAudioChannel = pos;
|
||||||
|
}
|
||||||
if (Setup.CurrentDolby && i == ttDolbyLast) {
|
if (Setup.CurrentDolby && i == ttDolbyLast) {
|
||||||
i = ttAudioFirst - 1;
|
i = ttAudioFirst - 1;
|
||||||
EndCheck = ttAudioLast;
|
EndCheck = ttAudioLast;
|
||||||
@ -811,8 +815,9 @@ void cDevice::EnsureAudioTrack(bool Force)
|
|||||||
const tTrackId *Track = GetTrack(GetCurrentAudioTrack());
|
const tTrackId *Track = GetTrack(GetCurrentAudioTrack());
|
||||||
if (Force || !Track || !Track->id || PreferredTrack != GetCurrentAudioTrack()) {
|
if (Force || !Track || !Track->id || PreferredTrack != GetCurrentAudioTrack()) {
|
||||||
if (!Force) // only log this for automatic changes
|
if (!Force) // only log this for automatic changes
|
||||||
dsyslog("setting audio track to %d", PreferredTrack);
|
dsyslog("setting audio track to %d (%d)", PreferredTrack, PreferredAudioChannel);
|
||||||
SetCurrentAudioTrack(PreferredTrack);
|
SetCurrentAudioTrack(PreferredTrack);
|
||||||
|
SetAudioChannel(PreferredAudioChannel);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1185,6 +1190,15 @@ bool cDevice::AttachReceiver(cReceiver *Receiver)
|
|||||||
return false;
|
return false;
|
||||||
if (Receiver->device == this)
|
if (Receiver->device == this)
|
||||||
return true;
|
return true;
|
||||||
|
// activate the following line if you need it - actually the driver should be fixed!
|
||||||
|
//#define WAIT_FOR_TUNER_LOCK
|
||||||
|
#ifdef WAIT_FOR_TUNER_LOCK
|
||||||
|
#define TUNER_LOCK_TIMEOUT 5000 // ms
|
||||||
|
if (!HasLock(TUNER_LOCK_TIMEOUT)) {
|
||||||
|
esyslog("ERROR: device %d has no lock, can't attach receiver!", CardIndex() + 1);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
cMutexLock MutexLock(&mutexReceiver);
|
cMutexLock MutexLock(&mutexReceiver);
|
||||||
for (int i = 0; i < MAXRECEIVERS; i++) {
|
for (int i = 0; i < MAXRECEIVERS; i++) {
|
||||||
if (!receiver[i]) {
|
if (!receiver[i]) {
|
||||||
|
8
device.h
8
device.h
@ -4,12 +4,13 @@
|
|||||||
* See the main source file 'vdr.c' for copyright information and
|
* See the main source file 'vdr.c' for copyright information and
|
||||||
* how to reach the author.
|
* how to reach the author.
|
||||||
*
|
*
|
||||||
* $Id: device.h 1.62 2005/08/21 08:52:20 kls Exp $
|
* $Id: device.h 1.64 2005/09/10 11:54:02 kls Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __DEVICE_H
|
#ifndef __DEVICE_H
|
||||||
#define __DEVICE_H
|
#define __DEVICE_H
|
||||||
|
|
||||||
|
#include "channels.h"
|
||||||
#include "ci.h"
|
#include "ci.h"
|
||||||
#include "eit.h"
|
#include "eit.h"
|
||||||
#include "filter.h"
|
#include "filter.h"
|
||||||
@ -82,11 +83,10 @@ enum eTrackType { ttNone,
|
|||||||
|
|
||||||
struct tTrackId {
|
struct tTrackId {
|
||||||
uint16_t id; // The PES packet id or the PID.
|
uint16_t id; // The PES packet id or the PID.
|
||||||
char language[8]; // something like either "eng" or "deu/eng"
|
char language[MAXLANGCODE2]; // something like either "eng" or "deu+eng"
|
||||||
char description[32]; // something like "Dolby Digital 5.1"
|
char description[32]; // something like "Dolby Digital 5.1"
|
||||||
};
|
};
|
||||||
|
|
||||||
class cChannel;
|
|
||||||
class cPlayer;
|
class cPlayer;
|
||||||
class cReceiver;
|
class cReceiver;
|
||||||
class cPesAssembler;
|
class cPesAssembler;
|
||||||
@ -266,7 +266,7 @@ protected:
|
|||||||
///< On indicates whether the PID shall be added or deleted.
|
///< On indicates whether the PID shall be added or deleted.
|
||||||
///< Handle->handle can be used by the device to store information it
|
///< Handle->handle can be used by the device to store information it
|
||||||
///< needs to receive this PID (for instance a file handle).
|
///< needs to receive this PID (for instance a file handle).
|
||||||
///< Handle->used indicated how many receivers are using this PID.
|
///< Handle->used indicates how many receivers are using this PID.
|
||||||
///< Type indicates some special types of PIDs, which the device may
|
///< Type indicates some special types of PIDs, which the device may
|
||||||
///< need to set in a specific way.
|
///< need to set in a specific way.
|
||||||
|
|
||||||
|
@ -4,7 +4,7 @@
|
|||||||
* See the main source file 'vdr.c' for copyright information and
|
* See the main source file 'vdr.c' for copyright information and
|
||||||
* how to reach the author.
|
* how to reach the author.
|
||||||
*
|
*
|
||||||
* $Id: dvbplayer.c 1.38 2005/08/14 10:52:45 kls Exp $
|
* $Id: dvbplayer.c 1.40 2005/08/29 15:43:30 kls Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "dvbplayer.h"
|
#include "dvbplayer.h"
|
||||||
@ -621,7 +621,10 @@ int cDvbPlayer::SkipFrames(int Frames)
|
|||||||
int Current, Total;
|
int Current, Total;
|
||||||
GetIndex(Current, Total, true);
|
GetIndex(Current, Total, true);
|
||||||
int OldCurrent = Current;
|
int OldCurrent = Current;
|
||||||
Current = index->GetNextIFrame(Current + Frames, Frames > 0);
|
// As GetNextIFrame() increments/decrements at least once, the
|
||||||
|
// destination frame (= Current + Frames) must be adjusted by
|
||||||
|
// -1/+1 respectively.
|
||||||
|
Current = index->GetNextIFrame(Current + Frames + (Frames > 0 ? -1 : 1), Frames > 0);
|
||||||
return Current >= 0 ? Current : OldCurrent;
|
return Current >= 0 ? Current : OldCurrent;
|
||||||
}
|
}
|
||||||
return -1;
|
return -1;
|
||||||
@ -661,7 +664,7 @@ void cDvbPlayer::Goto(int Index, bool Still)
|
|||||||
if (playMode == pmPause)
|
if (playMode == pmPause)
|
||||||
DevicePlay();
|
DevicePlay();
|
||||||
// append sequence end code to get the image shown immediately with softdevices
|
// append sequence end code to get the image shown immediately with softdevices
|
||||||
if (r > 6) { // should be always true
|
if (r > 6 && (b[3] & 0xF0) == 0xE0) { // make sure to append it only to a video packet
|
||||||
b[r++] = 0x00;
|
b[r++] = 0x00;
|
||||||
b[r++] = 0x00;
|
b[r++] = 0x00;
|
||||||
b[r++] = 0x01;
|
b[r++] = 0x01;
|
||||||
|
6
eit.c
6
eit.c
@ -8,7 +8,7 @@
|
|||||||
* Robert Schneider <Robert.Schneider@web.de> and Rolf Hakenes <hakenes@hippomi.de>.
|
* Robert Schneider <Robert.Schneider@web.de> and Rolf Hakenes <hakenes@hippomi.de>.
|
||||||
* Adapted to 'libsi' for VDR 1.3.0 by Marcel Wiesweg <marcel.wiesweg@gmx.de>.
|
* Adapted to 'libsi' for VDR 1.3.0 by Marcel Wiesweg <marcel.wiesweg@gmx.de>.
|
||||||
*
|
*
|
||||||
* $Id: eit.c 1.110 2005/08/13 13:27:34 kls Exp $
|
* $Id: eit.c 1.111 2005/09/04 11:36:30 kls Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "eit.h"
|
#include "eit.h"
|
||||||
@ -99,7 +99,7 @@ cEIT::cEIT(cSchedules *Schedules, int Source, u_char Tid, const u_char *Data)
|
|||||||
switch (d->getDescriptorTag()) {
|
switch (d->getDescriptorTag()) {
|
||||||
case SI::ExtendedEventDescriptorTag: {
|
case SI::ExtendedEventDescriptorTag: {
|
||||||
SI::ExtendedEventDescriptor *eed = (SI::ExtendedEventDescriptor *)d;
|
SI::ExtendedEventDescriptor *eed = (SI::ExtendedEventDescriptor *)d;
|
||||||
if (I18nIsPreferredLanguage(Setup.EPGLanguages, I18nLanguageIndex(eed->languageCode), LanguagePreferenceExt) || !ExtendedEventDescriptors) {
|
if (I18nIsPreferredLanguage(Setup.EPGLanguages, eed->languageCode, LanguagePreferenceExt) || !ExtendedEventDescriptors) {
|
||||||
delete ExtendedEventDescriptors;
|
delete ExtendedEventDescriptors;
|
||||||
ExtendedEventDescriptors = new SI::ExtendedEventDescriptors;
|
ExtendedEventDescriptors = new SI::ExtendedEventDescriptors;
|
||||||
UseExtendedEventDescriptor = true;
|
UseExtendedEventDescriptor = true;
|
||||||
@ -114,7 +114,7 @@ cEIT::cEIT(cSchedules *Schedules, int Source, u_char Tid, const u_char *Data)
|
|||||||
break;
|
break;
|
||||||
case SI::ShortEventDescriptorTag: {
|
case SI::ShortEventDescriptorTag: {
|
||||||
SI::ShortEventDescriptor *sed = (SI::ShortEventDescriptor *)d;
|
SI::ShortEventDescriptor *sed = (SI::ShortEventDescriptor *)d;
|
||||||
if (I18nIsPreferredLanguage(Setup.EPGLanguages, I18nLanguageIndex(sed->languageCode), LanguagePreferenceShort) || !ShortEventDescriptor) {
|
if (I18nIsPreferredLanguage(Setup.EPGLanguages, sed->languageCode, LanguagePreferenceShort) || !ShortEventDescriptor) {
|
||||||
delete ShortEventDescriptor;
|
delete ShortEventDescriptor;
|
||||||
ShortEventDescriptor = sed;
|
ShortEventDescriptor = sed;
|
||||||
d = NULL; // so that it is not deleted
|
d = NULL; // so that it is not deleted
|
||||||
|
@ -4,14 +4,16 @@
|
|||||||
* See the main source file 'vdr.c' for copyright information and
|
* See the main source file 'vdr.c' for copyright information and
|
||||||
* how to reach the author.
|
* how to reach the author.
|
||||||
*
|
*
|
||||||
* $Id: eitscan.h 1.8 2004/01/17 15:36:24 kls Exp $
|
* $Id: eitscan.h 1.9 2005/09/04 10:51:35 kls Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __EITSCAN_H
|
#ifndef __EITSCAN_H
|
||||||
#define __EITSCAN_H
|
#define __EITSCAN_H
|
||||||
|
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
|
#include "channels.h"
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
|
#include "device.h"
|
||||||
|
|
||||||
class cScanList;
|
class cScanList;
|
||||||
class cTransponderList;
|
class cTransponderList;
|
||||||
|
4
epg.c
4
epg.c
@ -7,7 +7,7 @@
|
|||||||
* Original version (as used in VDR before 1.3.0) written by
|
* Original version (as used in VDR before 1.3.0) written by
|
||||||
* Robert Schneider <Robert.Schneider@web.de> and Rolf Hakenes <hakenes@hippomi.de>.
|
* Robert Schneider <Robert.Schneider@web.de> and Rolf Hakenes <hakenes@hippomi.de>.
|
||||||
*
|
*
|
||||||
* $Id: epg.c 1.36 2005/07/30 14:44:54 kls Exp $
|
* $Id: epg.c 1.37 2005/09/09 15:14:11 kls Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "epg.h"
|
#include "epg.h"
|
||||||
@ -471,7 +471,7 @@ void cEvent::FixEpgBugs(void)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Some channels put the Description into the ShortText (preceeded
|
// Some channels put the Description into the ShortText (preceded
|
||||||
// by a blank) if there is no actual ShortText and the Description
|
// by a blank) if there is no actual ShortText and the Description
|
||||||
// is short enough:
|
// is short enough:
|
||||||
//
|
//
|
||||||
|
6
epg.h
6
epg.h
@ -7,7 +7,7 @@
|
|||||||
* Original version (as used in VDR before 1.3.0) written by
|
* Original version (as used in VDR before 1.3.0) written by
|
||||||
* Robert Schneider <Robert.Schneider@web.de> and Rolf Hakenes <hakenes@hippomi.de>.
|
* Robert Schneider <Robert.Schneider@web.de> and Rolf Hakenes <hakenes@hippomi.de>.
|
||||||
*
|
*
|
||||||
* $Id: epg.h 1.25 2005/05/28 11:32:36 kls Exp $
|
* $Id: epg.h 1.26 2005/09/11 12:54:30 kls Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __EPG_H
|
#ifndef __EPG_H
|
||||||
@ -132,8 +132,8 @@ public:
|
|||||||
void Cleanup(void);
|
void Cleanup(void);
|
||||||
cEvent *AddEvent(cEvent *Event);
|
cEvent *AddEvent(cEvent *Event);
|
||||||
void DelEvent(cEvent *Event);
|
void DelEvent(cEvent *Event);
|
||||||
void cSchedule::HashEvent(cEvent *Event);
|
void HashEvent(cEvent *Event);
|
||||||
void cSchedule::UnhashEvent(cEvent *Event);
|
void UnhashEvent(cEvent *Event);
|
||||||
const cList<cEvent> *Events(void) const { return &events; }
|
const cList<cEvent> *Events(void) const { return &events; }
|
||||||
const cEvent *GetPresentEvent(bool CheckRunningStatus = false) const;
|
const cEvent *GetPresentEvent(bool CheckRunningStatus = false) const;
|
||||||
const cEvent *GetFollowingEvent(bool CheckRunningStatus = false) const;
|
const cEvent *GetFollowingEvent(bool CheckRunningStatus = false) const;
|
||||||
|
16
i18n.h
16
i18n.h
@ -4,7 +4,7 @@
|
|||||||
* See the main source file 'vdr.c' for copyright information and
|
* See the main source file 'vdr.c' for copyright information and
|
||||||
* how to reach the author.
|
* how to reach the author.
|
||||||
*
|
*
|
||||||
* $Id: i18n.h 1.14 2004/11/02 17:21:19 kls Exp $
|
* $Id: i18n.h 1.16 2005/09/09 14:50:35 kls Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __I18N_H
|
#ifndef __I18N_H
|
||||||
@ -25,7 +25,19 @@ const char * const * I18nCharSets(void);
|
|||||||
const char *I18nLanguageCode(int Index);
|
const char *I18nLanguageCode(int Index);
|
||||||
int I18nLanguageIndex(const char *Code);
|
int I18nLanguageIndex(const char *Code);
|
||||||
const char *I18nNormalizeLanguageCode(const char *Code);
|
const char *I18nNormalizeLanguageCode(const char *Code);
|
||||||
bool I18nIsPreferredLanguage(int *PreferredLanguages, int LanguageIndex, int &OldPreference);
|
///< Returns a 3 letter language code that may not be zero terminated.
|
||||||
|
///< If no normalized language code can be found, the given Code is returned.
|
||||||
|
///< Make sure at most 3 characters are copied when using it!
|
||||||
|
bool I18nIsPreferredLanguage(int *PreferredLanguages, const char *LanguageCode, int &OldPreference, int *Position = NULL);
|
||||||
|
///< Checks the given LanguageCode (which may be something like "eng" or "eng+deu")
|
||||||
|
///< against the PreferredLanguages and returns true if one is found that has an index
|
||||||
|
///< smaller than OldPreference (which should be initialized to -1 before the first
|
||||||
|
///< call to this function in a sequence of checks). If LanguageCode is not any of
|
||||||
|
///< the PreferredLanguages, and OldPreference is less than zero, OldPreference will
|
||||||
|
///< be set to a value higher than the highest language index. If Position is given,
|
||||||
|
///< it will return 0 if this was a single language code (like "eng"), 1 if it was
|
||||||
|
///< the first of two language codes (like "eng" out of "eng+deu") and 2 if it was
|
||||||
|
///< the second one (like "deu" out of ""eng+deu").
|
||||||
|
|
||||||
#ifdef PLUGIN_NAME_I18N
|
#ifdef PLUGIN_NAME_I18N
|
||||||
#define tr(s) I18nTranslate(s, PLUGIN_NAME_I18N)
|
#define tr(s) I18nTranslate(s, PLUGIN_NAME_I18N)
|
||||||
|
@ -4,7 +4,7 @@
|
|||||||
* See the main source file 'vdr.c' for copyright information and
|
* See the main source file 'vdr.c' for copyright information and
|
||||||
* how to reach the author.
|
* how to reach the author.
|
||||||
*
|
*
|
||||||
* $Id: interface.c 1.68 2004/11/01 14:23:28 kls Exp $
|
* $Id: interface.c 1.69 2005/09/03 09:07:23 kls Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "interface.h"
|
#include "interface.h"
|
||||||
@ -56,7 +56,7 @@ eKeys cInterface::Wait(int Seconds, bool KeepChar)
|
|||||||
time_t timeout = time(NULL) + Seconds;
|
time_t timeout = time(NULL) + Seconds;
|
||||||
for (;;) {
|
for (;;) {
|
||||||
Key = GetKey();
|
Key = GetKey();
|
||||||
if ((Key != kNone && (RAWKEY(Key) != kOk || RAWKEY(Key) == Key)) || time(NULL) > timeout || interrupted)
|
if (ISRAWKEY(Key) || time(NULL) > timeout || interrupted)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (KeepChar && ISRAWKEY(Key))
|
if (KeepChar && ISRAWKEY(Key))
|
||||||
|
3
keys.c
3
keys.c
@ -4,7 +4,7 @@
|
|||||||
* See the main source file 'vdr.c' for copyright information and
|
* See the main source file 'vdr.c' for copyright information and
|
||||||
* how to reach the author.
|
* how to reach the author.
|
||||||
*
|
*
|
||||||
* $Id: keys.c 1.7 2004/12/27 11:08:34 kls Exp $
|
* $Id: keys.c 1.8 2005/09/03 11:28:34 kls Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "keys.h"
|
#include "keys.h"
|
||||||
@ -210,7 +210,6 @@ bool cKeyMacro::Parse(char *s)
|
|||||||
}
|
}
|
||||||
macro[n++] = k_Plugin;
|
macro[n++] = k_Plugin;
|
||||||
if (n < MAXKEYSINMACRO) {
|
if (n < MAXKEYSINMACRO) {
|
||||||
macro[n] = kOk;
|
|
||||||
plugin = strdup(p + 1);
|
plugin = strdup(p + 1);
|
||||||
if (!cPluginManager::GetPlugin(plugin)) {
|
if (!cPluginManager::GetPlugin(plugin)) {
|
||||||
esyslog("ERROR: unknown plugin '%s'", plugin);
|
esyslog("ERROR: unknown plugin '%s'", plugin);
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
* the Free Software Foundation; either version 2 of the License, or *
|
* the Free Software Foundation; either version 2 of the License, or *
|
||||||
* (at your option) any later version. *
|
* (at your option) any later version. *
|
||||||
* *
|
* *
|
||||||
* $Id: descriptor.c 1.14 2004/10/16 09:51:05 kls Exp $
|
* $Id: descriptor.c 1.15 2005/09/03 15:16:49 kls Exp $
|
||||||
* *
|
* *
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
@ -655,14 +655,32 @@ LinkageType LinkageDescriptor::getLinkageType() const {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void ISO639LanguageDescriptor::Parse() {
|
void ISO639LanguageDescriptor::Parse() {
|
||||||
unsigned int offset=0;
|
languageLoop.setData(data+sizeof(descr_iso_639_language), getLength()-sizeof(descr_iso_639_language));
|
||||||
data.setPointerAndOffset<const descr_iso_639_language>(s, offset);
|
|
||||||
|
//all this is for backwards compatibility only
|
||||||
|
Loop::Iterator it;
|
||||||
|
Language first;
|
||||||
|
if (languageLoop.getNext(first, it)) {
|
||||||
|
languageCode[0]=first.languageCode[0];
|
||||||
|
languageCode[1]=first.languageCode[1];
|
||||||
|
languageCode[2]=first.languageCode[2];
|
||||||
|
languageCode[3]=0;
|
||||||
|
} else
|
||||||
|
languageCode[0]=0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void ISO639LanguageDescriptor::Language::Parse() {
|
||||||
|
s=data.getData<const descr_iso_639_language_loop>();
|
||||||
languageCode[0]=s->lang_code1;
|
languageCode[0]=s->lang_code1;
|
||||||
languageCode[1]=s->lang_code2;
|
languageCode[1]=s->lang_code2;
|
||||||
languageCode[2]=s->lang_code3;
|
languageCode[2]=s->lang_code3;
|
||||||
languageCode[3]=0;
|
languageCode[3]=0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
AudioType ISO639LanguageDescriptor::Language::getAudioType() {
|
||||||
|
return (AudioType)s->audio_type;
|
||||||
|
}
|
||||||
|
|
||||||
void PDCDescriptor::Parse() {
|
void PDCDescriptor::Parse() {
|
||||||
unsigned int offset=0;
|
unsigned int offset=0;
|
||||||
data.setPointerAndOffset<const descr_pdc>(s, offset);
|
data.setPointerAndOffset<const descr_pdc>(s, offset);
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
* the Free Software Foundation; either version 2 of the License, or *
|
* the Free Software Foundation; either version 2 of the License, or *
|
||||||
* (at your option) any later version. *
|
* (at your option) any later version. *
|
||||||
* *
|
* *
|
||||||
* $Id: descriptor.h 1.12 2005/05/08 14:08:19 kls Exp $
|
* $Id: descriptor.h 1.13 2005/09/03 15:17:35 kls Exp $
|
||||||
* *
|
* *
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
@ -392,7 +392,18 @@ private:
|
|||||||
|
|
||||||
class ISO639LanguageDescriptor : public Descriptor {
|
class ISO639LanguageDescriptor : public Descriptor {
|
||||||
public:
|
public:
|
||||||
|
char languageCode[4]; //for backwards compatibility
|
||||||
|
class Language : public LoopElement {
|
||||||
|
public:
|
||||||
|
virtual int getLength() { return sizeof(descr_iso_639_language_loop); }
|
||||||
char languageCode[4];
|
char languageCode[4];
|
||||||
|
AudioType getAudioType();
|
||||||
|
protected:
|
||||||
|
virtual void Parse();
|
||||||
|
private:
|
||||||
|
const descr_iso_639_language_loop *s;
|
||||||
|
};
|
||||||
|
StructureLoop<Language> languageLoop;
|
||||||
protected:
|
protected:
|
||||||
virtual void Parse();
|
virtual void Parse();
|
||||||
private:
|
private:
|
||||||
|
@ -10,7 +10,7 @@
|
|||||||
* the Free Software Foundation; either version 2 of the License, or *
|
* the Free Software Foundation; either version 2 of the License, or *
|
||||||
* (at your option) any later version. *
|
* (at your option) any later version. *
|
||||||
* *
|
* *
|
||||||
* $Id: headers.h 1.4 2004/02/22 11:12:46 kls Exp $
|
* $Id: headers.h 1.5 2005/09/03 15:18:16 kls Exp $
|
||||||
* *
|
* *
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
@ -821,9 +821,13 @@ struct descr_ca {
|
|||||||
struct descr_iso_639_language {
|
struct descr_iso_639_language {
|
||||||
u_char descriptor_tag :8;
|
u_char descriptor_tag :8;
|
||||||
u_char descriptor_length :8;
|
u_char descriptor_length :8;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct descr_iso_639_language_loop {
|
||||||
u_char lang_code1 :8;
|
u_char lang_code1 :8;
|
||||||
u_char lang_code2 :8;
|
u_char lang_code2 :8;
|
||||||
u_char lang_code3 :8;
|
u_char lang_code3 :8;
|
||||||
|
u_char audio_type :8;
|
||||||
};
|
};
|
||||||
|
|
||||||
/* 0x13 carousel_identifier_descriptor */
|
/* 0x13 carousel_identifier_descriptor */
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
* the Free Software Foundation; either version 2 of the License, or *
|
* the Free Software Foundation; either version 2 of the License, or *
|
||||||
* (at your option) any later version. *
|
* (at your option) any later version. *
|
||||||
* *
|
* *
|
||||||
* $Id: si.h 1.11 2004/10/16 09:58:10 kls Exp $
|
* $Id: si.h 1.12 2005/09/03 15:19:00 kls Exp $
|
||||||
* *
|
* *
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
@ -166,6 +166,12 @@ enum LinkageType { LinkageTypeInformationService = 0x01,
|
|||||||
LinkageTypeTSContainingSsuBatOrNit = 0x0A
|
LinkageTypeTSContainingSsuBatOrNit = 0x0A
|
||||||
};
|
};
|
||||||
|
|
||||||
|
enum AudioType { AudioTypeUndefined = 0x00,
|
||||||
|
AudioTypeCleanEffects = 0x01,
|
||||||
|
AudioTypeHearingImpaired = 0x02,
|
||||||
|
AudioTypeVisualImpairedCommentary = 0x03
|
||||||
|
};
|
||||||
|
|
||||||
/* Some principles:
|
/* Some principles:
|
||||||
- Objects that return references to other objects contained in their data must make sure
|
- Objects that return references to other objects contained in their data must make sure
|
||||||
that the returned objects have been parsed.
|
that the returned objects have been parsed.
|
||||||
|
7
lirc.c
7
lirc.c
@ -6,7 +6,7 @@
|
|||||||
*
|
*
|
||||||
* LIRC support added by Carsten Koch <Carsten.Koch@icem.de> 2000-06-16.
|
* LIRC support added by Carsten Koch <Carsten.Koch@icem.de> 2000-06-16.
|
||||||
*
|
*
|
||||||
* $Id: lirc.c 1.12 2005/08/15 12:28:10 kls Exp $
|
* $Id: lirc.c 1.13 2005/09/02 12:51:35 kls Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "lirc.h"
|
#include "lirc.h"
|
||||||
@ -76,7 +76,10 @@ void cLircRemote::Action(void)
|
|||||||
if (ready && ret > 21) {
|
if (ready && ret > 21) {
|
||||||
int count;
|
int count;
|
||||||
char KeyName[LIRC_KEY_BUF];
|
char KeyName[LIRC_KEY_BUF];
|
||||||
sscanf(buf, "%*x %x %29s", &count, KeyName); // '29' in '%29s' is LIRC_KEY_BUF-1!
|
if (sscanf(buf, "%*x %x %29s", &count, KeyName) != 2) { // '29' in '%29s' is LIRC_KEY_BUF-1!
|
||||||
|
esyslog("ERROR: unparseable lirc command: %s", buf);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
if (count == 0) {
|
if (count == 0) {
|
||||||
if (strcmp(KeyName, LastKeyName) == 0 && FirstTime.Elapsed() < KEYPRESSDELAY)
|
if (strcmp(KeyName, LastKeyName) == 0 && FirstTime.Elapsed() < KEYPRESSDELAY)
|
||||||
continue; // skip keys coming in too fast
|
continue; // skip keys coming in too fast
|
||||||
|
26
menu.c
26
menu.c
@ -4,7 +4,7 @@
|
|||||||
* See the main source file 'vdr.c' for copyright information and
|
* See the main source file 'vdr.c' for copyright information and
|
||||||
* how to reach the author.
|
* how to reach the author.
|
||||||
*
|
*
|
||||||
* $Id: menu.c 1.357 2005/08/27 09:37:23 kls Exp $
|
* $Id: menu.c 1.359 2005/09/03 11:42:27 kls Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "menu.h"
|
#include "menu.h"
|
||||||
@ -29,7 +29,6 @@
|
|||||||
#include "transfer.h"
|
#include "transfer.h"
|
||||||
#include "videodir.h"
|
#include "videodir.h"
|
||||||
|
|
||||||
#define MENUTIMEOUT 120 // seconds
|
|
||||||
#define MAXWAIT4EPGINFO 3 // seconds
|
#define MAXWAIT4EPGINFO 3 // seconds
|
||||||
#define MODETIMEOUT 3 // seconds
|
#define MODETIMEOUT 3 // seconds
|
||||||
|
|
||||||
@ -1300,7 +1299,6 @@ cMenuCam::cMenuCam(cCiMenu *CiMenu)
|
|||||||
Add(new cOsdItem(ciMenu->BottomText()));
|
Add(new cOsdItem(ciMenu->BottomText()));
|
||||||
Display();
|
Display();
|
||||||
dsyslog("CAM: Menu - %s", ciMenu->TitleText());
|
dsyslog("CAM: Menu - %s", ciMenu->TitleText());
|
||||||
lastActivity = time(NULL);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
cMenuCam::~cMenuCam()
|
cMenuCam::~cMenuCam()
|
||||||
@ -1329,10 +1327,6 @@ eOSState cMenuCam::ProcessKey(eKeys Key)
|
|||||||
default: break;
|
default: break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (Key != kNone)
|
|
||||||
lastActivity = time(NULL);
|
|
||||||
else if (time(NULL) - lastActivity > MENUTIMEOUT)
|
|
||||||
state = osEnd;
|
|
||||||
return state;
|
return state;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1350,7 +1344,6 @@ cMenuCamEnquiry::cMenuCamEnquiry(cCiEnquiry *CiEnquiry)
|
|||||||
SetTitle(ciEnquiry->Text() ? ciEnquiry->Text() : "CAM");
|
SetTitle(ciEnquiry->Text() ? ciEnquiry->Text() : "CAM");
|
||||||
Add(new cMenuEditNumItem("Input", input, Length, ciEnquiry->Blind()));
|
Add(new cMenuEditNumItem("Input", input, Length, ciEnquiry->Blind()));
|
||||||
Display();
|
Display();
|
||||||
lastActivity = time(NULL);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
cMenuCamEnquiry::~cMenuCamEnquiry()
|
cMenuCamEnquiry::~cMenuCamEnquiry()
|
||||||
@ -1379,10 +1372,6 @@ eOSState cMenuCamEnquiry::ProcessKey(eKeys Key)
|
|||||||
default: break;
|
default: break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (Key != kNone)
|
|
||||||
lastActivity = time(NULL);
|
|
||||||
else if (time(NULL) - lastActivity > MENUTIMEOUT)
|
|
||||||
state = osEnd;
|
|
||||||
return state;
|
return state;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2402,11 +2391,11 @@ cMenuPluginItem::cMenuPluginItem(const char *Name, int Index)
|
|||||||
|
|
||||||
cOsdObject *cMenuMain::pluginOsdObject = NULL;
|
cOsdObject *cMenuMain::pluginOsdObject = NULL;
|
||||||
|
|
||||||
cMenuMain::cMenuMain(bool Replaying, eOSState State, const char *Plugin)
|
cMenuMain::cMenuMain(bool Replaying, eOSState State)
|
||||||
:cOsdMenu("")
|
:cOsdMenu("")
|
||||||
{
|
{
|
||||||
replaying = Replaying;
|
replaying = Replaying;
|
||||||
Set(Plugin);
|
Set();
|
||||||
|
|
||||||
// Initial submenus:
|
// Initial submenus:
|
||||||
|
|
||||||
@ -2417,7 +2406,6 @@ cMenuMain::cMenuMain(bool Replaying, eOSState State, const char *Plugin)
|
|||||||
case osRecordings: AddSubMenu(new cMenuRecordings(NULL, 0, true)); break;
|
case osRecordings: AddSubMenu(new cMenuRecordings(NULL, 0, true)); break;
|
||||||
case osSetup: AddSubMenu(new cMenuSetup); break;
|
case osSetup: AddSubMenu(new cMenuSetup); break;
|
||||||
case osCommands: AddSubMenu(new cMenuCommands(tr("Commands"), &Commands)); break;
|
case osCommands: AddSubMenu(new cMenuCommands(tr("Commands"), &Commands)); break;
|
||||||
case osPlugin: break; // the actual work is done in Set()
|
|
||||||
default: break;
|
default: break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -2429,7 +2417,7 @@ cOsdObject *cMenuMain::PluginOsdObject(void)
|
|||||||
return o;
|
return o;
|
||||||
}
|
}
|
||||||
|
|
||||||
void cMenuMain::Set(const char *Plugin)
|
void cMenuMain::Set(void)
|
||||||
{
|
{
|
||||||
Clear();
|
Clear();
|
||||||
//XXX //SetTitle("VDR"); // this is done below, including disk usage
|
//XXX //SetTitle("VDR"); // this is done below, including disk usage
|
||||||
@ -2463,7 +2451,7 @@ void cMenuMain::Set(const char *Plugin)
|
|||||||
if (p) {
|
if (p) {
|
||||||
const char *item = p->MainMenuEntry();
|
const char *item = p->MainMenuEntry();
|
||||||
if (item)
|
if (item)
|
||||||
Add(new cMenuPluginItem(hk(item), i), Plugin && strcmp(Plugin, p->Name()) == 0);
|
Add(new cMenuPluginItem(hk(item), i));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
break;
|
break;
|
||||||
@ -2506,7 +2494,6 @@ void cMenuMain::Set(const char *Plugin)
|
|||||||
|
|
||||||
SetHelp(!replaying ? tr("Record") : NULL, tr("Audio"), replaying ? NULL : tr("Pause"), replaying ? tr("Button$Stop") : cReplayControl::LastReplayed() ? tr("Resume") : NULL);
|
SetHelp(!replaying ? tr("Record") : NULL, tr("Audio"), replaying ? NULL : tr("Pause"), replaying ? tr("Button$Stop") : cReplayControl::LastReplayed() ? tr("Resume") : NULL);
|
||||||
Display();
|
Display();
|
||||||
lastActivity = time(NULL);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
eOSState cMenuMain::ProcessKey(eKeys Key)
|
eOSState cMenuMain::ProcessKey(eKeys Key)
|
||||||
@ -2579,15 +2566,12 @@ eOSState cMenuMain::ProcessKey(eKeys Key)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (Key != kNone) {
|
if (Key != kNone) {
|
||||||
lastActivity = time(NULL);
|
|
||||||
if (Setup.OSDLanguage != osdLanguage) {
|
if (Setup.OSDLanguage != osdLanguage) {
|
||||||
Set();
|
Set();
|
||||||
if (!HasSubMenu())
|
if (!HasSubMenu())
|
||||||
Display();
|
Display();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (time(NULL) - lastActivity > MENUTIMEOUT)
|
|
||||||
state = osEnd;
|
|
||||||
return state;
|
return state;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
9
menu.h
9
menu.h
@ -4,7 +4,7 @@
|
|||||||
* See the main source file 'vdr.c' for copyright information and
|
* See the main source file 'vdr.c' for copyright information and
|
||||||
* how to reach the author.
|
* how to reach the author.
|
||||||
*
|
*
|
||||||
* $Id: menu.h 1.71 2005/08/27 09:37:33 kls Exp $
|
* $Id: menu.h 1.73 2005/09/03 11:41:41 kls Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __MENU_H
|
#ifndef __MENU_H
|
||||||
@ -55,12 +55,11 @@ public:
|
|||||||
|
|
||||||
class cMenuMain : public cOsdMenu {
|
class cMenuMain : public cOsdMenu {
|
||||||
private:
|
private:
|
||||||
time_t lastActivity;
|
|
||||||
bool replaying;
|
bool replaying;
|
||||||
static cOsdObject *pluginOsdObject;
|
static cOsdObject *pluginOsdObject;
|
||||||
void Set(const char *Plugin = NULL);
|
void Set(void);
|
||||||
public:
|
public:
|
||||||
cMenuMain(bool Replaying, eOSState State = osUnknown, const char *Plugin = NULL);
|
cMenuMain(bool Replaying, eOSState State = osUnknown);
|
||||||
virtual eOSState ProcessKey(eKeys Key);
|
virtual eOSState ProcessKey(eKeys Key);
|
||||||
static cOsdObject *PluginOsdObject(void);
|
static cOsdObject *PluginOsdObject(void);
|
||||||
};
|
};
|
||||||
@ -120,7 +119,6 @@ public:
|
|||||||
class cMenuCam : public cOsdMenu {
|
class cMenuCam : public cOsdMenu {
|
||||||
private:
|
private:
|
||||||
cCiMenu *ciMenu;
|
cCiMenu *ciMenu;
|
||||||
time_t lastActivity;
|
|
||||||
bool selected;
|
bool selected;
|
||||||
eOSState Select(void);
|
eOSState Select(void);
|
||||||
public:
|
public:
|
||||||
@ -132,7 +130,6 @@ public:
|
|||||||
class cMenuCamEnquiry : public cOsdMenu {
|
class cMenuCamEnquiry : public cOsdMenu {
|
||||||
private:
|
private:
|
||||||
cCiEnquiry *ciEnquiry;
|
cCiEnquiry *ciEnquiry;
|
||||||
time_t lastActivity;
|
|
||||||
char *input;
|
char *input;
|
||||||
bool replied;
|
bool replied;
|
||||||
eOSState Reply(void);
|
eOSState Reply(void);
|
||||||
|
25
pat.c
25
pat.c
@ -4,7 +4,7 @@
|
|||||||
* See the main source file 'vdr.c' for copyright information and
|
* See the main source file 'vdr.c' for copyright information and
|
||||||
* how to reach the author.
|
* how to reach the author.
|
||||||
*
|
*
|
||||||
* $Id: pat.c 1.13 2005/08/06 12:23:51 kls Exp $
|
* $Id: pat.c 1.14 2005/09/04 14:32:39 kls Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "pat.h"
|
#include "pat.h"
|
||||||
@ -326,8 +326,8 @@ void cPatFilter::Process(u_short Pid, u_char Tid, const u_char *Data, int Length
|
|||||||
int Ppid = pmt.getPCRPid();
|
int Ppid = pmt.getPCRPid();
|
||||||
int Apids[MAXAPIDS + 1] = { 0 }; // these lists are zero-terminated
|
int Apids[MAXAPIDS + 1] = { 0 }; // these lists are zero-terminated
|
||||||
int Dpids[MAXDPIDS + 1] = { 0 };
|
int Dpids[MAXDPIDS + 1] = { 0 };
|
||||||
char ALangs[MAXAPIDS][4] = { "" };
|
char ALangs[MAXAPIDS][MAXLANGCODE2] = { "" };
|
||||||
char DLangs[MAXDPIDS][4] = { "" };
|
char DLangs[MAXDPIDS][MAXLANGCODE2] = { "" };
|
||||||
int Tpid = 0;
|
int Tpid = 0;
|
||||||
int NumApids = 0;
|
int NumApids = 0;
|
||||||
int NumDpids = 0;
|
int NumDpids = 0;
|
||||||
@ -347,9 +347,18 @@ void cPatFilter::Process(u_short Pid, u_char Tid, const u_char *Data, int Length
|
|||||||
switch (d->getDescriptorTag()) {
|
switch (d->getDescriptorTag()) {
|
||||||
case SI::ISO639LanguageDescriptorTag: {
|
case SI::ISO639LanguageDescriptorTag: {
|
||||||
SI::ISO639LanguageDescriptor *ld = (SI::ISO639LanguageDescriptor *)d;
|
SI::ISO639LanguageDescriptor *ld = (SI::ISO639LanguageDescriptor *)d;
|
||||||
|
SI::ISO639LanguageDescriptor::Language l;
|
||||||
|
char *s = ALangs[NumApids];
|
||||||
|
int n = 0;
|
||||||
|
for (SI::Loop::Iterator it; ld->languageLoop.getNext(l, it); ) {
|
||||||
if (*ld->languageCode != '-') { // some use "---" to indicate "none"
|
if (*ld->languageCode != '-') { // some use "---" to indicate "none"
|
||||||
strn0cpy(ALangs[NumApids], I18nNormalizeLanguageCode(ld->languageCode), 4);
|
if (n > 0)
|
||||||
ALangs[NumApids][4] = 0;
|
*s++ = '+';
|
||||||
|
strn0cpy(s, I18nNormalizeLanguageCode(l.languageCode), MAXLANGCODE1);
|
||||||
|
s += strlen(s);
|
||||||
|
if (n++ > 1)
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -366,7 +375,7 @@ void cPatFilter::Process(u_short Pid, u_char Tid, const u_char *Data, int Length
|
|||||||
//XXX case 8: // STREAMTYPE_13818_DSMCC
|
//XXX case 8: // STREAMTYPE_13818_DSMCC
|
||||||
{
|
{
|
||||||
int dpid = 0;
|
int dpid = 0;
|
||||||
char lang[4] = { 0 };
|
char lang[MAXLANGCODE1] = { 0 };
|
||||||
SI::Descriptor *d;
|
SI::Descriptor *d;
|
||||||
for (SI::Loop::Iterator it; (d = stream.streamDescriptors.getNext(it)); ) {
|
for (SI::Loop::Iterator it; (d = stream.streamDescriptors.getNext(it)); ) {
|
||||||
switch (d->getDescriptorTag()) {
|
switch (d->getDescriptorTag()) {
|
||||||
@ -378,7 +387,7 @@ void cPatFilter::Process(u_short Pid, u_char Tid, const u_char *Data, int Length
|
|||||||
break;
|
break;
|
||||||
case SI::ISO639LanguageDescriptorTag: {
|
case SI::ISO639LanguageDescriptorTag: {
|
||||||
SI::ISO639LanguageDescriptor *ld = (SI::ISO639LanguageDescriptor *)d;
|
SI::ISO639LanguageDescriptor *ld = (SI::ISO639LanguageDescriptor *)d;
|
||||||
strn0cpy(lang, I18nNormalizeLanguageCode(ld->languageCode), 4);
|
strn0cpy(lang, I18nNormalizeLanguageCode(ld->languageCode), MAXLANGCODE1);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default: ;
|
default: ;
|
||||||
@ -388,7 +397,7 @@ void cPatFilter::Process(u_short Pid, u_char Tid, const u_char *Data, int Length
|
|||||||
if (dpid) {
|
if (dpid) {
|
||||||
if (NumDpids < MAXDPIDS) {
|
if (NumDpids < MAXDPIDS) {
|
||||||
Dpids[NumDpids] = dpid;
|
Dpids[NumDpids] = dpid;
|
||||||
strn0cpy(DLangs[NumDpids], lang, 4);
|
strn0cpy(DLangs[NumDpids], lang, MAXLANGCODE1);
|
||||||
NumDpids++;
|
NumDpids++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
34
recording.c
34
recording.c
@ -4,7 +4,7 @@
|
|||||||
* See the main source file 'vdr.c' for copyright information and
|
* See the main source file 'vdr.c' for copyright information and
|
||||||
* how to reach the author.
|
* how to reach the author.
|
||||||
*
|
*
|
||||||
* $Id: recording.c 1.111 2005/08/13 14:00:48 kls Exp $
|
* $Id: recording.c 1.113 2005/09/10 12:36:48 kls Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "recording.h"
|
#include "recording.h"
|
||||||
@ -36,15 +36,8 @@
|
|||||||
#define DATAFORMAT "%4d-%02d-%02d.%02d:%02d.%02d.%02d" RECEXT
|
#define DATAFORMAT "%4d-%02d-%02d.%02d:%02d.%02d.%02d" RECEXT
|
||||||
#define NAMEFORMAT "%s/%s/" DATAFORMAT
|
#define NAMEFORMAT "%s/%s/" DATAFORMAT
|
||||||
*/
|
*/
|
||||||
// start of implementation for brain dead systems
|
|
||||||
#define DATAFORMAT "%4d-%02d-%02d.%02d%*c%02d.%02d.%02d" RECEXT
|
#define DATAFORMAT "%4d-%02d-%02d.%02d%*c%02d.%02d.%02d" RECEXT
|
||||||
#ifdef VFAT
|
#define NAMEFORMAT "%s/%s/" "%4d-%02d-%02d.%02d.%02d.%02d.%02d" RECEXT
|
||||||
#define nameFORMAT "%4d-%02d-%02d.%02d.%02d.%02d.%02d" RECEXT
|
|
||||||
#else
|
|
||||||
#define nameFORMAT "%4d-%02d-%02d.%02d:%02d.%02d.%02d" RECEXT
|
|
||||||
#endif
|
|
||||||
#define NAMEFORMAT "%s/%s/" nameFORMAT
|
|
||||||
// end of implementation for brain dead systems
|
|
||||||
|
|
||||||
#define RESUMEFILESUFFIX "/resume%s%s.vdr"
|
#define RESUMEFILESUFFIX "/resume%s%s.vdr"
|
||||||
#ifdef SUMMARYFALLBACK
|
#ifdef SUMMARYFALLBACK
|
||||||
@ -65,6 +58,8 @@
|
|||||||
|
|
||||||
#define MAX_SUBTITLE_LENGTH 40
|
#define MAX_SUBTITLE_LENGTH 40
|
||||||
|
|
||||||
|
bool VfatFileSystem = false;
|
||||||
|
|
||||||
void RemoveDeletedRecordings(void)
|
void RemoveDeletedRecordings(void)
|
||||||
{
|
{
|
||||||
static time_t LastRemoveCheck = 0;
|
static time_t LastRemoveCheck = 0;
|
||||||
@ -297,7 +292,7 @@ static char *ExchangeChars(char *s, bool ToFileSystem)
|
|||||||
{
|
{
|
||||||
char *p = s;
|
char *p = s;
|
||||||
while (*p) {
|
while (*p) {
|
||||||
#ifdef VFAT
|
if (VfatFileSystem) {
|
||||||
// The VFAT file system can't handle all characters, so we
|
// The VFAT file system can't handle all characters, so we
|
||||||
// have to take extra efforts to encode/decode them:
|
// have to take extra efforts to encode/decode them:
|
||||||
if (ToFileSystem) {
|
if (ToFileSystem) {
|
||||||
@ -362,14 +357,15 @@ static char *ExchangeChars(char *s, bool ToFileSystem)
|
|||||||
case '\x03': *p = ':'; break;
|
case '\x03': *p = ':'; break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#else
|
}
|
||||||
|
else {
|
||||||
for (struct tCharExchange *ce = CharExchange; ce->a && ce->b; ce++) {
|
for (struct tCharExchange *ce = CharExchange; ce->a && ce->b; ce++) {
|
||||||
if (*p == (ToFileSystem ? ce->a : ce->b)) {
|
if (*p == (ToFileSystem ? ce->a : ce->b)) {
|
||||||
*p = ToFileSystem ? ce->b : ce->a;
|
*p = ToFileSystem ? ce->b : ce->a;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
}
|
||||||
p++;
|
p++;
|
||||||
}
|
}
|
||||||
return s;
|
return s;
|
||||||
@ -500,6 +496,20 @@ cRecording::cRecording(const char *FileName)
|
|||||||
data[2] = data[1];
|
data[2] = data[1];
|
||||||
data[1] = NULL;
|
data[1] = NULL;
|
||||||
}
|
}
|
||||||
|
else if (line == 2) {
|
||||||
|
// if line 1 is too long, it can't be the short text,
|
||||||
|
// so assume the short text is missing and concatenate
|
||||||
|
// line 1 and line 2 to be the long text:
|
||||||
|
int len = strlen(data[1]);
|
||||||
|
if (len > 80) {
|
||||||
|
data[1] = (char *)realloc(data[1], len + 1 + strlen(data[2]) + 1);
|
||||||
|
strcat(data[1], "\n");
|
||||||
|
strcat(data[1], data[2]);
|
||||||
|
free(data[2]);
|
||||||
|
data[2] = data[1];
|
||||||
|
data[1] = NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
info->SetData(data[0], data[1], data[2]);
|
info->SetData(data[0], data[1], data[2]);
|
||||||
for (int i = 0; i < 3; i ++)
|
for (int i = 0; i < 3; i ++)
|
||||||
free(data[i]);
|
free(data[i]);
|
||||||
|
@ -4,7 +4,7 @@
|
|||||||
* See the main source file 'vdr.c' for copyright information and
|
* See the main source file 'vdr.c' for copyright information and
|
||||||
* how to reach the author.
|
* how to reach the author.
|
||||||
*
|
*
|
||||||
* $Id: recording.h 1.39 2005/08/13 14:09:50 kls Exp $
|
* $Id: recording.h 1.40 2005/09/03 13:04:41 kls Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __RECORDING_H
|
#ifndef __RECORDING_H
|
||||||
@ -18,6 +18,8 @@
|
|||||||
#include "timers.h"
|
#include "timers.h"
|
||||||
#include "tools.h"
|
#include "tools.h"
|
||||||
|
|
||||||
|
extern bool VfatFileSystem;
|
||||||
|
|
||||||
void RemoveDeletedRecordings(void);
|
void RemoveDeletedRecordings(void);
|
||||||
void AssertFreeDiskSpace(int Priority = 0);
|
void AssertFreeDiskSpace(int Priority = 0);
|
||||||
///< The special Priority value -1 means that we shall get rid of any
|
///< The special Priority value -1 means that we shall get rid of any
|
||||||
|
8
remote.c
8
remote.c
@ -4,7 +4,7 @@
|
|||||||
* See the main source file 'vdr.c' for copyright information and
|
* See the main source file 'vdr.c' for copyright information and
|
||||||
* how to reach the author.
|
* how to reach the author.
|
||||||
*
|
*
|
||||||
* $Id: remote.c 1.44 2005/08/14 10:53:55 kls Exp $
|
* $Id: remote.c 1.45 2005/09/03 12:29:48 kls Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "remote.h"
|
#include "remote.h"
|
||||||
@ -143,6 +143,12 @@ bool cRemote::Put(const char *Code, bool Repeat, bool Release)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void cRemote::CallPlugin(const char *Plugin)
|
||||||
|
{
|
||||||
|
plugin = Plugin;
|
||||||
|
Put(k_Plugin);
|
||||||
|
}
|
||||||
|
|
||||||
bool cRemote::HasKeys(void)
|
bool cRemote::HasKeys(void)
|
||||||
{
|
{
|
||||||
cMutexLock MutexLock(&mutex);
|
cMutexLock MutexLock(&mutex);
|
||||||
|
6
remote.h
6
remote.h
@ -4,7 +4,7 @@
|
|||||||
* See the main source file 'vdr.c' for copyright information and
|
* See the main source file 'vdr.c' for copyright information and
|
||||||
* how to reach the author.
|
* how to reach the author.
|
||||||
*
|
*
|
||||||
* $Id: remote.h 1.30 2005/08/13 11:28:10 kls Exp $
|
* $Id: remote.h 1.31 2005/09/03 12:28:42 kls Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __REMOTE_H
|
#ifndef __REMOTE_H
|
||||||
@ -44,6 +44,10 @@ public:
|
|||||||
static void Clear(void);
|
static void Clear(void);
|
||||||
static bool Put(eKeys Key, bool AtFront = false);
|
static bool Put(eKeys Key, bool AtFront = false);
|
||||||
static bool PutMacro(eKeys Key);
|
static bool PutMacro(eKeys Key);
|
||||||
|
static void CallPlugin(const char *Plugin);
|
||||||
|
///< Initiates calling the given plugin's main menu function.
|
||||||
|
///< The Plugin parameter is the name of the plugin, and must be
|
||||||
|
///< a static string.
|
||||||
static const char *GetPlugin(void) { return plugin; }
|
static const char *GetPlugin(void) { return plugin; }
|
||||||
static bool HasKeys(void);
|
static bool HasKeys(void);
|
||||||
static eKeys Get(int WaitMs = 1000, char **UnknownCode = NULL);
|
static eKeys Get(int WaitMs = 1000, char **UnknownCode = NULL);
|
||||||
|
112
remux.c
112
remux.c
@ -11,7 +11,7 @@
|
|||||||
* The cRepacker family's code was originally written by Reinhard Nissl <rnissl@gmx.de>,
|
* The cRepacker family's code was originally written by Reinhard Nissl <rnissl@gmx.de>,
|
||||||
* and adapted to the VDR coding style by Klaus.Schmidinger@cadsoft.de.
|
* and adapted to the VDR coding style by Klaus.Schmidinger@cadsoft.de.
|
||||||
*
|
*
|
||||||
* $Id: remux.c 1.42 2005/08/28 11:46:44 kls Exp $
|
* $Id: remux.c 1.47 2005/09/11 13:26:50 kls Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "remux.h"
|
#include "remux.h"
|
||||||
@ -98,7 +98,7 @@ public:
|
|||||||
static int Put(cRingBufferLinear *ResultBuffer, const uchar *Data, int Count, int CapacityNeeded);
|
static int Put(cRingBufferLinear *ResultBuffer, const uchar *Data, int Count, int CapacityNeeded);
|
||||||
cRepacker(void) { initiallySyncing = true; maxPacketSize = 6 + 65535; subStreamId = 0; }
|
cRepacker(void) { initiallySyncing = true; maxPacketSize = 6 + 65535; subStreamId = 0; }
|
||||||
virtual ~cRepacker() {}
|
virtual ~cRepacker() {}
|
||||||
virtual void Reset(void) { /* initiallySyncing = true; */ }
|
virtual void Reset(void) { initiallySyncing = true; }
|
||||||
virtual void Repack(cRingBufferLinear *ResultBuffer, const uchar *Data, int Count) = 0;
|
virtual void Repack(cRingBufferLinear *ResultBuffer, const uchar *Data, int Count) = 0;
|
||||||
virtual int BreakAt(const uchar *Data, int Count) = 0;
|
virtual int BreakAt(const uchar *Data, int Count) = 0;
|
||||||
virtual int QuerySnoopSize(void) { return 0; }
|
virtual int QuerySnoopSize(void) { return 0; }
|
||||||
@ -142,7 +142,7 @@ void cCommonRepacker::Reset(void)
|
|||||||
{
|
{
|
||||||
cRepacker::Reset();
|
cRepacker::Reset();
|
||||||
skippedBytes = 0;
|
skippedBytes = 0;
|
||||||
packetTodo = maxPacketSize - 6 - 3;
|
packetTodo = 0;
|
||||||
fragmentLen = 0;
|
fragmentLen = 0;
|
||||||
pesHeaderLen = 0;
|
pesHeaderLen = 0;
|
||||||
pesHeaderBackupLen = 0;
|
pesHeaderBackupLen = 0;
|
||||||
@ -161,8 +161,10 @@ bool cCommonRepacker::PushOutPacket(cRingBufferLinear *ResultBuffer, const uchar
|
|||||||
int PesPayloadOffset = 0;
|
int PesPayloadOffset = 0;
|
||||||
if (AnalyzePesHeader(fragmentData, fragmentLen, PesPayloadOffset) <= phInvalid)
|
if (AnalyzePesHeader(fragmentData, fragmentLen, PesPayloadOffset) <= phInvalid)
|
||||||
esyslog("cCommonRepacker: invalid PES packet encountered in fragment buffer!");
|
esyslog("cCommonRepacker: invalid PES packet encountered in fragment buffer!");
|
||||||
else if (6 + PacketLen <= PesPayloadOffset)
|
else if (6 + PacketLen <= PesPayloadOffset) {
|
||||||
|
fragmentLen = 0;
|
||||||
return true; // skip empty packet
|
return true; // skip empty packet
|
||||||
|
}
|
||||||
// amount of data to put into result buffer: a negative Count value means
|
// amount of data to put into result buffer: a negative Count value means
|
||||||
// to strip off any partially contained start code.
|
// to strip off any partially contained start code.
|
||||||
int Bite = fragmentLen + (Count >= 0 ? 0 : Count);
|
int Bite = fragmentLen + (Count >= 0 ? 0 : Count);
|
||||||
@ -180,8 +182,10 @@ bool cCommonRepacker::PushOutPacket(cRingBufferLinear *ResultBuffer, const uchar
|
|||||||
int PesPayloadOffset = 0;
|
int PesPayloadOffset = 0;
|
||||||
if (AnalyzePesHeader(pesHeader, pesHeaderLen, PesPayloadOffset) <= phInvalid)
|
if (AnalyzePesHeader(pesHeader, pesHeaderLen, PesPayloadOffset) <= phInvalid)
|
||||||
esyslog("cCommonRepacker: invalid PES packet encountered in header buffer!");
|
esyslog("cCommonRepacker: invalid PES packet encountered in header buffer!");
|
||||||
else if (6 + PacketLen <= PesPayloadOffset)
|
else if (6 + PacketLen <= PesPayloadOffset) {
|
||||||
|
pesHeaderLen = 0;
|
||||||
return true; // skip empty packet
|
return true; // skip empty packet
|
||||||
|
}
|
||||||
// amount of data to put into result buffer: a negative Count value means
|
// amount of data to put into result buffer: a negative Count value means
|
||||||
// to strip off any partially contained start code.
|
// to strip off any partially contained start code.
|
||||||
int Bite = pesHeaderLen + (Count >= 0 ? 0 : Count);
|
int Bite = pesHeaderLen + (Count >= 0 ? 0 : Count);
|
||||||
@ -361,7 +365,7 @@ void cVideoRepacker::Repack(cRingBufferLinear *ResultBuffer, const uchar *Data,
|
|||||||
done++;
|
done++;
|
||||||
todo--;
|
todo--;
|
||||||
// do we have to start a new packet as there is no more space left?
|
// do we have to start a new packet as there is no more space left?
|
||||||
if (--packetTodo <= 0) {
|
if (state != syncing && --packetTodo <= 0) {
|
||||||
// we connot start a new packet here if the current might end in a start
|
// we connot start a new packet here if the current might end in a start
|
||||||
// code and this start code shall possibly be put in the next packet. So
|
// code and this start code shall possibly be put in the next packet. So
|
||||||
// overfill the current packet until we can safely detect that we won't
|
// overfill the current packet until we can safely detect that we won't
|
||||||
@ -468,6 +472,9 @@ void cVideoRepacker::Repack(cRingBufferLinear *ResultBuffer, const uchar *Data,
|
|||||||
|
|
||||||
int cVideoRepacker::BreakAt(const uchar *Data, int Count)
|
int cVideoRepacker::BreakAt(const uchar *Data, int Count)
|
||||||
{
|
{
|
||||||
|
if (initiallySyncing)
|
||||||
|
return -1; // fill the packet buffer completely until we have synced once
|
||||||
|
|
||||||
int PesPayloadOffset = 0;
|
int PesPayloadOffset = 0;
|
||||||
|
|
||||||
if (AnalyzePesHeader(Data, Count, PesPayloadOffset) <= phInvalid)
|
if (AnalyzePesHeader(Data, Count, PesPayloadOffset) <= phInvalid)
|
||||||
@ -513,31 +520,31 @@ private:
|
|||||||
} state;
|
} state;
|
||||||
int frameTodo;
|
int frameTodo;
|
||||||
int frameSize;
|
int frameSize;
|
||||||
|
int cid;
|
||||||
static bool IsValidAudioHeader(uint32_t Header, bool Mpeg2, int *FrameSize = NULL);
|
static bool IsValidAudioHeader(uint32_t Header, bool Mpeg2, int *FrameSize = NULL);
|
||||||
public:
|
public:
|
||||||
cAudioRepacker(void);
|
cAudioRepacker(int Cid);
|
||||||
virtual void Reset(void);
|
virtual void Reset(void);
|
||||||
virtual void Repack(cRingBufferLinear *ResultBuffer, const uchar *Data, int Count);
|
virtual void Repack(cRingBufferLinear *ResultBuffer, const uchar *Data, int Count);
|
||||||
virtual int BreakAt(const uchar *Data, int Count);
|
virtual int BreakAt(const uchar *Data, int Count);
|
||||||
};
|
};
|
||||||
|
|
||||||
int cAudioRepacker::bitRates[2][3][16] = { // all values are specified as kbits/s
|
int cAudioRepacker::bitRates[2][3][16] = { // all values are specified as kbits/s
|
||||||
// MPEG 1, Layer I
|
{
|
||||||
0, 32, 64, 96, 128, 160, 192, 224, 256, 288, 320, 352, 384, 416, 448, -1,
|
{ 0, 32, 64, 96, 128, 160, 192, 224, 256, 288, 320, 352, 384, 416, 448, -1 }, // MPEG 1, Layer I
|
||||||
// MPEG 1, Layer II
|
{ 0, 32, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320, 384, -1 }, // MPEG 1, Layer II
|
||||||
0, 32, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320, 384, -1,
|
{ 0, 32, 40, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320, -1 } // MPEG 1, Layer III
|
||||||
// MPEG 1, Layer III
|
},
|
||||||
0, 32, 40, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320, -1,
|
{
|
||||||
// MPEG 2, Layer I
|
{ 0, 32, 48, 56, 64, 80, 96, 112, 128, 144, 160, 176, 192, 224, 256, -1 }, // MPEG 2, Layer I
|
||||||
0, 32, 48, 56, 64, 80, 96, 112, 128, 144, 160, 176, 192, 224, 256, -1,
|
{ 0, 8, 16, 24, 32, 40, 48, 56, 64, 80, 96, 112, 128, 144, 160, -1 }, // MPEG 2, Layer II/III
|
||||||
// MPEG 2, Layer II/III
|
{ 0, 8, 16, 24, 32, 40, 48, 56, 64, 80, 96, 112, 128, 144, 160, -1 } // MPEG 2, Layer II/III
|
||||||
0, 8, 16, 24, 32, 40, 48, 56, 64, 80, 96, 112, 128, 144, 160, -1,
|
}
|
||||||
// MPEG 2, Layer II/III
|
|
||||||
0, 8, 16, 24, 32, 40, 48, 56, 64, 80, 96, 112, 128, 144, 160, -1
|
|
||||||
};
|
};
|
||||||
|
|
||||||
cAudioRepacker::cAudioRepacker(void)
|
cAudioRepacker::cAudioRepacker(int Cid)
|
||||||
{
|
{
|
||||||
|
cid = Cid;
|
||||||
Reset();
|
Reset();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -589,17 +596,13 @@ bool cAudioRepacker::IsValidAudioHeader(uint32_t Header, bool Mpeg2, int *FrameS
|
|||||||
*FrameSize = 0;
|
*FrameSize = 0;
|
||||||
else {
|
else {
|
||||||
static int samplingFrequencies[2][4] = { // all values are specified in Hz
|
static int samplingFrequencies[2][4] = { // all values are specified in Hz
|
||||||
// MPEG 1
|
{ 44100, 48000, 32000, -1 }, // MPEG 1
|
||||||
44100, 48000, 32000, -1,
|
{ 22050, 24000, 16000, -1 } // MPEG 2
|
||||||
// MPEG 2
|
|
||||||
22050, 24000, 16000, -1
|
|
||||||
};
|
};
|
||||||
|
|
||||||
static int slots_per_frame[2][3] = {
|
static int slots_per_frame[2][3] = {
|
||||||
// MPEG 1, Layer I, II, III
|
{ 12, 144, 144 }, // MPEG 1, Layer I, II, III
|
||||||
12, 144, 144,
|
{ 12, 144, 72 } // MPEG 2, Layer I, II, III
|
||||||
// MPEG 2, Layer I, II, III
|
|
||||||
12, 144, 72
|
|
||||||
};
|
};
|
||||||
|
|
||||||
int mpegIndex = 1 - id;
|
int mpegIndex = 1 - id;
|
||||||
@ -652,21 +655,11 @@ void cAudioRepacker::Repack(cRingBufferLinear *ResultBuffer, const uchar *Data,
|
|||||||
// collect number of skipped bytes while syncing
|
// collect number of skipped bytes while syncing
|
||||||
if (state <= syncing)
|
if (state <= syncing)
|
||||||
skippedBytes++;
|
skippedBytes++;
|
||||||
else if (frameTodo > 0) {
|
|
||||||
frameTodo--;
|
|
||||||
if (frameTodo == 0 && state == scanFrame) {
|
|
||||||
// the current audio frame is is done now. So push out the packet to
|
|
||||||
// start a new packet for the next audio frame.
|
|
||||||
PushOutPacket(ResultBuffer, payload, data - payload);
|
|
||||||
// go on with syncing to the next audio frame
|
|
||||||
state = syncing;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// did we reach an audio frame header?
|
// did we reach an audio frame header?
|
||||||
scanner <<= 8;
|
scanner <<= 8;
|
||||||
scanner |= *data;
|
scanner |= *data;
|
||||||
if ((scanner & 0xFFF00000) == 0xFFF00000) {
|
if ((scanner & 0xFFF00000) == 0xFFF00000) {
|
||||||
if (frameTodo <= 0 && IsValidAudioHeader(scanner, mpegLevel == phMPEG2, &frameSize)) {
|
if (frameTodo <= 0 && (frameSize == 0 || skippedBytes >= 4) && IsValidAudioHeader(scanner, mpegLevel == phMPEG2, &frameSize)) {
|
||||||
if (state == scanFrame) {
|
if (state == scanFrame) {
|
||||||
// As a new audio frame starts here, the previous one is done. So push
|
// As a new audio frame starts here, the previous one is done. So push
|
||||||
// out the packet to start a new packet for the next audio frame. If
|
// out the packet to start a new packet for the next audio frame. If
|
||||||
@ -681,7 +674,7 @@ void cAudioRepacker::Repack(cRingBufferLinear *ResultBuffer, const uchar *Data,
|
|||||||
if (initiallySyncing) // omit report for the typical initial case
|
if (initiallySyncing) // omit report for the typical initial case
|
||||||
initiallySyncing = false;
|
initiallySyncing = false;
|
||||||
else if (skippedBytes > SkippedBytesLimit) // report that syncing dropped some bytes
|
else if (skippedBytes > SkippedBytesLimit) // report that syncing dropped some bytes
|
||||||
esyslog("cAudioRepacker: skipped %d bytes to sync on next audio frame", skippedBytes - SkippedBytesLimit);
|
esyslog("cAudioRepacker(0x%02X): skipped %d bytes to sync on next audio frame", cid, skippedBytes - SkippedBytesLimit);
|
||||||
skippedBytes = 0;
|
skippedBytes = 0;
|
||||||
// if there is a PES header available, then use it ...
|
// if there is a PES header available, then use it ...
|
||||||
if (pesHeaderBackupLen > 0) {
|
if (pesHeaderBackupLen > 0) {
|
||||||
@ -731,8 +724,18 @@ void cAudioRepacker::Repack(cRingBufferLinear *ResultBuffer, const uchar *Data,
|
|||||||
data++;
|
data++;
|
||||||
done++;
|
done++;
|
||||||
todo--;
|
todo--;
|
||||||
|
// do we have to start a new packet as the current is done?
|
||||||
|
if (frameTodo > 0) {
|
||||||
|
if (--frameTodo == 0) {
|
||||||
|
// the current audio frame is is done now. So push out the packet to
|
||||||
|
// start a new packet for the next audio frame.
|
||||||
|
PushOutPacket(ResultBuffer, payload, data - payload);
|
||||||
|
// go on with syncing to the next audio frame
|
||||||
|
state = syncing;
|
||||||
|
}
|
||||||
|
}
|
||||||
// do we have to start a new packet as there is no more space left?
|
// do we have to start a new packet as there is no more space left?
|
||||||
if (--packetTodo <= 0) {
|
if (state != syncing && --packetTodo <= 0) {
|
||||||
// We connot start a new packet here if the current might end in an audio
|
// We connot start a new packet here if the current might end in an audio
|
||||||
// frame header and this header shall possibly be put in the next packet. So
|
// frame header and this header shall possibly be put in the next packet. So
|
||||||
// overfill the current packet until we can safely detect that we won't
|
// overfill the current packet until we can safely detect that we won't
|
||||||
@ -829,13 +832,16 @@ void cAudioRepacker::Repack(cRingBufferLinear *ResultBuffer, const uchar *Data,
|
|||||||
// report that syncing dropped some bytes
|
// report that syncing dropped some bytes
|
||||||
if (skippedBytes > SkippedBytesLimit) {
|
if (skippedBytes > SkippedBytesLimit) {
|
||||||
if (!initiallySyncing) // omit report for the typical initial case
|
if (!initiallySyncing) // omit report for the typical initial case
|
||||||
esyslog("cAudioRepacker: skipped %d bytes while syncing on next audio frame", skippedBytes - SkippedBytesLimit);
|
esyslog("cAudioRepacker(0x%02X): skipped %d bytes while syncing on next audio frame", cid, skippedBytes - SkippedBytesLimit);
|
||||||
skippedBytes = SkippedBytesLimit;
|
skippedBytes = SkippedBytesLimit;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int cAudioRepacker::BreakAt(const uchar *Data, int Count)
|
int cAudioRepacker::BreakAt(const uchar *Data, int Count)
|
||||||
{
|
{
|
||||||
|
if (initiallySyncing)
|
||||||
|
return -1; // fill the packet buffer completely until we have synced once
|
||||||
|
|
||||||
int PesPayloadOffset = 0;
|
int PesPayloadOffset = 0;
|
||||||
|
|
||||||
ePesHeader MpegLevel = AnalyzePesHeader(Data, Count, PesPayloadOffset);
|
ePesHeader MpegLevel = AnalyzePesHeader(Data, Count, PesPayloadOffset);
|
||||||
@ -1189,6 +1195,8 @@ void cDolbyRepacker::Repack(cRingBufferLinear *ResultBuffer, const uchar *Data,
|
|||||||
|
|
||||||
int cDolbyRepacker::BreakAt(const uchar *Data, int Count)
|
int cDolbyRepacker::BreakAt(const uchar *Data, int Count)
|
||||||
{
|
{
|
||||||
|
if (initiallySyncing)
|
||||||
|
return -1; // fill the packet buffer completely until we have synced once
|
||||||
// enough data for test?
|
// enough data for test?
|
||||||
if (Count < 6 + 3)
|
if (Count < 6 + 3)
|
||||||
return -1;
|
return -1;
|
||||||
@ -1263,7 +1271,7 @@ private:
|
|||||||
int count;
|
int count;
|
||||||
uint8_t *buf;
|
uint8_t *buf;
|
||||||
uint8_t cid;
|
uint8_t cid;
|
||||||
uint8_t audioCid;
|
uint8_t rewriteCid;
|
||||||
uint8_t subStreamId;
|
uint8_t subStreamId;
|
||||||
int plength;
|
int plength;
|
||||||
uint8_t plen[2];
|
uint8_t plen[2];
|
||||||
@ -1287,7 +1295,7 @@ private:
|
|||||||
void write_ipack(const uint8_t *Data, int Count);
|
void write_ipack(const uint8_t *Data, int Count);
|
||||||
void instant_repack(const uint8_t *Buf, int Count);
|
void instant_repack(const uint8_t *Buf, int Count);
|
||||||
public:
|
public:
|
||||||
cTS2PES(int Pid, cRingBufferLinear *ResultBuffer, int Size, uint8_t AudioCid = 0x00, uint8_t SubStreamId = 0x00, cRepacker *Repacker = NULL);
|
cTS2PES(int Pid, cRingBufferLinear *ResultBuffer, int Size, uint8_t RewriteCid = 0x00, uint8_t SubStreamId = 0x00, cRepacker *Repacker = NULL);
|
||||||
~cTS2PES();
|
~cTS2PES();
|
||||||
int Pid(void) { return pid; }
|
int Pid(void) { return pid; }
|
||||||
void ts_to_pes(const uint8_t *Buf); // don't need count (=188)
|
void ts_to_pes(const uint8_t *Buf); // don't need count (=188)
|
||||||
@ -1296,12 +1304,12 @@ public:
|
|||||||
|
|
||||||
uint8_t cTS2PES::headr[] = { 0x00, 0x00, 0x01 };
|
uint8_t cTS2PES::headr[] = { 0x00, 0x00, 0x01 };
|
||||||
|
|
||||||
cTS2PES::cTS2PES(int Pid, cRingBufferLinear *ResultBuffer, int Size, uint8_t AudioCid, uint8_t SubStreamId, cRepacker *Repacker)
|
cTS2PES::cTS2PES(int Pid, cRingBufferLinear *ResultBuffer, int Size, uint8_t RewriteCid, uint8_t SubStreamId, cRepacker *Repacker)
|
||||||
{
|
{
|
||||||
pid = Pid;
|
pid = Pid;
|
||||||
resultBuffer = ResultBuffer;
|
resultBuffer = ResultBuffer;
|
||||||
size = Size;
|
size = Size;
|
||||||
audioCid = AudioCid;
|
rewriteCid = RewriteCid;
|
||||||
subStreamId = SubStreamId;
|
subStreamId = SubStreamId;
|
||||||
repacker = Repacker;
|
repacker = Repacker;
|
||||||
if (repacker) {
|
if (repacker) {
|
||||||
@ -1363,7 +1371,7 @@ void cTS2PES::send_ipack(void)
|
|||||||
{
|
{
|
||||||
if (count <= ((mpeg == 2) ? 9 : 7)) // skip empty packets
|
if (count <= ((mpeg == 2) ? 9 : 7)) // skip empty packets
|
||||||
return;
|
return;
|
||||||
buf[3] = (AUDIO_STREAM_S <= cid && cid <= AUDIO_STREAM_E && audioCid) ? audioCid : cid;
|
buf[3] = rewriteCid ? rewriteCid : cid;
|
||||||
buf[4] = (uint8_t)(((count - 6) & 0xFF00) >> 8);
|
buf[4] = (uint8_t)(((count - 6) & 0xFF00) >> 8);
|
||||||
buf[5] = (uint8_t)((count - 6) & 0x00FF);
|
buf[5] = (uint8_t)((count - 6) & 0x00FF);
|
||||||
store(buf, count);
|
store(buf, count);
|
||||||
@ -1679,20 +1687,22 @@ cRemux::cRemux(int VPid, const int *APids, const int *DPids, const int *SPids, b
|
|||||||
if (VPid)
|
if (VPid)
|
||||||
#define TEST_cVideoRepacker
|
#define TEST_cVideoRepacker
|
||||||
#ifdef TEST_cVideoRepacker
|
#ifdef TEST_cVideoRepacker
|
||||||
ts2pes[numTracks++] = new cTS2PES(VPid, resultBuffer, IPACKS, 0x00, 0x00, new cVideoRepacker);
|
ts2pes[numTracks++] = new cTS2PES(VPid, resultBuffer, IPACKS, 0xE0, 0x00, new cVideoRepacker);
|
||||||
#else
|
#else
|
||||||
ts2pes[numTracks++] = new cTS2PES(VPid, resultBuffer, IPACKS);
|
ts2pes[numTracks++] = new cTS2PES(VPid, resultBuffer, IPACKS, 0xE0);
|
||||||
#endif
|
#endif
|
||||||
if (APids) {
|
if (APids) {
|
||||||
int n = 0;
|
int n = 0;
|
||||||
while (*APids && numTracks < MAXTRACKS && n < MAXAPIDS)
|
while (*APids && numTracks < MAXTRACKS && n < MAXAPIDS) {
|
||||||
#define TEST_cAudioRepacker
|
#define TEST_cAudioRepacker
|
||||||
#ifdef TEST_cAudioRepacker
|
#ifdef TEST_cAudioRepacker
|
||||||
ts2pes[numTracks++] = new cTS2PES(*APids++, resultBuffer, IPACKS, 0xC0 + n++, 0x00, new cAudioRepacker);
|
ts2pes[numTracks++] = new cTS2PES(*APids++, resultBuffer, IPACKS, 0xC0 + n, 0x00, new cAudioRepacker(0xC0 + n));
|
||||||
|
n++;
|
||||||
#else
|
#else
|
||||||
ts2pes[numTracks++] = new cTS2PES(*APids++, resultBuffer, IPACKS, 0xC0 + n++);
|
ts2pes[numTracks++] = new cTS2PES(*APids++, resultBuffer, IPACKS, 0xC0 + n++);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
}
|
||||||
if (DPids) {
|
if (DPids) {
|
||||||
int n = 0;
|
int n = 0;
|
||||||
while (*DPids && numTracks < MAXTRACKS && n < MAXDPIDS)
|
while (*DPids && numTracks < MAXTRACKS && n < MAXDPIDS)
|
||||||
|
@ -10,7 +10,7 @@
|
|||||||
# See the main source file 'vdr.c' for copyright information and
|
# See the main source file 'vdr.c' for copyright information and
|
||||||
# how to reach the author.
|
# how to reach the author.
|
||||||
#
|
#
|
||||||
# $Id: summary2info.pl 1.3 2005/06/04 11:33:09 kls Exp $
|
# $Id: summary2info.pl 1.4 2005/09/10 12:40:40 kls Exp $
|
||||||
|
|
||||||
$VideoDir = $ARGV[0] || die "please provide the name of the video directory\n";
|
$VideoDir = $ARGV[0] || die "please provide the name of the video directory\n";
|
||||||
|
|
||||||
@ -37,6 +37,15 @@ for $SummaryFile (@SummaryFiles) {
|
|||||||
$data[2] = $data[1];
|
$data[2] = $data[1];
|
||||||
$data[1] = "";
|
$data[1] = "";
|
||||||
}
|
}
|
||||||
|
elsif ($line == 2) {
|
||||||
|
# if line 1 is too long, it can't be the short text,
|
||||||
|
# so assume the short text is missing and concatenate
|
||||||
|
# line 1 and line 2 to be the long text:
|
||||||
|
if (length($data[1]) > 80) {
|
||||||
|
$data[2] = $data[1] . "|" . $data[2];
|
||||||
|
$data[1] = "";
|
||||||
|
}
|
||||||
|
}
|
||||||
($InfoFile = $SummaryFile) =~ s/summary\.vdr$/info.vdr/;
|
($InfoFile = $SummaryFile) =~ s/summary\.vdr$/info.vdr/;
|
||||||
open(F, ">$InfoFile") || die "$InfoFile: $!\n";
|
open(F, ">$InfoFile") || die "$InfoFile: $!\n";
|
||||||
print F "T $data[0]\n" if ($data[0]);
|
print F "T $data[0]\n" if ($data[0]);
|
||||||
|
61
svdrp.c
61
svdrp.c
@ -10,7 +10,7 @@
|
|||||||
* and interact with the Video Disk Recorder - or write a full featured
|
* and interact with the Video Disk Recorder - or write a full featured
|
||||||
* graphical interface that sits on top of an SVDRP connection.
|
* graphical interface that sits on top of an SVDRP connection.
|
||||||
*
|
*
|
||||||
* $Id: svdrp.c 1.77 2005/08/28 14:12:00 kls Exp $
|
* $Id: svdrp.c 1.80 2005/09/03 14:09:02 kls Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "svdrp.h"
|
#include "svdrp.h"
|
||||||
@ -269,12 +269,16 @@ const char *HelpPages[] = {
|
|||||||
" at the position where any previous replay was stopped, or from the beginning\n"
|
" at the position where any previous replay was stopped, or from the beginning\n"
|
||||||
" by default. To control or stop the replay session, use the usual remote\n"
|
" by default. To control or stop the replay session, use the usual remote\n"
|
||||||
" control keypresses via the HITK command.",
|
" control keypresses via the HITK command.",
|
||||||
"PLUG <name> [ <command> [ <options> ]]\n"
|
"PLUG <name> [ help | main ] [ <command> [ <options> ]]\n"
|
||||||
" Send a command to a plugin.\n"
|
" Send a command to a plugin.\n"
|
||||||
" The PLUG command without any parameters lists all plugins.\n"
|
" The PLUG command without any parameters lists all plugins.\n"
|
||||||
" If only a name is given, all commands known to that plugin are listed.\n"
|
" If only a name is given, all commands known to that plugin are listed.\n"
|
||||||
" If a command is given (optionally followed by parameters), that command\n"
|
" If a command is given (optionally followed by parameters), that command\n"
|
||||||
" is sent to the plugin, and the result will be displayed.",
|
" is sent to the plugin, and the result will be displayed.\n"
|
||||||
|
" The keyword 'help' lists all the SVDRP commands known to the named plugin.\n"
|
||||||
|
" If 'help' is followed by a command, the detailed help for that command is\n"
|
||||||
|
" given. The keyword 'main' initiates a call to the main menu function of the\n"
|
||||||
|
" given plugin.\n",
|
||||||
"PUTE\n"
|
"PUTE\n"
|
||||||
" Put data into the EPG list. The data entered has to strictly follow the\n"
|
" Put data into the EPG list. The data entered has to strictly follow the\n"
|
||||||
" format defined in vdr(5) for the 'epg.data' file. A '.' on a line\n"
|
" format defined in vdr(5) for the 'epg.data' file. A '.' on a line\n"
|
||||||
@ -1035,8 +1039,51 @@ void cSVDRP::CmdMODT(const char *Option)
|
|||||||
|
|
||||||
void cSVDRP::CmdMOVC(const char *Option)
|
void cSVDRP::CmdMOVC(const char *Option)
|
||||||
{
|
{
|
||||||
//TODO combine this with menu action (timers must be updated)
|
if (*Option) {
|
||||||
Reply(502, "MOVC not yet implemented");
|
if (!Channels.BeingEdited() && !Timers.BeingEdited()) {
|
||||||
|
char *tail;
|
||||||
|
int From = strtol(Option, &tail, 10);
|
||||||
|
if (tail && tail != Option) {
|
||||||
|
tail = skipspace(tail);
|
||||||
|
if (tail && tail != Option) {
|
||||||
|
int To = strtol(tail, NULL, 10);
|
||||||
|
int CurrentChannelNr = cDevice::CurrentChannel();
|
||||||
|
cChannel *CurrentChannel = Channels.GetByNumber(CurrentChannelNr);
|
||||||
|
cChannel *FromChannel = Channels.GetByNumber(From);
|
||||||
|
if (FromChannel) {
|
||||||
|
cChannel *ToChannel = Channels.GetByNumber(To);
|
||||||
|
if (ToChannel) {
|
||||||
|
int FromNumber = FromChannel->Number();
|
||||||
|
int ToNumber = ToChannel->Number();
|
||||||
|
if (FromNumber != ToNumber) {
|
||||||
|
Channels.Move(FromChannel, ToChannel);
|
||||||
|
Channels.ReNumber();
|
||||||
|
Channels.SetModified(true);
|
||||||
|
if (CurrentChannel && CurrentChannel->Number() != CurrentChannelNr)
|
||||||
|
Channels.SwitchTo(CurrentChannel->Number());
|
||||||
|
isyslog("channel %d moved to %d", FromNumber, ToNumber);
|
||||||
|
Reply(250,"Channel \"%d\" moved to \"%d\"", From, To);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
Reply(501, "Can't move channel to same postion");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
Reply(501, "Channel \"%d\" not defined", To);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
Reply(501, "Channel \"%d\" not defined", From);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
Reply(501, "Error in channel number");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
Reply(501, "Error in channel number");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
Reply(550, "Channels or timers are being edited - try again later");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
Reply(501, "Missing channel number");
|
||||||
}
|
}
|
||||||
|
|
||||||
void cSVDRP::CmdMOVT(const char *Option)
|
void cSVDRP::CmdMOVT(const char *Option)
|
||||||
@ -1204,6 +1251,10 @@ void cSVDRP::CmdPLUG(const char *Option)
|
|||||||
Reply(214, "This plugin has no SVDRP commands");
|
Reply(214, "This plugin has no SVDRP commands");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else if (strcasecmp(cmd, "MAIN") == 0) {
|
||||||
|
cRemote::CallPlugin(plugin->Name());
|
||||||
|
Reply(250, "Initiated call to main menu function of plugin \"%s\"", plugin->Name());
|
||||||
|
}
|
||||||
else {
|
else {
|
||||||
int ReplyCode = 900;
|
int ReplyCode = 900;
|
||||||
cString s = plugin->SVDRPCommand(cmd, option, ReplyCode);
|
cString s = plugin->SVDRPCommand(cmd, option, ReplyCode);
|
||||||
|
8
timers.c
8
timers.c
@ -4,12 +4,13 @@
|
|||||||
* See the main source file 'vdr.c' for copyright information and
|
* See the main source file 'vdr.c' for copyright information and
|
||||||
* how to reach the author.
|
* how to reach the author.
|
||||||
*
|
*
|
||||||
* $Id: timers.c 1.34 2005/07/30 13:03:51 kls Exp $
|
* $Id: timers.c 1.36 2005/09/09 15:22:33 kls Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "timers.h"
|
#include "timers.h"
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
#include "channels.h"
|
#include "channels.h"
|
||||||
|
#include "device.h"
|
||||||
#include "i18n.h"
|
#include "i18n.h"
|
||||||
#include "remote.h"
|
#include "remote.h"
|
||||||
|
|
||||||
@ -518,7 +519,10 @@ cTimers::cTimers(void)
|
|||||||
cTimer *cTimers::GetTimer(cTimer *Timer)
|
cTimer *cTimers::GetTimer(cTimer *Timer)
|
||||||
{
|
{
|
||||||
for (cTimer *ti = First(); ti; ti = Next(ti)) {
|
for (cTimer *ti = First(); ti; ti = Next(ti)) {
|
||||||
if (ti->Channel() == Timer->Channel() && ti->Day() == Timer->Day() && ti->Start() == Timer->Start() && ti->Stop() == Timer->Stop())
|
if (ti->Channel() == Timer->Channel() &&
|
||||||
|
(ti->WeekDays() && ti->WeekDays() == Timer->WeekDays() || !ti->WeekDays() && ti->Day() == Timer->Day()) &&
|
||||||
|
ti->Start() == Timer->Start() &&
|
||||||
|
ti->Stop() == Timer->Stop())
|
||||||
return ti;
|
return ti;
|
||||||
}
|
}
|
||||||
return NULL;
|
return NULL;
|
||||||
|
13
tools.c
13
tools.c
@ -4,7 +4,7 @@
|
|||||||
* See the main source file 'vdr.c' for copyright information and
|
* See the main source file 'vdr.c' for copyright information and
|
||||||
* how to reach the author.
|
* how to reach the author.
|
||||||
*
|
*
|
||||||
* $Id: tools.c 1.97 2005/08/27 14:43:55 kls Exp $
|
* $Id: tools.c 1.98 2005/09/11 13:11:05 kls Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "tools.h"
|
#include "tools.h"
|
||||||
@ -1080,8 +1080,7 @@ cHashBase::cHashBase(int Size)
|
|||||||
|
|
||||||
cHashBase::~cHashBase(void)
|
cHashBase::~cHashBase(void)
|
||||||
{
|
{
|
||||||
for (int i = 0; i < size; i++)
|
Clear();
|
||||||
delete hashTable[i];
|
|
||||||
free(hashTable);
|
free(hashTable);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1106,6 +1105,14 @@ void cHashBase::Del(cListObject *Object, unsigned int Id)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void cHashBase::Clear(void)
|
||||||
|
{
|
||||||
|
for (int i = 0; i < size; i++) {
|
||||||
|
delete hashTable[i];
|
||||||
|
hashTable[i] = NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
cListObject *cHashBase::Get(unsigned int Id) const
|
cListObject *cHashBase::Get(unsigned int Id) const
|
||||||
{
|
{
|
||||||
cList<cHashObject> *list = hashTable[hashfn(Id)];
|
cList<cHashObject> *list = hashTable[hashfn(Id)];
|
||||||
|
4
tools.h
4
tools.h
@ -4,7 +4,7 @@
|
|||||||
* See the main source file 'vdr.c' for copyright information and
|
* See the main source file 'vdr.c' for copyright information and
|
||||||
* how to reach the author.
|
* how to reach the author.
|
||||||
*
|
*
|
||||||
* $Id: tools.h 1.75 2005/08/27 14:40:08 kls Exp $
|
* $Id: tools.h 1.76 2005/09/11 13:04:03 kls Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __TOOLS_H
|
#ifndef __TOOLS_H
|
||||||
@ -259,6 +259,7 @@ private:
|
|||||||
cListObject *object;
|
cListObject *object;
|
||||||
public:
|
public:
|
||||||
cHashObject(cListObject *Object, unsigned int Id) { object = Object; id = Id; }
|
cHashObject(cListObject *Object, unsigned int Id) { object = Object; id = Id; }
|
||||||
|
cListObject *Object(void) { return object; }
|
||||||
};
|
};
|
||||||
|
|
||||||
class cHashBase {
|
class cHashBase {
|
||||||
@ -272,6 +273,7 @@ public:
|
|||||||
virtual ~cHashBase();
|
virtual ~cHashBase();
|
||||||
void Add(cListObject *Object, unsigned int Id);
|
void Add(cListObject *Object, unsigned int Id);
|
||||||
void Del(cListObject *Object, unsigned int Id);
|
void Del(cListObject *Object, unsigned int Id);
|
||||||
|
void Clear(void);
|
||||||
cListObject *Get(unsigned int Id) const;
|
cListObject *Get(unsigned int Id) const;
|
||||||
cList<cHashObject> *GetList(unsigned int Id) const;
|
cList<cHashObject> *GetList(unsigned int Id) const;
|
||||||
};
|
};
|
||||||
|
7
vdr.5
7
vdr.5
@ -8,7 +8,7 @@
|
|||||||
.\" License as specified in the file COPYING that comes with the
|
.\" License as specified in the file COPYING that comes with the
|
||||||
.\" vdr distribution.
|
.\" vdr distribution.
|
||||||
.\"
|
.\"
|
||||||
.\" $Id: vdr.5 1.37 2005/05/16 14:16:48 kls Exp $
|
.\" $Id: vdr.5 1.38 2005/09/04 14:43:42 kls Exp $
|
||||||
.\"
|
.\"
|
||||||
.TH vdr 5 "19 Mar 2005" "1.3.23" "Video Disk Recorder Files"
|
.TH vdr 5 "19 Mar 2005" "1.3.23" "Video Disk Recorder Files"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
@ -136,6 +136,11 @@ by an '=' sign, as in
|
|||||||
|
|
||||||
.B ...:101=deu,102=eng;103=deu,104=eng:...
|
.B ...:101=deu,102=eng;103=deu,104=eng:...
|
||||||
|
|
||||||
|
Some channels broadcast two different languages in the two stereo channels, which
|
||||||
|
can be indicated by adding a second language code, delimited by a '+' sign, as in
|
||||||
|
|
||||||
|
.B ...:101=deu,102=eng+spa;103=deu,104=eng:...
|
||||||
|
|
||||||
.TP
|
.TP
|
||||||
.B TPID
|
.B TPID
|
||||||
The teletext PID.
|
The teletext PID.
|
||||||
|
40
vdr.c
40
vdr.c
@ -22,7 +22,7 @@
|
|||||||
*
|
*
|
||||||
* The project's page is at http://www.cadsoft.de/vdr
|
* The project's page is at http://www.cadsoft.de/vdr
|
||||||
*
|
*
|
||||||
* $Id: vdr.c 1.211 2005/08/21 08:47:06 kls Exp $
|
* $Id: vdr.c 1.216 2005/09/04 08:57:15 kls Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <getopt.h>
|
#include <getopt.h>
|
||||||
@ -66,6 +66,7 @@
|
|||||||
#define LASTCAMMENUTIMEOUT 3 // seconds to run the main loop 'fast' after a CAM menu has been closed
|
#define LASTCAMMENUTIMEOUT 3 // seconds to run the main loop 'fast' after a CAM menu has been closed
|
||||||
// in order to react on a possible new CAM menu as soon as possible
|
// in order to react on a possible new CAM menu as soon as possible
|
||||||
#define DEVICEREADYTIMEOUT 30 // seconds to wait until all devices are ready
|
#define DEVICEREADYTIMEOUT 30 // seconds to wait until all devices are ready
|
||||||
|
#define MENUTIMEOUT 120 // seconds of user inactivity after which an OSD display is closed
|
||||||
|
|
||||||
#define EXIT(v) { ExitCode = (v); goto Exit; }
|
#define EXIT(v) { ExitCode = (v); goto Exit; }
|
||||||
|
|
||||||
@ -130,6 +131,9 @@ int main(int argc, char *argv[])
|
|||||||
#elif defined(REMOTE_RCU)
|
#elif defined(REMOTE_RCU)
|
||||||
RcuDevice = RCU_DEVICE;
|
RcuDevice = RCU_DEVICE;
|
||||||
#endif
|
#endif
|
||||||
|
#if defined(VFAT)
|
||||||
|
VfatFileSystem = true;
|
||||||
|
#endif
|
||||||
|
|
||||||
cPluginManager PluginManager(DEFAULTPLUGINDIR);
|
cPluginManager PluginManager(DEFAULTPLUGINDIR);
|
||||||
int ExitCode = 0;
|
int ExitCode = 0;
|
||||||
@ -153,6 +157,7 @@ int main(int argc, char *argv[])
|
|||||||
{ "shutdown", required_argument, NULL, 's' },
|
{ "shutdown", required_argument, NULL, 's' },
|
||||||
{ "terminal", required_argument, NULL, 't' },
|
{ "terminal", required_argument, NULL, 't' },
|
||||||
{ "version", no_argument, NULL, 'V' },
|
{ "version", no_argument, NULL, 'V' },
|
||||||
|
{ "vfat", no_argument, NULL, 'v' | 0x100 },
|
||||||
{ "video", required_argument, NULL, 'v' },
|
{ "video", required_argument, NULL, 'v' },
|
||||||
{ "watchdog", required_argument, NULL, 'w' },
|
{ "watchdog", required_argument, NULL, 'w' },
|
||||||
{ NULL }
|
{ NULL }
|
||||||
@ -245,6 +250,9 @@ int main(int argc, char *argv[])
|
|||||||
break;
|
break;
|
||||||
case 'V': DisplayVersion = true;
|
case 'V': DisplayVersion = true;
|
||||||
break;
|
break;
|
||||||
|
case 'v' | 0x100:
|
||||||
|
VfatFileSystem = true;
|
||||||
|
break;
|
||||||
case 'v': VideoDirectory = optarg;
|
case 'v': VideoDirectory = optarg;
|
||||||
while (optarg && *optarg && optarg[strlen(optarg) - 1] == '/')
|
while (optarg && *optarg && optarg[strlen(optarg) - 1] == '/')
|
||||||
optarg[strlen(optarg) - 1] = 0;
|
optarg[strlen(optarg) - 1] = 0;
|
||||||
@ -303,6 +311,8 @@ int main(int argc, char *argv[])
|
|||||||
" -t TTY, --terminal=TTY controlling tty\n"
|
" -t TTY, --terminal=TTY controlling tty\n"
|
||||||
" -v DIR, --video=DIR use DIR as video directory (default: %s)\n"
|
" -v DIR, --video=DIR use DIR as video directory (default: %s)\n"
|
||||||
" -V, --version print version information and exit\n"
|
" -V, --version print version information and exit\n"
|
||||||
|
" --vfat encode special characters in recording names to\n"
|
||||||
|
" avoid problems with VFAT file systems\n"
|
||||||
" -w SEC, --watchdog=SEC activate the watchdog timer with a timeout of SEC\n"
|
" -w SEC, --watchdog=SEC activate the watchdog timer with a timeout of SEC\n"
|
||||||
" seconds (default: %d); '0' disables the watchdog\n"
|
" seconds (default: %d); '0' disables the watchdog\n"
|
||||||
"\n",
|
"\n",
|
||||||
@ -695,7 +705,7 @@ int main(int argc, char *argv[])
|
|||||||
Menu = new cMenuMain(cControl::Control());
|
Menu = new cMenuMain(cControl::Control());
|
||||||
Temp = NULL;
|
Temp = NULL;
|
||||||
break;
|
break;
|
||||||
#define DirectMainFunction(function...)\
|
#define DirectMainFunction(function)\
|
||||||
DELETENULL(Menu);\
|
DELETENULL(Menu);\
|
||||||
if (cControl::Control())\
|
if (cControl::Control())\
|
||||||
cControl::Control()->Hide();\
|
cControl::Control()->Hide();\
|
||||||
@ -709,7 +719,25 @@ int main(int argc, char *argv[])
|
|||||||
case kSetup: DirectMainFunction(osSetup); break;
|
case kSetup: DirectMainFunction(osSetup); break;
|
||||||
case kCommands: DirectMainFunction(osCommands); break;
|
case kCommands: DirectMainFunction(osCommands); break;
|
||||||
case kUser1 ... kUser9: cRemote::PutMacro(key); key = kNone; break;
|
case kUser1 ... kUser9: cRemote::PutMacro(key); key = kNone; break;
|
||||||
case k_Plugin: DirectMainFunction(osPlugin, cRemote::GetPlugin()); break;
|
case k_Plugin: {
|
||||||
|
DELETENULL(Menu);
|
||||||
|
Temp = NULL;
|
||||||
|
if (cControl::Control())
|
||||||
|
cControl::Control()->Hide();
|
||||||
|
cPlugin *plugin = cPluginManager::GetPlugin(cRemote::GetPlugin());
|
||||||
|
if (plugin) {
|
||||||
|
Menu = Temp = plugin->MainMenuAction();
|
||||||
|
if (Menu) {
|
||||||
|
Menu->Show();
|
||||||
|
if (Menu->IsMenu())
|
||||||
|
((cOsdMenu*)Menu)->Display();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
esyslog("ERROR: unknown plugin '%s'", cRemote::GetPlugin());
|
||||||
|
key = kNone; // nobody else needs to see these keys
|
||||||
|
}
|
||||||
|
break;
|
||||||
// Channel up/down:
|
// Channel up/down:
|
||||||
case kChanUp|k_Repeat:
|
case kChanUp|k_Repeat:
|
||||||
case kChanUp:
|
case kChanUp:
|
||||||
@ -790,8 +818,12 @@ int main(int argc, char *argv[])
|
|||||||
Interact = Menu ? Menu : cControl::Control(); // might have been closed in the mean time
|
Interact = Menu ? Menu : cControl::Control(); // might have been closed in the mean time
|
||||||
if (Interact) {
|
if (Interact) {
|
||||||
eOSState state = Interact->ProcessKey(key);
|
eOSState state = Interact->ProcessKey(key);
|
||||||
if (state == osUnknown && ISMODELESSKEY(key) && cControl::Control() && Interact != cControl::Control())
|
if (state == osUnknown && Interact != cControl::Control()) {
|
||||||
|
if (ISMODELESSKEY(key) && cControl::Control())
|
||||||
state = cControl::Control()->ProcessKey(key);
|
state = cControl::Control()->ProcessKey(key);
|
||||||
|
else if (time(NULL) - LastActivity > MENUTIMEOUT)
|
||||||
|
state = osEnd;
|
||||||
|
}
|
||||||
switch (state) {
|
switch (state) {
|
||||||
case osPause: DELETENULL(Menu);
|
case osPause: DELETENULL(Menu);
|
||||||
cControl::Shutdown(); // just in case
|
cControl::Shutdown(); // just in case
|
||||||
|
Loading…
x
Reference in New Issue
Block a user