-
Notifications
You must be signed in to change notification settings - Fork 16
/
pagelist.h
113 lines (91 loc) · 3.71 KB
/
pagelist.h
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
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
#ifndef _PAGELIST_H_
#define _PAGELIST_H_
#include <iostream>
#include <string>
#include <dirent.h>
#include <errno.h>
#include <vector>
#include <list>
#include "configure.h"
#include "debug.h"
#include "ttxpagestream.h"
#include "packetmag.h"
namespace ttx
{
/** @brief A PageList maintains the set of all teletext pages in a teletext service
* It can load, save, add, delete, edit pages.
* Internally each magazine has its own list of pages.
*
*/
class PageList
{
public:
/** @brief Create am empty page list
*/
PageList(Configure *configure, vbit::Debug *debug);
~PageList();
/**
* @param filepath Path to pages directory
* @param Return 0 if OK or errno
*/
int LoadPageList(std::string filepath);
vbit::PacketMag **GetMagazines(){vbit::PacketMag **p=_mag;return p;};
/** Return the page object that was loaded from <filename>
* @param filename The filename of the page we are looking for.
*/
TTXPageStream* Locate(std::string filename);
// Probably want a nextPage function to scan using a wildcard
/**
* \brief Match - Find and mark all pages that match the page identity
* \param page - A page identity string
* \return - The number of pages that matched this identity
*/
int Match(char* page);
/** Add a teletext page to the proper magazine
* @param page TTXPageStream object that has already been loaded
*/
void AddPage(TTXPageStream* page);
/** Clear all the exists flags
*/
void ClearFlags();
/** Delete all pages that no longer exist
*/
void DeleteOldPages();
/** \brief Iterate through all pages
* \return Returns the next page or nullptr if we are at the end
*/
TTXPageStream* NextPage();
/** \brief Iterate through all pages
* \return Returns the previous page or nullptr if we are at the beginning
*/
TTXPageStream* PrevPage();
/** \brief Last Page in the selected list
* \return Returns the last selected page or nullptr if there isn't one
*/
TTXPageStream* LastPage();
/** \brief Iterate through selected pages (using the P command)
* \return Returns the next page or nullptr if we are at the end
*/
TTXPageStream* NextSelectedPage();
/** \brief Reset the page iterator to the beginning
* Afterwards repeatedly call NextPage() until it returns nullptr
* \return the initial page or nullptr if there is no page
*/
TTXPageStream* FirstPage();
void CheckForPacket29OrCustomHeader(TTXPageStream* page);
private:
Configure* _configure; // The configuration object
vbit::Debug* _debug;
std::list<TTXPageStream> _pageList[8]; /// The list of Pages in this service. One list per magazine
vbit::PacketMag* _mag[8];
int ReadDirectory(std::string filepath);
/** Get pages of each type into their respective lists
*/
void PopulatePageTypeLists();
// iterators through selected pages. (use the same iterator for D command and MD, L etc.)
uint8_t _iterMag; /// Magazine number for the iterator
std::list<TTXPageStream>::iterator _iter; /// pages in a magazine
TTXPageStream* _iterSubpage; /// Subpages in a carousel
};
}
#endif