203 lines
7.1 KiB
C
Raw Normal View History

2013-07-09 00:17:42 +02:00
/* -*- c++ -*-
Copyright (C) 2004-2013 Christian Wieninger
2013-05-26 17:44:04 +02:00
This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License
as published by the Free Software Foundation; either version 2
of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
Or, point your browser to http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
The author can be reached at cwieninger@gmx.de
The project's page is at http://winni.vdr-developer.org/epgsearch
*/
#ifndef EPGSEARCHSERVICES_INC
#define EPGSEARCHSERVICES_INC
#include <string>
#include <list>
#include <memory>
#include <set>
#include <vdr/osdbase.h>
// Data structure for service "Epgsearch-search-v1.0"
2019-03-23 15:55:42 +01:00
struct Epgsearch_search_v1_0 {
2013-05-26 17:44:04 +02:00
// in
2019-03-23 15:55:42 +01:00
char* query; // search term
int mode; // search mode (0=phrase, 1=and, 2=or, 3=regular expression)
int channelNr; // channel number to search in (0=any)
bool useTitle; // search in title
bool useSubTitle; // search in subtitle
bool useDescription; // search in description
2013-05-26 17:44:04 +02:00
// out
2019-03-23 15:55:42 +01:00
cOsdMenu* pResultMenu; // pointer to the menu of results
2013-05-26 17:44:04 +02:00
};
// Data structure for service "Epgsearch-exttimeredit-v1.0"
2019-03-23 15:55:42 +01:00
struct Epgsearch_exttimeredit_v1_0 {
2013-05-26 17:44:04 +02:00
// in
2019-03-23 15:55:42 +01:00
cTimer* timer; // pointer to the timer to edit
bool bNew; // flag that indicates, if this is a new timer or an existing one
const cEvent* event; // pointer to the event corresponding to this timer (may be NULL)
2013-05-26 17:44:04 +02:00
// out
2019-03-23 15:55:42 +01:00
cOsdMenu* pTimerMenu; // pointer to the menu of results
2013-05-26 17:44:04 +02:00
};
2013-07-09 00:17:42 +02:00
// Data structure for service "Epgsearch-enablesearchtimers-v1.0"
2019-03-23 15:55:42 +01:00
struct Epgsearch_enablesearchtimers_v1_0 {
2013-07-09 00:17:42 +02:00
// in
2019-03-23 15:55:42 +01:00
bool enable; // enable search timer thread?
2013-07-09 00:17:42 +02:00
};
2013-05-26 17:44:04 +02:00
// Data structure for service "Epgsearch-updatesearchtimers-v1.0"
2019-03-23 15:55:42 +01:00
struct Epgsearch_updatesearchtimers_v1_0 {
2013-05-26 17:44:04 +02:00
// in
2019-03-23 15:55:42 +01:00
bool showMessage; // inform via osd when finished?
2013-05-26 17:44:04 +02:00
};
// Data structure for service "Epgsearch-osdmessage-v1.0"
2019-03-23 15:55:42 +01:00
struct Epgsearch_osdmessage_v1_0 {
2013-05-26 17:44:04 +02:00
// in
2019-03-23 15:55:42 +01:00
char* message; // the message to display
eMessageType type;
2013-05-26 17:44:04 +02:00
};
// Data structure for service "EpgsearchMenu-v1.0"
2019-03-23 15:55:42 +01:00
struct EpgSearchMenu_v1_0 {
2013-05-26 17:44:04 +02:00
// in
// out
2019-03-23 15:55:42 +01:00
cOsdMenu* Menu; // pointer to the menu
2013-05-26 17:44:04 +02:00
};
// Data structure for service "Epgsearch-lastconflictinfo-v1.0"
2019-03-23 15:55:42 +01:00
struct Epgsearch_lastconflictinfo_v1_0 {
2013-05-26 17:44:04 +02:00
// in
// out
2019-03-23 15:55:42 +01:00
time_t nextConflict; // next conflict date, 0 if none
int relevantConflicts; // number of relevant conflicts
int totalConflicts; // total number of conflicts
2013-05-26 17:44:04 +02:00
};
// Data structure for service "Epgsearch-searchresults-v1.0"
2019-03-23 15:55:42 +01:00
struct Epgsearch_searchresults_v1_0 {
2013-05-26 17:44:04 +02:00
// in
2019-03-23 15:55:42 +01:00
char* query; // search term
int mode; // search mode (0=phrase, 1=and, 2=or, 3=regular expression)
int channelNr; // channel number to search in (0=any)
bool useTitle; // search in title
bool useSubTitle; // search in subtitle
bool useDescription; // search in description
2013-05-26 17:44:04 +02:00
// out
2019-03-23 15:55:42 +01:00
class cServiceSearchResult : public cListObject
{
public:
const cEvent* event;
cServiceSearchResult(const cEvent* Event) : event(Event) {}
};
2013-05-26 17:44:04 +02:00
2019-03-23 15:55:42 +01:00
cList<cServiceSearchResult>* pResultList; // pointer to the results
2013-05-26 17:44:04 +02:00
};
// Data structure for service "Epgsearch-switchtimer-v1.0"
2019-03-23 15:55:42 +01:00
struct Epgsearch_switchtimer_v1_0 {
2013-05-26 17:44:04 +02:00
// in
2019-03-23 15:55:42 +01:00
const cEvent* event;
int mode; // mode (0=query existence, 1=add/modify, 2=delete)
2013-05-26 17:44:04 +02:00
// in/out
2019-03-23 15:55:42 +01:00
int switchMinsBefore;
int announceOnly;
2013-07-09 00:17:42 +02:00
// out
2019-03-23 15:55:42 +01:00
bool success; // result
2013-05-26 17:44:04 +02:00
};
// Data structures for service "Epgsearch-services-v1.0"
class cServiceHandler
{
2019-03-23 15:55:42 +01:00
public:
virtual std::list<std::string> SearchTimerList() = 0;
// returns a list of search timer entries in the same format as used in epgsearch.conf
virtual int AddSearchTimer(const std::string&) = 0;
// adds a new search timer and returns its ID (-1 on error)
virtual bool ModSearchTimer(const std::string&) = 0;
// edits an existing search timer and returns success
virtual bool DelSearchTimer(int) = 0;
// deletes search timer with given ID and returns success
virtual std::list<std::string> QuerySearchTimer(int) = 0;
// returns the search result of the searchtimer with given ID in the same format as used in SVDRP command 'QRYS' (->MANUAL)
virtual std::list<std::string> QuerySearch(std::string) = 0;
// returns the search result of the searchtimer with given settings in the same format as used in SVDRP command 'QRYS' (->MANUAL)
virtual std::list<std::string> ExtEPGInfoList() = 0;
// returns a list of extended EPG categories in the same format as used in epgsearchcats.conf
virtual std::list<std::string> ChanGrpList() = 0;
// returns a list of channel groups maintained by epgsearch
virtual std::list<std::string> BlackList() = 0;
// returns a list of blacklists in the same format as used in epgsearchblacklists.conf
virtual std::set<std::string> DirectoryList() = 0;
// List of all recording directories used in recordings, timers, search timers or in epgsearchdirs.conf
virtual ~cServiceHandler() {}
// Read a setup value
virtual std::string ReadSetupValue(const std::string& entry) = 0;
// Write a setup value
virtual bool WriteSetupValue(const std::string& entry, const std::string& value) = 0;
2013-05-26 17:44:04 +02:00
};
2019-03-23 15:55:42 +01:00
struct Epgsearch_services_v1_0 {
2013-05-26 17:44:04 +02:00
// in/out
2019-04-07 18:27:53 +02:00
#if __cplusplus < 201103L
std::auto_ptr<cServiceHandler> handler;
#else
2019-03-23 15:55:42 +01:00
std::unique_ptr<cServiceHandler> handler;
2019-04-07 18:27:53 +02:00
#endif
2013-05-26 17:44:04 +02:00
};
2013-07-09 00:17:42 +02:00
// Data structures for service "Epgsearch-services-v1.1"
class cServiceHandler_v1_1 : public cServiceHandler
{
2019-03-23 15:55:42 +01:00
public:
// Get timer conflicts
virtual std::list<std::string> TimerConflictList(bool relOnly = false) = 0;
// Check if a conflict check is advised
virtual bool IsConflictCheckAdvised() = 0;
2013-07-09 00:17:42 +02:00
};
2019-03-23 15:55:42 +01:00
struct Epgsearch_services_v1_1 {
2013-07-09 00:17:42 +02:00
// in/out
2019-04-07 18:27:53 +02:00
#if __cplusplus < 201103L
2019-04-09 16:20:50 +02:00
std::auto_ptr<cServiceHandler_v1_1> handler;
2019-04-07 18:27:53 +02:00
#else
2019-03-23 15:55:42 +01:00
std::unique_ptr<cServiceHandler_v1_1> handler;
2019-04-07 18:27:53 +02:00
#endif
2013-07-09 00:17:42 +02:00
};
// Data structures for service "Epgsearch-services-v1.2"
class cServiceHandler_v1_2 : public cServiceHandler_v1_1
{
2019-03-23 15:55:42 +01:00
public:
// List of all recording directories used in recordings, timers (and optionally search timers or in epgsearchdirs.conf)
virtual std::set<std::string> ShortDirectoryList() = 0;
// Evaluate an expression against an event
virtual std::string Evaluate(const std::string& expr, const cEvent* event) = 0;
2013-07-09 00:17:42 +02:00
};
2019-03-23 15:55:42 +01:00
struct Epgsearch_services_v1_2 {
2013-07-09 00:17:42 +02:00
// in/out
2019-04-07 18:27:53 +02:00
#if __cplusplus < 201103L
2019-04-09 16:20:50 +02:00
std::auto_ptr<cServiceHandler_v1_2> handler;
2019-04-07 18:27:53 +02:00
#else
2019-03-23 15:55:42 +01:00
std::unique_ptr<cServiceHandler_v1_2> handler;
2019-04-07 18:27:53 +02:00
#endif
2013-07-09 00:17:42 +02:00
};
2013-05-26 17:44:04 +02:00
#endif