mirror of
				https://github.com/rofafor/vdr-plugin-femon.git
				synced 2023-10-10 11:36:53 +00:00 
			
		
		
		
	Compare commits
	
		
			4 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 22802773b8 | ||
|  | ca717b0425 | ||
|  | 9ce3009e39 | ||
|  | b08205607c | 
							
								
								
									
										95
									
								
								HISTORY
									
									
									
									
									
								
							
							
						
						
									
										95
									
								
								HISTORY
									
									
									
									
									
								
							| @@ -106,98 +106,3 @@ VDR Plugin 'femon' Revision History | |||||||
|  |  | ||||||
| - Yet Another Minor Release. | - Yet Another Minor Release. | ||||||
| - Integrated the CA system names patch: "Setup / Show CA System". | - Integrated the CA system names patch: "Setup / Show CA System". | ||||||
|  |  | ||||||
| 2004-11-28: Version 0.1.7 |  | ||||||
|  |  | ||||||
| - Updated for vdr-1.3.17. |  | ||||||
| - Fixed receiver related crash (Thanks to Marco Schluessler). |  | ||||||
|  |  | ||||||
| 2005-01-15: Version 0.7.7 |  | ||||||
|  |  | ||||||
| - Updated for vdr-1.3.18. |  | ||||||
| - Added DEBUG mode (make DEBUG=1 plugins). |  | ||||||
| - OSD height is now user configurable. |  | ||||||
| - Added audio channel selection into Yellow key. |  | ||||||
|  |  | ||||||
| 2005-01-23: Version 0.7.9 |  | ||||||
|  |  | ||||||
| - Some minor cosmetic fixes. |  | ||||||
|  |  | ||||||
| 2005-01-23: Version 0.8.0 |  | ||||||
|  |  | ||||||
| - Updated for vdr-1.3.19. |  | ||||||
|  |  | ||||||
| 2005-01-24: Version 0.8.1 |  | ||||||
|  |  | ||||||
| - Added Estonian translations (Thanks to Arthur Konovalov). |  | ||||||
|  |  | ||||||
| 2005-02-24: Version 0.8.5 |  | ||||||
|  |  | ||||||
| - Updated for vdr-1.3.21. |  | ||||||
| - Minor modification for DEBUG mode. |  | ||||||
| - Added preliminary support for themes and some GUI tweaks. |  | ||||||
| - Added horizontal offset setup option. |  | ||||||
|  |  | ||||||
| 2005-02-26: Version 0.8.6 |  | ||||||
|  |  | ||||||
| - Horizontal offset setup option should be functional now. |  | ||||||
|  |  | ||||||
| 2005-04-01: Version 0.8.7 |  | ||||||
|  |  | ||||||
| - Default make target is now all. |  | ||||||
| - Fixed the access rights of symbols subdirectory (Thanks to Harri Kukkonen). |  | ||||||
| - Added a new theme: Moronimo (Thanks to Morone). |  | ||||||
|  |  | ||||||
| 2005-04-02: Version 0.8.8 |  | ||||||
|  |  | ||||||
| - Cleaned up finnish translations (Thanks to Ville Skytt<74>). |  | ||||||
|  |  | ||||||
| 2005-04-04: Version 0.8.9 |  | ||||||
|  |  | ||||||
| - Updated Estonian translations (Thanks to Arthur Konovalov). |  | ||||||
| - Added the missing german translations (Thanks to #vdr-portal). |  | ||||||
|  |  | ||||||
| 2005-05-20: Version 0.9.0 |  | ||||||
|  |  | ||||||
| - Renamed compiling switches ('DEBUG' to 'FEMON_DEBUG' and 'NTSC_SYSTEM' to 'FEMON_NTSC'). |  | ||||||
| - Enabled preliminary support for the device switching. |  | ||||||
|  |  | ||||||
| 2005-07-23: Version 0.9.1 |  | ||||||
|  |  | ||||||
| - Fixed AC3-info flickering (Thanks to Pasi Juppo for reporting this one). |  | ||||||
| - Added "Analog" type CA system. |  | ||||||
| - Plugin is now stripped by default. |  | ||||||
|  |  | ||||||
| 2005-08-15: Version 0.9.2 |  | ||||||
|  |  | ||||||
| - Threads updated for vdr-1.3.29. |  | ||||||
|  |  | ||||||
| 2005-08-28: Version 0.9.3 |  | ||||||
|  |  | ||||||
| - Updated for vdr-1.3.31. |  | ||||||
| - Added preliminary svdrp and service support. |  | ||||||
|  |  | ||||||
| 2005-10-04: Version 0.9.4 |  | ||||||
|  |  | ||||||
| - Updated for vdr-1.3.34. |  | ||||||
| - Added Enigma theme (Thanks to Rolf Hoverath). |  | ||||||
| - Added EgalsTry theme (Thanks to Uwe Hanke). |  | ||||||
| - Added option to disable rounded corners. |  | ||||||
|  |  | ||||||
| 2005-11-13: Version 0.9.5 |  | ||||||
|  |  | ||||||
| - Updated for vdr-1.3.36. |  | ||||||
| - Added french translation (Thanks to Nicolas Huillard). |  | ||||||
| - Enabled bitrate commands via SVDRP. |  | ||||||
| - Added new SVDRP commands. |  | ||||||
| - Modified femon service without incrementing version number. |  | ||||||
| - Added "Duotone" theme for 2bpp on screen displays. |  | ||||||
| - Fixed crash bug in femonreceiver. |  | ||||||
| - Fixed setup page bug (Thanks to Thomas G<>nther for reporting this one). |  | ||||||
|  |  | ||||||
| 2006-01-25: Version 0.9.6 |  | ||||||
|  |  | ||||||
| - Updated for vdr-1.3.40. |  | ||||||
| - Fixed a translation bug (Thanks to Antti Hartikainen). |  | ||||||
| - Fixed AC3 header parsing bug (Thanks to Axel Katzur for reporting this one). |  | ||||||
| - Fixed EgalsTry theme (Thanks to Uwe Hanke). |  | ||||||
|   | |||||||
							
								
								
									
										18
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										18
									
								
								Makefile
									
									
									
									
									
								
							| @@ -16,7 +16,7 @@ VERSION = $(shell grep 'static const char \*VERSION *=' $(PLUGIN).h | awk '{ pri | |||||||
| ### The C++ compiler and options: | ### The C++ compiler and options: | ||||||
|  |  | ||||||
| CXX      ?= g++ | CXX      ?= g++ | ||||||
| CXXFLAGS ?= -fPIC -g -O2 -Wall -Woverloaded-virtual | CXXFLAGS ?= -O2 -Wall -Woverloaded-virtual | ||||||
|  |  | ||||||
| ### The directory environment: | ### The directory environment: | ||||||
|  |  | ||||||
| @@ -44,20 +44,13 @@ INCLUDES += -I$(VDRDIR)/include -I$(DVBDIR)/include | |||||||
|  |  | ||||||
| DEFINES += -D_GNU_SOURCE -DPLUGIN_NAME_I18N='"$(PLUGIN)"' | DEFINES += -D_GNU_SOURCE -DPLUGIN_NAME_I18N='"$(PLUGIN)"' | ||||||
|  |  | ||||||
| ifdef FEMON_NTSC | ifdef NTSC_SYSTEM | ||||||
| DEFINES += -DFEMON_NTSC | DEFINES += -DNTSC_SYSTEM | ||||||
| endif | endif | ||||||
|  |  | ||||||
| ifdef FEMON_DEBUG |  | ||||||
| DEFINES += -DFEMON_DEBUG |  | ||||||
| endif |  | ||||||
|  |  | ||||||
| .PHONY: all all-redirect |  | ||||||
| all-redirect: all |  | ||||||
|  |  | ||||||
| ### The object files (add further files here): | ### The object files (add further files here): | ||||||
|  |  | ||||||
| OBJS = femon.o femonosd.o femonreceiver.o femoncfg.o femoni18n.o femontools.o | OBJS = femon.o femonosd.o femonreceiver.o femoncfg.o femoni18n.o | ||||||
|  |  | ||||||
| ### Implicit rules: | ### Implicit rules: | ||||||
|  |  | ||||||
| @@ -80,9 +73,6 @@ all: libvdr-$(PLUGIN).so | |||||||
| libvdr-$(PLUGIN).so: $(OBJS) | libvdr-$(PLUGIN).so: $(OBJS) | ||||||
| 	$(CXX) $(CXXFLAGS) -shared $(OBJS) -o $@ | 	$(CXX) $(CXXFLAGS) -shared $(OBJS) -o $@ | ||||||
| 	@cp $@ $(LIBDIR)/$@.$(VDRVERSION) | 	@cp $@ $(LIBDIR)/$@.$(VDRVERSION) | ||||||
| ifndef FEMON_DEBUG |  | ||||||
| 	strip $(LIBDIR)/$@.$(VDRVERSION) |  | ||||||
| endif |  | ||||||
|  |  | ||||||
| dist: clean | dist: clean | ||||||
| 	@-rm -rf $(TMPDIR)/$(ARCHIVE) | 	@-rm -rf $(TMPDIR)/$(ARCHIVE) | ||||||
|   | |||||||
							
								
								
									
										35
									
								
								README
									
									
									
									
									
								
							
							
						
						
									
										35
									
								
								README
									
									
									
									
									
								
							| @@ -21,14 +21,16 @@ transponder and stream information are also available in advanced display modes. | |||||||
|  |  | ||||||
| The plugin is based on a neat console frontend status monitor application | The plugin is based on a neat console frontend status monitor application | ||||||
| called 'femon' by Johannes Stezenbach (see DVB-apps/szap/femon.c for further | called 'femon' by Johannes Stezenbach (see DVB-apps/szap/femon.c for further | ||||||
| information). The bitrate calculation trick originates from the 'dvbstream' | information). The other parts of plugin code are borrowed from the excellent | ||||||
| application by Dave Chapman and the stream information routines are taken from | 'OSD Picture-In-Picture' plugin by Sascha Volkenandt and Andreas Regel. The | ||||||
| the 'libdvb' library by Metzler Brothers. | bitrate calculation algorithm originates from the 'dvbstream' application by | ||||||
|  | Dave Chapman and the stream information routines from the 'libdvb' library by | ||||||
|  | Metzler Brothers. | ||||||
|  |  | ||||||
| Terminology: | Terminology: | ||||||
|  |  | ||||||
| -------------------------------------------------------------- | -------------------------------------------------------------- | ||||||
| |## Channel Name ########################## [AR][VF][A/DD][D]| | |## Channel Name ######################### [DD][AR][VF][A][D]| | ||||||
| |[=====Signal Strength in % ==============|=================]| | |[=====Signal Strength in % ==============|=================]| | ||||||
| |[=====Signal-to-Noise Ratio in % ========|=================]| | |[=====Signal-to-Noise Ratio in % ========|=================]| | ||||||
| | STR: #0000 (0%)       BER: #00000000       Video: 0 Mbit/s | | | STR: #0000 (0%)       BER: #00000000       Video: 0 Mbit/s | | ||||||
| @@ -49,9 +51,10 @@ CARRIER - Found a DVB signal | |||||||
| VITERBI - FEC (forward error correction) is stable | VITERBI - FEC (forward error correction) is stable | ||||||
| SYNC    - Found sync bytes | SYNC    - Found sync bytes | ||||||
|  |  | ||||||
|  | DD      - AC-3 stream (optional) | ||||||
| AR      - Aspect Ratio: 1:1/4:3/16:9/2.21:1 (optional) | AR      - Aspect Ratio: 1:1/4:3/16:9/2.21:1 (optional) | ||||||
| VF      - Video format: PAL/NTSC (optional) | VF      - Video format: PAL/NTSC (optional) | ||||||
| A/DD    - Audio (0..5) / AC-3 track (optional) | A       - Audio track: 1..2 (optional) | ||||||
| D       - Device number: 0..3 (optional) | D       - Device number: 0..3 (optional) | ||||||
|  |  | ||||||
| Controls: | Controls: | ||||||
| @@ -60,10 +63,9 @@ ChanUp/ChanDn - Switch channel up/down | |||||||
| Up/Down       - Switch channel up/down | Up/Down       - Switch channel up/down | ||||||
| 0-9           - Select channel | 0-9           - Select channel | ||||||
| Ok            - Switch between display modes: basic, transponder, stream, AC-3 | Ok            - Switch between display modes: basic, transponder, stream, AC-3 | ||||||
| Green         - Select next audio track | Right/Left    - Switch to next/previous device that provides the current channel | ||||||
| Yellow        - Select audio channel: stereo, mono left, mono right | Green         - Select language (APID) | ||||||
| Back          - Exit plugin | Back          - Exit plugin | ||||||
| Left/Right    - Switch to next/previous device that provides the current channel |  | ||||||
|  |  | ||||||
| Installation: | Installation: | ||||||
|  |  | ||||||
| @@ -77,18 +79,17 @@ make plugins | |||||||
|  |  | ||||||
| Notes: | Notes: | ||||||
|  |  | ||||||
| - The plugin supports only those DVB cards with _one_ frontend, because I | - The plugin supports only those DVB cards with _one_ frontend (do any cards | ||||||
|   haven't yet figured howto do it without patching the VDR core. |   with multiple frontends even exist?), because I haven't yet figured howto do | ||||||
|  |   it without patching the VDR core. | ||||||
|  | - Sometimes (read always) ttxtsubs plugin messes up the OSD - user should disable | ||||||
|  |   ttxtsubs, but closing and reopening the femon plugin might help temporarily as | ||||||
|  |   well. Btw., this same thing happens with OSDTeletext plugin too :) | ||||||
| - Disable the stream analyze to speed up heavy zapping sessions. | - Disable the stream analyze to speed up heavy zapping sessions. | ||||||
|  |  | ||||||
| - The signal strength and signal-to-noise ratio values are comparable only | - The signal strength and signal-to-noise ratio values are comparable only | ||||||
|   between the same brand/model frontends. Due to the lack of proper frontend |   between the same brand/model frontends. Due to the lack of proper frontend | ||||||
|   specifications those values cannot be calculated into any real units. |   specifications those values cannot be calculated into any real units. | ||||||
|  | - Shrinked OSD is available for NTSC users: make NTSC_SYSTEM=1 | ||||||
| - If the OSD isn't visible, you've configured the OSD height too big or too | - The device switching feature is still non-functional. | ||||||
|   small. Please, try to adjust the variable on the setup page before writing |  | ||||||
|   any bug reports. NTSC users should use a shrinked default OSD height by |  | ||||||
|   compiling the plugin with: make FEMON_NTSC=1 |  | ||||||
|  |  | ||||||
| "Femon - A real womon who lives according to her natural feminine inclinations." | "Femon - A real womon who lives according to her natural feminine inclinations." | ||||||
|   | |||||||
							
								
								
									
										200
									
								
								femon.c
									
									
									
									
									
								
							
							
						
						
									
										200
									
								
								femon.c
									
									
									
									
									
								
							| @@ -6,31 +6,26 @@ | |||||||
|  * $Id$ |  * $Id$ | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #include <vdr/remote.h> |  | ||||||
| #include "femoncfg.h" | #include "femoncfg.h" | ||||||
| #include "femoni18n.h" | #include "femoni18n.h" | ||||||
| #include "femonreceiver.h" | #include "femonreceiver.h" | ||||||
| #include "femonosd.h" | #include "femonosd.h" | ||||||
| #include "femonservice.h" |  | ||||||
| #include "femontools.h" |  | ||||||
| #include "femon.h" | #include "femon.h" | ||||||
|  |  | ||||||
| #if defined(VDRVERSNUM) && VDRVERSNUM < 10340 | #if VDRVERSNUM && VDRVERSNUM >= 10307 | ||||||
| #error "You don't exist! Go away! Upgrade yourself!" | #error "You don't exist! Go away!" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| cPluginFemon::cPluginFemon() | cPluginFemon::cPluginFemon(void) | ||||||
| { | { | ||||||
|   // Initialize any member variables here. |   // Initialize any member variables here. | ||||||
|   // DON'T DO ANYTHING ELSE THAT MAY HAVE SIDE EFFECTS, REQUIRE GLOBAL |   // DON'T DO ANYTHING ELSE THAT MAY HAVE SIDE EFFECTS, REQUIRE GLOBAL | ||||||
|   // VDR OBJECTS TO EXIST OR PRODUCE ANY OUTPUT! |   // VDR OBJECTS TO EXIST OR PRODUCE ANY OUTPUT! | ||||||
|   Dprintf("%s()\n", __PRETTY_FUNCTION__); |  | ||||||
| } | } | ||||||
|  |  | ||||||
| cPluginFemon::~cPluginFemon() | cPluginFemon::~cPluginFemon() | ||||||
| { | { | ||||||
|   // Clean up after yourself! |   // Clean up after yourself! | ||||||
|   Dprintf("%s()\n", __PRETTY_FUNCTION__); |  | ||||||
| } | } | ||||||
|  |  | ||||||
| const char *cPluginFemon::CommandLineHelp(void) | const char *cPluginFemon::CommandLineHelp(void) | ||||||
| @@ -58,11 +53,6 @@ bool cPluginFemon::Start(void) | |||||||
|   return true; |   return true; | ||||||
| } | } | ||||||
|  |  | ||||||
| void cPluginFemon::Stop(void) |  | ||||||
| { |  | ||||||
|   // Stop the background activities. |  | ||||||
| } |  | ||||||
|  |  | ||||||
| void cPluginFemon::Housekeeping(void) | void cPluginFemon::Housekeeping(void) | ||||||
| { | { | ||||||
|   // Perform any cleanup or other regular tasks. |   // Perform any cleanup or other regular tasks. | ||||||
| @@ -71,8 +61,7 @@ void cPluginFemon::Housekeeping(void) | |||||||
| cOsdObject *cPluginFemon::MainMenuAction(void) | cOsdObject *cPluginFemon::MainMenuAction(void) | ||||||
| { | { | ||||||
|   // Perform the action when selected from the main VDR menu. |   // Perform the action when selected from the main VDR menu. | ||||||
|   Dprintf("%s()\n", __PRETTY_FUNCTION__); |   return new cFemonOsd(); | ||||||
|   return cFemonOsd::Instance(true); |  | ||||||
| } | } | ||||||
|  |  | ||||||
| bool cPluginFemon::SetupParse(const char *Name, const char *Value) | bool cPluginFemon::SetupParse(const char *Name, const char *Value) | ||||||
| @@ -82,10 +71,6 @@ bool cPluginFemon::SetupParse(const char *Name, const char *Value) | |||||||
|   else if (!strcasecmp(Name, "SyslogOutput"))   femonConfig.syslogoutput   = atoi(Value); |   else if (!strcasecmp(Name, "SyslogOutput"))   femonConfig.syslogoutput   = atoi(Value); | ||||||
|   else if (!strcasecmp(Name, "DisplayMode"))    femonConfig.displaymode    = atoi(Value); |   else if (!strcasecmp(Name, "DisplayMode"))    femonConfig.displaymode    = atoi(Value); | ||||||
|   else if (!strcasecmp(Name, "Position"))       femonConfig.position       = atoi(Value); |   else if (!strcasecmp(Name, "Position"))       femonConfig.position       = atoi(Value); | ||||||
|   else if (!strcasecmp(Name, "OSDHeight"))      femonConfig.osdheight      = atoi(Value); |  | ||||||
|   else if (!strcasecmp(Name, "OSDOffset"))      femonConfig.osdoffset      = atoi(Value); |  | ||||||
|   else if (!strcasecmp(Name, "Skin"))           femonConfig.skin           = atoi(Value); |  | ||||||
|   else if (!strcasecmp(Name, "Theme"))          femonConfig.theme          = atoi(Value); |  | ||||||
|   else if (!strcasecmp(Name, "ShowCASystem"))   femonConfig.showcasystem   = atoi(Value); |   else if (!strcasecmp(Name, "ShowCASystem"))   femonConfig.showcasystem   = atoi(Value); | ||||||
|   else if (!strcasecmp(Name, "RedLimit"))       femonConfig.redlimit       = atoi(Value); |   else if (!strcasecmp(Name, "RedLimit"))       femonConfig.redlimit       = atoi(Value); | ||||||
|   else if (!strcasecmp(Name, "GreenLimit"))     femonConfig.greenlimit     = atoi(Value); |   else if (!strcasecmp(Name, "GreenLimit"))     femonConfig.greenlimit     = atoi(Value); | ||||||
| @@ -94,150 +79,17 @@ bool cPluginFemon::SetupParse(const char *Name, const char *Value) | |||||||
|   else if (!strcasecmp(Name, "CalcInterval"))   femonConfig.calcinterval   = atoi(Value); |   else if (!strcasecmp(Name, "CalcInterval"))   femonConfig.calcinterval   = atoi(Value); | ||||||
|   else |   else | ||||||
|     return false; |     return false; | ||||||
|   if (femonConfig.displaymode < 0 || femonConfig.displaymode >= eFemonModeMaxNumber) femonConfig.displaymode = 0; |   if (femonConfig.displaymode < 0 || femonConfig.displaymode >= modeMaxNumber) femonConfig.displaymode = 0; | ||||||
|  |  | ||||||
|   return true; |   return true; | ||||||
| } | } | ||||||
|  |  | ||||||
| bool cPluginFemon::Service(const char *Id, void *Data) |  | ||||||
| { |  | ||||||
|   if ((strcmp(Id,"FemonService-v1.0") == 0) && Data) { |  | ||||||
|      FemonService_v1_0 *data = (FemonService_v1_0*)Data; |  | ||||||
|      int ndx = cDevice::ActualDevice()->CardIndex(); |  | ||||||
|      data->fe_name = getFrontendName(ndx); |  | ||||||
|      data->fe_status = getFrontendStatus(ndx); |  | ||||||
|      data->fe_snr = getSNR(ndx); |  | ||||||
|      data->fe_signal = getSignal(ndx); |  | ||||||
|      data->fe_ber = getBER(ndx); |  | ||||||
|      data->fe_unc = getUNC(ndx); |  | ||||||
|      data->video_bitrate = cFemonOsd::Instance() ? cFemonOsd::Instance()->GetVideoBitrate() : 0.0; |  | ||||||
|      data->audio_bitrate = cFemonOsd::Instance() ? cFemonOsd::Instance()->GetAudioBitrate() : 0.0; |  | ||||||
|      data->dolby_bitrate = cFemonOsd::Instance() ? cFemonOsd::Instance()->GetDolbyBitrate() : 0.0; |  | ||||||
|      return true; |  | ||||||
|      } |  | ||||||
|  |  | ||||||
|   return false; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| const char **cPluginFemon::SVDRPHelpPages(void) |  | ||||||
| {  |  | ||||||
|   static const char *HelpPages[] = { |  | ||||||
|     "OPEN\n" |  | ||||||
|     "    Open femon plugin.", |  | ||||||
|     "QUIT\n" |  | ||||||
|     "    Close femon plugin.", |  | ||||||
|     "NEXT\n" |  | ||||||
|     "    Switch to next possible device.", |  | ||||||
|     "PREV\n" |  | ||||||
|     "    Switch to previous possible device.", |  | ||||||
|     "NAME\n" |  | ||||||
|     "    Print the current frontend name.", |  | ||||||
|     "STAT\n" |  | ||||||
|     "    Print the current frontend status.", |  | ||||||
|     "SGNL\n" |  | ||||||
|     "    Print the current signal strength.", |  | ||||||
|     "SNRA\n" |  | ||||||
|     "    Print the current signal-to-noise ratio.", |  | ||||||
|     "BERA\n" |  | ||||||
|     "    Print the current bit error rate.", |  | ||||||
|     "UNCB\n" |  | ||||||
|     "    Print the current uncorrcted blocks rate.", |  | ||||||
|     "VIBR\n" |  | ||||||
|     "    Print the actual device and current video bitrate [Mbit/s].", |  | ||||||
|     "AUBR\n" |  | ||||||
|     "    Print the actual device and current audio bitrate [kbit/s].", |  | ||||||
|     "DDBR\n" |  | ||||||
|     "    Print the actual device and current dolby bitrate [kbit/s].", |  | ||||||
|     NULL |  | ||||||
|     }; |  | ||||||
|   return HelpPages; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| cString cPluginFemon::SVDRPCommand(const char *Command, const char *Option, int &ReplyCode) |  | ||||||
| { |  | ||||||
|   if (strcasecmp(Command, "OPEN") == 0) { |  | ||||||
|      if (!cFemonOsd::Instance()) |  | ||||||
|         cRemote::CallPlugin("femon"); |  | ||||||
|      return cString("Opening femon plugin"); |  | ||||||
|      } |  | ||||||
|   else if (strcasecmp(Command, "QUIT") == 0) { |  | ||||||
|      if (cFemonOsd::Instance()) |  | ||||||
|         cRemote::Put(kBack); |  | ||||||
|      return cString("Closing femon plugin"); |  | ||||||
|      } |  | ||||||
|   else if (strcasecmp(Command, "NEXT") == 0) { |  | ||||||
|      if (cFemonOsd::Instance()) |  | ||||||
|         return cString::sprintf("Switching to next device: %s", cFemonOsd::Instance()->DeviceSwitch(1) ? "ok" : "failed"); |  | ||||||
|      else |  | ||||||
|         return cString("Cannot switch device"); |  | ||||||
|      } |  | ||||||
|   else if (strcasecmp(Command, "PREV") == 0) { |  | ||||||
|      if (cFemonOsd::Instance()) |  | ||||||
|         return cString::sprintf("Switching to previous device: %s", cFemonOsd::Instance()->DeviceSwitch(-1) ? "ok" : "failed"); |  | ||||||
|      else |  | ||||||
|         return cString("Cannot switch device"); |  | ||||||
|      } |  | ||||||
|   else if (strcasecmp(Command, "NAME") == 0) { |  | ||||||
|      return getFrontendName(cDevice::ActualDevice()->CardIndex()); |  | ||||||
|      } |  | ||||||
|   else if (strcasecmp(Command, "STAT") == 0) { |  | ||||||
|      return getFrontendStatus(cDevice::ActualDevice()->CardIndex()); |  | ||||||
|      } |  | ||||||
|   else if (strcasecmp(Command, "SGNL") == 0) { |  | ||||||
|      int value = getSignal(cDevice::ActualDevice()->CardIndex()); |  | ||||||
|      return cString::sprintf("%04X (%02d%%) on device #%d", value, value / 655, cDevice::ActualDevice()->CardIndex()); |  | ||||||
|      } |  | ||||||
|   else if (strcasecmp(Command, "SNRA") == 0) { |  | ||||||
|      int value = getSNR(cDevice::ActualDevice()->CardIndex()); |  | ||||||
|      return cString::sprintf("%04X (%02d%%) on device #%d", value, value / 655, cDevice::ActualDevice()->CardIndex()); |  | ||||||
|      } |  | ||||||
|   else if (strcasecmp(Command, "BERA") == 0) { |  | ||||||
|      return cString::sprintf("%08X on device #%d", getBER(cDevice::ActualDevice()->CardIndex()), cDevice::ActualDevice()->CardIndex()); |  | ||||||
|      } |  | ||||||
|   else if (strcasecmp(Command, "UNCB") == 0) { |  | ||||||
|      return cString::sprintf("%08X on device #%d", getUNC(cDevice::ActualDevice()->CardIndex()), cDevice::ActualDevice()->CardIndex()); |  | ||||||
|      } |  | ||||||
|   else if (strcasecmp(Command, "VIBR") == 0) { |  | ||||||
|      if (cFemonOsd::Instance()) |  | ||||||
|         return cString::sprintf("%.2f Mbit/s on device #%d", cFemonOsd::Instance()->GetVideoBitrate(), cDevice::ActualDevice()->CardIndex()); |  | ||||||
|      else |  | ||||||
|         return cString::sprintf("--- Mbit/s on device #%d", cDevice::ActualDevice()->CardIndex()); |  | ||||||
|      } |  | ||||||
|   else if (strcasecmp(Command, "AUBR") == 0) { |  | ||||||
|      if (cFemonOsd::Instance()) |  | ||||||
|         return cString::sprintf("%.0f kbit/s on device #%d", cFemonOsd::Instance()->GetAudioBitrate(), cDevice::ActualDevice()->CardIndex()); |  | ||||||
|      else |  | ||||||
|         return cString::sprintf("--- kbit/s on device #%d", cDevice::ActualDevice()->CardIndex()); |  | ||||||
|      } |  | ||||||
|   else if (strcasecmp(Command, "DDBR") == 0) { |  | ||||||
|      if (cFemonOsd::Instance()) |  | ||||||
|         return cString::sprintf("%.0f kbit/s on device #%d", cFemonOsd::Instance()->GetDolbyBitrate(), cDevice::ActualDevice()->CardIndex()); |  | ||||||
|      else |  | ||||||
|         return cString::sprintf("--- kbit/s on device #%d", cDevice::ActualDevice()->CardIndex()); |  | ||||||
|      } |  | ||||||
|   return NULL; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| cMenuFemonSetup::cMenuFemonSetup(void) | cMenuFemonSetup::cMenuFemonSetup(void) | ||||||
| { | { | ||||||
|   Dprintf("%s()\n", __PRETTY_FUNCTION__); |   dispmodes[modeBasic]       = tr("basic"); | ||||||
|   dispmodes[eFemonModeBasic]       = tr("basic"); |   dispmodes[modeTransponder] = tr("transponder"); | ||||||
|   dispmodes[eFemonModeTransponder] = tr("transponder"); |   dispmodes[modeStream]      = tr("stream"); | ||||||
|   dispmodes[eFemonModeStream]      = tr("stream"); |   dispmodes[modeAC3]         = tr("AC-3"); | ||||||
|   dispmodes[eFemonModeAC3]         = tr("AC-3"); |  | ||||||
|  |  | ||||||
|   skins[eFemonSkinClassic]         = tr("Classic"); |  | ||||||
|   skins[eFemonSkinElchi]           = tr("Elchi"); |  | ||||||
|  |  | ||||||
|   themes[eFemonThemeClassic]       = tr("Classic"); |  | ||||||
|   themes[eFemonThemeElchi]         = tr("Elchi"); |  | ||||||
|   themes[eFemonThemeDeepBlue]      = tr("DeepBlue"); |  | ||||||
|   themes[eFemonThemeMoronimo]      = tr("Moronimo"); |  | ||||||
|   themes[eFemonThemeEnigma]        = tr("Enigma"); |  | ||||||
|   themes[eFemonThemeEgalsTry]      = tr("EgalsTry"); |  | ||||||
|   themes[eFemonThemeDuotone]       = tr("Duotone"); |  | ||||||
|  |  | ||||||
|   data = femonConfig; |  | ||||||
|   Setup(); |   Setup(); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -246,21 +98,17 @@ void cMenuFemonSetup::Setup(void) | |||||||
|   int current = Current(); |   int current = Current(); | ||||||
|  |  | ||||||
|   Clear(); |   Clear(); | ||||||
|   Add(new cMenuEditBoolItem(  tr("Hide main menu entry"),        &data.hidemenu,       tr("no"),            tr("yes"))); |   Add(new cMenuEditBoolItem(  tr("Hide Mainmenu Entry"),         &femonConfig.hidemenu,       tr("no"),      tr("yes"))); | ||||||
|   Add(new cMenuEditBoolItem(  tr("Use syslog output"),           &data.syslogoutput,   tr("no"),            tr("yes"))); |   Add(new cMenuEditBoolItem(  tr("Use Syslog Output"),           &femonConfig.syslogoutput,   tr("no"),      tr("yes"))); | ||||||
|   Add(new cMenuEditStraItem(  tr("Default display mode"),        &data.displaymode,    eFemonModeMaxNumber, dispmodes)); |   Add(new cMenuEditStraItem(  tr("Default Display Mode"),        &femonConfig.displaymode,    modeMaxNumber, dispmodes)); | ||||||
|   Add(new cMenuEditStraItem(  tr("Skin"),                        &data.skin,           eFemonSkinMaxNumber, skins)); |   Add(new cMenuEditBoolItem(  tr("Position"),                    &femonConfig.position,       tr("bottom"),  tr("top"))); | ||||||
|   Add(new cMenuEditStraItem(  tr("Theme"),                       &data.theme,          eFemonThemeMaxNumber,themes)); |   Add(new cMenuEditBoolItem(  tr("Show CA System"),              &femonConfig.showcasystem,   tr("no"),      tr("yes"))); | ||||||
|   Add(new cMenuEditBoolItem(  tr("Position"),                    &data.position,       tr("bottom"),        tr("top"))); |   Add(new cMenuEditIntItem(   tr("Red Limit [%]"),               &femonConfig.redlimit,       1,             50)); | ||||||
|   Add(new cMenuEditIntItem(   tr("Height"),                      &data.osdheight,      400,                 500)); |   Add(new cMenuEditIntItem(   tr("Green Limit [%]"),             &femonConfig.greenlimit,     51,            100)); | ||||||
|   Add(new cMenuEditIntItem(   tr("Horizontal offset"),           &data.osdoffset,      -50,                 50)); |   Add(new cMenuEditIntItem(   tr("OSD Update Interval [0.1s]"),  &femonConfig.updateinterval, 1,             100)); | ||||||
|   Add(new cMenuEditBoolItem(  tr("Show CA system"),              &data.showcasystem,   tr("no"),            tr("yes"))); |   Add(new cMenuEditBoolItem(  tr("Analyze Stream"),              &femonConfig.analyzestream,  tr("no"),      tr("yes"))); | ||||||
|   Add(new cMenuEditIntItem(   tr("Red limit [%]"),               &data.redlimit,       1,                   50)); |  | ||||||
|   Add(new cMenuEditIntItem(   tr("Green limit [%]"),             &data.greenlimit,     51,                  100)); |  | ||||||
|   Add(new cMenuEditIntItem(   tr("OSD update interval [0.1s]"),  &data.updateinterval, 1,                   100)); |  | ||||||
|   Add(new cMenuEditBoolItem(  tr("Analyze stream"),              &data.analyzestream,  tr("no"),            tr("yes"))); |  | ||||||
|   if (femonConfig.analyzestream) |   if (femonConfig.analyzestream) | ||||||
|      Add(new cMenuEditIntItem(tr("Calculation interval [0.1s]"), &data.calcinterval,   1,                   100)); |      Add(new cMenuEditIntItem(tr("Calculation Interval [0.1s]"), &femonConfig.calcinterval,   1,             100)); | ||||||
|  |  | ||||||
|   SetCurrent(Get(current)); |   SetCurrent(Get(current)); | ||||||
|   Display(); |   Display(); | ||||||
| @@ -268,16 +116,10 @@ void cMenuFemonSetup::Setup(void) | |||||||
|  |  | ||||||
| void cMenuFemonSetup::Store(void) | void cMenuFemonSetup::Store(void) | ||||||
| { | { | ||||||
|   Dprintf("%s()\n", __PRETTY_FUNCTION__); |  | ||||||
|   femonConfig = data; |  | ||||||
|   SetupStore("HideMenu",       femonConfig.hidemenu); |   SetupStore("HideMenu",       femonConfig.hidemenu); | ||||||
|   SetupStore("SyslogOutput",   femonConfig.syslogoutput); |   SetupStore("SyslogOutput",   femonConfig.syslogoutput); | ||||||
|   SetupStore("DisplayMode",    femonConfig.displaymode); |   SetupStore("DisplayMode",    femonConfig.displaymode); | ||||||
|   SetupStore("Skin",           femonConfig.skin); |  | ||||||
|   SetupStore("Theme",          femonConfig.theme); |  | ||||||
|   SetupStore("Position",       femonConfig.position); |   SetupStore("Position",       femonConfig.position); | ||||||
|   SetupStore("OSDHeight",      femonConfig.osdheight); |  | ||||||
|   SetupStore("OSDOffset",      femonConfig.osdoffset); |  | ||||||
|   SetupStore("ShowCASystem",   femonConfig.showcasystem); |   SetupStore("ShowCASystem",   femonConfig.showcasystem); | ||||||
|   SetupStore("RedLimit",       femonConfig.redlimit); |   SetupStore("RedLimit",       femonConfig.redlimit); | ||||||
|   SetupStore("GreenLimit",     femonConfig.greenlimit); |   SetupStore("GreenLimit",     femonConfig.greenlimit); | ||||||
| @@ -288,11 +130,11 @@ void cMenuFemonSetup::Store(void) | |||||||
|  |  | ||||||
| eOSState cMenuFemonSetup::ProcessKey(eKeys Key) | eOSState cMenuFemonSetup::ProcessKey(eKeys Key) | ||||||
| { | { | ||||||
|   int oldAnalyzestream = data.analyzestream; |   int oldAnalyzestream = femonConfig.analyzestream; | ||||||
|  |  | ||||||
|   eOSState state = cMenuSetupPage::ProcessKey(Key); |   eOSState state = cMenuSetupPage::ProcessKey(Key); | ||||||
|  |  | ||||||
|   if (Key != kNone && (data.analyzestream != oldAnalyzestream)) { |   if (Key != kNone && (femonConfig.analyzestream != oldAnalyzestream)) { | ||||||
|      Setup(); |      Setup(); | ||||||
|      } |      } | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										13
									
								
								femon.h
									
									
									
									
									
								
							
							
						
						
									
										13
									
								
								femon.h
									
									
									
									
									
								
							| @@ -11,11 +11,13 @@ | |||||||
|  |  | ||||||
| #include <vdr/plugin.h> | #include <vdr/plugin.h> | ||||||
|  |  | ||||||
| static const char *VERSION        = "0.9.6"; | static const char *VERSION        = "0.0.7"; | ||||||
| static const char *DESCRIPTION    = "DVB Signal Information Monitor (OSD)"; | static const char *DESCRIPTION    = "DVB Signal Information Monitor (OSD)"; | ||||||
| static const char *MAINMENUENTRY  = "Signal Information"; | static const char *MAINMENUENTRY  = "Signal Information"; | ||||||
|  |  | ||||||
| class cPluginFemon : public cPlugin { | class cPluginFemon : public cPlugin { | ||||||
|  | private: | ||||||
|  |   // Add any member variables or functions you may need here. | ||||||
| public: | public: | ||||||
|   cPluginFemon(void); |   cPluginFemon(void); | ||||||
|   virtual ~cPluginFemon(); |   virtual ~cPluginFemon(); | ||||||
| @@ -25,23 +27,16 @@ public: | |||||||
|   virtual bool ProcessArgs(int argc, char *argv[]); |   virtual bool ProcessArgs(int argc, char *argv[]); | ||||||
|   virtual bool Initialize(void); |   virtual bool Initialize(void); | ||||||
|   virtual bool Start(void); |   virtual bool Start(void); | ||||||
|   virtual void Stop(void); |  | ||||||
|   virtual void Housekeeping(void); |   virtual void Housekeeping(void); | ||||||
|   virtual const char *MainMenuEntry(void) { return (femonConfig.hidemenu ? NULL : tr(MAINMENUENTRY)); } |   virtual const char *MainMenuEntry(void) { return (femonConfig.hidemenu ? NULL : tr(MAINMENUENTRY)); } | ||||||
|   virtual cOsdObject *MainMenuAction(void); |   virtual cOsdObject *MainMenuAction(void); | ||||||
|   virtual cMenuSetupPage *SetupMenu(void); |   virtual cMenuSetupPage *SetupMenu(void); | ||||||
|   virtual bool SetupParse(const char *Name, const char *Value); |   virtual bool SetupParse(const char *Name, const char *Value); | ||||||
|   virtual bool Service(const char *Id, void *Data); |  | ||||||
|   virtual const char **SVDRPHelpPages(void); |  | ||||||
|   virtual cString SVDRPCommand(const char *Command, const char *Option, int &ReplyCode); |  | ||||||
|   }; |   }; | ||||||
|  |  | ||||||
| class cMenuFemonSetup : public cMenuSetupPage { | class cMenuFemonSetup : public cMenuSetupPage { | ||||||
|   private: |   private: | ||||||
|     const char *dispmodes[eFemonModeMaxNumber]; |     const char *dispmodes[modeMaxNumber]; | ||||||
|     const char *skins[eFemonSkinMaxNumber]; |  | ||||||
|     const char *themes[eFemonThemeMaxNumber]; |  | ||||||
|     cFemonConfig data; |  | ||||||
|     virtual void Setup(void); |     virtual void Setup(void); | ||||||
|   protected: |   protected: | ||||||
|     virtual eOSState ProcessKey(eKeys Key); |     virtual eOSState ProcessKey(eKeys Key); | ||||||
|   | |||||||
							
								
								
									
										96
									
								
								femoncfg.c
									
									
									
									
									
								
							
							
						
						
									
										96
									
								
								femoncfg.c
									
									
									
									
									
								
							| @@ -14,8 +14,6 @@ cFemonConfig::cFemonConfig(void) | |||||||
| { | { | ||||||
|   hidemenu       = 0; |   hidemenu       = 0; | ||||||
|   displaymode    = 0; |   displaymode    = 0; | ||||||
|   skin           = 0; |  | ||||||
|   theme          = 0; |  | ||||||
|   position       = 1; |   position       = 1; | ||||||
|   redlimit       = 33; |   redlimit       = 33; | ||||||
|   greenlimit     = 66; |   greenlimit     = 66; | ||||||
| @@ -24,98 +22,4 @@ cFemonConfig::cFemonConfig(void) | |||||||
|   calcinterval   = 20; |   calcinterval   = 20; | ||||||
|   syslogoutput   = 0; |   syslogoutput   = 0; | ||||||
|   showcasystem   = 0; |   showcasystem   = 0; | ||||||
| #ifdef FEMON_NTSC |  | ||||||
|   osdheight      = 420; |  | ||||||
| #else |  | ||||||
|   osdheight      = 480; |  | ||||||
| #endif |  | ||||||
|   osdoffset      = 0; |  | ||||||
| } | } | ||||||
|  |  | ||||||
| const cFemonTheme femonTheme[eFemonThemeMaxNumber] = |  | ||||||
| { |  | ||||||
|   { |  | ||||||
|     // eFemonThemeClassic |  | ||||||
|     4,          // bpp |  | ||||||
|     0x7F000000, // clrBackground |  | ||||||
|     0xFFFCFCFC, // clrTitleBackground |  | ||||||
|     0xFF000000, // clrTitleText |  | ||||||
|     0xFFFCC024, // clrActiveText |  | ||||||
|     0xFFFCFCFC, // clrInactiveText |  | ||||||
|     0xFFFC1414, // clrRed |  | ||||||
|     0xFFFCC024, // clrYellow |  | ||||||
|     0xFF24FC24, // clrGreen |  | ||||||
|   }, |  | ||||||
|   { |  | ||||||
|     // eFemonThemeElchi |  | ||||||
|     4,          // bpp |  | ||||||
|     0xC8000066, // clrBackground |  | ||||||
|     0xC833AAEE, // clrTitleBackground |  | ||||||
|     0xFF000000, // clrTitleText |  | ||||||
|     0xFFCCBB22, // clrActiveText |  | ||||||
|     0xFFFFFFFF, // clrInactiveText |  | ||||||
|     0xFFFF0000, // clrRed |  | ||||||
|     0xFFFFEE00, // clrYellow |  | ||||||
|     0xFF33CC33, // clrGreen |  | ||||||
|   }, |  | ||||||
|   { |  | ||||||
|     // eFemonThemeDeepBlue |  | ||||||
|     4,          // bpp |  | ||||||
|     0xC80C0C0C, // clrBackground |  | ||||||
|     0xC832557A, // clrTitleBackground |  | ||||||
|     0xFF000000, // clrTitleText |  | ||||||
|     0xFFCE7B00, // clrActiveText |  | ||||||
|     0xFF9A9A9A, // clrInactiveText |  | ||||||
|     0xFF992900, // clrRed |  | ||||||
|     0xFFCE7B00, // clrYellow |  | ||||||
|     0xFF336600, // clrGreen |  | ||||||
|   }, |  | ||||||
|   { |  | ||||||
|     // eFemonThemeMoronimo |  | ||||||
|     4,          // bpp |  | ||||||
|     0xDF294A6B, // clrBackground |  | ||||||
|     0xDF3E5578, // clrTitleBackground |  | ||||||
|     0xFF9BBAD7, // clrTitleText |  | ||||||
|     0xFFCE7B00, // clrActiveText |  | ||||||
|     0xFF9A9A9A, // clrInactiveText |  | ||||||
|     0xFF992900, // clrRed |  | ||||||
|     0xFFCE7B00, // clrYellow |  | ||||||
|     0xFF336600, // clrGreen |  | ||||||
|   }, |  | ||||||
|   { |  | ||||||
|     // eFemonThemeEnigma |  | ||||||
|     4,          // bpp |  | ||||||
|     0xB8DEE5FA, // clrBackground |  | ||||||
|     0xB84158BC, // clrTitleBackground |  | ||||||
|     0xFFFFFFFF, // clrTitleText |  | ||||||
|     0xFF000000, // clrActiveText |  | ||||||
|     0xFF000000, // clrInactiveText |  | ||||||
|     0xB8C40000, // clrRed |  | ||||||
|     0xB8C4C400, // clrYellow |  | ||||||
|     0xB800C400, // clrGreen |  | ||||||
|   }, |  | ||||||
|   { |  | ||||||
|     // eFemonThemeEgalsTry |  | ||||||
|     4,          // bpp |  | ||||||
|     0xCA2B1B9E, // clrBackground |  | ||||||
|     0xDFBEBAC3, // clrTitleBackground |  | ||||||
|     0xFF280249, // clrTitleText |  | ||||||
|     0xFFD4D7DB, // clrActiveText |  | ||||||
|     0xDFCFCFCF, // clrInactiveText |  | ||||||
|     0xFFFF0000, // clrRed |  | ||||||
|     0xFFFCC024, // clrYellow |  | ||||||
|     0xFF20980B, // clrGreen |  | ||||||
|   }, |  | ||||||
|   { |  | ||||||
|     // eFemonThemeDuotone |  | ||||||
|     2,          // bpp |  | ||||||
|     0x7F000000, // clrBackground |  | ||||||
|     0xFFFCFCFC, // clrTitleBackground |  | ||||||
|     0x7F000000, // clrTitleText |  | ||||||
|     0xFFFCFCFC, // clrActiveText |  | ||||||
|     0xFFFCFCFC, // clrInactiveText |  | ||||||
|     0xFFFC1414, // clrRed |  | ||||||
|     0xFFFCFCFC, // clrYellow |  | ||||||
|     0xFFFCFCFC, // clrGreen |  | ||||||
|   }, |  | ||||||
| }; |  | ||||||
|   | |||||||
							
								
								
									
										53
									
								
								femoncfg.h
									
									
									
									
									
								
							
							
						
						
									
										53
									
								
								femoncfg.h
									
									
									
									
									
								
							| @@ -9,14 +9,13 @@ | |||||||
| #ifndef __FEMONCFG_H | #ifndef __FEMONCFG_H | ||||||
| #define __FEMONCFG_H | #define __FEMONCFG_H | ||||||
|  |  | ||||||
| enum eFemonModes | enum dispModes { | ||||||
| { |   modeBasic, | ||||||
|   eFemonModeBasic, |   modeTransponder, | ||||||
|   eFemonModeTransponder, |   modeStream, | ||||||
|   eFemonModeStream, |   modeAC3, | ||||||
|   eFemonModeAC3, |   modeMaxNumber | ||||||
|   eFemonModeMaxNumber |   }; | ||||||
| }; |  | ||||||
|  |  | ||||||
| struct cFemonConfig | struct cFemonConfig | ||||||
| { | { | ||||||
| @@ -24,8 +23,6 @@ public: | |||||||
|   cFemonConfig(void); |   cFemonConfig(void); | ||||||
|   int hidemenu; |   int hidemenu; | ||||||
|   int displaymode; |   int displaymode; | ||||||
|   int skin; |  | ||||||
|   int theme; |  | ||||||
|   int position; |   int position; | ||||||
|   int redlimit; |   int redlimit; | ||||||
|   int greenlimit; |   int greenlimit; | ||||||
| @@ -34,44 +31,8 @@ public: | |||||||
|   int calcinterval; |   int calcinterval; | ||||||
|   int syslogoutput; |   int syslogoutput; | ||||||
|   int showcasystem; |   int showcasystem; | ||||||
|   int osdheight; |  | ||||||
|   int osdoffset; |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| extern cFemonConfig femonConfig; | extern cFemonConfig femonConfig; | ||||||
|  |  | ||||||
| enum eFemonSkins |  | ||||||
| { |  | ||||||
|   eFemonSkinClassic, |  | ||||||
|   eFemonSkinElchi, |  | ||||||
|   eFemonSkinMaxNumber |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| enum eFemonThemes |  | ||||||
| { |  | ||||||
|   eFemonThemeClassic, |  | ||||||
|   eFemonThemeElchi, |  | ||||||
|   eFemonThemeDeepBlue, |  | ||||||
|   eFemonThemeMoronimo, |  | ||||||
|   eFemonThemeEnigma, |  | ||||||
|   eFemonThemeEgalsTry, |  | ||||||
|   eFemonThemeDuotone, |  | ||||||
|   eFemonThemeMaxNumber |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| struct cFemonTheme |  | ||||||
| { |  | ||||||
|   int bpp; |  | ||||||
|   int clrBackground; |  | ||||||
|   int clrTitleBackground; |  | ||||||
|   int clrTitleText; |  | ||||||
|   int clrActiveText; |  | ||||||
|   int clrInactiveText; |  | ||||||
|   int clrRed; |  | ||||||
|   int clrYellow; |  | ||||||
|   int clrGreen; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| extern const cFemonTheme femonTheme[eFemonThemeMaxNumber]; |  | ||||||
|  |  | ||||||
| #endif // __FEMONCFG_H | #endif // __FEMONCFG_H | ||||||
|   | |||||||
| @@ -1,340 +0,0 @@ | |||||||
| 		    GNU GENERAL PUBLIC LICENSE |  | ||||||
| 		       Version 2, June 1991 |  | ||||||
|  |  | ||||||
|  Copyright (C) 1989, 1991 Free Software Foundation, Inc. |  | ||||||
|                        59 Temple Place, Suite 330, Boston, MA  02111-1307  USA |  | ||||||
|  Everyone is permitted to copy and distribute verbatim copies |  | ||||||
|  of this license document, but changing it is not allowed. |  | ||||||
|  |  | ||||||
| 			    Preamble |  | ||||||
|  |  | ||||||
|   The licenses for most software are designed to take away your |  | ||||||
| freedom to share and change it.  By contrast, the GNU General Public |  | ||||||
| License is intended to guarantee your freedom to share and change free |  | ||||||
| software--to make sure the software is free for all its users.  This |  | ||||||
| General Public License applies to most of the Free Software |  | ||||||
| Foundation's software and to any other program whose authors commit to |  | ||||||
| using it.  (Some other Free Software Foundation software is covered by |  | ||||||
| the GNU Library General Public License instead.)  You can apply it to |  | ||||||
| your programs, too. |  | ||||||
|  |  | ||||||
|   When we speak of free software, we are referring to freedom, not |  | ||||||
| price.  Our General Public Licenses are designed to make sure that you |  | ||||||
| have the freedom to distribute copies of free software (and charge for |  | ||||||
| this service if you wish), that you receive source code or can get it |  | ||||||
| if you want it, that you can change the software or use pieces of it |  | ||||||
| in new free programs; and that you know you can do these things. |  | ||||||
|  |  | ||||||
|   To protect your rights, we need to make restrictions that forbid |  | ||||||
| anyone to deny you these rights or to ask you to surrender the rights. |  | ||||||
| These restrictions translate to certain responsibilities for you if you |  | ||||||
| distribute copies of the software, or if you modify it. |  | ||||||
|  |  | ||||||
|   For example, if you distribute copies of such a program, whether |  | ||||||
| gratis or for a fee, you must give the recipients all the rights that |  | ||||||
| you have.  You must make sure that they, too, receive or can get the |  | ||||||
| source code.  And you must show them these terms so they know their |  | ||||||
| rights. |  | ||||||
|  |  | ||||||
|   We protect your rights with two steps: (1) copyright the software, and |  | ||||||
| (2) offer you this license which gives you legal permission to copy, |  | ||||||
| distribute and/or modify the software. |  | ||||||
|  |  | ||||||
|   Also, for each author's protection and ours, we want to make certain |  | ||||||
| that everyone understands that there is no warranty for this free |  | ||||||
| software.  If the software is modified by someone else and passed on, we |  | ||||||
| want its recipients to know that what they have is not the original, so |  | ||||||
| that any problems introduced by others will not reflect on the original |  | ||||||
| authors' reputations. |  | ||||||
|  |  | ||||||
|   Finally, any free program is threatened constantly by software |  | ||||||
| patents.  We wish to avoid the danger that redistributors of a free |  | ||||||
| program will individually obtain patent licenses, in effect making the |  | ||||||
| program proprietary.  To prevent this, we have made it clear that any |  | ||||||
| patent must be licensed for everyone's free use or not licensed at all. |  | ||||||
|  |  | ||||||
|   The precise terms and conditions for copying, distribution and |  | ||||||
| modification follow. |  | ||||||
|  |  | ||||||
| 		    GNU GENERAL PUBLIC LICENSE |  | ||||||
|    TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION |  | ||||||
|  |  | ||||||
|   0. This License applies to any program or other work which contains |  | ||||||
| a notice placed by the copyright holder saying it may be distributed |  | ||||||
| under the terms of this General Public License.  The "Program", below, |  | ||||||
| refers to any such program or work, and a "work based on the Program" |  | ||||||
| means either the Program or any derivative work under copyright law: |  | ||||||
| that is to say, a work containing the Program or a portion of it, |  | ||||||
| either verbatim or with modifications and/or translated into another |  | ||||||
| language.  (Hereinafter, translation is included without limitation in |  | ||||||
| the term "modification".)  Each licensee is addressed as "you". |  | ||||||
|  |  | ||||||
| Activities other than copying, distribution and modification are not |  | ||||||
| covered by this License; they are outside its scope.  The act of |  | ||||||
| running the Program is not restricted, and the output from the Program |  | ||||||
| is covered only if its contents constitute a work based on the |  | ||||||
| Program (independent of having been made by running the Program). |  | ||||||
| Whether that is true depends on what the Program does. |  | ||||||
|  |  | ||||||
|   1. You may copy and distribute verbatim copies of the Program's |  | ||||||
| source code as you receive it, in any medium, provided that you |  | ||||||
| conspicuously and appropriately publish on each copy an appropriate |  | ||||||
| copyright notice and disclaimer of warranty; keep intact all the |  | ||||||
| notices that refer to this License and to the absence of any warranty; |  | ||||||
| and give any other recipients of the Program a copy of this License |  | ||||||
| along with the Program. |  | ||||||
|  |  | ||||||
| You may charge a fee for the physical act of transferring a copy, and |  | ||||||
| you may at your option offer warranty protection in exchange for a fee. |  | ||||||
|  |  | ||||||
|   2. You may modify your copy or copies of the Program or any portion |  | ||||||
| of it, thus forming a work based on the Program, and copy and |  | ||||||
| distribute such modifications or work under the terms of Section 1 |  | ||||||
| above, provided that you also meet all of these conditions: |  | ||||||
|  |  | ||||||
|     a) You must cause the modified files to carry prominent notices |  | ||||||
|     stating that you changed the files and the date of any change. |  | ||||||
|  |  | ||||||
|     b) You must cause any work that you distribute or publish, that in |  | ||||||
|     whole or in part contains or is derived from the Program or any |  | ||||||
|     part thereof, to be licensed as a whole at no charge to all third |  | ||||||
|     parties under the terms of this License. |  | ||||||
|  |  | ||||||
|     c) If the modified program normally reads commands interactively |  | ||||||
|     when run, you must cause it, when started running for such |  | ||||||
|     interactive use in the most ordinary way, to print or display an |  | ||||||
|     announcement including an appropriate copyright notice and a |  | ||||||
|     notice that there is no warranty (or else, saying that you provide |  | ||||||
|     a warranty) and that users may redistribute the program under |  | ||||||
|     these conditions, and telling the user how to view a copy of this |  | ||||||
|     License.  (Exception: if the Program itself is interactive but |  | ||||||
|     does not normally print such an announcement, your work based on |  | ||||||
|     the Program is not required to print an announcement.) |  | ||||||
|  |  | ||||||
| These requirements apply to the modified work as a whole.  If |  | ||||||
| identifiable sections of that work are not derived from the Program, |  | ||||||
| and can be reasonably considered independent and separate works in |  | ||||||
| themselves, then this License, and its terms, do not apply to those |  | ||||||
| sections when you distribute them as separate works.  But when you |  | ||||||
| distribute the same sections as part of a whole which is a work based |  | ||||||
| on the Program, the distribution of the whole must be on the terms of |  | ||||||
| this License, whose permissions for other licensees extend to the |  | ||||||
| entire whole, and thus to each and every part regardless of who wrote it. |  | ||||||
|  |  | ||||||
| Thus, it is not the intent of this section to claim rights or contest |  | ||||||
| your rights to work written entirely by you; rather, the intent is to |  | ||||||
| exercise the right to control the distribution of derivative or |  | ||||||
| collective works based on the Program. |  | ||||||
|  |  | ||||||
| In addition, mere aggregation of another work not based on the Program |  | ||||||
| with the Program (or with a work based on the Program) on a volume of |  | ||||||
| a storage or distribution medium does not bring the other work under |  | ||||||
| the scope of this License. |  | ||||||
|  |  | ||||||
|   3. You may copy and distribute the Program (or a work based on it, |  | ||||||
| under Section 2) in object code or executable form under the terms of |  | ||||||
| Sections 1 and 2 above provided that you also do one of the following: |  | ||||||
|  |  | ||||||
|     a) Accompany it with the complete corresponding machine-readable |  | ||||||
|     source code, which must be distributed under the terms of Sections |  | ||||||
|     1 and 2 above on a medium customarily used for software interchange; or, |  | ||||||
|  |  | ||||||
|     b) Accompany it with a written offer, valid for at least three |  | ||||||
|     years, to give any third party, for a charge no more than your |  | ||||||
|     cost of physically performing source distribution, a complete |  | ||||||
|     machine-readable copy of the corresponding source code, to be |  | ||||||
|     distributed under the terms of Sections 1 and 2 above on a medium |  | ||||||
|     customarily used for software interchange; or, |  | ||||||
|  |  | ||||||
|     c) Accompany it with the information you received as to the offer |  | ||||||
|     to distribute corresponding source code.  (This alternative is |  | ||||||
|     allowed only for noncommercial distribution and only if you |  | ||||||
|     received the program in object code or executable form with such |  | ||||||
|     an offer, in accord with Subsection b above.) |  | ||||||
|  |  | ||||||
| The source code for a work means the preferred form of the work for |  | ||||||
| making modifications to it.  For an executable work, complete source |  | ||||||
| code means all the source code for all modules it contains, plus any |  | ||||||
| associated interface definition files, plus the scripts used to |  | ||||||
| control compilation and installation of the executable.  However, as a |  | ||||||
| special exception, the source code distributed need not include |  | ||||||
| anything that is normally distributed (in either source or binary |  | ||||||
| form) with the major components (compiler, kernel, and so on) of the |  | ||||||
| operating system on which the executable runs, unless that component |  | ||||||
| itself accompanies the executable. |  | ||||||
|  |  | ||||||
| If distribution of executable or object code is made by offering |  | ||||||
| access to copy from a designated place, then offering equivalent |  | ||||||
| access to copy the source code from the same place counts as |  | ||||||
| distribution of the source code, even though third parties are not |  | ||||||
| compelled to copy the source along with the object code. |  | ||||||
|  |  | ||||||
|   4. You may not copy, modify, sublicense, or distribute the Program |  | ||||||
| except as expressly provided under this License.  Any attempt |  | ||||||
| otherwise to copy, modify, sublicense or distribute the Program is |  | ||||||
| void, and will automatically terminate your rights under this License. |  | ||||||
| However, parties who have received copies, or rights, from you under |  | ||||||
| this License will not have their licenses terminated so long as such |  | ||||||
| parties remain in full compliance. |  | ||||||
|  |  | ||||||
|   5. You are not required to accept this License, since you have not |  | ||||||
| signed it.  However, nothing else grants you permission to modify or |  | ||||||
| distribute the Program or its derivative works.  These actions are |  | ||||||
| prohibited by law if you do not accept this License.  Therefore, by |  | ||||||
| modifying or distributing the Program (or any work based on the |  | ||||||
| Program), you indicate your acceptance of this License to do so, and |  | ||||||
| all its terms and conditions for copying, distributing or modifying |  | ||||||
| the Program or works based on it. |  | ||||||
|  |  | ||||||
|   6. Each time you redistribute the Program (or any work based on the |  | ||||||
| Program), the recipient automatically receives a license from the |  | ||||||
| original licensor to copy, distribute or modify the Program subject to |  | ||||||
| these terms and conditions.  You may not impose any further |  | ||||||
| restrictions on the recipients' exercise of the rights granted herein. |  | ||||||
| You are not responsible for enforcing compliance by third parties to |  | ||||||
| this License. |  | ||||||
|  |  | ||||||
|   7. If, as a consequence of a court judgment or allegation of patent |  | ||||||
| infringement or for any other reason (not limited to patent issues), |  | ||||||
| conditions are imposed on you (whether by court order, agreement or |  | ||||||
| otherwise) that contradict the conditions of this License, they do not |  | ||||||
| excuse you from the conditions of this License.  If you cannot |  | ||||||
| distribute so as to satisfy simultaneously your obligations under this |  | ||||||
| License and any other pertinent obligations, then as a consequence you |  | ||||||
| may not distribute the Program at all.  For example, if a patent |  | ||||||
| license would not permit royalty-free redistribution of the Program by |  | ||||||
| all those who receive copies directly or indirectly through you, then |  | ||||||
| the only way you could satisfy both it and this License would be to |  | ||||||
| refrain entirely from distribution of the Program. |  | ||||||
|  |  | ||||||
| If any portion of this section is held invalid or unenforceable under |  | ||||||
| any particular circumstance, the balance of the section is intended to |  | ||||||
| apply and the section as a whole is intended to apply in other |  | ||||||
| circumstances. |  | ||||||
|  |  | ||||||
| It is not the purpose of this section to induce you to infringe any |  | ||||||
| patents or other property right claims or to contest validity of any |  | ||||||
| such claims; this section has the sole purpose of protecting the |  | ||||||
| integrity of the free software distribution system, which is |  | ||||||
| implemented by public license practices.  Many people have made |  | ||||||
| generous contributions to the wide range of software distributed |  | ||||||
| through that system in reliance on consistent application of that |  | ||||||
| system; it is up to the author/donor to decide if he or she is willing |  | ||||||
| to distribute software through any other system and a licensee cannot |  | ||||||
| impose that choice. |  | ||||||
|  |  | ||||||
| This section is intended to make thoroughly clear what is believed to |  | ||||||
| be a consequence of the rest of this License. |  | ||||||
|  |  | ||||||
|   8. If the distribution and/or use of the Program is restricted in |  | ||||||
| certain countries either by patents or by copyrighted interfaces, the |  | ||||||
| original copyright holder who places the Program under this License |  | ||||||
| may add an explicit geographical distribution limitation excluding |  | ||||||
| those countries, so that distribution is permitted only in or among |  | ||||||
| countries not thus excluded.  In such case, this License incorporates |  | ||||||
| the limitation as if written in the body of this License. |  | ||||||
|  |  | ||||||
|   9. The Free Software Foundation may publish revised and/or new versions |  | ||||||
| of the General Public License from time to time.  Such new versions will |  | ||||||
| be similar in spirit to the present version, but may differ in detail to |  | ||||||
| address new problems or concerns. |  | ||||||
|  |  | ||||||
| Each version is given a distinguishing version number.  If the Program |  | ||||||
| specifies a version number of this License which applies to it and "any |  | ||||||
| later version", you have the option of following the terms and conditions |  | ||||||
| either of that version or of any later version published by the Free |  | ||||||
| Software Foundation.  If the Program does not specify a version number of |  | ||||||
| this License, you may choose any version ever published by the Free Software |  | ||||||
| Foundation. |  | ||||||
|  |  | ||||||
|   10. If you wish to incorporate parts of the Program into other free |  | ||||||
| programs whose distribution conditions are different, write to the author |  | ||||||
| to ask for permission.  For software which is copyrighted by the Free |  | ||||||
| Software Foundation, write to the Free Software Foundation; we sometimes |  | ||||||
| make exceptions for this.  Our decision will be guided by the two goals |  | ||||||
| of preserving the free status of all derivatives of our free software and |  | ||||||
| of promoting the sharing and reuse of software generally. |  | ||||||
|  |  | ||||||
| 			    NO WARRANTY |  | ||||||
|  |  | ||||||
|   11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY |  | ||||||
| FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW.  EXCEPT WHEN |  | ||||||
| OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES |  | ||||||
| PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED |  | ||||||
| OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF |  | ||||||
| MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.  THE ENTIRE RISK AS |  | ||||||
| TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU.  SHOULD THE |  | ||||||
| PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, |  | ||||||
| REPAIR OR CORRECTION. |  | ||||||
|  |  | ||||||
|   12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING |  | ||||||
| WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR |  | ||||||
| REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, |  | ||||||
| INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING |  | ||||||
| OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED |  | ||||||
| TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY |  | ||||||
| YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER |  | ||||||
| PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE |  | ||||||
| POSSIBILITY OF SUCH DAMAGES. |  | ||||||
|  |  | ||||||
| 		     END OF TERMS AND CONDITIONS |  | ||||||
|  |  | ||||||
| 	    How to Apply These Terms to Your New Programs |  | ||||||
|  |  | ||||||
|   If you develop a new program, and you want it to be of the greatest |  | ||||||
| possible use to the public, the best way to achieve this is to make it |  | ||||||
| free software which everyone can redistribute and change under these terms. |  | ||||||
|  |  | ||||||
|   To do so, attach the following notices to the program.  It is safest |  | ||||||
| to attach them to the start of each source file to most effectively |  | ||||||
| convey the exclusion of warranty; and each file should have at least |  | ||||||
| the "copyright" line and a pointer to where the full notice is found. |  | ||||||
|  |  | ||||||
|     <one line to give the program's name and a brief idea of what it does.> |  | ||||||
|     Copyright (C) <year>  <name of author> |  | ||||||
|  |  | ||||||
|     This program is free software; you can redistribute it and/or modify |  | ||||||
|     it under the terms of the GNU General Public License as published by |  | ||||||
|     the Free Software Foundation; either version 2 of the License, or |  | ||||||
|     (at your option) any later version. |  | ||||||
|  |  | ||||||
|     This program is distributed in the hope that it will be useful, |  | ||||||
|     but WITHOUT ANY WARRANTY; without even the implied warranty of |  | ||||||
|     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the |  | ||||||
|     GNU General Public License for more details. |  | ||||||
|  |  | ||||||
|     You should have received a copy of the GNU General Public License |  | ||||||
|     along with this program; if not, write to the Free Software |  | ||||||
|     Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA |  | ||||||
|  |  | ||||||
|  |  | ||||||
| Also add information on how to contact you by electronic and paper mail. |  | ||||||
|  |  | ||||||
| If the program is interactive, make it output a short notice like this |  | ||||||
| when it starts in an interactive mode: |  | ||||||
|  |  | ||||||
|     Gnomovision version 69, Copyright (C) year name of author |  | ||||||
|     Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'. |  | ||||||
|     This is free software, and you are welcome to redistribute it |  | ||||||
|     under certain conditions; type `show c' for details. |  | ||||||
|  |  | ||||||
| The hypothetical commands `show w' and `show c' should show the appropriate |  | ||||||
| parts of the General Public License.  Of course, the commands you use may |  | ||||||
| be called something other than `show w' and `show c'; they could even be |  | ||||||
| mouse-clicks or menu items--whatever suits your program. |  | ||||||
|  |  | ||||||
| You should also get your employer (if you work as a programmer) or your |  | ||||||
| school, if any, to sign a "copyright disclaimer" for the program, if |  | ||||||
| necessary.  Here is a sample; alter the names: |  | ||||||
|  |  | ||||||
|   Yoyodyne, Inc., hereby disclaims all copyright interest in the program |  | ||||||
|   `Gnomovision' (which makes passes at compilers) written by James Hacker. |  | ||||||
|  |  | ||||||
|   <signature of Ty Coon>, 1 April 1989 |  | ||||||
|   Ty Coon, President of Vice |  | ||||||
|  |  | ||||||
| This General Public License does not permit incorporating your program into |  | ||||||
| proprietary programs.  If your program is a subroutine library, you may |  | ||||||
| consider it more useful to permit linking proprietary applications with the |  | ||||||
| library.  If this is what you want to do, use the GNU Library General |  | ||||||
| Public License instead of this License. |  | ||||||
| @@ -1,6 +0,0 @@ | |||||||
| VDR Plugin 'femonclient' Revision History |  | ||||||
| ----------------------------------------- |  | ||||||
|  |  | ||||||
| 2005-08-28: Version 0.0.1 |  | ||||||
|  |  | ||||||
| - Initial revision. |  | ||||||
| @@ -1,82 +0,0 @@ | |||||||
| # |  | ||||||
| # Makefile for a Video Disk Recorder plugin |  | ||||||
| # |  | ||||||
| # $Id: Makefile 1.1 2005/08/21 10:43:12 kls Exp $ |  | ||||||
|  |  | ||||||
| # The official name of this plugin. |  | ||||||
| # This name will be used in the '-P...' option of VDR to load the plugin. |  | ||||||
| # By default the main source file also carries this name. |  | ||||||
| # |  | ||||||
| PLUGIN = femonclient |  | ||||||
|  |  | ||||||
| ### The version number of this plugin (taken from the main source file): |  | ||||||
|  |  | ||||||
| VERSION = $(shell grep 'static const char \*VERSION *=' $(PLUGIN).c | awk '{ print $$6 }' | sed -e 's/[";]//g') |  | ||||||
|  |  | ||||||
| ### The C++ compiler and options: |  | ||||||
|  |  | ||||||
| CXX      ?= g++ |  | ||||||
| CXXFLAGS ?= -fPIC -g -O2 -Wall -Woverloaded-virtual |  | ||||||
|  |  | ||||||
| ### The directory environment: |  | ||||||
|  |  | ||||||
| DVBDIR = ../../../../DVB |  | ||||||
| VDRDIR = ../../.. |  | ||||||
| LIBDIR = ../../lib |  | ||||||
| TMPDIR = /tmp |  | ||||||
|  |  | ||||||
| ### Allow user defined options to overwrite defaults: |  | ||||||
|  |  | ||||||
| -include $(VDRDIR)/Make.config |  | ||||||
|  |  | ||||||
| ### The version number of VDR (taken from VDR's "config.h"): |  | ||||||
|  |  | ||||||
| VDRVERSION = $(shell grep 'define VDRVERSION ' $(VDRDIR)/config.h | awk '{ print $$3 }' | sed -e 's/"//g') |  | ||||||
|  |  | ||||||
| ### The name of the distribution archive: |  | ||||||
|  |  | ||||||
| ARCHIVE = svcintf-$(VERSION) |  | ||||||
| PACKAGE = vdr-$(ARCHIVE) |  | ||||||
|  |  | ||||||
| ### Includes and Defines (add further entries here): |  | ||||||
|  |  | ||||||
| INCLUDES += -I$(VDRDIR)/include -I$(DVBDIR)/include -I$(VDRDIR)/PLUGINS/src/femon/ |  | ||||||
|  |  | ||||||
| DEFINES += -D_GNU_SOURCE -DPLUGIN_NAME_I18N='"$(PLUGIN)"' |  | ||||||
|  |  | ||||||
| ### The object files (add further files here): |  | ||||||
|  |  | ||||||
| OBJS = $(PLUGIN).o |  | ||||||
|  |  | ||||||
| ### Implicit rules: |  | ||||||
|  |  | ||||||
| %.o: %.c |  | ||||||
| 	$(CXX) $(CXXFLAGS) -c $(DEFINES) $(INCLUDES) $< |  | ||||||
|  |  | ||||||
| # Dependencies: |  | ||||||
|  |  | ||||||
| MAKEDEP = g++ -MM -MG |  | ||||||
| DEPFILE = .dependencies |  | ||||||
| $(DEPFILE): Makefile |  | ||||||
| 	@$(MAKEDEP) $(DEFINES) $(INCLUDES) $(OBJS:%.o=%.c) > $@ |  | ||||||
|  |  | ||||||
| -include $(DEPFILE) |  | ||||||
|  |  | ||||||
| ### Targets: |  | ||||||
|  |  | ||||||
| all: libvdr-$(PLUGIN).so |  | ||||||
|  |  | ||||||
| libvdr-$(PLUGIN).so: $(PLUGIN).o |  | ||||||
| 	$(CXX) $(CXXFLAGS) -shared $(PLUGIN).o -o $@ |  | ||||||
| 	@cp $@ $(LIBDIR)/$@.$(VDRVERSION) |  | ||||||
|  |  | ||||||
| dist: clean |  | ||||||
| 	@-rm -rf $(TMPDIR)/$(ARCHIVE) |  | ||||||
| 	@mkdir $(TMPDIR)/$(ARCHIVE) |  | ||||||
| 	@cp -a * $(TMPDIR)/$(ARCHIVE) |  | ||||||
| 	@tar czf $(PACKAGE).tgz -C $(TMPDIR) $(ARCHIVE) |  | ||||||
| 	@-rm -rf $(TMPDIR)/$(ARCHIVE) |  | ||||||
| 	@echo Distribution package created as $(PACKAGE).tgz |  | ||||||
|  |  | ||||||
| clean: |  | ||||||
| 	@-rm -f $(OBJS) $(DEPFILE) *.so *.tgz core* *~ |  | ||||||
| @@ -1,14 +0,0 @@ | |||||||
| This is a "plugin" for the Video Disk Recorder (VDR). |  | ||||||
|  |  | ||||||
| Written by:                  R o l f . A h r e n b e r g @ s c i . f i |  | ||||||
|  |  | ||||||
| Project's homepage:          http://www.saunalahti.fi/~rahrenbe/vdr/femon/ |  | ||||||
|  |  | ||||||
| Latest version available at: http://www.saunalahti.fi/~rahrenbe/vdr/femon/ |  | ||||||
|  |  | ||||||
| See the file COPYING for license information. |  | ||||||
|  |  | ||||||
| Description: |  | ||||||
|  |  | ||||||
| Demo client for the service interface of the Femon plugin. |  | ||||||
|  |  | ||||||
| @@ -1,51 +0,0 @@ | |||||||
| /* |  | ||||||
|  * femonclient.c: Demo femon service client plugin |  | ||||||
|  * |  | ||||||
|  * See the README file for copyright information and how to reach the author. |  | ||||||
|  * |  | ||||||
|  * $Id: $ |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| #include <stdlib.h> |  | ||||||
| #include <vdr/interface.h> |  | ||||||
| #include <vdr/plugin.h> |  | ||||||
| #include "femonservice.h" |  | ||||||
|  |  | ||||||
| static const char *VERSION        = "0.0.1"; |  | ||||||
| static const char *DESCRIPTION    = "Femon client"; |  | ||||||
| static const char *MAINMENUENTRY  = "Show frontend statistic on console"; |  | ||||||
|  |  | ||||||
| class cPluginFemonClient : public cPlugin { |  | ||||||
| public: |  | ||||||
|   virtual const char *Version(void) { return VERSION; } |  | ||||||
|   virtual const char *Description(void) { return DESCRIPTION; } |  | ||||||
|   virtual const char *MainMenuEntry(void) { return MAINMENUENTRY; } |  | ||||||
|   virtual cOsdObject *MainMenuAction(void); |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
| // --- cPluginFemonClient ---------------------------------------------------------- |  | ||||||
|  |  | ||||||
| cOsdObject *cPluginFemonClient::MainMenuAction(void) |  | ||||||
| { |  | ||||||
|   FemonService_v1_0 femon; |  | ||||||
|   cPlugin *p; |  | ||||||
|  |  | ||||||
|   p = cPluginManager::CallFirstService("FemonService-v1.0", &femon); |  | ||||||
|   if (p) { |  | ||||||
|      printf("Device : %s\n", *femon.fe_name); |  | ||||||
|      printf("Status : %s\n", *femon.fe_status); |  | ||||||
|      printf("Signal : %04X (%2d%%)\n", femon.fe_signal, femon.fe_signal / 655); |  | ||||||
|      printf("SNR    : %04X (%2d%%)\n", femon.fe_snr, femon.fe_snr / 655); |  | ||||||
|      printf("BER    : %08X\n", femon.fe_ber); |  | ||||||
|      printf("UNC    : %08X\n", femon.fe_unc); |  | ||||||
|      printf("Video  : %.2f Mbit/s\n", femon.video_bitrate); |  | ||||||
|      printf("Audio  : %.0f kbit/s\n", femon.audio_bitrate); |  | ||||||
|      printf("Dolby  : %.0f kbit/s\n", femon.dolby_bitrate); |  | ||||||
|      } |  | ||||||
|   else |  | ||||||
|      printf("\n--- No support for FemonService-v1.0 found ---\n"); |  | ||||||
|  |  | ||||||
|   return NULL; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| VDRPLUGINCREATOR(cPluginFemonClient); // Don't touch this! |  | ||||||
							
								
								
									
										1060
									
								
								femoni18n.c
									
									
									
									
									
								
							
							
						
						
									
										1060
									
								
								femoni18n.c
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -9,6 +9,7 @@ | |||||||
| #ifndef __FEMONI18N_H | #ifndef __FEMONI18N_H | ||||||
| #define __FEMONI18N_H | #define __FEMONI18N_H | ||||||
|  |  | ||||||
|  | #include <vdr/config.h> // for VDRVERSNUM | ||||||
| #include <vdr/i18n.h> | #include <vdr/i18n.h> | ||||||
|  |  | ||||||
| extern const tI18nPhrase Phrases[]; | extern const tI18nPhrase Phrases[]; | ||||||
|   | |||||||
							
								
								
									
										1018
									
								
								femonosd.c
									
									
									
									
									
								
							
							
						
						
									
										1018
									
								
								femonosd.c
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										28
									
								
								femonosd.h
									
									
									
									
									
								
							
							
						
						
									
										28
									
								
								femonosd.h
									
									
									
									
									
								
							| @@ -16,53 +16,41 @@ | |||||||
| #include <vdr/thread.h> | #include <vdr/thread.h> | ||||||
| #include <vdr/status.h> | #include <vdr/status.h> | ||||||
| #include <vdr/channels.h> | #include <vdr/channels.h> | ||||||
| #include <vdr/transfer.h> | #include <vdr/font.h> | ||||||
| #include <vdr/tools.h> |  | ||||||
|  |  | ||||||
| class cFemonOsd : public cOsdObject, public cThread, public cStatus { | class cFemonOsd : public cOsdObject, public cThread, public cStatus { | ||||||
| private: | private: | ||||||
|   static cFemonOsd *pInstance; |   bool m_Active; | ||||||
|   cOsd *m_Osd; |   cOsdBase *m_Osd; | ||||||
|  |   tWindowHandle m_InfoWindow; | ||||||
|  |   tWindowHandle m_StatusWindow; | ||||||
|   cFemonReceiver *m_Receiver; |   cFemonReceiver *m_Receiver; | ||||||
|   int m_Frontend; |   int m_Frontend; | ||||||
|   struct dvb_frontend_info m_FrontendInfo; |   struct dvb_frontend_info m_FrontendInfo; | ||||||
|   int m_Number; |   int m_Number; | ||||||
|   int m_OldNumber; |   int m_OldNumber; | ||||||
|  |   int m_InputTime; | ||||||
|   uint16_t m_SNR; |   uint16_t m_SNR; | ||||||
|   uint16_t m_Signal; |   uint16_t m_Signal; | ||||||
|   uint32_t m_BER; |   uint32_t m_BER; | ||||||
|   uint32_t m_UNC; |   uint32_t m_UNC; | ||||||
|   fe_status_t m_FrontendStatus; |   fe_status_t m_FrontendStatus; | ||||||
|   int m_DisplayMode; |   int m_DisplayMode; | ||||||
|   const cFont *m_Font; |   eDvbFont m_Font; | ||||||
|   cTimeMs m_InputTime; |  | ||||||
|   cMutex* m_Mutex; |   cMutex* m_Mutex; | ||||||
|   static cBitmap bmStereo, bmMonoLeft, bmMonoRight, bmDD, bmDD20, bmDD51; |  | ||||||
|   static cBitmap bmZero, bmDevice, bmPAL, bmNTSC, bmOne, bmTwo, bmThree, bmFour, bmFive; |  | ||||||
|   static cBitmap bmAspectRatio_1_1, bmAspectRatio_16_9, bmAspectRatio_2_21_1, bmAspectRatio_4_3; |  | ||||||
|   static cBitmap bmLock, bmSignal, bmCarrier, bmViterbi, bmSync; |  | ||||||
|   void DrawStatusWindow(void); |   void DrawStatusWindow(void); | ||||||
|   void DrawInfoWindow(void); |   void DrawInfoWindow(void); | ||||||
|  |  | ||||||
| protected: | protected: | ||||||
|   cFemonOsd(); |  | ||||||
|   cFemonOsd(const cFemonOsd&); |  | ||||||
|   cFemonOsd& operator= (const cFemonOsd&); |  | ||||||
|   virtual void Action(void); |   virtual void Action(void); | ||||||
|   virtual void ChannelSwitch(const cDevice * device, int channelNumber); |   virtual void ChannelSwitch(const cDevice * device, int channelNumber); | ||||||
|   virtual void SetAudioTrack(int Index, const char * const *Tracks); |  | ||||||
|  |  | ||||||
| public: | public: | ||||||
|   static cFemonOsd *Instance(bool create = false); |   cFemonOsd(void); | ||||||
|   ~cFemonOsd(); |   ~cFemonOsd(); | ||||||
|  |  | ||||||
|   virtual void Show(void); |   virtual void Show(void); | ||||||
|   virtual eOSState ProcessKey(eKeys Key); |   virtual eOSState ProcessKey(eKeys Key); | ||||||
|  |  | ||||||
|   bool DeviceSwitch(int direction); |  | ||||||
|   double GetVideoBitrate(void); |  | ||||||
|   double GetAudioBitrate(void); |  | ||||||
|   double GetDolbyBitrate(void); |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| #endif //__FEMONOSD_H | #endif //__FEMONOSD_H | ||||||
|   | |||||||
							
								
								
									
										124
									
								
								femonreceiver.c
									
									
									
									
									
								
							
							
						
						
									
										124
									
								
								femonreceiver.c
									
									
									
									
									
								
							| @@ -7,7 +7,6 @@ | |||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #include <unistd.h> | #include <unistd.h> | ||||||
| #include "femontools.h" |  | ||||||
| #include "femoncfg.h" | #include "femoncfg.h" | ||||||
| #include "femonreceiver.h" | #include "femonreceiver.h" | ||||||
|  |  | ||||||
| @@ -17,13 +16,18 @@ | |||||||
| #define PAYLOAD       0x10 | #define PAYLOAD       0x10 | ||||||
| #define PTS_DTS_FLAGS 0xC0 | #define PTS_DTS_FLAGS 0xC0 | ||||||
|  |  | ||||||
| cFemonReceiver::cFemonReceiver(int Ca, int Vpid, int Apid[], int Dpid[]) | cFemonReceiver::cFemonReceiver(int Ca, int Vpid, int Apid, int Dpid) | ||||||
| :cReceiver(Ca, -1, Vpid, Apid, Dpid, NULL), cThread("femon receiver") | #if VDRVERSNUM >= 10300 | ||||||
|  | :cReceiver(Ca, -1, 3, Vpid, Apid, Dpid), cThread("femon receiver") | ||||||
|  | #else | ||||||
|  | :cReceiver(Ca, -1, 3, Vpid, Apid, Dpid) | ||||||
|  | #endif | ||||||
| { | { | ||||||
|   Dprintf("%s()\n", __PRETTY_FUNCTION__); |   //printf("cFemonReceiver::cFemonReceiver()\n"); | ||||||
|  |   m_Active = false; | ||||||
|   m_VideoPid = Vpid; |   m_VideoPid = Vpid; | ||||||
|   m_AudioPid = Apid[0]; |   m_AudioPid = Apid; | ||||||
|   m_AC3Pid = Dpid[0]; |   m_AC3Pid = Dpid;       | ||||||
|   m_VideoValid = false; |   m_VideoValid = false; | ||||||
|   m_VideoPacketCount = 0; |   m_VideoPacketCount = 0; | ||||||
|   m_VideoHorizontalSize = 0; |   m_VideoHorizontalSize = 0; | ||||||
| @@ -57,18 +61,21 @@ cFemonReceiver::cFemonReceiver(int Ca, int Vpid, int Apid[], int Dpid[]) | |||||||
|   |   | ||||||
| cFemonReceiver::~cFemonReceiver(void) | cFemonReceiver::~cFemonReceiver(void) | ||||||
| { | { | ||||||
|   Dprintf("%s()\n", __PRETTY_FUNCTION__); |   //printf("cFemonReceiver::~cFemonReceiver()\n"); | ||||||
|   if (Running()) |   if (m_Active) { | ||||||
|      Cancel(3); |      m_Active = false; | ||||||
|  |      Cancel(0); | ||||||
|  |      } | ||||||
| } | } | ||||||
|  |  | ||||||
| /* The following function originates from libdvbmpeg: */ | /* The following function originates from libdvbmpeg: */ | ||||||
| void cFemonReceiver::GetVideoInfo(uint8_t *mbuf, int count) | void cFemonReceiver::GetVideoInfo(uint8_t *mbuf, int count) | ||||||
| { | { | ||||||
|  |   //printf("cFemonReceiver::GetVideoInfo()\n"); | ||||||
|   uint8_t *headr; |   uint8_t *headr; | ||||||
|   int found = 0; |   int found = 0; | ||||||
|   int c = 0; |   int c = 0; | ||||||
|   //m_VideoValid = false; |   m_VideoValid = false; | ||||||
|   while ((found < 4) && ((c + 4) < count)) { |   while ((found < 4) && ((c + 4) < count)) { | ||||||
|     uint8_t *b; |     uint8_t *b; | ||||||
|     b = mbuf + c; |     b = mbuf + c; | ||||||
| @@ -157,11 +164,12 @@ static unsigned int samplerates[4] = | |||||||
| /* The following function originates from libdvbmpeg: */ | /* The following function originates from libdvbmpeg: */ | ||||||
| void cFemonReceiver::GetAudioInfo(uint8_t *mbuf, int count) | void cFemonReceiver::GetAudioInfo(uint8_t *mbuf, int count) | ||||||
| { | { | ||||||
|  |   //printf("cFemonReceiver::GetAudioInfo()\n"); | ||||||
|   uint8_t *headr; |   uint8_t *headr; | ||||||
|   int found = 0; |   int found = 0; | ||||||
|   int c = 0; |   int c = 0; | ||||||
|   int tmp = 0; |   int tmp = 0; | ||||||
|   //m_AudioValid = false; |   m_AudioValid = false; | ||||||
|   while (!found && (c < count)) { |   while (!found && (c < count)) { | ||||||
|     uint8_t *b = mbuf + c; |     uint8_t *b = mbuf + c; | ||||||
|     if ((b[0] == 0xff) && ((b[1] & 0xf8) == 0xf8)) |     if ((b[0] == 0xff) && ((b[1] & 0xf8) == 0xf8)) | ||||||
| @@ -210,7 +218,7 @@ void cFemonReceiver::GetAC3Info(uint8_t *mbuf, int count) | |||||||
|   int found = 0; |   int found = 0; | ||||||
|   int c = 0; |   int c = 0; | ||||||
|   uint8_t frame; |   uint8_t frame; | ||||||
|   //m_AC3Valid = false; |   m_AC3Valid = false; | ||||||
|   while (!found && (c < count)) { |   while (!found && (c < count)) { | ||||||
|     uint8_t *b = mbuf + c; |     uint8_t *b = mbuf + c; | ||||||
|     if ((b[0] == 0x0b) && (b[1] == 0x77)) |     if ((b[0] == 0x0b) && (b[1] == 0x77)) | ||||||
| @@ -230,84 +238,31 @@ void cFemonReceiver::GetAC3Info(uint8_t *mbuf, int count) | |||||||
|      m_AC3FrameSize <<= 1; |      m_AC3FrameSize <<= 1; | ||||||
|   m_AC3BitStreamMode = (headr[3] & 7); |   m_AC3BitStreamMode = (headr[3] & 7); | ||||||
|   m_AC3AudioCodingMode = (headr[4] & 0xE0) >> 5; |   m_AC3AudioCodingMode = (headr[4] & 0xE0) >> 5; | ||||||
|   if ((m_AC3AudioCodingMode & 0x01) && (m_AC3AudioCodingMode != 0x01)) { |   if ((m_AC3AudioCodingMode & 0x01) && (m_AC3AudioCodingMode != 0x01)) // if 3 front channels | ||||||
|      // 3 front channels |  | ||||||
|      m_AC3CenterMixLevel = (headr[4] & 0x18) >> 3; |      m_AC3CenterMixLevel = (headr[4] & 0x18) >> 3; | ||||||
|      if (m_AC3AudioCodingMode & 0x04) { |   else | ||||||
|         // a surround channel exists |      m_AC3CenterMixLevel = FR_NOTVALID; | ||||||
|  |   if (m_AC3AudioCodingMode & 0x04) //  if a surround channel exists | ||||||
|      m_AC3SurroundMixLevel = (headr[4] & 0x06) >> 1; |      m_AC3SurroundMixLevel = (headr[4] & 0x06) >> 1; | ||||||
|         if (m_AC3AudioCodingMode == 0x02) { |   else | ||||||
|            // if in 2/0 mode |      m_AC3SurroundMixLevel = FR_NOTVALID; | ||||||
|            m_AC3DolbySurroundMode = ((headr[4] & 0x01) << 1) | ((headr[5] & 0x80) >> 7); |   if (m_AC3AudioCodingMode == 0x02) // if in 2/0 mode | ||||||
|  |      m_AC3DolbySurroundMode = ((headr[4] & 1) << 1) | ((headr[5] & 0x80) >> 7); | ||||||
|  |   else  | ||||||
|  |      m_AC3DolbySurroundMode = FR_NOTVALID; | ||||||
|   m_AC3LfeOn = (headr[5] & 0x40) >> 6; |   m_AC3LfeOn = (headr[5] & 0x40) >> 6; | ||||||
|   m_AC3DialogLevel = (headr[5] & 0x3e) >> 1; |   m_AC3DialogLevel = (headr[5] & 0x3e) >> 1; | ||||||
|            } |  | ||||||
|         else { |  | ||||||
|            m_AC3DolbySurroundMode = FR_NOTVALID; |  | ||||||
|            m_AC3LfeOn = (headr[4] & 0x01); |  | ||||||
|            m_AC3DialogLevel = (headr[5] & 0xF8) >> 3; |  | ||||||
|            } |  | ||||||
|         } |  | ||||||
|      else { |  | ||||||
|         m_AC3SurroundMixLevel = FR_NOTVALID; |  | ||||||
|         if (m_AC3AudioCodingMode == 0x02) { |  | ||||||
|            // if in 2/0 mode |  | ||||||
|             m_AC3DolbySurroundMode = (headr[4] & 0x06) >> 1; |  | ||||||
|             m_AC3LfeOn = (headr[4] & 0x01); |  | ||||||
|             m_AC3DialogLevel = (headr[5] & 0xF8) >> 3; |  | ||||||
|            } |  | ||||||
|         else { |  | ||||||
|            m_AC3DolbySurroundMode = FR_NOTVALID; |  | ||||||
|            m_AC3LfeOn = (headr[4] & 0x04) >> 2; |  | ||||||
|            m_AC3DialogLevel = (headr[4] & 0x03) << 3 | ((headr[5] & 0xE0) >> 5); |  | ||||||
|            } |  | ||||||
|         } |  | ||||||
|      } |  | ||||||
|   else { |  | ||||||
|      m_AC3CenterMixLevel = FR_NOTVALID; |  | ||||||
|      if (m_AC3AudioCodingMode & 0x04) { |  | ||||||
|         // a surround channel exists |  | ||||||
|         m_AC3SurroundMixLevel = (headr[4] & 0x18) >> 3; |  | ||||||
|         if (m_AC3AudioCodingMode == 0x02) { |  | ||||||
|            // if in 2/0 mode |  | ||||||
|            m_AC3DolbySurroundMode = (headr[4] & 0x06) >> 1; |  | ||||||
|            m_AC3LfeOn = (headr[4] & 0x01); |  | ||||||
|            m_AC3DialogLevel = (headr[5] & 0xF8) >> 3; |  | ||||||
|            } |  | ||||||
|         else { |  | ||||||
|            m_AC3DolbySurroundMode = FR_NOTVALID; |  | ||||||
|            m_AC3LfeOn = (headr[4] & 0x04) >> 2; |  | ||||||
|            m_AC3DialogLevel = (headr[4] & 0x03) << 3 | ((headr[5] & 0xE0) >> 5); |  | ||||||
|            } |  | ||||||
|         } |  | ||||||
|      else { |  | ||||||
|         m_AC3SurroundMixLevel = FR_NOTVALID; |  | ||||||
|         if (m_AC3AudioCodingMode == 0x02) { |  | ||||||
|            // if in 2/0 mode |  | ||||||
|            m_AC3DolbySurroundMode = (headr[4] & 0x18) >> 3; |  | ||||||
|            m_AC3LfeOn = (headr[4] & 0x04) >> 2; |  | ||||||
|            m_AC3DialogLevel = (headr[4] & 0x03) << 3 | ((headr[5] & 0xE0) >> 5); |  | ||||||
|            } |  | ||||||
|         else { |  | ||||||
|            m_AC3DolbySurroundMode = FR_NOTVALID; |  | ||||||
|            m_AC3LfeOn = (headr[4] & 0x10) >> 4; |  | ||||||
|            m_AC3DialogLevel = ((headr[4] & 0x0F) << 1) | ((headr[5] & 0x80) >> 7); |  | ||||||
|            } |  | ||||||
|         } |  | ||||||
|      } |  | ||||||
| } | } | ||||||
|  |  | ||||||
| void cFemonReceiver::Activate(bool On) | void cFemonReceiver::Activate(bool On) | ||||||
| { | { | ||||||
|   Dprintf("%s(%d)\n", __PRETTY_FUNCTION__, On); |   //printf("cFemonReceiver::Activate()\n"); | ||||||
|   if (On) |  | ||||||
|   Start(); |   Start(); | ||||||
|   else |  | ||||||
|      Cancel(); |  | ||||||
| } | } | ||||||
|  |  | ||||||
| void cFemonReceiver::Receive(uchar *Data, int Length) | void cFemonReceiver::Receive(uchar *Data, int Length) | ||||||
| { | { | ||||||
|  |   //printf("cFemonReceiver::Receive()\n"); | ||||||
|   // TS packet length: TS_SIZE |   // TS packet length: TS_SIZE | ||||||
|   if (Length == TS_SIZE) { |   if (Length == TS_SIZE) { | ||||||
|      int pid = ((Data[1] & 0x1f) << 8) | (Data[2]); |      int pid = ((Data[1] & 0x1f) << 8) | (Data[2]); | ||||||
| @@ -350,10 +305,12 @@ void cFemonReceiver::Receive(uchar *Data, int Length) | |||||||
|  |  | ||||||
| void cFemonReceiver::Action(void) | void cFemonReceiver::Action(void) | ||||||
| { | { | ||||||
|   Dprintf("%s()\n", __PRETTY_FUNCTION__); |   //printf("cFemonReceiver::Action()\n"); | ||||||
|   cTimeMs t; | #if (VDRVERSNUM < 10300) | ||||||
|   while (Running()) { |   isyslog("femon receiver: thread started (pid = %d)", getpid()); | ||||||
|         t.Set(0); | #endif | ||||||
|  |   m_Active = true; | ||||||
|  |   while (m_Active) { | ||||||
|         // TS packet 188 bytes - 4 byte header; MPEG standard defines 1Mbit = 1000000bit |         // TS packet 188 bytes - 4 byte header; MPEG standard defines 1Mbit = 1000000bit | ||||||
|         m_VideoBitrate = (8.0 * 184.0 * m_VideoPacketCount) / (femonConfig.calcinterval * 100000.0); |         m_VideoBitrate = (8.0 * 184.0 * m_VideoPacketCount) / (femonConfig.calcinterval * 100000.0); | ||||||
|         m_VideoPacketCount = 0; |         m_VideoPacketCount = 0; | ||||||
| @@ -361,6 +318,9 @@ void cFemonReceiver::Action(void) | |||||||
|         m_AudioPacketCount = 0; |         m_AudioPacketCount = 0; | ||||||
|         m_AC3Bitrate   = (8.0 * 184.0 * m_AC3PacketCount)   / (femonConfig.calcinterval * 100.0); |         m_AC3Bitrate   = (8.0 * 184.0 * m_AC3PacketCount)   / (femonConfig.calcinterval * 100.0); | ||||||
|         m_AC3PacketCount = 0; |         m_AC3PacketCount = 0; | ||||||
|         cCondWait::SleepMs(100 * femonConfig.calcinterval - t.Elapsed()); |         usleep(100000L * femonConfig.calcinterval); | ||||||
|     } |     } | ||||||
|  | #if (VDRVERSNUM < 10300) | ||||||
|  |   isyslog("femon receiver: thread stopped (pid = %d)", getpid()); | ||||||
|  | #endif | ||||||
| } | } | ||||||
|   | |||||||
| @@ -53,6 +53,7 @@ enum eDolbySurroundMode { | |||||||
|  |  | ||||||
| class cFemonReceiver : public cReceiver, public cThread { | class cFemonReceiver : public cReceiver, public cThread { | ||||||
| private: | private: | ||||||
|  |   bool   m_Active; | ||||||
|   int    m_VideoPid; |   int    m_VideoPid; | ||||||
|   int    m_AudioPid; |   int    m_AudioPid; | ||||||
|   int    m_AC3Pid; |   int    m_AC3Pid; | ||||||
| @@ -94,7 +95,7 @@ protected: | |||||||
|   virtual void Action(void); |   virtual void Action(void); | ||||||
|  |  | ||||||
| public: | public: | ||||||
|   cFemonReceiver(int Ca, int Vpid, int Apid[], int Dpid[]); |   cFemonReceiver(int Ca, int Vpid, int Apid, int Dpid); | ||||||
|   virtual ~cFemonReceiver(); |   virtual ~cFemonReceiver(); | ||||||
|  |  | ||||||
|   bool VideoValid(void)           { return m_VideoValid; };          // boolean |   bool VideoValid(void)           { return m_VideoValid; };          // boolean | ||||||
|   | |||||||
| @@ -1,27 +0,0 @@ | |||||||
| /* |  | ||||||
|  * Frontend Status Monitor plugin for the Video Disk Recorder |  | ||||||
|  * |  | ||||||
|  * See the README file for copyright information and how to reach the author. |  | ||||||
|  * |  | ||||||
|  * $Id$ |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| #ifndef __FEMONSERVICE_H |  | ||||||
| #define __FEMONSERVICE_H |  | ||||||
|  |  | ||||||
| #include <linux/dvb/frontend.h> |  | ||||||
|  |  | ||||||
| struct FemonService_v1_0 { |  | ||||||
|   cString fe_name; |  | ||||||
|   cString fe_status; |  | ||||||
|   uint16_t fe_snr; |  | ||||||
|   uint16_t fe_signal; |  | ||||||
|   uint32_t fe_ber; |  | ||||||
|   uint32_t fe_unc; |  | ||||||
|   double video_bitrate; |  | ||||||
|   double audio_bitrate; |  | ||||||
|   double dolby_bitrate; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
| #endif //__FEMONSERVICE_H |  | ||||||
|  |  | ||||||
							
								
								
									
										110
									
								
								femontools.c
									
									
									
									
									
								
							
							
						
						
									
										110
									
								
								femontools.c
									
									
									
									
									
								
							| @@ -1,110 +0,0 @@ | |||||||
| /* |  | ||||||
|  * Frontend Status Monitor plugin for the Video Disk Recorder |  | ||||||
|  * |  | ||||||
|  * See the README file for copyright information and how to reach the author. |  | ||||||
|  * |  | ||||||
|  * $Id$ |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| #include <stdlib.h> |  | ||||||
| #include <unistd.h> |  | ||||||
| #include <sys/ioctl.h> |  | ||||||
| #include <linux/dvb/frontend.h> |  | ||||||
| #include "femontools.h" |  | ||||||
|  |  | ||||||
| cString getFrontendName(int cardIndex) |  | ||||||
| { |  | ||||||
|   struct dvb_frontend_info value; |  | ||||||
|   char *dev = NULL; |  | ||||||
|  |  | ||||||
|   asprintf(&dev, FRONTEND_DEVICE, cardIndex, 0); |  | ||||||
|   int fe = open(dev, O_RDONLY | O_NONBLOCK); |  | ||||||
|   free(dev); |  | ||||||
|   if (fe < 0) |  | ||||||
|      return NULL; |  | ||||||
|   ioctl(fe, FE_GET_INFO, &value); |  | ||||||
|   close(fe); |  | ||||||
|  |  | ||||||
|   return (cString::sprintf("%s on device #%d", value.name, cardIndex)); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| cString getFrontendStatus(int cardIndex) |  | ||||||
| { |  | ||||||
|   fe_status_t value; |  | ||||||
|   char *dev = NULL; |  | ||||||
|  |  | ||||||
|   asprintf(&dev, FRONTEND_DEVICE, cardIndex, 0); |  | ||||||
|   int fe = open(dev, O_RDONLY | O_NONBLOCK); |  | ||||||
|   free(dev); |  | ||||||
|   if (fe < 0) |  | ||||||
|      return NULL; |  | ||||||
|   CHECK(ioctl(fe, FE_READ_STATUS, &value)); |  | ||||||
|   close(fe); |  | ||||||
|  |  | ||||||
|   return (cString::sprintf("Status %s:%s:%s:%s:%s on device #%d", (value & FE_HAS_LOCK) ? "LOCKED" : "-", (value & FE_HAS_SIGNAL) ? "SIGNAL" : "-", (value & FE_HAS_CARRIER) ? "CARRIER" : "-", (value & FE_HAS_VITERBI) ? "VITERBI" : "-", (value & FE_HAS_SYNC) ? "SYNC" : "-", cardIndex)); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| uint16_t getSignal(int cardIndex) |  | ||||||
| { |  | ||||||
|   uint16_t value = 0; |  | ||||||
|   char *dev = NULL; |  | ||||||
|  |  | ||||||
|   asprintf(&dev, FRONTEND_DEVICE, cardIndex, 0); |  | ||||||
|   int fe = open(dev, O_RDONLY | O_NONBLOCK); |  | ||||||
|   free(dev); |  | ||||||
|   if (fe < 0) |  | ||||||
|      return (value); |  | ||||||
|   CHECK(ioctl(fe, FE_READ_SIGNAL_STRENGTH, &value)); |  | ||||||
|   close(fe); |  | ||||||
|  |  | ||||||
|   return (value); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| uint16_t getSNR(int cardIndex) |  | ||||||
| { |  | ||||||
|   uint16_t value = 0; |  | ||||||
|   char *dev = NULL; |  | ||||||
|  |  | ||||||
|   asprintf(&dev, FRONTEND_DEVICE, cardIndex, 0); |  | ||||||
|   int fe = open(dev, O_RDONLY | O_NONBLOCK); |  | ||||||
|   free(dev); |  | ||||||
|   if (fe < 0) |  | ||||||
|      return (value); |  | ||||||
|   CHECK(ioctl(fe, FE_READ_SNR, &value)); |  | ||||||
|   close(fe); |  | ||||||
|  |  | ||||||
|   return (value); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| uint32_t getBER(int cardIndex) |  | ||||||
| { |  | ||||||
|   uint32_t value = 0; |  | ||||||
|   char *dev = NULL; |  | ||||||
|  |  | ||||||
|   asprintf(&dev, FRONTEND_DEVICE, cardIndex, 0); |  | ||||||
|   int fe = open(dev, O_RDONLY | O_NONBLOCK); |  | ||||||
|   free(dev); |  | ||||||
|   if (fe < 0) |  | ||||||
|      return (value); |  | ||||||
|   CHECK(ioctl(fe, FE_READ_BER, &value)); |  | ||||||
|   close(fe); |  | ||||||
|  |  | ||||||
|   return (value); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| uint32_t getUNC(int cardIndex) |  | ||||||
| { |  | ||||||
|   uint32_t value = 0; |  | ||||||
|   char *dev = NULL; |  | ||||||
|  |  | ||||||
|   asprintf(&dev, FRONTEND_DEVICE, cardIndex, 0); |  | ||||||
|   int fe = open(dev, O_RDONLY | O_NONBLOCK); |  | ||||||
|   free(dev); |  | ||||||
|   if (fe < 0) |  | ||||||
|      return (value); |  | ||||||
|   CHECK(ioctl(fe, FE_READ_UNCORRECTED_BLOCKS, &value)); |  | ||||||
|   close(fe); |  | ||||||
|  |  | ||||||
|   return (value); |  | ||||||
| } |  | ||||||
|  |  | ||||||
							
								
								
									
										30
									
								
								femontools.h
									
									
									
									
									
								
							
							
						
						
									
										30
									
								
								femontools.h
									
									
									
									
									
								
							| @@ -1,30 +0,0 @@ | |||||||
| /* |  | ||||||
|  * Frontend Status Monitor plugin for the Video Disk Recorder |  | ||||||
|  * |  | ||||||
|  * See the README file for copyright information and how to reach the author. |  | ||||||
|  * |  | ||||||
|  * $Id$ |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| #ifndef __FEMONTOOLS_H |  | ||||||
| #define __FEMONTOOLS_H |  | ||||||
|  |  | ||||||
| #include <stdint.h> |  | ||||||
| #include <vdr/tools.h> |  | ||||||
|  |  | ||||||
| #ifdef FEMON_DEBUG |  | ||||||
| #define Dprintf(x...) printf(x); |  | ||||||
| #else |  | ||||||
| #define Dprintf(x...) ; |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #define FRONTEND_DEVICE "/dev/dvb/adapter%d/frontend%d" |  | ||||||
|  |  | ||||||
| cString getFrontendName(int cardIndex = 0); |  | ||||||
| cString getFrontendStatus(int cardIndex = 0); |  | ||||||
| uint16_t getSNR(int cardIndex = 0); |  | ||||||
| uint16_t getSignal(int cardIndex = 0); |  | ||||||
| uint32_t getBER(int cardIndex = 0); |  | ||||||
| uint32_t getUNC(int cardIndex = 0); |  | ||||||
|  |  | ||||||
| #endif // __FEMONTOOLS_H |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static char * ar11_xpm[] = { |  | ||||||
| "26 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "++++++++++++++++++++++++++", |  | ||||||
| "+........................+", |  | ||||||
| "+......++..........++....+", |  | ||||||
| "+...+++++.......+++++....+", |  | ||||||
| "+...+++++.......+++++....+", |  | ||||||
| "+......++...++.....++....+", |  | ||||||
| "+......++...++.....++....+", |  | ||||||
| "+......++..........++....+", |  | ||||||
| "+......++..........++....+", |  | ||||||
| "+......++..........++....+", |  | ||||||
| "+......++..........++....+", |  | ||||||
| "+......++..........++....+", |  | ||||||
| "+......++..........++....+", |  | ||||||
| "+......++..........++....+", |  | ||||||
| "+......++...++.....++....+", |  | ||||||
| "+......++...++.....++....+", |  | ||||||
| "+........................+", |  | ||||||
| "++++++++++++++++++++++++++"}; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static char * ar169_xpm[] = { |  | ||||||
| "38 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "+....................................+", |  | ||||||
| "+......++.....++++..........++++.....+", |  | ||||||
| "+...+++++....+++++++.......++++++....+", |  | ||||||
| "+...+++++....++...++......++...+++...+", |  | ||||||
| "+......++...++........++..++....++...+", |  | ||||||
| "+......++...++........++..++....++...+", |  | ||||||
| "+......++...++............++....++...+", |  | ||||||
| "+......++...++.+++.........+++++++...+", |  | ||||||
| "+......++...+++++++.........+++.++...+", |  | ||||||
| "+......++...++....++............++...+", |  | ||||||
| "+......++...++....++............++...+", |  | ||||||
| "+......++...++....++............++...+", |  | ||||||
| "+......++...+++...++......++...++....+", |  | ||||||
| "+......++....++++++...++..+++++++....+", |  | ||||||
| "+......++.....++++....++...+++++.....+", |  | ||||||
| "+....................................+", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++"}; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static char * ar2211_xpm[] = { |  | ||||||
| "52 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "+..................................................+", |  | ||||||
| "+.....++++..........++++........++...........++....+", |  | ||||||
| "+...+++++++.......+++++++....+++++........+++++....+", |  | ||||||
| "+...++....++......++....++...+++++........+++++....+", |  | ||||||
| "+.........++............++......++...++......++....+", |  | ||||||
| "+.........++............++......++...++......++....+", |  | ||||||
| "+........+++...........+++......++...........++....+", |  | ||||||
| "+.......+++...........+++.......++...........++....+", |  | ||||||
| "+......+++...........+++........++...........++....+", |  | ||||||
| "+.....+++...........+++.........++...........++....+", |  | ||||||
| "+....+++...........+++..........++...........++....+", |  | ||||||
| "+...+++...........+++...........++...........++....+", |  | ||||||
| "+...++............++............++...........++....+", |  | ||||||
| "+...++++++++..++..++++++++......++...++......++....+", |  | ||||||
| "+...++++++++..++..++++++++......++...++......++....+", |  | ||||||
| "+..................................................+", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++"}; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static char * ar43_xpm[] = { |  | ||||||
| "31 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "+++++++++++++++++++++++++++++++", |  | ||||||
| "+.............................+", |  | ||||||
| "+.........++.........+++++....+", |  | ||||||
| "+........+++........+++++++...+", |  | ||||||
| "+.......++++.......++....++...+", |  | ||||||
| "+......++.++...++..++....++...+", |  | ||||||
| "+.....++..++...++........++...+", |  | ||||||
| "+.....++..++............++....+", |  | ||||||
| "+....++...++..........+++.....+", |  | ||||||
| "+...++....++..........++++....+", |  | ||||||
| "+...+++++++++...........+++...+", |  | ||||||
| "+...+++++++++............++...+", |  | ||||||
| "+.........++.......++....++...+", |  | ||||||
| "+.........++.......++...+++...+", |  | ||||||
| "+.........++...++...++++++....+", |  | ||||||
| "+.........++...++....++++.....+", |  | ||||||
| "+.............................+", |  | ||||||
| "+++++++++++++++++++++++++++++++"}; |  | ||||||
| @@ -1,24 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static char * carrier_xpm[] = { |  | ||||||
| "96 19 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++...........+++++.......+++++.....++++++++....++++++++....+++...++++++++...++++++++..........++", |  | ||||||
| "++..........+++++++......+++++.....+++++++++...+++++++++...+++...++++++++...+++++++++.........++", |  | ||||||
| "++..........+++.++++.....+++++.....+++...+++...+++...+++...+++...+++........+++...+++.........++", |  | ||||||
| "++.........+++...++.....+++.+++....+++...+++...+++...+++...+++...+++........+++...+++.........++", |  | ||||||
| "++.........+++..........+++.+++....++++++++....++++++++....+++...+++++++....++++++++..........++", |  | ||||||
| "++.........+++..........+++.+++....+++++++.....+++++++.....+++...+++++++....+++++++...........++", |  | ||||||
| "++.........+++.........+++...+++...+++..+++....+++..+++....+++...+++........+++..+++..........++", |  | ||||||
| "++.........+++...++....+++++++++...+++..+++....+++..+++....+++...+++........+++..+++..........++", |  | ||||||
| "++..........+++.++++...+++++++++...+++...+++...+++...+++...+++...+++........+++...+++.........++", |  | ||||||
| "++..........+++++++...+++.....+++..+++...+++...+++...+++...+++...++++++++...+++...+++.........++", |  | ||||||
| "++...........+++++....+++.....+++..+++....+++..+++....+++..+++...++++++++...+++....+++........++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++"}; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static char * device_xpm[] = { |  | ||||||
| "14 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "++++++++++++++", |  | ||||||
| "+.............", |  | ||||||
| "+.......+..+..", |  | ||||||
| "+.......+..+..", |  | ||||||
| "+.......+..+..", |  | ||||||
| "+....+++++++++", |  | ||||||
| "+....+++++++++", |  | ||||||
| "+......+..+...", |  | ||||||
| "+......+..+...", |  | ||||||
| "+......+..+...", |  | ||||||
| "+......+..+...", |  | ||||||
| "+...+++++++++.", |  | ||||||
| "+...+++++++++.", |  | ||||||
| "+.....+..+....", |  | ||||||
| "+.....+..+....", |  | ||||||
| "+.....+..+....", |  | ||||||
| "+.............", |  | ||||||
| "++++++++++++++"}; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static char * dolbydigital_xpm[] = { |  | ||||||
| "31 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "+++++++++++++++++++++++++++++++", |  | ||||||
| "+.............................+", |  | ||||||
| "+...+++++++++++.+++++++++++...+", |  | ||||||
| "+...++.++++++++.++++++++.++...+", |  | ||||||
| "+...++...++++++.++++++...++...+", |  | ||||||
| "+...++.....++++.++++.....++...+", |  | ||||||
| "+...++......+++.+++......++...+", |  | ||||||
| "+...++.......++.++.......++...+", |  | ||||||
| "+...++.......++.++.......++...+", |  | ||||||
| "+...++.......++.++.......++...+", |  | ||||||
| "+...++.......++.++.......++...+", |  | ||||||
| "+...++......+++.+++......++...+", |  | ||||||
| "+...++.....++++.++++.....++...+", |  | ||||||
| "+...++...++++++.++++++...++...+", |  | ||||||
| "+...++.++++++++.++++++++.++...+", |  | ||||||
| "+...+++++++++++.+++++++++++...+", |  | ||||||
| "+.............................+", |  | ||||||
| "+++++++++++++++++++++++++++++++"}; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static char * dolbydigital20_xpm[] = { |  | ||||||
| "55 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "+++++++++++++++++++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "+.....................................................+", |  | ||||||
| "+...+++++++++++.+++++++++++.....++++.........++++.....+", |  | ||||||
| "+...++.++++++++.++++++++.++...+++++++.......++++++....+", |  | ||||||
| "+...++...++++++.++++++...++...++....++......++..++....+", |  | ||||||
| "+...++.....++++.++++.....++.........++.....++....++...+", |  | ||||||
| "+...++......+++.+++......++.........++.....++....++...+", |  | ||||||
| "+...++.......++.++.......++........+++.....++....++...+", |  | ||||||
| "+...++.......++.++.......++.......+++......++....++...+", |  | ||||||
| "+...++.......++.++.......++......+++.......++....++...+", |  | ||||||
| "+...++.......++.++.......++.....+++........++....++...+", |  | ||||||
| "+...++......+++.+++......++....+++.........++....++...+", |  | ||||||
| "+...++.....++++.++++.....++...+++..........++....++...+", |  | ||||||
| "+...++...++++++.++++++...++...++............++..++....+", |  | ||||||
| "+...++.++++++++.++++++++.++...++++++++..++..++++++....+", |  | ||||||
| "+...+++++++++++.+++++++++++...++++++++..++...++++.....+", |  | ||||||
| "+.....................................................+", |  | ||||||
| "+++++++++++++++++++++++++++++++++++++++++++++++++++++++"}; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static char * dolbydigital51_xpm[] = { |  | ||||||
| "51 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "+++++++++++++++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "+.................................................+", |  | ||||||
| "+...+++++++++++.+++++++++++...+++++++........++...+", |  | ||||||
| "+...++.++++++++.++++++++.++...+++++++.....+++++...+", |  | ||||||
| "+...++...++++++.++++++...++...++..........+++++...+", |  | ||||||
| "+...++.....++++.++++.....++...++.............++...+", |  | ||||||
| "+...++......+++.+++......++...++++++.........++...+", |  | ||||||
| "+...++.......++.++.......++...+++++++........++...+", |  | ||||||
| "+...++.......++.++.......++...++...+++.......++...+", |  | ||||||
| "+...++.......++.++.......++.........++.......++...+", |  | ||||||
| "+...++.......++.++.......++.........++.......++...+", |  | ||||||
| "+...++......+++.+++......++.........++.......++...+", |  | ||||||
| "+...++.....++++.++++.....++...++....++.......++...+", |  | ||||||
| "+...++...++++++.++++++...++...++...+++.......++...+", |  | ||||||
| "+...++.++++++++.++++++++.++...+++++++...++...++...+", |  | ||||||
| "+...+++++++++++.+++++++++++....+++++....++...++...+", |  | ||||||
| "+.................................................+", |  | ||||||
| "+++++++++++++++++++++++++++++++++++++++++++++++++++"}; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static char * five_xpm[] = { |  | ||||||
| "15 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "+++++++++++++++", |  | ||||||
| "..............+", |  | ||||||
| "...+++++++....+", |  | ||||||
| "...+++++++....+", |  | ||||||
| "...++.........+", |  | ||||||
| "...++.........+", |  | ||||||
| "...++.........+", |  | ||||||
| "...++++++.....+", |  | ||||||
| "...+++++++....+", |  | ||||||
| "...++...+++...+", |  | ||||||
| ".........++...+", |  | ||||||
| ".........++...+", |  | ||||||
| "...++....++...+", |  | ||||||
| "...++...+++...+", |  | ||||||
| "...+++++++....+", |  | ||||||
| "....+++++.....+", |  | ||||||
| "..............+", |  | ||||||
| "+++++++++++++++"}; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static char * four_xpm[] = { |  | ||||||
| "15 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "+++++++++++++++", |  | ||||||
| "..............+", |  | ||||||
| ".........++...+", |  | ||||||
| "........+++...+", |  | ||||||
| ".......++++...+", |  | ||||||
| "......++.++...+", |  | ||||||
| ".....++..++...+", |  | ||||||
| ".....++..++...+", |  | ||||||
| "....++...++...+", |  | ||||||
| "...++....++...+", |  | ||||||
| "...+++++++++..+", |  | ||||||
| "...+++++++++..+", |  | ||||||
| ".........++...+", |  | ||||||
| ".........++...+", |  | ||||||
| ".........++...+", |  | ||||||
| ".........++...+", |  | ||||||
| "..............+", |  | ||||||
| "+++++++++++++++"}; |  | ||||||
| @@ -1,24 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static char * lock_xpm[] = { |  | ||||||
| "96 19 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++........................+++........+++++........+++++.....+++....+++........................++", |  | ||||||
| "++........................+++.......++++++++.....+++++++....+++...+++.........................++", |  | ||||||
| "++........................+++.......+++..+++.....+++.++++...+++..+++..........................++", |  | ||||||
| "++........................+++......+++....+++...+++...++....+++.+++...........................++", |  | ||||||
| "++........................+++......+++....+++...+++.........+++++++...........................++", |  | ||||||
| "++........................+++......+++....+++...+++.........++++.+++..........................++", |  | ||||||
| "++........................+++......+++....+++...+++.........+++..+++..........................++", |  | ||||||
| "++........................+++......+++....+++...+++...++....+++...+++.........................++", |  | ||||||
| "++........................+++.......+++..+++.....+++.++++...+++...+++.........................++", |  | ||||||
| "++........................+++++++...++++++++.....+++++++....+++....+++........................++", |  | ||||||
| "++........................+++++++.....++++........+++++.....+++.....+++.......................++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++"}; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static char * monoleft_xpm[] = { |  | ||||||
| "17 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "+++++++++++++++++", |  | ||||||
| "+................", |  | ||||||
| "+...++...........", |  | ||||||
| "+...++++.........", |  | ||||||
| "+...++++++.......", |  | ||||||
| "+...++++++++.....", |  | ||||||
| "+...+++++++++++++", |  | ||||||
| "+...+++++++++++++", |  | ||||||
| "+...+++++++++..++", |  | ||||||
| "+...+++++++++..++", |  | ||||||
| "+...+++++++++++++", |  | ||||||
| "+...+++++++++++++", |  | ||||||
| "+...++++++++.....", |  | ||||||
| "+...++++++.......", |  | ||||||
| "+...++++.........", |  | ||||||
| "+...+++..........", |  | ||||||
| "+................", |  | ||||||
| "+++++++++++++++++"}; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static char * monoright_xpm[] = { |  | ||||||
| "17 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "+++++++++++++++++", |  | ||||||
| "+................", |  | ||||||
| "+..............++", |  | ||||||
| "+............++++", |  | ||||||
| "+..........++++++", |  | ||||||
| "+........++++++++", |  | ||||||
| "+...+++++++++++++", |  | ||||||
| "+...+++++++++++++", |  | ||||||
| "+...++..+++++++++", |  | ||||||
| "+...++..+++++++++", |  | ||||||
| "+...+++++++++++++", |  | ||||||
| "+...+++++++++++++", |  | ||||||
| "+........++++++++", |  | ||||||
| "+..........++++++", |  | ||||||
| "+............++++", |  | ||||||
| "+.............+++", |  | ||||||
| "+................", |  | ||||||
| "+++++++++++++++++"}; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static char * ntsc_xpm[] = { |  | ||||||
| "19 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "+++++++++++++++++++", |  | ||||||
| "+.................+", |  | ||||||
| "+...++.......++...+", |  | ||||||
| "+...+++......++...+", |  | ||||||
| "+...++++.....++...+", |  | ||||||
| "+...++++.....++...+", |  | ||||||
| "+...++.++....++...+", |  | ||||||
| "+...++..++...++...+", |  | ||||||
| "+...++..++...++...+", |  | ||||||
| "+...++...++..++...+", |  | ||||||
| "+...++...++..++...+", |  | ||||||
| "+...++....++.++...+", |  | ||||||
| "+...++.....++++...+", |  | ||||||
| "+...++.....++++...+", |  | ||||||
| "+...++......+++...+", |  | ||||||
| "+...++.......++...+", |  | ||||||
| "+.................+", |  | ||||||
| "+++++++++++++++++++"}; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static char * one_xpm[] = { |  | ||||||
| "15 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "+++++++++++++++", |  | ||||||
| "..............+", |  | ||||||
| ".......++.....+", |  | ||||||
| "....+++++.....+", |  | ||||||
| "....+++++.....+", |  | ||||||
| ".......++.....+", |  | ||||||
| ".......++.....+", |  | ||||||
| ".......++.....+", |  | ||||||
| ".......++.....+", |  | ||||||
| ".......++.....+", |  | ||||||
| ".......++.....+", |  | ||||||
| ".......++.....+", |  | ||||||
| ".......++.....+", |  | ||||||
| ".......++.....+", |  | ||||||
| ".......++.....+", |  | ||||||
| ".......++.....+", |  | ||||||
| "..............+", |  | ||||||
| "+++++++++++++++"}; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static char * pal_xpm[] = { |  | ||||||
| "18 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "++++++++++++++++++", |  | ||||||
| "+................+", |  | ||||||
| "+...++++++++.....+", |  | ||||||
| "+...+++++++++....+", |  | ||||||
| "+...++.....+++...+", |  | ||||||
| "+...++......++...+", |  | ||||||
| "+...++......++...+", |  | ||||||
| "+...++.....+++...+", |  | ||||||
| "+...+++++++++....+", |  | ||||||
| "+...++++++++.....+", |  | ||||||
| "+...++...........+", |  | ||||||
| "+...++...........+", |  | ||||||
| "+...++...........+", |  | ||||||
| "+...++...........+", |  | ||||||
| "+...++...........+", |  | ||||||
| "+...++...........+", |  | ||||||
| "+................+", |  | ||||||
| "++++++++++++++++++"}; |  | ||||||
| @@ -1,24 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static char * signal_xpm[] = { |  | ||||||
| "96 19 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++.................+++++....+++......+++++.....+++....+++.....+++++.....+++...................++", |  | ||||||
| "++...............++++++++...+++....++++++++....++++...+++.....+++++.....+++...................++", |  | ||||||
| "++...............+++..+++...+++....+++..++++...+++++..+++.....+++++.....+++...................++", |  | ||||||
| "++...............+++........+++...+++....++....+++++..+++....+++.+++....+++...................++", |  | ||||||
| "++...............++++++.....+++...+++..........++++++.+++....+++.+++....+++...................++", |  | ||||||
| "++................++++++....+++...+++..+++++...+++.++.+++....+++.+++....+++...................++", |  | ||||||
| "++..................+++++...+++...+++..+++++...+++.++++++...+++...+++...+++...................++", |  | ||||||
| "++...............+++..+++...+++...+++....+++...+++..+++++...+++++++++...+++...................++", |  | ||||||
| "++...............+++..+++...+++....+++...+++...+++..+++++...+++++++++...+++...................++", |  | ||||||
| "++................++++++....+++....+++++++++...+++...++++..+++.....+++..+++++++...............++", |  | ||||||
| "++.................++++.....+++......+++++.....+++....+++..+++.....+++..+++++++...............++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++"}; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static char * stereo_xpm[] = { |  | ||||||
| "17 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "+++++++++++++++++", |  | ||||||
| "+................", |  | ||||||
| "+..............++", |  | ||||||
| "+............++++", |  | ||||||
| "+..........+++.++", |  | ||||||
| "+........+++...++", |  | ||||||
| "+...+++++++....++", |  | ||||||
| "+...++++++.....++", |  | ||||||
| "+...++..++.....++", |  | ||||||
| "+...++..++.....++", |  | ||||||
| "+...++++++.....++", |  | ||||||
| "+...+++++++....++", |  | ||||||
| "+........+++...++", |  | ||||||
| "+..........+++.++", |  | ||||||
| "+............++++", |  | ||||||
| "+.............+++", |  | ||||||
| "+................", |  | ||||||
| "+++++++++++++++++"}; |  | ||||||
| @@ -1,24 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static char * sync_xpm[] = { |  | ||||||
| "96 19 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++.........................+++++...+++.....+++..+++....+++.....+++++..........................++", |  | ||||||
| "++.......................++++++++...+++...+++...++++...+++....+++++++.........................++", |  | ||||||
| "++.......................+++..+++....+++.+++....+++++..+++....+++.++++........................++", |  | ||||||
| "++.......................+++.........+++.+++....+++++..+++...+++...++.........................++", |  | ||||||
| "++.......................++++++.......+++++.....++++++.+++...+++..............................++", |  | ||||||
| "++........................++++++......+++++.....+++.++.+++...+++..............................++", |  | ||||||
| "++..........................+++++......+++......+++.++++++...+++..............................++", |  | ||||||
| "++.......................+++..+++......+++......+++..+++++...+++...++.........................++", |  | ||||||
| "++.......................+++..+++......+++......+++..+++++....+++.++++........................++", |  | ||||||
| "++........................++++++.......+++......+++...++++....+++++++.........................++", |  | ||||||
| "++.........................++++........+++......+++....+++.....+++++..........................++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++"}; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static char * three_xpm[] = { |  | ||||||
| "15 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "+++++++++++++++", |  | ||||||
| "..............+", |  | ||||||
| ".....+++++....+", |  | ||||||
| "....+++++++...+", |  | ||||||
| "...++....++...+", |  | ||||||
| "...++....++...+", |  | ||||||
| ".........++...+", |  | ||||||
| "........++....+", |  | ||||||
| "......+++.....+", |  | ||||||
| "......++++....+", |  | ||||||
| "........+++...+", |  | ||||||
| ".........++...+", |  | ||||||
| "...++....++...+", |  | ||||||
| "...++...+++...+", |  | ||||||
| "....++++++....+", |  | ||||||
| ".....++++.....+", |  | ||||||
| "..............+", |  | ||||||
| "+++++++++++++++"}; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static char * two_xpm[] = { |  | ||||||
| "15 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "+++++++++++++++", |  | ||||||
| "..............+", |  | ||||||
| ".....++++.....+", |  | ||||||
| "...+++++++....+", |  | ||||||
| "...++....++...+", |  | ||||||
| ".........++...+", |  | ||||||
| ".........++...+", |  | ||||||
| "........+++...+", |  | ||||||
| ".......+++....+", |  | ||||||
| "......+++.....+", |  | ||||||
| ".....+++......+", |  | ||||||
| "....+++.......+", |  | ||||||
| "...+++........+", |  | ||||||
| "...++.........+", |  | ||||||
| "...++++++++...+", |  | ||||||
| "...++++++++...+", |  | ||||||
| "..............+", |  | ||||||
| "+++++++++++++++"}; |  | ||||||
| @@ -1,24 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static char * viterbi_xpm[] = { |  | ||||||
| "96 19 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++............+++.....+++..+++...+++++++++..++++++++...++++++++....++++++++....+++............++", |  | ||||||
| "++.............++.....++...+++...+++++++++..++++++++...+++++++++...+++++++++...+++............++", |  | ||||||
| "++.............+++...+++...+++......+++.....+++........+++...+++...+++...+++...+++............++", |  | ||||||
| "++.............+++...+++...+++......+++.....+++........+++...+++...+++...+++...+++............++", |  | ||||||
| "++..............++...++....+++......+++.....+++++++....++++++++....++++++++....+++............++", |  | ||||||
| "++..............+++.+++....+++......+++.....+++++++....+++++++.....++++++++....+++............++", |  | ||||||
| "++..............+++.+++....+++......+++.....+++........+++..+++....+++...+++...+++............++", |  | ||||||
| "++...............++.++.....+++......+++.....+++........+++..+++....+++...+++...+++............++", |  | ||||||
| "++...............+++++.....+++......+++.....+++........+++...+++...+++...+++...+++............++", |  | ||||||
| "++...............+++++.....+++......+++.....++++++++...+++...+++...+++++++++...+++............++", |  | ||||||
| "++................+++......+++......+++.....++++++++...+++....+++..++++++++....+++............++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++"}; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static char * zero_xpm[] = { |  | ||||||
| "15 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "+++++++++++++++", |  | ||||||
| "..............+", |  | ||||||
| ".....++++.....+", |  | ||||||
| "....++++++....+", |  | ||||||
| "....++..++....+", |  | ||||||
| "...++....++...+", |  | ||||||
| "...++....++...+", |  | ||||||
| "...++....++...+", |  | ||||||
| "...++....++...+", |  | ||||||
| "...++....++...+", |  | ||||||
| "...++....++...+", |  | ||||||
| "...++....++...+", |  | ||||||
| "...++....++...+", |  | ||||||
| "....++..++....+", |  | ||||||
| "....++++++....+", |  | ||||||
| ".....++++.....+", |  | ||||||
| "..............+", |  | ||||||
| "+++++++++++++++"}; |  | ||||||
		Reference in New Issue
	
	Block a user