Dolda2000 GitWeb
/
wrw.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Merge branch 'master' into python3
[wrw.git]
/
wrw
/
sp
/
cons.py
diff --git
a/wrw/sp/cons.py
b/wrw/sp/cons.py
index
d54c314
..
205de03
100644
(file)
--- a/
wrw/sp/cons.py
+++ b/
wrw/sp/cons.py
@@
-1,9
+1,7
@@
import xml.dom.minidom
class node(object):
import xml.dom.minidom
class node(object):
- def __str__(self):
- doc = xml.dom.minidom.Document()
- return self.__todom__(doc).toxml()
+ pass
class text(node, str):
def __todom__(self, doc):
class text(node, str):
def __todom__(self, doc):
@@
-23,9
+21,9
@@
class element(node):
def __call__(self, *children, **attrs):
for child in children:
def __call__(self, *children, **attrs):
for child in children:
- self.c
hildren.append(self.ctx.nodefrom(child)
)
+ self.c
tx.addchild(self, child
)
for k, v in attrs.items():
for k, v in attrs.items():
- self.
attrs[str(k)] = str(
v)
+ self.
ctx.addattr(self, k,
v)
return self
def __todom__(self, doc):
return self
def __todom__(self, doc):
@@
-36,6
+34,10
@@
class element(node):
el.appendChild(child.__todom__(doc))
return el
el.appendChild(child.__todom__(doc))
return el
+ def __str__(self):
+ doc = xml.dom.minidom.Document()
+ return self.__todom__(doc).toxml()
+
class context(object):
def __init__(self):
self.nodeconv = {}
class context(object):
def __init__(self):
self.nodeconv = {}
@@
-53,8
+55,15
@@
class context(object):
return self.nodeconv[type(ob)](ob)
raise Exception("No node conversion known for %s objects" % str(type(ob)))
return self.nodeconv[type(ob)](ob)
raise Exception("No node conversion known for %s objects" % str(type(ob)))
+ def addchild(self, node, child):
+ node.children.append(self.nodefrom(child))
+
+ def addattr(self, node, k, v):
+ if v is not None:
+ node.attrs[str(k)] = str(v)
+
class constructor(object):
class constructor(object):
- def __init__(self, ns, elcls
=
element, ctx=None):
+ def __init__(self, ns, elcls
=
element, ctx=None):
self._ns = ns
self._elcls = elcls
if ctx is None: ctx = context()
self._ns = ns
self._elcls = elcls
if ctx is None: ctx = context()