From d994dfef2dc15e4683f0219a7528f4abf937f5b4 Mon Sep 17 00:00:00 2001 From: lado Date: Sun, 24 Feb 2013 23:12:09 +0100 Subject: refactor --- vdr-vdrmanager/vdrmanager.cpp | 49 ++++++++++++++++++++----------------- vdr-vdrmanager/vdrmanagerthread.cpp | 18 +++++++------- vdr-vdrmanager/vdrmanagerthread.h | 6 ++--- 3 files changed, 38 insertions(+), 35 deletions(-) diff --git a/vdr-vdrmanager/vdrmanager.cpp b/vdr-vdrmanager/vdrmanager.cpp index 6903081..2b81464 100644 --- a/vdr-vdrmanager/vdrmanager.cpp +++ b/vdr-vdrmanager/vdrmanager.cpp @@ -13,22 +13,23 @@ #include #include "vdrmanagerthread.h" -#define ANDROVDR_PORT 6420 +#define VDRMANAGER_PORT 6420 static const char *VERSION = "0.9"; static const char *DESCRIPTION = "VDR-Manager support plugin"; -class cPluginAndroVdr: public cPlugin { +class cVdrManager: public cPlugin { private: // Add any member variables or functions you may need here. - cAndroVdrThread * Thread; + cVdrManagerThread * Thread; int port; const char * password; bool forceCheckSvdrp; + bool forceDelete; protected: public: - cPluginAndroVdr(void); - virtual ~cPluginAndroVdr(); + cVdrManager(void); + virtual ~cVdrManager(); virtual const char *Version(void) { return VERSION; } @@ -48,37 +49,36 @@ public: virtual bool ProcessArgs(int argc, char *argv[]); }; -cPluginAndroVdr::cPluginAndroVdr(void) { +cVdrManager::cVdrManager(void) { // Initialize any member variables here. // DON'T DO ANYTHING ELSE THAT MAY HAVE SIDE EFFECTS, REQUIRE GLOBAL // VDR OBJECTS TO EXIST OR PRODUCE ANY OUTPUT! Thread = NULL; - port = ANDROVDR_PORT; + port = VDRMANAGER_PORT; password = ""; forceCheckSvdrp = false; + forceDelete = false; } -cPluginAndroVdr::~cPluginAndroVdr() { +cVdrManager::~cVdrManager() { // Clean up after yourself! } -cOsdObject * cPluginAndroVdr::MainMenuAction(void) { +cOsdObject * cVdrManager::MainMenuAction(void) { return NULL; } -cMenuSetupPage * cPluginAndroVdr::SetupMenu(void) { +cMenuSetupPage * cVdrManager::SetupMenu(void) { return NULL; } -const char * cPluginAndroVdr::CommandLineHelp(void) { - return " -p port port number to listen to\n" - " -P password password (none if not given). No password forces check against svdrphosts.conf.\n" - " -s force check against svdrphosts.conf, even if a password was given\n"; +const char * cVdrManager::CommandLineHelp(void) { + return " -p port port number to listen to\n -P password password (none if not given). No password forces check against svdrphosts.conf.\n -s force check against svdrphosts.conf, even if a password was given\n -f force delete of a timer or a recording even if they are active\n"; } -bool cPluginAndroVdr::ProcessArgs(int argc, char *argv[]) { +bool cVdrManager::ProcessArgs(int argc, char *argv[]) { int c; - while ((c = getopt(argc, argv, "p:P:s")) != -1) + while ((c = getopt(argc, argv, "p:P:s:f")) != -1) switch (c) { case 'p': port = atoi(optarg); @@ -89,6 +89,9 @@ bool cPluginAndroVdr::ProcessArgs(int argc, char *argv[]) { case 's': forceCheckSvdrp = true; break; + case 'f': + forceDelete = true; + break; case '?': if (optopt == 'c') { fprintf(stderr, "Option -%c requires an argument.\n", optopt); @@ -103,34 +106,34 @@ bool cPluginAndroVdr::ProcessArgs(int argc, char *argv[]) { // default port if (port <= 0) - port = ANDROVDR_PORT; + port = VDRMANAGER_PORT; return true; } -bool cPluginAndroVdr::Initialize(void) { +bool cVdrManager::Initialize(void) { // Initialize any background activities the plugin shall perform. // Start any background activities the plugin shall perform. - Thread = new cAndroVdrThread(port, password, forceCheckSvdrp); + Thread = new cVdrManagerThread(port, password, forceCheckSvdrp); return Thread != NULL; } -bool cPluginAndroVdr::Start(void) { +bool cVdrManager::Start(void) { Thread->Start(); return true; } -void cPluginAndroVdr::Stop(void) { +void cVdrManager::Stop(void) { // Stop any background activities the plugin shall perform. Thread->Shutdown(); } -void cPluginAndroVdr::Housekeeping(void) { +void cVdrManager::Housekeeping(void) { // Perform any cleanup or other regular tasks. } -VDRPLUGINCREATOR(cPluginAndroVdr); +VDRPLUGINCREATOR(cVdrManager); // Don't touch this! diff --git a/vdr-vdrmanager/vdrmanagerthread.cpp b/vdr-vdrmanager/vdrmanagerthread.cpp index 7c72444..2a4ca64 100644 --- a/vdr-vdrmanager/vdrmanagerthread.cpp +++ b/vdr-vdrmanager/vdrmanagerthread.cpp @@ -8,20 +8,20 @@ #include "select.h" #include "helpers.h" -cAndroVdrThread::cAndroVdrThread(int port, const char * password, bool forceCheckSvdrp) +cVdrManagerThread::cVdrManagerThread(int port, const char * password, bool forceCheckSvdrp) { select = NULL; - this->port = port; - this->password = password; - this->forceCheckSvdrp = forceCheckSvdrp; + this -> port = port; + this -> password = password; + this -> forceCheckSvdrp = forceCheckSvdrp; } -cAndroVdrThread::~cAndroVdrThread() +cVdrManagerThread::~cVdrManagerThread() { Cleanup(); } -void cAndroVdrThread::Action(void) +void cVdrManagerThread::Action(void) { // create listener socket if (!Init()) @@ -34,7 +34,7 @@ void cAndroVdrThread::Action(void) Cleanup(); } -bool cAndroVdrThread::Init() +bool cVdrManagerThread::Init() { // create select select = new cSelect(); @@ -52,12 +52,12 @@ bool cAndroVdrThread::Init() return true; } -void cAndroVdrThread::Cleanup() +void cVdrManagerThread::Cleanup() { if (select) delete select; } -void cAndroVdrThread::Shutdown() +void cVdrManagerThread::Shutdown() { } diff --git a/vdr-vdrmanager/vdrmanagerthread.h b/vdr-vdrmanager/vdrmanagerthread.h index 223f253..83f5f31 100644 --- a/vdr-vdrmanager/vdrmanagerthread.h +++ b/vdr-vdrmanager/vdrmanagerthread.h @@ -16,18 +16,18 @@ using namespace std; class cSelect; -class cAndroVdrThread : public cThread { +class cVdrManagerThread : public cThread { private: cSelect * select; int port; const char * password; bool forceCheckSvdrp; public: - cAndroVdrThread(int port, const char * password, bool forceCheckSvdrp); + cVdrManagerThread(int port, const char * password, bool forceCheckSvdrp); virtual void Action(void); void Shutdown(); private: - virtual ~cAndroVdrThread(); + virtual ~cVdrManagerThread(); void Cleanup(); bool Init(); }; -- cgit v1.2.3