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
127
128
|
/*
* Copyright (C) 2004-2012 Geometer Plus <contact@geometerplus.com>
*
* 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.
*/
#include <ZLUnicodeUtil.h>
#include "HtmlSectionReader.h"
#include "CHMReferenceCollection.h"
#include "CHMFileImage.h"
#include "../util/MiscUtil.h"
#include "../html/HtmlTagActions.h"
class HtmlSectionHrefTagAction : public HtmlHrefTagAction {
public:
HtmlSectionHrefTagAction(HtmlSectionReader &reader);
void run(const HtmlReader::HtmlTag &tag);
};
class HtmlSectionImageTagAction : public HtmlTagAction {
public:
HtmlSectionImageTagAction(HtmlSectionReader &reader);
void run(const HtmlReader::HtmlTag &tag);
};
shared_ptr<HtmlTagAction> HtmlSectionReader::createAction(const std::string &tag) {
if (tag == "IMG") {
return new HtmlSectionImageTagAction(*this);
} else if (tag == "A") {
return new HtmlSectionHrefTagAction(*this);
}
return HtmlBookReader::createAction(tag);
}
HtmlSectionReader::HtmlSectionReader(BookModel &model, const PlainTextFormat &format, const std::string &encoding, shared_ptr<CHMFileInfo> info, CHMReferenceCollection &collection) : HtmlBookReader("", model, format, encoding), myInfo(info), myReferenceCollection(collection) {
setBuildTableOfContent(false);
}
void HtmlSectionReader::setSectionName(const std::string §ionName) {
myCurrentSectionName = ZLUnicodeUtil::toLower(sectionName);
myReferenceCollection.setPrefix(myCurrentSectionName);
}
void HtmlSectionReader::startDocumentHandler() {
HtmlBookReader::startDocumentHandler();
myBookReader.addHyperlinkLabel(ZLUnicodeUtil::toLower(myCurrentSectionName));
}
void HtmlSectionReader::endDocumentHandler() {
HtmlBookReader::endDocumentHandler();
myBookReader.insertEndOfTextParagraph();
}
HtmlSectionHrefTagAction::HtmlSectionHrefTagAction(HtmlSectionReader &reader) : HtmlHrefTagAction(reader) {
}
void HtmlSectionHrefTagAction::run(const HtmlReader::HtmlTag &tag) {
if (tag.Start) {
HtmlSectionReader &reader = (HtmlSectionReader&)myReader;
for (unsigned int i = 0; i < tag.Attributes.size(); ++i) {
if (tag.Attributes[i].Name == "NAME") {
bookReader().addHyperlinkLabel(ZLUnicodeUtil::toLower(reader.myCurrentSectionName + '#' + tag.Attributes[i].Value));
} else if ((hyperlinkType() == REGULAR) && (tag.Attributes[i].Name == "HREF")) {
const std::string &value = tag.Attributes[i].Value;
if (!value.empty()) {
FBTextKind referenceType = MiscUtil::referenceType(value);
if (referenceType != INTERNAL_HYPERLINK) {
bookReader().addHyperlinkControl(referenceType, value);
setHyperlinkType(referenceType);
} else {
const int index = value.find('#');
std::string sectionName = (index == -1) ? value : value.substr(0, index);
sectionName = ZLUnicodeUtil::toLower(MiscUtil::decodeHtmlURL(sectionName));
if (sectionName.empty()) {
sectionName = reader.myCurrentSectionName;
} else {
sectionName = reader.myReferenceCollection.addReference(sectionName, true);
}
bookReader().addHyperlinkControl(
INTERNAL_HYPERLINK, ZLUnicodeUtil::toLower((index == -1) ? sectionName : (sectionName + value.substr(index)))
);
setHyperlinkType(INTERNAL_HYPERLINK);
}
}
}
}
} else if (hyperlinkType() != REGULAR) {
bookReader().addControl(hyperlinkType(), false);
setHyperlinkType(REGULAR);
}
}
HtmlSectionImageTagAction::HtmlSectionImageTagAction(HtmlSectionReader &reader) : HtmlTagAction(reader) {
}
void HtmlSectionImageTagAction::run(const HtmlReader::HtmlTag &tag) {
if (tag.Start) {
//bookReader().endParagraph();
HtmlSectionReader &reader = (HtmlSectionReader&)myReader;
for (unsigned int i = 0; i < tag.Attributes.size(); ++i) {
if (tag.Attributes[i].Name == "SRC") {
std::string fileName = MiscUtil::decodeHtmlURL(tag.Attributes[i].Value);
fileName = CHMReferenceCollection::fullReference(reader.myReferenceCollection.prefix(), fileName);
fileName = ZLUnicodeUtil::toLower(fileName);
bookReader().addImageReference(fileName);
bookReader().addImage(fileName, new CHMFileImage(reader.myInfo, fileName));
break;
}
}
//bookReader().beginParagraph();
}
}
|