summaryrefslogtreecommitdiffstats
blob: bf134d752361334343a2c7e3004334a71ad2e5f9 (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
/*
 * Copyright (c) 2010 Remko Tronçon
 * Licensed under the GNU General Public License v3.
 * See Documentation/Licenses/GPLv3.txt for more information.
 */

#include "Swiften/Parser/PayloadParsers/SecurityLabelParser.h"
#include "Swiften/Parser/SerializingParser.h"

namespace Swift {

SecurityLabelParser::SecurityLabelParser() : level_(TopLevel), labelParser_(0) {
}

void SecurityLabelParser::handleStartElement(const std::string& element, const std::string& ns, const AttributeMap& attributes) {
	++level_;
	if (level_ == DisplayMarkingOrLabelLevel) {
		if (element == "displaymarking") {
			currentText_ = "";
			getPayloadInternal()->setBackgroundColor(attributes.getAttribute("bgcolor"));
			getPayloadInternal()->setForegroundColor(attributes.getAttribute("fgcolor"));
		}
		else if (element == "label" || element == "equivalentlabel") {
			assert(!labelParser_);
			labelParser_ = new SerializingParser();
		}
	}
	else if (level_ >= SecurityLabelLevel && labelParser_) {
		labelParser_->handleStartElement(element, ns, attributes);
	}
}

void SecurityLabelParser::handleEndElement(const std::string& element, const std::string& ns) {
	if (level_ == DisplayMarkingOrLabelLevel) {
		if (element == "displaymarking") {
			getPayloadInternal()->setDisplayMarking(currentText_);
		}
		else if (labelParser_) {
			if (element == "label") {
				getPayloadInternal()->setLabel(labelParser_->getResult());
			}
			else {
				getPayloadInternal()->addEquivalentLabel(labelParser_->getResult());
			}
			delete labelParser_;
			labelParser_ = 0;
		}
	}
	else if (labelParser_ && level_ >= SecurityLabelLevel) {
		labelParser_->handleEndElement(element, ns);
	}
	--level_;

}

void SecurityLabelParser::handleCharacterData(const std::string& data) {
	if (labelParser_) {
		labelParser_->handleCharacterData(data);
	}
	else {
		currentText_ += data;
	}
}

}