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
|
/*
* This file is part of the XSL implementation.
*
* Copyright (C) 2004, 2007, 2008 Apple, Inc. All rights reserved.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library 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
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public License
* along with this library; see the file COPYING.LIB. If not, write to
* the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
* Boston, MA 02110-1301, USA.
*
*/
#ifndef XSLTProcessor_h
#define XSLTProcessor_h
#include "bindings/core/v8/ScriptWrappable.h"
#include "core/dom/Node.h"
#include "core/xml/XSLStyleSheet.h"
#include "platform/RuntimeEnabledFeatures.h"
#include "wtf/HashMap.h"
#include "wtf/text/StringHash.h"
#include <libxml/parserInternals.h>
#include <libxslt/documents.h>
namespace blink {
class LocalFrame;
class Document;
class DocumentFragment;
class XSLTProcessor final : public GarbageCollectedFinalized<XSLTProcessor>,
public ScriptWrappable {
DEFINE_WRAPPERTYPEINFO();
public:
static XSLTProcessor* create(Document& document) {
DCHECK(RuntimeEnabledFeatures::xsltEnabled());
return new XSLTProcessor(document);
}
~XSLTProcessor();
void setXSLStyleSheet(XSLStyleSheet* styleSheet) {
m_stylesheet = styleSheet;
}
bool transformToString(Node* source,
String& resultMIMEType,
String& resultString,
String& resultEncoding);
Document* createDocumentFromSource(const String& source,
const String& sourceEncoding,
const String& sourceMIMEType,
Node* sourceNode,
LocalFrame*);
// DOM methods
void importStylesheet(Node* style) { m_stylesheetRootNode = style; }
DocumentFragment* transformToFragment(Node* source, Document* ouputDoc);
Document* transformToDocument(Node* source);
void setParameter(const String& namespaceURI,
const String& localName,
const String& value);
String getParameter(const String& namespaceURI,
const String& localName) const;
void removeParameter(const String& namespaceURI, const String& localName);
void clearParameters() { m_parameters.clear(); }
void reset();
static void parseErrorFunc(void* userData, xmlError*);
static void genericErrorFunc(void* userData, const char* msg, ...);
// Only for libXSLT callbacks
XSLStyleSheet* xslStylesheet() const { return m_stylesheet.get(); }
typedef HashMap<String, String> ParameterMap;
DECLARE_TRACE();
private:
XSLTProcessor(Document& document) : m_document(&document) {}
Member<XSLStyleSheet> m_stylesheet;
Member<Node> m_stylesheetRootNode;
Member<Document> m_document;
ParameterMap m_parameters;
};
} // namespace blink
#endif // XSLTProcessor_h
|