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 | 
							
								
								
									
										142
									
								
								HISTORY
									
									
									
									
									
								
							
							
						
						
									
										142
									
								
								HISTORY
									
									
									
									
									
								
							| @@ -106,145 +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). |  | ||||||
|  |  | ||||||
| 2006-02-06: Version 0.9.7 |  | ||||||
|  |  | ||||||
| - Updated for vdr-1.3.42. |  | ||||||
| - Added "SilverGreen" theme (Thanks to Rififi77 @ VDRPortal). |  | ||||||
|  |  | ||||||
| 2006-03-08: Version 0.9.8 |  | ||||||
|  |  | ||||||
| - Updated for vdr-1.3.44. |  | ||||||
| - Minor Makefile changes. |  | ||||||
| - Made all symbol data 'const'. |  | ||||||
| - Added spanish translation (Thanks to Luis Palacios). |  | ||||||
|  |  | ||||||
| 2006-04-20: Version 0.9.9 |  | ||||||
|  |  | ||||||
| - Updated for vdr-1.3.47. |  | ||||||
|  |  | ||||||
| 2006-04-23: Version 0.9.10 |  | ||||||
|  |  | ||||||
| - Added STRIP option for Makefile (Thanks to Ville Skytt<74>). |  | ||||||
| - Modified APIVERSION code in Makefile. |  | ||||||
|  |  | ||||||
| 2006-04-30: Version 1.0.0 |  | ||||||
|  |  | ||||||
| - Updated for vdr-1.4.0. |  | ||||||
| - Modified APIVERSION code in Makefile. |  | ||||||
| - Updated german translation (Thanks to Andreas Brachold). |  | ||||||
|  |  | ||||||
| 2006-06-06: Version 1.0.1 |  | ||||||
|  |  | ||||||
| - Fixed device switching priority (Thanks to Andreas Brugger). |  | ||||||
| - Fixed device switching back to the primary device. |  | ||||||
|  |  | ||||||
| 2006-09-17: Version 1.1.0 |  | ||||||
|  |  | ||||||
| - Added support for svdrpservice plugin (Thanks to Frank Schmirler). |  | ||||||
| - Added INFO SVDRP command (partially based on patch by Herbert P<>tzl). |  | ||||||
| - Removed system log option - use SVDRP instead. |  | ||||||
| - Added --remove-destination to the 'cp' command in Makefile. |  | ||||||
|  |  | ||||||
| 2007-01-08: Version 1.1.1 |  | ||||||
|  |  | ||||||
| - Updated for vdr-1.5.0. |  | ||||||
|  |  | ||||||
| 2007-05-01: Version 1.1.2 |  | ||||||
|  |  | ||||||
| - Fixed opening while replaying (Thanks to Antti Sepp<70>l<EFBFBD> for reporting this one). |  | ||||||
|   | |||||||
							
								
								
									
										38
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										38
									
								
								Makefile
									
									
									
									
									
								
							| @@ -3,15 +3,6 @@ | |||||||
| # | # | ||||||
| # $Id$ | # $Id$ | ||||||
|  |  | ||||||
| # Debugging on/off  |  | ||||||
| #FEMON_DEBUG = 1 |  | ||||||
|  |  | ||||||
| # NTSC on/off  |  | ||||||
| #FEMON_NTSC = 1 |  | ||||||
|  |  | ||||||
| # Strip debug symbols?  Set eg. to /bin/true if not |  | ||||||
| STRIP = strip |  | ||||||
|  |  | ||||||
| # The official name of this plugin. | # The official name of this plugin. | ||||||
| # This name will be used in the '-P...' option of VDR to load the 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. | # By default the main source file also carries this name. | ||||||
| @@ -20,15 +11,16 @@ PLUGIN = femon | |||||||
|  |  | ||||||
| ### The version number of this plugin (taken from the main source file): | ### The version number of this plugin (taken from the main source file): | ||||||
|  |  | ||||||
| VERSION = $(shell grep 'static const char VERSION\[\] *=' $(PLUGIN).h | awk '{ print $$6 }' | sed -e 's/[";]//g') | VERSION = $(shell grep 'static const char \*VERSION *=' $(PLUGIN).h | awk '{ print $$6 }' | sed -e 's/[";]//g') | ||||||
|  |  | ||||||
| ### 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: | ||||||
|  |  | ||||||
|  | DVBDIR = ../../../../DVB | ||||||
| VDRDIR = ../../.. | VDRDIR = ../../.. | ||||||
| LIBDIR = ../../lib | LIBDIR = ../../lib | ||||||
| TMPDIR = /tmp | TMPDIR = /tmp | ||||||
| @@ -37,9 +29,9 @@ TMPDIR = /tmp | |||||||
|  |  | ||||||
| -include $(VDRDIR)/Make.config | -include $(VDRDIR)/Make.config | ||||||
|  |  | ||||||
| ### The version number of VDR's plugin API (taken from VDR's "config.h"): | ### The version number of VDR (taken from VDR's "config.h"): | ||||||
|  |  | ||||||
| APIVERSION = $(shell sed -ne '/define APIVERSION/s/^.*"\(.*\)".*$$/\1/p' $(VDRDIR)/config.h) | VDRVERSION = $(shell grep 'define VDRVERSION ' $(VDRDIR)/config.h | awk '{ print $$3 }' | sed -e 's/"//g') | ||||||
|  |  | ||||||
| ### The name of the distribution archive: | ### The name of the distribution archive: | ||||||
|  |  | ||||||
| @@ -48,24 +40,17 @@ PACKAGE = vdr-$(ARCHIVE) | |||||||
|  |  | ||||||
| ### Includes and Defines (add further entries here): | ### Includes and Defines (add further entries here): | ||||||
|  |  | ||||||
| INCLUDES += -I$(VDRDIR)/include | 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 += -DNTSC | DEFINES += -DNTSC_SYSTEM | ||||||
| endif | endif | ||||||
|  |  | ||||||
| ifdef FEMON_DEBUG |  | ||||||
| DEFINES += -DDEBUG |  | ||||||
| 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: | ||||||
|  |  | ||||||
| @@ -87,10 +72,7 @@ all: libvdr-$(PLUGIN).so | |||||||
|  |  | ||||||
| libvdr-$(PLUGIN).so: $(OBJS) | libvdr-$(PLUGIN).so: $(OBJS) | ||||||
| 	$(CXX) $(CXXFLAGS) -shared $(OBJS) -o $@ | 	$(CXX) $(CXXFLAGS) -shared $(OBJS) -o $@ | ||||||
| ifndef FEMON_DEBUG | 	@cp $@ $(LIBDIR)/$@.$(VDRVERSION) | ||||||
| 	@$(STRIP) $@ |  | ||||||
| endif |  | ||||||
| 	@cp --remove-destination $@ $(LIBDIR)/$@.$(APIVERSION) |  | ||||||
|  |  | ||||||
| dist: clean | dist: clean | ||||||
| 	@-rm -rf $(TMPDIR)/$(ARCHIVE) | 	@-rm -rf $(TMPDIR)/$(ARCHIVE) | ||||||
|   | |||||||
							
								
								
									
										60
									
								
								README
									
									
									
									
									
								
							
							
						
						
									
										60
									
								
								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 ################### [SVDRP][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,11 +51,11 @@ 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 | ||||||
|  |  | ||||||
| SVDRP   - SVDRP connection active (optional) | 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..N) / AC-3 track (optional) | A       - Audio track: 1..2 (optional) | ||||||
| D       - Device number: 0..N (optional) | D       - Device number: 0..3 (optional) | ||||||
|  |  | ||||||
| Controls: | Controls: | ||||||
|  |  | ||||||
| @@ -61,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: | ||||||
|  |  | ||||||
| @@ -76,42 +77,19 @@ make | |||||||
| make plugins | make plugins | ||||||
| ./vdr -P femon | ./vdr -P femon | ||||||
|  |  | ||||||
| Client-server architecture: |  | ||||||
|  |  | ||||||
| The SVDRP service extension can be used in client-server configurations. |  | ||||||
| A streamdev based VDR-to-VDR streaming client can retrieve frontend |  | ||||||
| information from a server, if the SVDRP service has been activated and |  | ||||||
| properly configured in femon. The svdrpservice plugin is required on the |  | ||||||
| VDR client. |  | ||||||
|  |  | ||||||
| If the client fails to open a DVB card frontend corresponding to the |  | ||||||
| current receiving device, it will connect to the SVDRP server, look for |  | ||||||
| the femon plugin and tune the channel on the server to the one currently |  | ||||||
| viewed on the client. If one of these steps fails, the femon OSD won't |  | ||||||
| open on the client. An SVDRP icon in the femon title bar indicates that |  | ||||||
| the data source is SVDRP. The device number in the title bar is always |  | ||||||
| the local device number. |  | ||||||
|  |  | ||||||
| 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 |  | ||||||
|  |  | ||||||
| - If the SVDRP service is used: femon won't notice if the server is tuned |  | ||||||
|   to a different channel and tuning the channel on the server might annoy |  | ||||||
|   people watching live TV. In some situations the server will refuse |  | ||||||
|   switching to the requested channel. On a headless server you can avoid |  | ||||||
|   this by installing the dummydevice plugin. |  | ||||||
|  |  | ||||||
| "Femon - A real womon who lives according to her natural feminine inclinations." | "Femon - A real womon who lives according to her natural feminine inclinations." | ||||||
|   | |||||||
							
								
								
									
										228
									
								
								femon.c
									
									
									
									
									
								
							
							
						
						
									
										228
									
								
								femon.c
									
									
									
									
									
								
							| @@ -6,32 +6,26 @@ | |||||||
|  * $Id$ |  * $Id$ | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #include <vdr/menu.h> |  | ||||||
| #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(APIVERSNUM) && APIVERSNUM < 10400 | #if VDRVERSNUM && VDRVERSNUM >= 10307 | ||||||
| #error "VDR-1.4.0 API version or greater is required!" | #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) | ||||||
| @@ -59,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. | ||||||
| @@ -72,189 +61,35 @@ 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(); | ||||||
|   if (cReplayControl::NowReplaying()) |  | ||||||
|      Skins.Message(mtInfo, tr("Femon not available while replaying")); |  | ||||||
|   else |  | ||||||
|      return cFemonOsd::Instance(true); |  | ||||||
|   return NULL; |  | ||||||
| } | } | ||||||
|  |  | ||||||
| bool cPluginFemon::SetupParse(const char *Name, const char *Value) | bool cPluginFemon::SetupParse(const char *Name, const char *Value) | ||||||
| { | { | ||||||
|   // Parse your own setup parameters and store their values. |   // Parse your own setup parameters and store their values. | ||||||
|   if      (!strcasecmp(Name, "HideMenu"))       femonConfig.hidemenu       = atoi(Value); |   if      (!strcasecmp(Name, "HideMenu"))       femonConfig.hidemenu       = 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); | ||||||
|   else if (!strcasecmp(Name, "UpdateInterval")) femonConfig.updateinterval = atoi(Value); |   else if (!strcasecmp(Name, "UpdateInterval")) femonConfig.updateinterval = atoi(Value); | ||||||
|   else if (!strcasecmp(Name, "AnalStream"))     femonConfig.analyzestream  = atoi(Value); |   else if (!strcasecmp(Name, "AnalStream"))     femonConfig.analyzestream  = atoi(Value); | ||||||
|   else if (!strcasecmp(Name, "CalcInterval"))   femonConfig.calcinterval   = atoi(Value); |   else if (!strcasecmp(Name, "CalcInterval"))   femonConfig.calcinterval   = atoi(Value); | ||||||
|   else if (!strcasecmp(Name, "UseSvdrp"))       femonConfig.usesvdrp       = atoi(Value); |  | ||||||
|   else if (!strcasecmp(Name, "ServerPort"))     femonConfig.svdrpport      = atoi(Value); |  | ||||||
|   else if (!strcasecmp(Name, "ServerIp"))       strn0cpy(femonConfig.svdrpip, Value, sizeof(femonConfig.svdrpip)); |  | ||||||
|   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.", |  | ||||||
|     "INFO\n" |  | ||||||
|     "    Print the current frontend information.", |  | ||||||
|     "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 uncorrected 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 (cReplayControl::NowReplaying()) { |  | ||||||
|         ReplyCode = 550; // Requested action not taken |  | ||||||
|         return cString("Cannot open femon plugin while replaying"); |  | ||||||
|         } |  | ||||||
|      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, "INFO") == 0) { |  | ||||||
|      return getFrontendInfo(cDevice::ActualDevice()->CardIndex()); |  | ||||||
|      } |  | ||||||
|   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("%s on device #%d", *getBitrateMbits(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("%s on device #%d", *getBitrateKbits(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("%s on device #%d", *getBitrateKbits(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"); |  | ||||||
|   themes[eFemonThemeSilverGreen]   = tr("SilverGreen"); |  | ||||||
|  |  | ||||||
|   data = femonConfig; |  | ||||||
|   Setup(); |   Setup(); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -263,25 +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 cMenuEditStraItem(  tr("Default display mode"),        &data.displaymode,    eFemonModeMaxNumber, dispmodes)); |   Add(new cMenuEditBoolItem(  tr("Use Syslog Output"),           &femonConfig.syslogoutput,   tr("no"),      tr("yes"))); | ||||||
|   Add(new cMenuEditStraItem(  tr("Skin"),                        &data.skin,           eFemonSkinMaxNumber, skins)); |   Add(new cMenuEditStraItem(  tr("Default Display Mode"),        &femonConfig.displaymode,    modeMaxNumber, dispmodes)); | ||||||
|   Add(new cMenuEditStraItem(  tr("Theme"),                       &data.theme,          eFemonThemeMaxNumber,themes)); |   Add(new cMenuEditBoolItem(  tr("Position"),                    &femonConfig.position,       tr("bottom"),  tr("top"))); | ||||||
|   Add(new cMenuEditBoolItem(  tr("Position"),                    &data.position,       tr("bottom"),        tr("top"))); |   Add(new cMenuEditBoolItem(  tr("Show CA System"),              &femonConfig.showcasystem,   tr("no"),      tr("yes"))); | ||||||
|   Add(new cMenuEditIntItem(   tr("Height"),                      &data.osdheight,      400,                 500)); |   Add(new cMenuEditIntItem(   tr("Red Limit [%]"),               &femonConfig.redlimit,       1,             50)); | ||||||
|   Add(new cMenuEditIntItem(   tr("Horizontal offset"),           &data.osdoffset,      -50,                 50)); |   Add(new cMenuEditIntItem(   tr("Green Limit [%]"),             &femonConfig.greenlimit,     51,            100)); | ||||||
|   Add(new cMenuEditBoolItem(  tr("Show CA system"),              &data.showcasystem,   tr("no"),            tr("yes"))); |   Add(new cMenuEditIntItem(   tr("OSD Update Interval [0.1s]"),  &femonConfig.updateinterval, 1,             100)); | ||||||
|   Add(new cMenuEditIntItem(   tr("Red limit [%]"),               &data.redlimit,       1,                   50)); |   Add(new cMenuEditBoolItem(  tr("Analyze Stream"),              &femonConfig.analyzestream,  tr("no"),      tr("yes"))); | ||||||
|   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)); | ||||||
|   Add(new cMenuEditBoolItem(  tr("Use SVDRP service"),           &data.usesvdrp)); |  | ||||||
|   if (data.usesvdrp) { |  | ||||||
|      Add(new cMenuEditIntItem(tr("SVDRP service port"),          &data.svdrpport,      1,                   65535)); |  | ||||||
|      Add(new cMenuEditStrItem(tr("SVDRP service IP"),             data.svdrpip,        MaxSvdrpIp,          ".1234567890")); |  | ||||||
|      } |  | ||||||
|  |  | ||||||
|   SetCurrent(Get(current)); |   SetCurrent(Get(current)); | ||||||
|   Display(); |   Display(); | ||||||
| @@ -289,34 +116,25 @@ 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("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); | ||||||
|   SetupStore("UpdateInterval", femonConfig.updateinterval); |   SetupStore("UpdateInterval", femonConfig.updateinterval); | ||||||
|   SetupStore("AnalStream",     femonConfig.analyzestream); |   SetupStore("AnalStream",     femonConfig.analyzestream); | ||||||
|   SetupStore("CalcInterval",   femonConfig.calcinterval); |   SetupStore("CalcInterval",   femonConfig.calcinterval); | ||||||
|   SetupStore("UseSvdrp",       femonConfig.usesvdrp); |  | ||||||
|   SetupStore("ServerPort",     femonConfig.svdrpport); |  | ||||||
|   SetupStore("ServerIp",       femonConfig.svdrpip); |  | ||||||
| } | } | ||||||
|  |  | ||||||
| eOSState cMenuFemonSetup::ProcessKey(eKeys Key) | eOSState cMenuFemonSetup::ProcessKey(eKeys Key) | ||||||
| { | { | ||||||
|   int oldUsesvdrp = data.usesvdrp; |   int oldAnalyzestream = femonConfig.analyzestream; | ||||||
|   int oldAnalyzestream = data.analyzestream; |  | ||||||
|  |  | ||||||
|   eOSState state = cMenuSetupPage::ProcessKey(Key); |   eOSState state = cMenuSetupPage::ProcessKey(Key); | ||||||
|  |  | ||||||
|   if (Key != kNone && (data.analyzestream != oldAnalyzestream || data.usesvdrp != oldUsesvdrp)) { |   if (Key != kNone && (femonConfig.analyzestream != oldAnalyzestream)) { | ||||||
|      Setup(); |      Setup(); | ||||||
|      } |      } | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										33
									
								
								femon.h
									
									
									
									
									
								
							
							
						
						
									
										33
									
								
								femon.h
									
									
									
									
									
								
							| @@ -11,11 +11,13 @@ | |||||||
|  |  | ||||||
| #include <vdr/plugin.h> | #include <vdr/plugin.h> | ||||||
|  |  | ||||||
| static const char VERSION[]       = "1.1.2"; | 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,31 +27,22 @@ 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 void MainThreadHook(void) {} |  | ||||||
|   virtual cString Active(void) { return NULL; } |  | ||||||
|   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]; |     virtual void Setup(void); | ||||||
|   const char *themes[eFemonThemeMaxNumber]; |   protected: | ||||||
|   cFemonConfig data; |     virtual eOSState ProcessKey(eKeys Key); | ||||||
|   virtual void Setup(void); |     virtual void Store(void); | ||||||
| protected: |   public: | ||||||
|   virtual eOSState ProcessKey(eKeys Key); |     cMenuFemonSetup(void); | ||||||
|   virtual void Store(void); |  | ||||||
| public: |  | ||||||
|   cMenuFemonSetup(void); |  | ||||||
|   }; |   }; | ||||||
|  |  | ||||||
| #endif //__FEMON_H | #endif //__FEMON_H | ||||||
|   | |||||||
							
								
								
									
										113
									
								
								femoncfg.c
									
									
									
									
									
								
							
							
						
						
									
										113
									
								
								femoncfg.c
									
									
									
									
									
								
							| @@ -6,7 +6,6 @@ | |||||||
|  * $Id$ |  * $Id$ | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #include <string.h> |  | ||||||
| #include "femoncfg.h" | #include "femoncfg.h" | ||||||
|  |  | ||||||
| cFemonConfig femonConfig; | cFemonConfig femonConfig; | ||||||
| @@ -15,122 +14,12 @@ 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; | ||||||
|   updateinterval = 5; |   updateinterval = 5; | ||||||
|   analyzestream  = 1; |   analyzestream  = 1; | ||||||
|   calcinterval   = 20; |   calcinterval   = 20; | ||||||
|  |   syslogoutput   = 0; | ||||||
|   showcasystem   = 0; |   showcasystem   = 0; | ||||||
| #ifdef NTSC |  | ||||||
|   osdheight      = 420; |  | ||||||
| #else |  | ||||||
|   osdheight      = 480; |  | ||||||
| #endif |  | ||||||
|   osdoffset      = 0; |  | ||||||
|   usesvdrp       = 0; |  | ||||||
|   svdrpport      = 2001; |  | ||||||
|   strncpy(svdrpip, "0.0.0.0", sizeof(svdrpip)); |  | ||||||
| } | } | ||||||
|  |  | ||||||
| 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 |  | ||||||
|   }, |  | ||||||
|   { |  | ||||||
|     // eFemonThemeSilverGreen |  | ||||||
|     4,          // bpp |  | ||||||
|     0xD9526470, // clrBackground |  | ||||||
|     0xD9293841, // clrTitleBackground |  | ||||||
|     0xFFB3BDCA, // clrTitleText |  | ||||||
|     0xFFCE7B00, // clrActiveText |  | ||||||
|     0xFFB3BDCA, // clrInactiveText |  | ||||||
|     0xFF992900, // clrRed |  | ||||||
|     0xFFCE7B00, // clrYellow |  | ||||||
|     0xFF336600, // clrGreen |  | ||||||
|   }, |  | ||||||
| }; |  | ||||||
|   | |||||||
							
								
								
									
										60
									
								
								femoncfg.h
									
									
									
									
									
								
							
							
						
						
									
										60
									
								
								femoncfg.h
									
									
									
									
									
								
							| @@ -9,16 +9,13 @@ | |||||||
| #ifndef __FEMONCFG_H | #ifndef __FEMONCFG_H | ||||||
| #define __FEMONCFG_H | #define __FEMONCFG_H | ||||||
|  |  | ||||||
| #define MaxSvdrpIp 15 // xxx.xxx.xxx.xxx | enum dispModes { | ||||||
|  |   modeBasic, | ||||||
| enum eFemonModes |   modeTransponder, | ||||||
| { |   modeStream, | ||||||
|   eFemonModeBasic, |   modeAC3, | ||||||
|   eFemonModeTransponder, |   modeMaxNumber | ||||||
|   eFemonModeStream, |   }; | ||||||
|   eFemonModeAC3, |  | ||||||
|   eFemonModeMaxNumber |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| struct cFemonConfig | struct cFemonConfig | ||||||
| { | { | ||||||
| @@ -26,57 +23,16 @@ 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; | ||||||
|   int updateinterval; |   int updateinterval; | ||||||
|   int analyzestream; |   int analyzestream; | ||||||
|   int calcinterval; |   int calcinterval; | ||||||
|  |   int syslogoutput; | ||||||
|   int showcasystem; |   int showcasystem; | ||||||
|   int osdheight; |  | ||||||
|   int osdoffset; |  | ||||||
|   int usesvdrp; |  | ||||||
|   int svdrpport; |  | ||||||
|   char svdrpip[MaxSvdrpIp + 1]; // must end with additional null |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| extern cFemonConfig femonConfig; | extern cFemonConfig femonConfig; | ||||||
|  |  | ||||||
| enum eFemonSkins |  | ||||||
| { |  | ||||||
|   eFemonSkinClassic, |  | ||||||
|   eFemonSkinElchi, |  | ||||||
|   eFemonSkinMaxNumber |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| enum eFemonThemes |  | ||||||
| { |  | ||||||
|   eFemonThemeClassic, |  | ||||||
|   eFemonThemeElchi, |  | ||||||
|   eFemonThemeDeepBlue, |  | ||||||
|   eFemonThemeMoronimo, |  | ||||||
|   eFemonThemeEnigma, |  | ||||||
|   eFemonThemeEgalsTry, |  | ||||||
|   eFemonThemeDuotone, |  | ||||||
|   eFemonThemeSilverGreen, |  | ||||||
|   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 | ||||||
|   | |||||||
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										1457
									
								
								femoni18n.c
									
									
									
									
									
								
							
							
						
						
									
										1457
									
								
								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[]; | ||||||
|   | |||||||
							
								
								
									
										1320
									
								
								femonosd.c
									
									
									
									
									
								
							
							
						
						
									
										1320
									
								
								femonosd.c
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										41
									
								
								femonosd.h
									
									
									
									
									
								
							
							
						
						
									
										41
									
								
								femonosd.h
									
									
									
									
									
								
							| @@ -15,67 +15,42 @@ | |||||||
| #include <vdr/osd.h> | #include <vdr/osd.h> | ||||||
| #include <vdr/thread.h> | #include <vdr/thread.h> | ||||||
| #include <vdr/status.h> | #include <vdr/status.h> | ||||||
| #include <vdr/plugin.h> |  | ||||||
| #include <vdr/channels.h> | #include <vdr/channels.h> | ||||||
| #include <vdr/transfer.h> | #include <vdr/font.h> | ||||||
| #include <vdr/tools.h> |  | ||||||
| #include "svdrpservice.h" |  | ||||||
|  |  | ||||||
| #define MAX_BM_NUMBER 5 |  | ||||||
|  |  | ||||||
| class cFemonOsd : public cOsdObject, public cThread, public cStatus { | class cFemonOsd : public cOsdObject, public cThread, public cStatus { | ||||||
| private: | private: | ||||||
|   enum { MAX_BMNUMBERS = 6 }; |   bool m_Active; | ||||||
|   static cFemonOsd *pInstance; |   cOsdBase *m_Osd; | ||||||
|   cOsd *m_Osd; |   tWindowHandle m_InfoWindow; | ||||||
|  |   tWindowHandle m_StatusWindow; | ||||||
|   cFemonReceiver *m_Receiver; |   cFemonReceiver *m_Receiver; | ||||||
|   int m_Frontend; |   int m_Frontend; | ||||||
|   int m_SvdrpFrontend; |  | ||||||
|   double m_SvdrpVideoBitrate; |  | ||||||
|   double m_SvdrpAudioBitrate; |  | ||||||
|   SvdrpConnection_v1_0 m_SvdrpConnection; |  | ||||||
|   cPlugin *m_SvdrpPlugin; |  | ||||||
|   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 bmNumbers[MAX_BMNUMBERS]; |  | ||||||
|   static cBitmap bmDevice, bmPAL, bmNTSC, bmSVDRP; |  | ||||||
|   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); | ||||||
|   bool SvdrpConnect(void); |  | ||||||
|   bool SvdrpTune(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 | ||||||
|   | |||||||
							
								
								
									
										142
									
								
								femonreceiver.c
									
									
									
									
									
								
							
							
						
						
									
										142
									
								
								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,17 +16,18 @@ | |||||||
| #define PAYLOAD       0x10 | #define PAYLOAD       0x10 | ||||||
| #define PTS_DTS_FLAGS 0xC0 | #define PTS_DTS_FLAGS 0xC0 | ||||||
|  |  | ||||||
| cFemonReceiver::cFemonReceiver(tChannelID ChannelID, int Ca, int Vpid, int Apid[], int Dpid[]) | cFemonReceiver::cFemonReceiver(int Ca, int Vpid, int Apid, int Dpid) | ||||||
| #if defined(APIVERSNUM) && APIVERSNUM < 10500 | #if VDRVERSNUM >= 10300 | ||||||
| :cReceiver(Ca, -1, Vpid, Apid, Dpid, NULL), cThread("femon receiver") | :cReceiver(Ca, -1, 3, Vpid, Apid, Dpid), cThread("femon receiver") | ||||||
| #else | #else | ||||||
| :cReceiver(ChannelID, -1, Vpid, Apid, Dpid, NULL), cThread("femon receiver") | :cReceiver(Ca, -1, 3, Vpid, Apid, Dpid) | ||||||
| #endif | #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; | ||||||
| @@ -61,18 +61,21 @@ cFemonReceiver::cFemonReceiver(tChannelID ChannelID, int Ca, int Vpid, int Apid[ | |||||||
|   |   | ||||||
| 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; | ||||||
| @@ -145,7 +148,7 @@ void cFemonReceiver::GetVideoInfo(uint8_t *mbuf, int count) | |||||||
|       m_VideoFormat = VF_UNKNOWN; |       m_VideoFormat = VF_UNKNOWN; | ||||||
|       break; |       break; | ||||||
|     } |     } | ||||||
|   m_VideoStreamBitrate = 400.0 * (((headr[4] << 10) & 0x0003FC00UL) | ((headr[5] << 2) & 0x000003FCUL) | (((headr[6] & 0xC0) >> 6) & 0x00000003UL)); |   m_VideoStreamBitrate = 400 * (((headr[4] << 10) & 0x0003FC00UL) | ((headr[5] << 2) & 0x000003FCUL) | (((headr[6] & 0xC0) >> 6) & 0x00000003UL)) / 1000000.0; | ||||||
| } | } | ||||||
|  |  | ||||||
| static unsigned int bitrates[3][16] = | static unsigned int bitrates[3][16] = | ||||||
| @@ -161,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)) | ||||||
| @@ -183,7 +187,7 @@ void cFemonReceiver::GetAudioInfo(uint8_t *mbuf, int count) | |||||||
|   else if (tmp == 0xf) |   else if (tmp == 0xf) | ||||||
|      m_AudioStreamBitrate = (double)FR_RESERVED; |      m_AudioStreamBitrate = (double)FR_RESERVED; | ||||||
|   else |   else | ||||||
|      m_AudioStreamBitrate = tmp; |      m_AudioStreamBitrate = tmp / 1000.0; | ||||||
|   tmp = samplerates[((headr[2] & 0x0c) >> 2)] * 100; |   tmp = samplerates[((headr[2] & 0x0c) >> 2)] * 100; | ||||||
|   if (tmp == 3) |   if (tmp == 3) | ||||||
|      m_AudioSamplingFreq = FR_RESERVED; |      m_AudioSamplingFreq = FR_RESERVED; | ||||||
| @@ -214,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)) | ||||||
| @@ -226,7 +230,7 @@ void cFemonReceiver::GetAC3Info(uint8_t *mbuf, int count) | |||||||
|   m_AC3Valid = true; |   m_AC3Valid = true; | ||||||
|   headr = mbuf + c + 2; |   headr = mbuf + c + 2; | ||||||
|   frame = (headr[2] & 0x3f); |   frame = (headr[2] & 0x3f); | ||||||
|   m_AC3StreamBitrate = ac3_bitrates[frame >> 1] * 1000; |   m_AC3StreamBitrate = ac3_bitrates[frame >> 1]; | ||||||
|   int fr = (headr[2] & 0xc0 ) >> 6; |   int fr = (headr[2] & 0xc0 ) >> 6; | ||||||
|   m_AC3SamplingFreq = ac3_freq[fr] * 100; |   m_AC3SamplingFreq = ac3_freq[fr] * 100; | ||||||
|   m_AC3FrameSize = ac3_frames[fr][frame >> 1]; |   m_AC3FrameSize = ac3_frames[fr][frame >> 1]; | ||||||
| @@ -234,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_AC3SurroundMixLevel = (headr[4] & 0x06) >> 1; |  | ||||||
|         if (m_AC3AudioCodingMode == 0x02) { |  | ||||||
|            // if in 2/0 mode |  | ||||||
|            m_AC3DolbySurroundMode = ((headr[4] & 0x01) << 1) | ((headr[5] & 0x80) >> 7); |  | ||||||
|            m_AC3LfeOn = (headr[5] & 0x40) >> 6; |  | ||||||
|            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; |      m_AC3CenterMixLevel = FR_NOTVALID; | ||||||
|      if (m_AC3AudioCodingMode & 0x04) { |   if (m_AC3AudioCodingMode & 0x04) //  if a surround channel exists | ||||||
|         // a surround channel exists |      m_AC3SurroundMixLevel = (headr[4] & 0x06) >> 1; | ||||||
|         m_AC3SurroundMixLevel = (headr[4] & 0x18) >> 3; |   else | ||||||
|         if (m_AC3AudioCodingMode == 0x02) { |      m_AC3SurroundMixLevel = FR_NOTVALID; | ||||||
|            // if in 2/0 mode |   if (m_AC3AudioCodingMode == 0x02) // if in 2/0 mode | ||||||
|            m_AC3DolbySurroundMode = (headr[4] & 0x06) >> 1; |      m_AC3DolbySurroundMode = ((headr[4] & 1) << 1) | ((headr[5] & 0x80) >> 7); | ||||||
|            m_AC3LfeOn = (headr[4] & 0x01); |   else  | ||||||
|            m_AC3DialogLevel = (headr[5] & 0xF8) >> 3; |      m_AC3DolbySurroundMode = FR_NOTVALID; | ||||||
|            } |   m_AC3LfeOn = (headr[5] & 0x40) >> 6; | ||||||
|         else { |   m_AC3DialogLevel = (headr[5] & 0x3e) >> 1; | ||||||
|            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]); | ||||||
| @@ -354,17 +305,22 @@ 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 = (10.0 * 8.0 * 184.0 * m_VideoPacketCount) / femonConfig.calcinterval; |         m_VideoBitrate = (8.0 * 184.0 * m_VideoPacketCount) / (femonConfig.calcinterval * 100000.0); | ||||||
|         m_VideoPacketCount = 0; |         m_VideoPacketCount = 0; | ||||||
|         m_AudioBitrate = (10.0 * 8.0 * 184.0 * m_AudioPacketCount) / femonConfig.calcinterval; |         m_AudioBitrate = (8.0 * 184.0 * m_AudioPacketCount) / (femonConfig.calcinterval * 100.0); | ||||||
|         m_AudioPacketCount = 0; |         m_AudioPacketCount = 0; | ||||||
|         m_AC3Bitrate   = (10.0 * 8.0 * 184.0 * m_AC3PacketCount)   / femonConfig.calcinterval; |         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 | ||||||
| } | } | ||||||
|   | |||||||
| @@ -47,14 +47,13 @@ enum eDolbySurroundMode { | |||||||
|   DSM_RESERVED          = 3, |   DSM_RESERVED          = 3, | ||||||
|   }; |   }; | ||||||
|  |  | ||||||
| enum eReveiverCodes { | #define FR_RESERVED    -1 | ||||||
|   FR_RESERVED = -1, | #define FR_FREE        -2 | ||||||
|   FR_FREE     = -2, | #define FR_NOTVALID    -3 | ||||||
|   FR_NOTVALID = -3 |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
| 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; | ||||||
| @@ -96,7 +95,7 @@ protected: | |||||||
|   virtual void Action(void); |   virtual void Action(void); | ||||||
|  |  | ||||||
| public: | public: | ||||||
|   cFemonReceiver(tChannelID ChannelID, 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 | ||||||
| @@ -105,19 +104,19 @@ public: | |||||||
|   int VideoAspectRatio(void)      { return m_VideoAspectRatio; };    // eAspectRatio |   int VideoAspectRatio(void)      { return m_VideoAspectRatio; };    // eAspectRatio | ||||||
|   int VideoFormat(void)           { return m_VideoFormat; };         // eVideoFormat |   int VideoFormat(void)           { return m_VideoFormat; };         // eVideoFormat | ||||||
|   double VideoFrameRate(void)     { return m_VideoFrameRate; };      // Hz |   double VideoFrameRate(void)     { return m_VideoFrameRate; };      // Hz | ||||||
|   double VideoStreamBitrate(void) { return m_VideoStreamBitrate; };  // bit/s |   double VideoStreamBitrate(void) { return m_VideoStreamBitrate; };  // Mbit/s | ||||||
|   double VideoBitrate(void)       { return m_VideoBitrate; };        // bit/s |   double VideoBitrate(void)       { return m_VideoBitrate; };        // Mbit/s | ||||||
|  |  | ||||||
|   bool AudioValid(void)           { return m_AudioValid; };          // boolean |   bool AudioValid(void)           { return m_AudioValid; };          // boolean | ||||||
|   int AudioMPEGLayer(void)        { return m_AudioMPEGLayer; };      // layer number |   int AudioMPEGLayer(void)        { return m_AudioMPEGLayer; };      // layer number | ||||||
|   int AudioSamplingFreq(void)     { return m_AudioSamplingFreq; };   // Hz |   int AudioSamplingFreq(void)     { return m_AudioSamplingFreq; };   // Hz | ||||||
|   double AudioStreamBitrate(void) { return m_AudioStreamBitrate; };  // bit/s |   double AudioStreamBitrate(void) { return m_AudioStreamBitrate; };  // kbit/s | ||||||
|   double AudioBitrate(void)       { return m_AudioBitrate; };        // bit/s |   double AudioBitrate(void)       { return m_AudioBitrate; };        // kbit/s | ||||||
|  |  | ||||||
|   bool AC3Valid(void)             { return m_AC3Valid; };                // boolean |   bool AC3Valid(void)             { return m_AC3Valid; };                // boolean | ||||||
|   int AC3SamplingFreq(void)       { return m_AC3SamplingFreq; };         // Hz |   int AC3SamplingFreq(void)       { return m_AC3SamplingFreq; };         // Hz | ||||||
|   double AC3StreamBitrate(void)   { return m_AC3StreamBitrate; };        // bit/s |   double AC3StreamBitrate(void)   { return m_AC3StreamBitrate; };        // kbit/s | ||||||
|   double AC3Bitrate(void)         { return m_AC3Bitrate; };              // bit/s |   double AC3Bitrate(void)         { return m_AC3Bitrate; };              // kbit/s | ||||||
|   int AC3FrameSize(void)          { return m_AC3FrameSize; };            // Bytes |   int AC3FrameSize(void)          { return m_AC3FrameSize; };            // Bytes | ||||||
|   int AC3BitStreamMode(void)      { return m_AC3BitStreamMode; };        // 0..7 |   int AC3BitStreamMode(void)      { return m_AC3BitStreamMode; };        // 0..7 | ||||||
|   int AC3AudioCodingMode(void)    { return m_AC3AudioCodingMode; };      // 0..7 |   int AC3AudioCodingMode(void)    { return m_AC3AudioCodingMode; };      // 0..7 | ||||||
|   | |||||||
| @@ -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 |  | ||||||
|  |  | ||||||
							
								
								
									
										426
									
								
								femontools.c
									
									
									
									
									
								
							
							
						
						
									
										426
									
								
								femontools.c
									
									
									
									
									
								
							| @@ -1,426 +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 "femoni18n.h" |  | ||||||
| #include "femonreceiver.h" |  | ||||||
| #include "femonosd.h" |  | ||||||
| #include "femontools.h" |  | ||||||
|  |  | ||||||
| cString getFrontendInfo(int cardIndex) |  | ||||||
| { |  | ||||||
|   cString info; |  | ||||||
|   struct dvb_frontend_info value; |  | ||||||
|   fe_status_t status; |  | ||||||
|   uint16_t signal = 0; |  | ||||||
|   uint16_t snr = 0; |  | ||||||
|   uint32_t ber = 0; |  | ||||||
|   uint32_t unc = 0; |  | ||||||
|   char *dev = NULL; |  | ||||||
|   cChannel *channel = Channels.GetByNumber(cDevice::CurrentChannel()); |  | ||||||
|  |  | ||||||
|   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_GET_INFO, &value)); |  | ||||||
|   CHECK(ioctl(fe, FE_READ_STATUS, &status)); |  | ||||||
|   CHECK(ioctl(fe, FE_READ_SIGNAL_STRENGTH, &signal)); |  | ||||||
|   CHECK(ioctl(fe, FE_READ_SNR, &snr)); |  | ||||||
|   CHECK(ioctl(fe, FE_READ_BER, &ber)); |  | ||||||
|   CHECK(ioctl(fe, FE_READ_UNCORRECTED_BLOCKS, &unc)); |  | ||||||
|   close(fe); |  | ||||||
|  |  | ||||||
|   info = cString::sprintf("CARD:%d\nTYPE:%d\nNAME:%s\nSTAT:%02X\nSGNL:%04X\nSNRA:%04X\nBERA:%08X\nUNCB:%08X", cardIndex, value.type, value.name, status, signal, snr, ber, unc); |  | ||||||
|  |  | ||||||
|   if (cFemonOsd::Instance()) |  | ||||||
|      info = cString::sprintf("%s\nVIBR:%.0f\nAUBR:%.0f\nDDBR:%.0f", *info, cFemonOsd::Instance()->GetVideoBitrate(), cFemonOsd::Instance()->GetAudioBitrate(), cFemonOsd::Instance()->GetDolbyBitrate()); |  | ||||||
|  |  | ||||||
|   if (channel) |  | ||||||
|      info  = cString::sprintf("%s\nCHAN:%s", *info, *channel->ToText()); |  | ||||||
|  |  | ||||||
|   return info; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| 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; |  | ||||||
|   CHECK(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); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| cString getApids(const cChannel *channel) |  | ||||||
| { |  | ||||||
|   int value = 0; |  | ||||||
|   cString apids = cString::sprintf("%d", channel->Apid(value)); |  | ||||||
|   while (channel->Apid(++value) && (value < MAXAPIDS)) |  | ||||||
|     apids = cString::sprintf("%s, %d", *apids, channel->Apid(value)); |  | ||||||
|   return apids; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| cString getDpids(const cChannel *channel) |  | ||||||
| { |  | ||||||
|   int value = 0; |  | ||||||
|   cString dpids = cString::sprintf("%d", channel->Dpid(value)); |  | ||||||
|   while (channel->Dpid(++value) && (value < MAXDPIDS)) |  | ||||||
|     dpids = cString::sprintf("%s, %d", *dpids, channel->Dpid(value)); |  | ||||||
|   return dpids; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| cString getCAids(const cChannel *channel, bool identify) |  | ||||||
| { |  | ||||||
|   cString caids; |  | ||||||
|   int value = 0; |  | ||||||
|  |  | ||||||
|   if (identify) { |  | ||||||
|      caids = cString::sprintf("%s", *getCA(channel->Ca(value))); |  | ||||||
|      while (channel->Ca(++value) && (value < MAXCAIDS)) |  | ||||||
|        caids = cString::sprintf("%s, %s", *caids, *getCA(channel->Ca(value))); |  | ||||||
|      } |  | ||||||
|   else { |  | ||||||
|      caids = cString::sprintf("%04x", channel->Ca(value)); |  | ||||||
|      while (channel->Ca(++value) && (value < MAXCAIDS)) |  | ||||||
|        caids = cString::sprintf("%s, %04x", *caids, channel->Ca(value)); |  | ||||||
|      } |  | ||||||
|   return caids; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| cString getCA(int value) |  | ||||||
| { |  | ||||||
|   /* http://www.dvb.org/index.php?id=174 */ |  | ||||||
|   switch (value) { |  | ||||||
|     case 0x0000:            return cString::sprintf("%s", tr("Free to Air")); /* Reserved */ |  | ||||||
|     case 0x0001 ... 0x009F: |  | ||||||
|     case 0x00A2 ... 0x00FF: return cString::sprintf("%s", tr("Fixed")); /* Standardized systems */ |  | ||||||
|     case 0x00A0 ... 0x00A1: return cString::sprintf("%s", tr("Analog")); /* Analog signals */ |  | ||||||
|     case 0x0100 ... 0x01FF: return cString::sprintf("%s", tr("SECA/Mediaguard")); /* Canal Plus */ |  | ||||||
|     case 0x0500 ... 0x05FF: return cString::sprintf("%s", tr("Viaccess")); /* France Telecom */ |  | ||||||
|     case 0x0600 ... 0x06FF: return cString::sprintf("%s", tr("Irdeto")); /* Irdeto */ |  | ||||||
|     case 0x0900 ... 0x09FF: return cString::sprintf("%s", tr("NDS/Videoguard")); /* News Datacom */ |  | ||||||
|     case 0x0B00 ... 0x0BFF: return cString::sprintf("%s", tr("Conax")); /* Norwegian Telekom */ |  | ||||||
|     case 0x0D00 ... 0x0DFF: return cString::sprintf("%s", tr("CryptoWorks")); /* Philips */ |  | ||||||
|     case 0x0E00 ... 0x0EFF: return cString::sprintf("%s", tr("PowerVu")); /* Scientific Atlanta */ |  | ||||||
|     case 0x1200 ... 0x12FF: return cString::sprintf("%s", tr("NagraVision")); /* BellVu Express */ |  | ||||||
|     case 0x1700 ... 0x17FF: return cString::sprintf("%s", tr("BetaCrypt")); /* BetaTechnik */ |  | ||||||
|     case 0x1800 ... 0x18FF: return cString::sprintf("%s", tr("NagraVision")); /* Kudelski SA */ |  | ||||||
|     case 0x4A60 ... 0x4A6F: return cString::sprintf("%s", tr("SkyCrypt")); /* @Sky */ |  | ||||||
|     } |  | ||||||
|   return cString::sprintf("%X", value); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| cString getCoderate(int value) |  | ||||||
| { |  | ||||||
|   switch (value) { |  | ||||||
|     case FEC_NONE: return cString::sprintf("%s", tr("None")); |  | ||||||
|     case FEC_1_2:  return cString::sprintf("1/2"); |  | ||||||
|     case FEC_2_3:  return cString::sprintf("2/3"); |  | ||||||
|     case FEC_3_4:  return cString::sprintf("3/4"); |  | ||||||
|     case FEC_4_5:  return cString::sprintf("4/5"); |  | ||||||
|     case FEC_5_6:  return cString::sprintf("5/6"); |  | ||||||
|     case FEC_6_7:  return cString::sprintf("6/7"); |  | ||||||
|     case FEC_7_8:  return cString::sprintf("7/8"); |  | ||||||
|     case FEC_8_9:  return cString::sprintf("8/9"); |  | ||||||
|     case FEC_AUTO: return cString::sprintf("%s", tr("Auto")); |  | ||||||
|     } |  | ||||||
|   return cString::sprintf("---"); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| cString getTransmission(int value) |  | ||||||
| { |  | ||||||
|   switch (value) { |  | ||||||
|     case TRANSMISSION_MODE_2K:   return cString::sprintf("2K"); |  | ||||||
|     case TRANSMISSION_MODE_8K:   return cString::sprintf("8K"); |  | ||||||
|     case TRANSMISSION_MODE_AUTO: return cString::sprintf("%s", tr("Auto")); |  | ||||||
|     } |  | ||||||
|   return cString::sprintf("---"); |  | ||||||
| } |  | ||||||
|   |  | ||||||
| cString getBandwidth(int value) |  | ||||||
| { |  | ||||||
|   switch (value) { |  | ||||||
|     case BANDWIDTH_8_MHZ: return cString::sprintf("8 %s", tr("MHz")); |  | ||||||
|     case BANDWIDTH_7_MHZ: return cString::sprintf("7 %s", tr("MHz")); |  | ||||||
|     case BANDWIDTH_6_MHZ: return cString::sprintf("6 %s", tr("MHz")); |  | ||||||
|     case BANDWIDTH_AUTO:  return cString::sprintf("%s", tr("Auto")); |  | ||||||
|     } |  | ||||||
|   return cString::sprintf("---"); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| cString getInversion(int value) |  | ||||||
| { |  | ||||||
|   switch (value) { |  | ||||||
|     case INVERSION_OFF:  return cString::sprintf("%s", tr("Off")); |  | ||||||
|     case INVERSION_ON:   return cString::sprintf("%s", tr("On")); |  | ||||||
|     case INVERSION_AUTO: return cString::sprintf("%s", tr("Auto")); |  | ||||||
|     } |  | ||||||
|   return cString::sprintf("---"); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| cString getHierarchy(int value) |  | ||||||
| { |  | ||||||
|   switch (value) { |  | ||||||
|     case HIERARCHY_NONE: return cString::sprintf("%s", tr("None")); |  | ||||||
|     case HIERARCHY_1:    return cString::sprintf("1"); |  | ||||||
|     case HIERARCHY_2:    return cString::sprintf("2"); |  | ||||||
|     case HIERARCHY_4:    return cString::sprintf("4"); |  | ||||||
|     case HIERARCHY_AUTO: cString::sprintf("%s", tr("Auto")); |  | ||||||
|     } |  | ||||||
|   return cString::sprintf("---"); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| cString getGuard(int value) |  | ||||||
| { |  | ||||||
|   switch (value) { |  | ||||||
|     case GUARD_INTERVAL_1_32: return cString::sprintf("1/32"); |  | ||||||
|     case GUARD_INTERVAL_1_16: return cString::sprintf("1/16"); |  | ||||||
|     case GUARD_INTERVAL_1_8:  return cString::sprintf("1/8"); |  | ||||||
|     case GUARD_INTERVAL_1_4:  return cString::sprintf("1/4"); |  | ||||||
|     case GUARD_INTERVAL_AUTO: cString::sprintf("%s", tr("Auto")); |  | ||||||
|     } |  | ||||||
|   return cString::sprintf("---"); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| cString getModulation(int value) |  | ||||||
| { |  | ||||||
|   switch (value) { |  | ||||||
|     case QPSK:     return cString::sprintf("QPSK"); |  | ||||||
|     case QAM_16:   return cString::sprintf("QAM 16"); |  | ||||||
|     case QAM_32:   return cString::sprintf("QAM 32"); |  | ||||||
|     case QAM_64:   return cString::sprintf("QAM 64"); |  | ||||||
|     case QAM_128:  return cString::sprintf("QAM 128"); |  | ||||||
|     case QAM_256:  return cString::sprintf("QAM 256"); |  | ||||||
|     case QAM_AUTO: return cString::sprintf("QAM %s", tr("Auto")); |  | ||||||
|     } |  | ||||||
|   return cString::sprintf("---"); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| cString getAspectRatio(int value) |  | ||||||
| { |  | ||||||
|   switch (value) { |  | ||||||
|     case AR_RESERVED: return cString::sprintf("%s", tr("reserved")); |  | ||||||
|     case AR_1_1:      return cString::sprintf("1:1"); |  | ||||||
|     case AR_4_3:      return cString::sprintf("4:3"); |  | ||||||
|     case AR_16_9:     return cString::sprintf("16:9"); |  | ||||||
|     case AR_2_21_1:   return cString::sprintf("2.21:1"); |  | ||||||
|     } |  | ||||||
|   return cString::sprintf("---"); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| cString getVideoFormat(int value) |  | ||||||
| { |  | ||||||
|   switch (value) { |  | ||||||
|     case VF_UNKNOWN: return cString::sprintf("%s", tr("unknown")); |  | ||||||
|     case VF_PAL:     return cString::sprintf("%s", tr("PAL")); |  | ||||||
|     case VF_NTSC:    return cString::sprintf("%s", tr("NTSC")); |  | ||||||
|     } |  | ||||||
|   return cString::sprintf("---"); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| cString getAC3BitStreamMode(int value, int coding) |  | ||||||
| { |  | ||||||
|   switch (value) { |  | ||||||
|     case 0: return cString::sprintf("%s", tr("Complete Main (CM)")); |  | ||||||
|     case 1: return cString::sprintf("%s", tr("Music and Effects (ME)")); |  | ||||||
|     case 2: return cString::sprintf("%s", tr("Visually Impaired (VI)")); |  | ||||||
|     case 3: return cString::sprintf("%s", tr("Hearing Impaired (HI)")); |  | ||||||
|     case 4: return cString::sprintf("%s", tr("Dialogue (D)")); |  | ||||||
|     case 5: return cString::sprintf("%s", tr("Commentary (C)")); |  | ||||||
|     case 6: return cString::sprintf("%s", tr("Emergency (E)")); |  | ||||||
|     case 7: return cString::sprintf("%s", (coding == 1) ? tr("Voice Over (VO)") : tr("Karaoke")); |  | ||||||
|     } |  | ||||||
|   return cString::sprintf("---"); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| cString getAC3AudioCodingMode(int value, int stream) |  | ||||||
| { |  | ||||||
|   if (stream != 7) { |  | ||||||
|      switch (value) { |  | ||||||
|        case 0: return cString::sprintf("1+1 - %s, %s", tr("Ch1"), tr("Ch2")); |  | ||||||
|        case 1: return cString::sprintf("1/0 - %s", tr("C")); |  | ||||||
|        case 2: return cString::sprintf("2/0 - %s, %s", tr("L"), tr("R")); |  | ||||||
|        case 3: return cString::sprintf("3/0 - %s, %s, %s", tr("L"), tr("C"), tr("R")); |  | ||||||
|        case 4: return cString::sprintf("2/1 - %s, %s, %s", tr("L"), tr("R"), tr("S")); |  | ||||||
|        case 5: return cString::sprintf("3/1 - %s, %s, %s, %s", tr("L"), tr("C"), tr("R"), tr("S")); |  | ||||||
|        case 6: return cString::sprintf("2/2 - %s, %s, %s, %s", tr("L"), tr("R"), tr("SL"), tr("SR")); |  | ||||||
|        case 7: return cString::sprintf("3/2 - %s, %s, %s, %s, %s", tr("L"), tr("C"), tr("R"), tr("SL"), tr("SR")); |  | ||||||
|        } |  | ||||||
|      } |  | ||||||
|   return cString::sprintf("---"); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| cString getAC3CenterMixLevel(int value) |  | ||||||
| { |  | ||||||
|   switch (value) { |  | ||||||
|     case CML_MINUS_3dB:   return cString::sprintf("-3.0 %s", tr("dB")); |  | ||||||
|     case CML_MINUS_4_5dB: return cString::sprintf("-4.5 %s", tr("dB")); |  | ||||||
|     case CML_MINUS_6dB:   return cString::sprintf("-6.0 %s", tr("dB")); |  | ||||||
|     case CML_RESERVED:    return cString::sprintf("%s", tr("reserved")); |  | ||||||
|     } |  | ||||||
|   return cString::sprintf("---"); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| cString getAC3SurroundMixLevel(int value) |  | ||||||
| { |  | ||||||
|   switch (value) { |  | ||||||
|     case SML_MINUS_3dB: return cString::sprintf("-3 %s", tr("dB")); |  | ||||||
|     case SML_MINUS_6dB: return cString::sprintf("-6 %s", tr("dB")); |  | ||||||
|     case SML_0_dB:      return cString::sprintf("0 %s", tr("dB")); |  | ||||||
|     case SML_RESERVED:  return cString::sprintf("%s", tr("reserved")); |  | ||||||
|     } |  | ||||||
|   return cString::sprintf("---"); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| cString getAC3DolbySurroundMode(int value) |  | ||||||
| { |  | ||||||
|   switch (value) { |  | ||||||
|     case DSM_NOT_INDICATED:     return cString::sprintf("%s", tr("not indicated")); |  | ||||||
|     case DSM_NOT_DOLBYSURROUND: return cString::sprintf("%s", tr("no")); |  | ||||||
|     case DSM_DOLBYSURROUND:     return cString::sprintf("%s", tr("yes")); |  | ||||||
|     case DSM_RESERVED:          return cString::sprintf("%s", tr("reserved")); |  | ||||||
|     } |  | ||||||
|   return cString::sprintf("---"); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| cString getAC3DialogLevel(int value) |  | ||||||
| { |  | ||||||
|   if (value > 0) |  | ||||||
|      return cString::sprintf("-%d %s", value, tr("dB")); |  | ||||||
|   return cString::sprintf("---"); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| cString getFrequencyMHz(int value) |  | ||||||
| { |  | ||||||
|    while (value > 20000) value /= 1000; |  | ||||||
|    return cString::sprintf("%d %s", value, tr("MHz")); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| cString getAudioSamplingFreq(int value) |  | ||||||
| { |  | ||||||
|   switch (value) { |  | ||||||
|     case FR_NOTVALID: return cString::sprintf("---"); |  | ||||||
|     case FR_RESERVED: return cString::sprintf("%s", tr("reserved")); |  | ||||||
|     } |  | ||||||
|   return cString::sprintf("%.1f %s", ((double)value / 1000.0), tr("kHz")); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| cString getAudioBitrate(double value, double stream) |  | ||||||
| { |  | ||||||
|   switch ((int)stream) { |  | ||||||
|     case FR_NOTVALID: return cString::sprintf("---"); |  | ||||||
|     case FR_RESERVED: return cString::sprintf("%s (%s)", tr("reserved"), *getBitrateKbits(value)); |  | ||||||
|     case FR_FREE:     return cString::sprintf("%s (%s)", tr("free"), *getBitrateKbits(value)); |  | ||||||
|     } |  | ||||||
|   return cString::sprintf("%s (%s)", *getBitrateKbits(stream), *getBitrateKbits(value)); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| cString getBitrateMbits(double value) |  | ||||||
| { |  | ||||||
|   if (value >= 0) |  | ||||||
|      return cString::sprintf("%.2f %s", value / 1000000.0, tr("Mbit/s")); |  | ||||||
|   return cString::sprintf("--- %s", tr("Mbit/s")); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| cString getBitrateKbits(double value) |  | ||||||
| { |  | ||||||
|   if (value >= 0)  |  | ||||||
|      return cString::sprintf("%.0f %s", value / 1000.0, tr("kbit/s")); |  | ||||||
|   return cString::sprintf("--- %s", tr("kbit/s")); |  | ||||||
| } |  | ||||||
							
								
								
									
										59
									
								
								femontools.h
									
									
									
									
									
								
							
							
						
						
									
										59
									
								
								femontools.h
									
									
									
									
									
								
							| @@ -1,59 +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/channels.h> |  | ||||||
| #include <vdr/tools.h> |  | ||||||
|  |  | ||||||
| #ifdef DEBUG |  | ||||||
| #define Dprintf(x...) printf(x); |  | ||||||
| #else |  | ||||||
| #define Dprintf(x...) ; |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #define FRONTEND_DEVICE "/dev/dvb/adapter%d/frontend%d" |  | ||||||
|  |  | ||||||
| cString getFrontendInfo(int cardIndex = 0); |  | ||||||
| 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); |  | ||||||
|  |  | ||||||
| cString getApids(const cChannel *channel); |  | ||||||
| cString getDpids(const cChannel *channel); |  | ||||||
| cString getCAids(const cChannel *channel, bool identify = false); |  | ||||||
| cString getCA(int value); |  | ||||||
| cString getCoderate(int value); |  | ||||||
| cString getTransmission(int value); |  | ||||||
| cString getBandwidth(int value); |  | ||||||
| cString getInversion(int value); |  | ||||||
| cString getHierarchy(int value); |  | ||||||
| cString getGuard(int value); |  | ||||||
| cString getModulation(int value); |  | ||||||
| cString getAspectRatio(int value); |  | ||||||
| cString getVideoFormat(int value); |  | ||||||
| cString getAC3BitStreamMode(int value, int coding); |  | ||||||
| cString getAC3AudioCodingMode(int value, int stream); |  | ||||||
| cString getAC3CenterMixLevel(int value); |  | ||||||
| cString getAC3SurroundMixLevel(int value); |  | ||||||
| cString getAC3DolbySurroundMode(int value); |  | ||||||
| cString getAC3DialogLevel(int value); |  | ||||||
| cString getFrequencyMHz(int value); |  | ||||||
| cString getAudioSamplingFreq(int value); |  | ||||||
| cString getAudioBitrate(double value, double stream); |  | ||||||
| cString getBitrateMbits(double value); |  | ||||||
| cString getBitrateKbits(double value); |  | ||||||
|  |  | ||||||
| #endif // __FEMONTOOLS_H |  | ||||||
| @@ -1,39 +0,0 @@ | |||||||
| /* |  | ||||||
|  * svdrpservice.h: Public interface of the plugin's services |  | ||||||
|  * |  | ||||||
|  * See the README file for copyright information and how to reach the author. |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| #ifndef _SVDRPSERVICE__H |  | ||||||
| #define _SVDRPSERVICE__H |  | ||||||
|  |  | ||||||
| #include <vdr/tools.h> |  | ||||||
|  |  | ||||||
| class cLine: public cListObject { |  | ||||||
| private: |  | ||||||
|   char *Line; |  | ||||||
| public: |  | ||||||
|   const char *Text()   { return Line; } |  | ||||||
|   cLine(const char *s) { Line = s ? strdup(s) : NULL; }; |  | ||||||
|   virtual ~cLine()     { if (Line) free(Line); }; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| struct SvdrpConnection_v1_0 { |  | ||||||
|   // in |  | ||||||
|   cString        serverIp; |  | ||||||
|   unsigned short serverPort; |  | ||||||
|   bool           shared; |  | ||||||
|   // in+out |  | ||||||
|   int            handle; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| struct SvdrpCommand_v1_0 { |  | ||||||
|   // in |  | ||||||
|   cString        command; |  | ||||||
|   int            handle; |  | ||||||
|   // out |  | ||||||
|   cList<cLine>   reply; |  | ||||||
|   unsigned short responseCode; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| #endif //_SVDRPSERVICE__H |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static const char *const ar11_xpm[] = { |  | ||||||
| "26 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "++++++++++++++++++++++++++", |  | ||||||
| "+........................+", |  | ||||||
| "+......++..........++....+", |  | ||||||
| "+...+++++.......+++++....+", |  | ||||||
| "+...+++++.......+++++....+", |  | ||||||
| "+......++...++.....++....+", |  | ||||||
| "+......++...++.....++....+", |  | ||||||
| "+......++..........++....+", |  | ||||||
| "+......++..........++....+", |  | ||||||
| "+......++..........++....+", |  | ||||||
| "+......++..........++....+", |  | ||||||
| "+......++..........++....+", |  | ||||||
| "+......++..........++....+", |  | ||||||
| "+......++..........++....+", |  | ||||||
| "+......++...++.....++....+", |  | ||||||
| "+......++...++.....++....+", |  | ||||||
| "+........................+", |  | ||||||
| "++++++++++++++++++++++++++"}; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static const char *const ar169_xpm[] = { |  | ||||||
| "38 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "+....................................+", |  | ||||||
| "+......++.....++++..........++++.....+", |  | ||||||
| "+...+++++....+++++++.......++++++....+", |  | ||||||
| "+...+++++....++...++......++...+++...+", |  | ||||||
| "+......++...++........++..++....++...+", |  | ||||||
| "+......++...++........++..++....++...+", |  | ||||||
| "+......++...++............++....++...+", |  | ||||||
| "+......++...++.+++.........+++++++...+", |  | ||||||
| "+......++...+++++++.........+++.++...+", |  | ||||||
| "+......++...++....++............++...+", |  | ||||||
| "+......++...++....++............++...+", |  | ||||||
| "+......++...++....++............++...+", |  | ||||||
| "+......++...+++...++......++...++....+", |  | ||||||
| "+......++....++++++...++..+++++++....+", |  | ||||||
| "+......++.....++++....++...+++++.....+", |  | ||||||
| "+....................................+", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++"}; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static const char *const ar2211_xpm[] = { |  | ||||||
| "52 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "+..................................................+", |  | ||||||
| "+.....++++..........++++........++...........++....+", |  | ||||||
| "+...+++++++.......+++++++....+++++........+++++....+", |  | ||||||
| "+...++....++......++....++...+++++........+++++....+", |  | ||||||
| "+.........++............++......++...++......++....+", |  | ||||||
| "+.........++............++......++...++......++....+", |  | ||||||
| "+........+++...........+++......++...........++....+", |  | ||||||
| "+.......+++...........+++.......++...........++....+", |  | ||||||
| "+......+++...........+++........++...........++....+", |  | ||||||
| "+.....+++...........+++.........++...........++....+", |  | ||||||
| "+....+++...........+++..........++...........++....+", |  | ||||||
| "+...+++...........+++...........++...........++....+", |  | ||||||
| "+...++............++............++...........++....+", |  | ||||||
| "+...++++++++..++..++++++++......++...++......++....+", |  | ||||||
| "+...++++++++..++..++++++++......++...++......++....+", |  | ||||||
| "+..................................................+", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++"}; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static const char *const ar43_xpm[] = { |  | ||||||
| "31 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "+++++++++++++++++++++++++++++++", |  | ||||||
| "+.............................+", |  | ||||||
| "+.........++.........+++++....+", |  | ||||||
| "+........+++........+++++++...+", |  | ||||||
| "+.......++++.......++....++...+", |  | ||||||
| "+......++.++...++..++....++...+", |  | ||||||
| "+.....++..++...++........++...+", |  | ||||||
| "+.....++..++............++....+", |  | ||||||
| "+....++...++..........+++.....+", |  | ||||||
| "+...++....++..........++++....+", |  | ||||||
| "+...+++++++++...........+++...+", |  | ||||||
| "+...+++++++++............++...+", |  | ||||||
| "+.........++.......++....++...+", |  | ||||||
| "+.........++.......++...+++...+", |  | ||||||
| "+.........++...++...++++++....+", |  | ||||||
| "+.........++...++....++++.....+", |  | ||||||
| "+.............................+", |  | ||||||
| "+++++++++++++++++++++++++++++++"}; |  | ||||||
| @@ -1,24 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static const char *const carrier_xpm[] = { |  | ||||||
| "96 19 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++...........+++++.......+++++.....++++++++....++++++++....+++...++++++++...++++++++..........++", |  | ||||||
| "++..........+++++++......+++++.....+++++++++...+++++++++...+++...++++++++...+++++++++.........++", |  | ||||||
| "++..........+++.++++.....+++++.....+++...+++...+++...+++...+++...+++........+++...+++.........++", |  | ||||||
| "++.........+++...++.....+++.+++....+++...+++...+++...+++...+++...+++........+++...+++.........++", |  | ||||||
| "++.........+++..........+++.+++....++++++++....++++++++....+++...+++++++....++++++++..........++", |  | ||||||
| "++.........+++..........+++.+++....+++++++.....+++++++.....+++...+++++++....+++++++...........++", |  | ||||||
| "++.........+++.........+++...+++...+++..+++....+++..+++....+++...+++........+++..+++..........++", |  | ||||||
| "++.........+++...++....+++++++++...+++..+++....+++..+++....+++...+++........+++..+++..........++", |  | ||||||
| "++..........+++.++++...+++++++++...+++...+++...+++...+++...+++...+++........+++...+++.........++", |  | ||||||
| "++..........+++++++...+++.....+++..+++...+++...+++...+++...+++...++++++++...+++...+++.........++", |  | ||||||
| "++...........+++++....+++.....+++..+++....+++..+++....+++..+++...++++++++...+++....+++........++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++"}; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static const char *const device_xpm[] = { |  | ||||||
| "14 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "++++++++++++++", |  | ||||||
| "+.............", |  | ||||||
| "+.......+..+..", |  | ||||||
| "+.......+..+..", |  | ||||||
| "+.......+..+..", |  | ||||||
| "+....+++++++++", |  | ||||||
| "+....+++++++++", |  | ||||||
| "+......+..+...", |  | ||||||
| "+......+..+...", |  | ||||||
| "+......+..+...", |  | ||||||
| "+......+..+...", |  | ||||||
| "+...+++++++++.", |  | ||||||
| "+...+++++++++.", |  | ||||||
| "+.....+..+....", |  | ||||||
| "+.....+..+....", |  | ||||||
| "+.....+..+....", |  | ||||||
| "+.............", |  | ||||||
| "++++++++++++++"}; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static const char *const dolbydigital_xpm[] = { |  | ||||||
| "31 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "+++++++++++++++++++++++++++++++", |  | ||||||
| "+.............................+", |  | ||||||
| "+...+++++++++++.+++++++++++...+", |  | ||||||
| "+...++.++++++++.++++++++.++...+", |  | ||||||
| "+...++...++++++.++++++...++...+", |  | ||||||
| "+...++.....++++.++++.....++...+", |  | ||||||
| "+...++......+++.+++......++...+", |  | ||||||
| "+...++.......++.++.......++...+", |  | ||||||
| "+...++.......++.++.......++...+", |  | ||||||
| "+...++.......++.++.......++...+", |  | ||||||
| "+...++.......++.++.......++...+", |  | ||||||
| "+...++......+++.+++......++...+", |  | ||||||
| "+...++.....++++.++++.....++...+", |  | ||||||
| "+...++...++++++.++++++...++...+", |  | ||||||
| "+...++.++++++++.++++++++.++...+", |  | ||||||
| "+...+++++++++++.+++++++++++...+", |  | ||||||
| "+.............................+", |  | ||||||
| "+++++++++++++++++++++++++++++++"}; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static const char *const dolbydigital20_xpm[] = { |  | ||||||
| "55 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "+++++++++++++++++++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "+.....................................................+", |  | ||||||
| "+...+++++++++++.+++++++++++.....++++.........++++.....+", |  | ||||||
| "+...++.++++++++.++++++++.++...+++++++.......++++++....+", |  | ||||||
| "+...++...++++++.++++++...++...++....++......++..++....+", |  | ||||||
| "+...++.....++++.++++.....++.........++.....++....++...+", |  | ||||||
| "+...++......+++.+++......++.........++.....++....++...+", |  | ||||||
| "+...++.......++.++.......++........+++.....++....++...+", |  | ||||||
| "+...++.......++.++.......++.......+++......++....++...+", |  | ||||||
| "+...++.......++.++.......++......+++.......++....++...+", |  | ||||||
| "+...++.......++.++.......++.....+++........++....++...+", |  | ||||||
| "+...++......+++.+++......++....+++.........++....++...+", |  | ||||||
| "+...++.....++++.++++.....++...+++..........++....++...+", |  | ||||||
| "+...++...++++++.++++++...++...++............++..++....+", |  | ||||||
| "+...++.++++++++.++++++++.++...++++++++..++..++++++....+", |  | ||||||
| "+...+++++++++++.+++++++++++...++++++++..++...++++.....+", |  | ||||||
| "+.....................................................+", |  | ||||||
| "+++++++++++++++++++++++++++++++++++++++++++++++++++++++"}; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static const char *const dolbydigital51_xpm[] = { |  | ||||||
| "51 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "+++++++++++++++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "+.................................................+", |  | ||||||
| "+...+++++++++++.+++++++++++...+++++++........++...+", |  | ||||||
| "+...++.++++++++.++++++++.++...+++++++.....+++++...+", |  | ||||||
| "+...++...++++++.++++++...++...++..........+++++...+", |  | ||||||
| "+...++.....++++.++++.....++...++.............++...+", |  | ||||||
| "+...++......+++.+++......++...++++++.........++...+", |  | ||||||
| "+...++.......++.++.......++...+++++++........++...+", |  | ||||||
| "+...++.......++.++.......++...++...+++.......++...+", |  | ||||||
| "+...++.......++.++.......++.........++.......++...+", |  | ||||||
| "+...++.......++.++.......++.........++.......++...+", |  | ||||||
| "+...++......+++.+++......++.........++.......++...+", |  | ||||||
| "+...++.....++++.++++.....++...++....++.......++...+", |  | ||||||
| "+...++...++++++.++++++...++...++...+++.......++...+", |  | ||||||
| "+...++.++++++++.++++++++.++...+++++++...++...++...+", |  | ||||||
| "+...+++++++++++.+++++++++++....+++++....++...++...+", |  | ||||||
| "+.................................................+", |  | ||||||
| "+++++++++++++++++++++++++++++++++++++++++++++++++++"}; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static const char *const five_xpm[] = { |  | ||||||
| "15 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "+++++++++++++++", |  | ||||||
| "..............+", |  | ||||||
| "...+++++++....+", |  | ||||||
| "...+++++++....+", |  | ||||||
| "...++.........+", |  | ||||||
| "...++.........+", |  | ||||||
| "...++.........+", |  | ||||||
| "...++++++.....+", |  | ||||||
| "...+++++++....+", |  | ||||||
| "...++...+++...+", |  | ||||||
| ".........++...+", |  | ||||||
| ".........++...+", |  | ||||||
| "...++....++...+", |  | ||||||
| "...++...+++...+", |  | ||||||
| "...+++++++....+", |  | ||||||
| "....+++++.....+", |  | ||||||
| "..............+", |  | ||||||
| "+++++++++++++++"}; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static const char *const four_xpm[] = { |  | ||||||
| "15 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "+++++++++++++++", |  | ||||||
| "..............+", |  | ||||||
| ".........++...+", |  | ||||||
| "........+++...+", |  | ||||||
| ".......++++...+", |  | ||||||
| "......++.++...+", |  | ||||||
| ".....++..++...+", |  | ||||||
| ".....++..++...+", |  | ||||||
| "....++...++...+", |  | ||||||
| "...++....++...+", |  | ||||||
| "...+++++++++..+", |  | ||||||
| "...+++++++++..+", |  | ||||||
| ".........++...+", |  | ||||||
| ".........++...+", |  | ||||||
| ".........++...+", |  | ||||||
| ".........++...+", |  | ||||||
| "..............+", |  | ||||||
| "+++++++++++++++"}; |  | ||||||
| @@ -1,24 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static const char *const lock_xpm[] = { |  | ||||||
| "96 19 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++........................+++........+++++........+++++.....+++....+++........................++", |  | ||||||
| "++........................+++.......++++++++.....+++++++....+++...+++.........................++", |  | ||||||
| "++........................+++.......+++..+++.....+++.++++...+++..+++..........................++", |  | ||||||
| "++........................+++......+++....+++...+++...++....+++.+++...........................++", |  | ||||||
| "++........................+++......+++....+++...+++.........+++++++...........................++", |  | ||||||
| "++........................+++......+++....+++...+++.........++++.+++..........................++", |  | ||||||
| "++........................+++......+++....+++...+++.........+++..+++..........................++", |  | ||||||
| "++........................+++......+++....+++...+++...++....+++...+++.........................++", |  | ||||||
| "++........................+++.......+++..+++.....+++.++++...+++...+++.........................++", |  | ||||||
| "++........................+++++++...++++++++.....+++++++....+++....+++........................++", |  | ||||||
| "++........................+++++++.....++++........+++++.....+++.....+++.......................++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++"}; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static const char *const monoleft_xpm[] = { |  | ||||||
| "17 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "+++++++++++++++++", |  | ||||||
| "+................", |  | ||||||
| "+...++...........", |  | ||||||
| "+...++++.........", |  | ||||||
| "+...++++++.......", |  | ||||||
| "+...++++++++.....", |  | ||||||
| "+...+++++++++++++", |  | ||||||
| "+...+++++++++++++", |  | ||||||
| "+...+++++++++..++", |  | ||||||
| "+...+++++++++..++", |  | ||||||
| "+...+++++++++++++", |  | ||||||
| "+...+++++++++++++", |  | ||||||
| "+...++++++++.....", |  | ||||||
| "+...++++++.......", |  | ||||||
| "+...++++.........", |  | ||||||
| "+...+++..........", |  | ||||||
| "+................", |  | ||||||
| "+++++++++++++++++"}; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static const char *const monoright_xpm[] = { |  | ||||||
| "17 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "+++++++++++++++++", |  | ||||||
| "+................", |  | ||||||
| "+..............++", |  | ||||||
| "+............++++", |  | ||||||
| "+..........++++++", |  | ||||||
| "+........++++++++", |  | ||||||
| "+...+++++++++++++", |  | ||||||
| "+...+++++++++++++", |  | ||||||
| "+...++..+++++++++", |  | ||||||
| "+...++..+++++++++", |  | ||||||
| "+...+++++++++++++", |  | ||||||
| "+...+++++++++++++", |  | ||||||
| "+........++++++++", |  | ||||||
| "+..........++++++", |  | ||||||
| "+............++++", |  | ||||||
| "+.............+++", |  | ||||||
| "+................", |  | ||||||
| "+++++++++++++++++"}; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static const char *const ntsc_xpm[] = { |  | ||||||
| "19 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "+++++++++++++++++++", |  | ||||||
| "+.................+", |  | ||||||
| "+...++.......++...+", |  | ||||||
| "+...+++......++...+", |  | ||||||
| "+...++++.....++...+", |  | ||||||
| "+...++++.....++...+", |  | ||||||
| "+...++.++....++...+", |  | ||||||
| "+...++..++...++...+", |  | ||||||
| "+...++..++...++...+", |  | ||||||
| "+...++...++..++...+", |  | ||||||
| "+...++...++..++...+", |  | ||||||
| "+...++....++.++...+", |  | ||||||
| "+...++.....++++...+", |  | ||||||
| "+...++.....++++...+", |  | ||||||
| "+...++......+++...+", |  | ||||||
| "+...++.......++...+", |  | ||||||
| "+.................+", |  | ||||||
| "+++++++++++++++++++"}; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static const char *const one_xpm[] = { |  | ||||||
| "15 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "+++++++++++++++", |  | ||||||
| "..............+", |  | ||||||
| ".......++.....+", |  | ||||||
| "....+++++.....+", |  | ||||||
| "....+++++.....+", |  | ||||||
| ".......++.....+", |  | ||||||
| ".......++.....+", |  | ||||||
| ".......++.....+", |  | ||||||
| ".......++.....+", |  | ||||||
| ".......++.....+", |  | ||||||
| ".......++.....+", |  | ||||||
| ".......++.....+", |  | ||||||
| ".......++.....+", |  | ||||||
| ".......++.....+", |  | ||||||
| ".......++.....+", |  | ||||||
| ".......++.....+", |  | ||||||
| "..............+", |  | ||||||
| "+++++++++++++++"}; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static const char *const pal_xpm[] = { |  | ||||||
| "18 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "++++++++++++++++++", |  | ||||||
| "+................+", |  | ||||||
| "+...++++++++.....+", |  | ||||||
| "+...+++++++++....+", |  | ||||||
| "+...++.....+++...+", |  | ||||||
| "+...++......++...+", |  | ||||||
| "+...++......++...+", |  | ||||||
| "+...++.....+++...+", |  | ||||||
| "+...+++++++++....+", |  | ||||||
| "+...++++++++.....+", |  | ||||||
| "+...++...........+", |  | ||||||
| "+...++...........+", |  | ||||||
| "+...++...........+", |  | ||||||
| "+...++...........+", |  | ||||||
| "+...++...........+", |  | ||||||
| "+...++...........+", |  | ||||||
| "+................+", |  | ||||||
| "++++++++++++++++++"}; |  | ||||||
| @@ -1,24 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static const char *const signal_xpm[] = { |  | ||||||
| "96 19 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++.................+++++....+++......+++++.....+++....+++.....+++++.....+++...................++", |  | ||||||
| "++...............++++++++...+++....++++++++....++++...+++.....+++++.....+++...................++", |  | ||||||
| "++...............+++..+++...+++....+++..++++...+++++..+++.....+++++.....+++...................++", |  | ||||||
| "++...............+++........+++...+++....++....+++++..+++....+++.+++....+++...................++", |  | ||||||
| "++...............++++++.....+++...+++..........++++++.+++....+++.+++....+++...................++", |  | ||||||
| "++................++++++....+++...+++..+++++...+++.++.+++....+++.+++....+++...................++", |  | ||||||
| "++..................+++++...+++...+++..+++++...+++.++++++...+++...+++...+++...................++", |  | ||||||
| "++...............+++..+++...+++...+++....+++...+++..+++++...+++++++++...+++...................++", |  | ||||||
| "++...............+++..+++...+++....+++...+++...+++..+++++...+++++++++...+++...................++", |  | ||||||
| "++................++++++....+++....+++++++++...+++...++++..+++.....+++..+++++++...............++", |  | ||||||
| "++.................++++.....+++......+++++.....+++....+++..+++.....+++..+++++++...............++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++"}; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static const char *const stereo_xpm[] = { |  | ||||||
| "17 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "+++++++++++++++++", |  | ||||||
| "+................", |  | ||||||
| "+..............++", |  | ||||||
| "+............++++", |  | ||||||
| "+..........+++.++", |  | ||||||
| "+........+++...++", |  | ||||||
| "+...+++++++....++", |  | ||||||
| "+...++++++.....++", |  | ||||||
| "+...++..++.....++", |  | ||||||
| "+...++..++.....++", |  | ||||||
| "+...++++++.....++", |  | ||||||
| "+...+++++++....++", |  | ||||||
| "+........+++...++", |  | ||||||
| "+..........+++.++", |  | ||||||
| "+............++++", |  | ||||||
| "+.............+++", |  | ||||||
| "+................", |  | ||||||
| "+++++++++++++++++"}; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static const char *const svdrp_xpm[] = { |  | ||||||
| "60 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "+..........................................................+", |  | ||||||
| "+.....+++++....++....++...++++++.....++++++.....++++++.....+", |  | ||||||
| "+....+++++++...++....++...+++++++....+++++++....+++++++....+", |  | ||||||
| "+...+++...++...++....++...++...+++...++...+++...++...+++...+", |  | ||||||
| "+...++....++...++....++...++....++...++....++...++....++...+", |  | ||||||
| "+...++.........++....++...++....++...++....++...++....++...+", |  | ||||||
| "+...+++.........++..++....++....++...++...+++...++...+++...+", |  | ||||||
| "+....+++++......++..++....++....++...+++++++....+++++++....+", |  | ||||||
| "+.....+++++.....++..++....++....++...++++++.....++++++.....+", |  | ||||||
| "+........+++....++..++....++....++...++...++....++.........+", |  | ||||||
| "+.........++.....++++.....++....++...++...++....++.........+", |  | ||||||
| "+...++....++.....++++.....++....++...++...++....++.........+", |  | ||||||
| "+...++...+++......++......++...+++...++....++...++.........+", |  | ||||||
| "+...+++++++.......++......+++++++....++....++...++.........+", |  | ||||||
| "+....+++++........++......++++++.....++....++...++.........+", |  | ||||||
| "+..........................................................+", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++"}; |  | ||||||
| @@ -1,24 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static const char *const sync_xpm[] = { |  | ||||||
| "96 19 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++.........................+++++...+++.....+++..+++....+++.....+++++..........................++", |  | ||||||
| "++.......................++++++++...+++...+++...++++...+++....+++++++.........................++", |  | ||||||
| "++.......................+++..+++....+++.+++....+++++..+++....+++.++++........................++", |  | ||||||
| "++.......................+++.........+++.+++....+++++..+++...+++...++.........................++", |  | ||||||
| "++.......................++++++.......+++++.....++++++.+++...+++..............................++", |  | ||||||
| "++........................++++++......+++++.....+++.++.+++...+++..............................++", |  | ||||||
| "++..........................+++++......+++......+++.++++++...+++..............................++", |  | ||||||
| "++.......................+++..+++......+++......+++..+++++...+++...++.........................++", |  | ||||||
| "++.......................+++..+++......+++......+++..+++++....+++.++++........................++", |  | ||||||
| "++........................++++++.......+++......+++...++++....+++++++.........................++", |  | ||||||
| "++.........................++++........+++......+++....+++.....+++++..........................++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++"}; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static const char *const three_xpm[] = { |  | ||||||
| "15 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "+++++++++++++++", |  | ||||||
| "..............+", |  | ||||||
| ".....+++++....+", |  | ||||||
| "....+++++++...+", |  | ||||||
| "...++....++...+", |  | ||||||
| "...++....++...+", |  | ||||||
| ".........++...+", |  | ||||||
| "........++....+", |  | ||||||
| "......+++.....+", |  | ||||||
| "......++++....+", |  | ||||||
| "........+++...+", |  | ||||||
| ".........++...+", |  | ||||||
| "...++....++...+", |  | ||||||
| "...++...+++...+", |  | ||||||
| "....++++++....+", |  | ||||||
| ".....++++.....+", |  | ||||||
| "..............+", |  | ||||||
| "+++++++++++++++"}; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static const char *const two_xpm[] = { |  | ||||||
| "15 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "+++++++++++++++", |  | ||||||
| "..............+", |  | ||||||
| ".....++++.....+", |  | ||||||
| "...+++++++....+", |  | ||||||
| "...++....++...+", |  | ||||||
| ".........++...+", |  | ||||||
| ".........++...+", |  | ||||||
| "........+++...+", |  | ||||||
| ".......+++....+", |  | ||||||
| "......+++.....+", |  | ||||||
| ".....+++......+", |  | ||||||
| "....+++.......+", |  | ||||||
| "...+++........+", |  | ||||||
| "...++.........+", |  | ||||||
| "...++++++++...+", |  | ||||||
| "...++++++++...+", |  | ||||||
| "..............+", |  | ||||||
| "+++++++++++++++"}; |  | ||||||
| @@ -1,24 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static const char *const viterbi_xpm[] = { |  | ||||||
| "96 19 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++............+++.....+++..+++...+++++++++..++++++++...++++++++....++++++++....+++............++", |  | ||||||
| "++.............++.....++...+++...+++++++++..++++++++...+++++++++...+++++++++...+++............++", |  | ||||||
| "++.............+++...+++...+++......+++.....+++........+++...+++...+++...+++...+++............++", |  | ||||||
| "++.............+++...+++...+++......+++.....+++........+++...+++...+++...+++...+++............++", |  | ||||||
| "++..............++...++....+++......+++.....+++++++....++++++++....++++++++....+++............++", |  | ||||||
| "++..............+++.+++....+++......+++.....+++++++....+++++++.....++++++++....+++............++", |  | ||||||
| "++..............+++.+++....+++......+++.....+++........+++..+++....+++...+++...+++............++", |  | ||||||
| "++...............++.++.....+++......+++.....+++........+++..+++....+++...+++...+++............++", |  | ||||||
| "++...............+++++.....+++......+++.....+++........+++...+++...+++...+++...+++............++", |  | ||||||
| "++...............+++++.....+++......+++.....++++++++...+++...+++...+++++++++...+++............++", |  | ||||||
| "++................+++......+++......+++.....++++++++...+++....+++..++++++++....+++............++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++............................................................................................++", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++", |  | ||||||
| "++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++"}; |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| /* XPM */ |  | ||||||
| static const char *const zero_xpm[] = { |  | ||||||
| "15 18 2 1", |  | ||||||
| ".	c #FFFFFF", |  | ||||||
| "+	c #000000", |  | ||||||
| "+++++++++++++++", |  | ||||||
| "..............+", |  | ||||||
| ".....++++.....+", |  | ||||||
| "....++++++....+", |  | ||||||
| "....++..++....+", |  | ||||||
| "...++....++...+", |  | ||||||
| "...++....++...+", |  | ||||||
| "...++....++...+", |  | ||||||
| "...++....++...+", |  | ||||||
| "...++....++...+", |  | ||||||
| "...++....++...+", |  | ||||||
| "...++....++...+", |  | ||||||
| "...++....++...+", |  | ||||||
| "....++..++....+", |  | ||||||
| "....++++++....+", |  | ||||||
| ".....++++.....+", |  | ||||||
| "..............+", |  | ||||||
| "+++++++++++++++"}; |  | ||||||
		Reference in New Issue
	
	Block a user