Node class describes syntax of separate XML Node. It have a constructor that
permits node creation from set of "namespace name", attributes and payload
of text strings and other nodes. It does not natively support building node
from text string and uses NodeBuilder class for that purpose. After
creation node can be mangled in many ways so it can be completely changed.
Also node can be serialised into string in one of two modes: default (where
the textual representation of node describes it exactly) and "fancy" - with
whitespace added to make indentation and thus make result more readable by
human.
Node class have attribute FORCE_NODE_RECREATION that is defaults to False
thus enabling fast node replication from the some other node. The drawback
of the fast way is that new node shares some info with the "original" node
that is changing the one node may influence the other. Though it is rarely
needed (in xmpppy it is never needed at all since I'm usually never using
original node after replication (and using replication only to move upwards
on the classes tree).
|
|
|
|
|
|
|
|
|
|
|
|
|
|
__init__(self,
tag=None,
attrs={},
payload=[],
parent=None,
nsp=None,
node_built=False,
node=None)
Takes "tag" argument as the name of node (prepended by namespace, if
needed and separated from it by a space), attrs dictionary as the set of
arguments, payload list as the set of textual strings and child nodes
that this node carries within itself and "parent" argument that is
another node that this one will be the child of. |
source code
|
|
|
|
|
|
|
|
|
|
addChild(self,
name=None,
attrs={},
payload=[],
namespace=None,
node=None)
If "node" argument is provided, adds it as child node. |
source code
|
|
|
|
|
|
|
|
|
|
|
|
|
delChild(self,
node,
attrs={})
Delete the "node" from the node's childs list, if "node" is an instance. |
source code
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
getTag(self,
name,
attrs={},
namespace=None)
Filter all child nodes using specified arguments as filter. |
source code
|
|
|
|
getTagAttr(self,
tag,
attr)
Return attribute value of the child with specified name (or None if no
such attribute) |
source code
|
|
|
|
|
|
|
getTags(self,
name,
attrs={},
namespace=None,
one=0)
Filter all child nodes using specified arguments as filter. |
source code
|
|
|
|
|
|
|
iterTags(self,
name,
attrs={},
namespace=None)
Iterate over all children using specified arguments as filter |
source code
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
setTag(self,
name,
attrs={},
namespace=None)
Same as getTag but if the node with specified namespace/attributes not
found, creates such node and returns it |
source code
|
|
|
|
setTagAttr(self,
tag,
attr,
val)
Create new node (if not already present) with name "tag" and set it's
attribute "attr" to value "val" |
source code
|
|
|
|
setTagData(self,
tag,
val,
attrs={})
Creates new node (if not already present) with name "tag" and
(optionally) attributes "attrs" and sets it's CDATA to string "val" |
source code
|
|
|
Inherited from object:
__delattr__,
__getattribute__,
__hash__,
__new__,
__reduce__,
__reduce_ex__,
__repr__,
__setattr__
|