blob: c25eb37260323a713fe113f41dd8cd659d2a1a49 (
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
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
|
/*********
*
* This file is part of BibleTime's source code, http://www.bibletime.info/.
*
* Copyright 1999-2008 by the BibleTime developers.
* The BibleTime source code is licensed under the GNU General Public License version 2.0.
*
**********/
#ifndef CSWORDBIBLEMODULEINFO_H
#define CSWORDBIBLEMODULEINFO_H
#include "cswordmoduleinfo.h"
#include "backend/keys/cswordversekey.h"
//Qt
#include <QStringList>
/**
* This is the CModuleInfo imlementation for Bible modules managed by Sword.
*
* @short Implementation for Sword Bibles
* @author The BibleTime team
* @version $Id: cswordbiblemoduleinfo.h,v 1.18 2006/02/25 11:38:15 joachim Exp $
*/
class CSwordBibleModuleInfo : public CSwordModuleInfo {
public:
enum Testament {
OldTestament = 1,
NewTestament = 2
};
/**
* The constructor of this class
*/
CSwordBibleModuleInfo( sword::SWModule* module, CSwordBackend* const );
/** The copy constructor for this Bible module.
*/
CSwordBibleModuleInfo( const CSwordBibleModuleInfo& m );
/**
* The destructor of this class
*/
~CSwordBibleModuleInfo();
/**
* Returns the number of avalable verses for the given chapter and book.
*
* @param book The number book we should use
* @param chapter The chapter we should use
* @return The number of verses for the given book and chapter
*/
virtual unsigned int verseCount( const unsigned int book, const unsigned int chapter );
/**
* Returns the number of avalable verses for the given chapter and book.
*
* @param book The name of the book we use
* @param chapter The number of the chapter we use
* @return The number of verses for the given book and chapter
*/
virtual unsigned int verseCount( const QString& book, const unsigned int chapter );
/** Information about the chapters in a book.
* @return The number of available chapters of the given book.
* @return The number of chapters for the given book
*/
virtual unsigned int chapterCount( const unsigned int book );
/** Information about the chapters in a book.
* @return The number of available chapters of the given book.
*/
virtual unsigned int chapterCount( const QString& book );
/** Return all book of this module.
* @return A QStringList containing the books which are available in this module.
*/
virtual QStringList* books();
/**
* Reimplementation, Returns the type
*/
virtual CSwordModuleInfo::ModuleType type() const;
/**
* @return the book number, values starting with 1; 0 if not found
*/
unsigned int bookNumber(const QString &book);
/**
* Returns true if his module has the text of desired type of testament
*/
bool hasTestament( CSwordBibleModuleInfo::Testament );
/** Reimplementation to clone this object. */
virtual CSwordModuleInfo* clone();
/**
* Returns the key which represents the lower bound of this module.
*/
inline const CSwordVerseKey& lowerBound();
/**
* Returns the key which represents the upper bound of this module.
*/
inline const CSwordVerseKey& upperBound();
private:
void initBounds();
CSwordVerseKey m_lowerBound;
CSwordVerseKey m_upperBound;
QStringList* m_bookList; //This booklist is cached
QString m_cachedLocale;
short int m_hasOT;
short int m_hasNT;
};
inline CSwordModuleInfo::ModuleType CSwordBibleModuleInfo::type() const {
return CSwordModuleInfo::Bible;
}
/** Returns the key which represents the lower bound of this module. */
inline const CSwordVerseKey& CSwordBibleModuleInfo::lowerBound() {
initBounds();
return m_lowerBound;
}
/** Returns the key which represents the lower bound of this module. */
inline const CSwordVerseKey& CSwordBibleModuleInfo::upperBound() {
initBounds();
return m_upperBound;
}
#endif
|