diff options
author | Johns <johns98@gmx.net> | 2012-03-08 15:28:10 +0100 |
---|---|---|
committer | Johns <johns98@gmx.net> | 2012-03-08 15:28:10 +0100 |
commit | d65fe88c83020b5dc5211b186989266bc16992e0 (patch) | |
tree | 16f1a80f6c6f7f809b8d1deb17f2bcc6340d2203 /softhddevice.cpp | |
parent | 7d3f4f4434da68c430a55453ce387febdb69fb1e (diff) | |
download | vdr-plugin-softhddevice-d65fe88c83020b5dc5211b186989266bc16992e0.tar.gz vdr-plugin-softhddevice-d65fe88c83020b5dc5211b186989266bc16992e0.tar.bz2 |
Support switching the primary device with svdrp.
Diffstat (limited to 'softhddevice.cpp')
-rw-r--r-- | softhddevice.cpp | 25 |
1 files changed, 19 insertions, 6 deletions
diff --git a/softhddevice.cpp b/softhddevice.cpp index ca0a036..9d498a8 100644 --- a/softhddevice.cpp +++ b/softhddevice.cpp @@ -101,7 +101,7 @@ static int ConfigAutoCropTolerance; ///< auto crop detection tolerance static char ConfigSuspendClose; ///< suspend should close devices static char ConfigSuspendX11; ///< suspend should stop x11 -static volatile char DoMakePrimary; ///< flag switch primary +static volatile int DoMakePrimary; ///< switch primary device to this #define SUSPEND_EXTERNAL -1 ///< play external suspend mode #define SUSPEND_NORMAL 0 ///< normal suspend mode @@ -1421,7 +1421,7 @@ bool cPluginSoftHdDevice::Start(void) // Must be done in the main thread dsyslog("[softhddev] makeing softhddevice %d the primary device!", MyDevice->DeviceNumber()); - DoMakePrimary = 1; + DoMakePrimary = MyDevice->DeviceNumber() + 1; } else { isyslog("[softhddev] softhddevice %d is not the primary device!", MyDevice->DeviceNumber()); @@ -1501,9 +1501,10 @@ void cPluginSoftHdDevice::MainThreadHook(void) { //dsyslog("[softhddev]%s:\n", __FUNCTION__); - if (DoMakePrimary && MyDevice) { - dsyslog("[softhddev]%s: switching primary device\n", __FUNCTION__); - cDevice::SetPrimaryDevice(MyDevice->DeviceNumber() + 1); + if (DoMakePrimary) { + dsyslog("[softhddev]%s: switching primary device to %d\n", + __FUNCTION__, DoMakePrimary); + cDevice::SetPrimaryDevice(DoMakePrimary); DoMakePrimary = 0; } // check if user is inactive, automatic enter suspend mode @@ -1679,7 +1680,8 @@ const char **cPluginSoftHdDevice::SVDRPHelpPages(void) "RESU\n" " Resume plugin.\n", "DETA\n" " Detach plugin.\n", "ATTA\n" " Attach plugin.\n", - "HOTK key\n" " Execute hotkey.\n", + "PRIM\n" " Make primary device.\n" "HOTK key\n" + " Execute hotkey.\n", NULL }; @@ -1756,6 +1758,17 @@ cString cPluginSoftHdDevice::SVDRPCommand(const char *command, HandleHotkey(hotk); return "hot-key executed"; } + if (!strcasecmp(command, "PRIM")) { + int primary; + + primary = strtol(option, NULL, 0); + if (!primary && MyDevice) { + primary = MyDevice->DeviceNumber() + 1; + } + dsyslog("[softhddev] switching primary device to %d\n", primary); + DoMakePrimary = primary; + return "switching primary device requested"; + } return NULL; } |