• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /**
2  * Copyright (C) 2008 Torch Mobile Inc. All rights reserved. (http://www.torchmobile.com/)
3  *
4  * This library is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU Library General Public
6  * License as published by the Free Software Foundation; either
7  * version 2 of the License, or (at your option) any later version.
8  *
9  * This library is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12  * Library General Public License for more details.
13  *
14  * You should have received a copy of the GNU Library General Public License
15  * along with this library; see the file COPYING.LIB.  If not, write to
16  * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
17  * Boston, MA 02110-1301, USA.
18  *
19  */
20 
21 #include "config.h"
22 
23 #if ENABLE(WML)
24 #include "WMLTaskElement.h"
25 
26 #include "WMLAnchorElement.h"
27 #include "WMLDoElement.h"
28 #include "WMLNames.h"
29 #include "WMLOnEventElement.h"
30 #include "WMLPageState.h"
31 #include "WMLSetvarElement.h"
32 
33 namespace WebCore {
34 
35 using namespace WMLNames;
36 
WMLTaskElement(const QualifiedName & tagName,Document * doc)37 WMLTaskElement::WMLTaskElement(const QualifiedName& tagName, Document* doc)
38     : WMLElement(tagName, doc)
39 {
40 }
41 
~WMLTaskElement()42 WMLTaskElement::~WMLTaskElement()
43 {
44 }
45 
insertedIntoDocument()46 void WMLTaskElement::insertedIntoDocument()
47 {
48     WMLElement::insertedIntoDocument();
49 
50     ContainerNode* parent = parentNode();
51     if (!parent || !parent->isWMLElement())
52         return;
53 
54     if (parent->hasTagName(anchorTag))
55         static_cast<WMLAnchorElement*>(parent)->registerTask(this);
56     else if (parent->hasTagName(doTag))
57         static_cast<WMLDoElement*>(parent)->registerTask(this);
58     else if (parent->hasTagName(oneventTag))
59         static_cast<WMLOnEventElement*>(parent)->registerTask(this);
60 }
61 
removedFromDocument()62 void WMLTaskElement::removedFromDocument()
63 {
64     ContainerNode* parent = parentNode();
65     if (parent && parent->isWMLElement()) {
66         if (parent->hasTagName(anchorTag))
67             static_cast<WMLAnchorElement*>(parent)->deregisterTask(this);
68         else if (parent->hasTagName(doTag))
69             static_cast<WMLDoElement*>(parent)->deregisterTask(this);
70         else if (parent->hasTagName(oneventTag))
71             static_cast<WMLOnEventElement*>(parent)->deregisterTask(this);
72     }
73 
74     WMLElement::removedFromDocument();
75 }
76 
registerVariableSetter(WMLSetvarElement * element)77 void WMLTaskElement::registerVariableSetter(WMLSetvarElement* element)
78 {
79     ASSERT(m_variableSetterElements.find(element) == WTF::notFound);
80     m_variableSetterElements.append(element);
81 }
82 
deregisterVariableSetter(WMLSetvarElement * element)83 void WMLTaskElement::deregisterVariableSetter(WMLSetvarElement* element)
84 {
85     size_t position = m_variableSetterElements.find(element);
86     ASSERT(position != WTF::notFound);
87     m_variableSetterElements.remove(position);
88 }
89 
storeVariableState(WMLPageState * pageState)90 void WMLTaskElement::storeVariableState(WMLPageState* pageState)
91 {
92     if (!pageState || m_variableSetterElements.isEmpty())
93         return;
94 
95     WMLVariableMap variables;
96     Vector<WMLSetvarElement*>::iterator it = m_variableSetterElements.begin();
97     Vector<WMLSetvarElement*>::iterator end = m_variableSetterElements.end();
98 
99     for (; it != end; ++it) {
100         WMLSetvarElement* setterElement = (*it);
101 
102         String name = setterElement->name();
103         if (name.isEmpty())
104             continue;
105 
106         String value = setterElement->value();
107         variables.set(name, value);
108 
109         // The next setvar element may depend on this variable value. It's safe to store the current
110         // name value pair in the page state, as the whole page state is replaced soon by this new map
111         pageState->storeVariable(name, value);
112     }
113 
114     pageState->storeVariables(variables);
115 }
116 
117 }
118 
119 #endif
120