X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/32e4324b9b5e615a84885b9132505e4706ededfe..e09118574a32038b352e01a2ed085175406778d7:/lib/service/listboxservice.h diff --git a/lib/service/listboxservice.h b/lib/service/listboxservice.h index 4e5a8dd5..1d5dc2a2 100644 --- a/lib/service/listboxservice.h +++ b/lib/service/listboxservice.h @@ -3,29 +3,32 @@ #include #include - #include +class eEPGCache; + class eListboxServiceContent: public virtual iListboxContent { DECLARE_REF(eListboxServiceContent); + eEPGCache *epgcache; public: eListboxServiceContent(); void setRoot(const eServiceReference &ref); void getCurrent(eServiceReference &ref); - + /* support for marked services */ void initMarked(); void addMarked(const eServiceReference &ref); void removeMarked(const eServiceReference &ref); int isMarked(const eServiceReference &ref); - + /* this is NOT thread safe! */ void markedQueryStart(); int markedQueryNext(eServiceReference &ref); int lookupService(const eServiceReference &ref); - + void setCurrent(const eServiceReference &ref); + enum { visModeSimple, visModeComplex @@ -35,9 +38,9 @@ public: /* only in complex mode: */ enum { - celServiceName, - celServiceNumber, celIcon, + celServiceNumber, + celServiceName, celServiceInfo, // "now" event celElements }; @@ -46,7 +49,10 @@ public: void setElementFont(int element, gFont *font); void sort(); - + + int setCurrentMarked(bool); + + void setNumberOffset(int offset) { m_numberoffset = offset; } protected: void cursorHome(); void cursorEnd(); @@ -54,7 +60,7 @@ protected: int cursorValid(); int cursorSet(int n); int cursorGet(); - + void cursorSave(); void cursorRestore(); int size(); @@ -82,11 +88,15 @@ private: ePtr m_service_center; eServiceReference m_root; - + /* support for marked services */ std::set m_marked; - std::set::const_iterator m_marked_iterator; + + /* support for movemode */ + bool m_current_marked; + + int m_numberoffset; }; #endif