blob: 66dcd4e9c9be64c85d06244b7d9e5b9247cf0b4d (
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
|
/*
* Copyright 2006 The Android Open Source Project
*
* Use of this source code is governed by a BSD-style license that can be
* found in the LICENSE file.
*/
#include "SkSVGElements.h"
#include "SkSVGParser.h"
SkSVGBase::~SkSVGBase() {
}
void SkSVGBase::addAttribute(SkSVGParser& parser, int attrIndex,
const char* attrValue, size_t attrLength) {
SkString* first = (SkString*) ((char*) this + sizeof(SkSVGElement));
first += attrIndex;
first->set(attrValue, attrLength);
}
SkSVGElement::SkSVGElement() : fParent(NULL), fIsDef(false), fIsNotDef(true) {
}
SkSVGElement::~SkSVGElement() {
}
SkSVGElement* SkSVGElement::getGradient() {
return NULL;
}
bool SkSVGElement::isGroupParent() {
SkSVGElement* parent = fParent;
while (parent) {
if (parent->getType() != SkSVGType_G)
return false;
parent = parent->fParent;
}
return true;
}
bool SkSVGElement::isDef() {
return isGroupParent() == false ? fParent->isDef() : fIsDef;
}
bool SkSVGElement::isFlushable() {
return true;
}
bool SkSVGElement::isGroup() {
return false;
}
bool SkSVGElement::isNotDef() {
return isGroupParent() == false ? fParent->isNotDef() : fIsNotDef;
}
bool SkSVGElement::onEndElement(SkSVGParser& parser) {
if (f_id.size() > 0)
parser.getIDs().set(f_id.c_str(), f_id.size(), this);
return false;
}
bool SkSVGElement::onStartElement(SkSVGElement* child) {
*fChildren.append() = child;
return false;
}
void SkSVGElement::translate(SkSVGParser& parser, bool) {
if (f_id.size() > 0)
SVG_ADD_ATTRIBUTE(id);
}
void SkSVGElement::setIsDef() {
fIsDef = isDef();
}
//void SkSVGElement::setIsNotDef() {
// fIsNotDef = isNotDef();
//}
void SkSVGElement::write(SkSVGParser& , SkString& ) {
SkASSERT(0);
}
|