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
|
########################################################################
#
# File Name: CopyOfElement.py
#
#
"""
Implementation of the XSLT Spec copy-of element.
WWW: http://4suite.com/4XSLT e-mail: support@4suite.com
Copyright (c) 1999-2000 Fourthought Inc, USA. All Rights Reserved.
See http://4suite.com/COPYRIGHT for license and copyright information
"""
from xml.dom import EMPTY_NAMESPACE
import xml.dom.ext
from xml.dom import Node
import xml.xslt
from xml.xslt import XsltElement, XsltException, Error
from xml.xslt import g_xsltRecognizedNodes
from xml.xpath import XPathParser, Conversions
from xml.dom import XMLNS_NAMESPACE
class CopyOfElement(XsltElement):
legalAttrs = ('select',)
def __init__(self, doc, uri=xml.xslt.XSL_NAMESPACE, localName='copy-of',
prefix='xsl', baseUri=''):
XsltElement.__init__(self, doc, uri, localName, prefix, baseUri)
return
def setup(self):
parser = XPathParser.XPathParser()
self.__dict__['_select'] = self.getAttributeNS(EMPTY_NAMESPACE, 'select')
if not self._select:
raise XsltException(Error.COPYOF_MISSING_SELECT)
self.__dict__['_expr'] = parser.parseExpression(self._select)
self.__dict__['_nss'] = xml.dom.ext.GetAllNs(self)
return
def instantiate(self, context, processor):
origState = context.copy()
context.setNamespaces(self._nss)
expResult = self._expr.evaluate(context)
if hasattr(expResult, "nodeType") and expResult.nodeType in g_xsltRecognizedNodes:
expResult = [expResult]
if type(expResult) == type([]) :
for child in expResult:
self.__copyNode(processor, child)
else:
st = Conversions.StringValue(expResult)
processor.writers[-1].text(st)
context.set(origState)
return (context,)
def __copyNode(self, processor, node):
if node.nodeType == Node.DOCUMENT_NODE:
for child in node.childNodes:
self.__copyNode(processor, child)
if node.nodeType == Node.DOCUMENT_FRAGMENT_NODE:
for child in node.childNodes:
self.__copyNode(processor, child)
if node.nodeType == Node.TEXT_NODE:
processor.writers[-1].text(node.data)
elif node.nodeType == Node.ELEMENT_NODE:
#FIXME: check if its a root element, and copy its children only, as the spec requires
processor.writers[-1].startElement(node.nodeName,node.namespaceURI)
for k in node.attributes.keys():
if k[0] != XMLNS_NAMESPACE:
self.__copyNode(processor, node.attributes[k])
for child in node.childNodes:
self.__copyNode(processor, child)
processor.writers[-1].endElement(node.nodeName)
elif node.nodeType == Node.ATTRIBUTE_NODE:
if node.namespaceURI != XMLNS_NAMESPACE:
processor.writers[-1].attribute(node.name, node.value, node.namespaceURI)
elif node.nodeType == Node.COMMENT_NODE:
processor.writers[-1].comment(node.data)
elif node.nodeType == Node.PROCESSING_INSTRUCTION_NODE:
processor.writers[-1].processingInstruction(node.target, node.data)
else:
pass
return
def __getinitargs__(self):
return (None, self.namespaceURI, self.localName, self.prefix,
self.baseUri)
def __getstate__(self):
base_state = XsltElement.__getstate__(self)
new_state = (base_state, self._nss, self._select, self._expr)
return new_state
def __setstate__(self, state):
XsltElement.__setstate__(self, state[0])
self._nss = state[1]
self._select = state[2]
self._expr = state[3]
return
|