summaryrefslogtreecommitdiff
path: root/epg_events.h
blob: 68eb0a4df3d4682d4f5b0e8573182fda2af41b9b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
#ifndef VDR_LIVE_WHATS_ON_H
#define VDR_LIVE_WHATS_ON_H

#include <ctime>
#include <vector>

#include <vdr/plugin.h>
#include <vdr/channels.h>
#include <vdr/epg.h>
#include <vdr/config.h>
#include <vdr/i18n.h>

#include "live.h"
#include "stdext.h"

namespace vdrlive
{
	class EpgEvent
	{
		public:
			EpgEvent(const std::string& id,
					 const std::string& caption,
					 const std::string& title,
					 const std::string& short_descr,
					 const std::string& long_descr,
					 time_t start_time,
					 time_t end_time);

			EpgEvent(const std::string& id,
					 const cEvent* event,
					 const char* channelName = "");

			EpgEvent(const std::string& id,
					 const std::string& caption,
					 const std::string& title,
					 const std::string& short_descr,
					 const std::string& long_descr,
					 const std::string& archived,
					 time_t start_time,
					 time_t end_time);

			virtual ~EpgEvent();

			const std::string& Id() const { return m_eventId; }

			const std::string& Title() const { return m_title; }

			const std::string& Caption() const { return m_caption; }

			const std::string& ShortDescr() const { return m_short_descr; }

			const std::string& LongDescr() const { return m_long_descr; }

			const std::string& Archived() const { return m_archived; }

			const std::string StartTime(const char* format) const;

			const std::string EndTime(const char* format) const;

			const std::string CurrentTime(const char* format) const;

			int Elapsed() const;

			const cTimer* GetTimer() const;

		private:
			std::string m_eventId;
			std::string m_caption;
			std::string m_title;
			std::string m_short_descr;
			std::string m_long_descr;
			std::string m_archived;
			time_t m_start_time;
			time_t m_end_time;
	};

	typedef std::tr1::shared_ptr<EpgEvent> EpgEventPtr;

	class EpgEvents : public std::vector<EpgEventPtr> {
		public:
			EpgEvents();
			virtual ~EpgEvents();

		private:
	};
}; // namespace vdrlive

#endif // VDR_LIVE_WHATS_ON_H