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
9df4725
..
205de03
100644
(file)
--- a/
wrw/sp/cons.py
+++ b/
wrw/sp/cons.py
@@
-1,48
+1,49
@@
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,
unicode
):
+class text(node,
str
):
def __todom__(self, doc):
return doc.createTextNode(self)
def __todom__(self, doc):
return doc.createTextNode(self)
-class raw(node,
unicode
):
+class raw(node,
str
):
def __todom__(self, doc):
raise Exception("Cannot convert raw code to DOM objects")
class element(node):
def __init__(self, ns, name, ctx):
self.ns = ns
def __todom__(self, doc):
raise Exception("Cannot convert raw code to DOM objects")
class element(node):
def __init__(self, ns, name, ctx):
self.ns = ns
- self.name =
unicode
(name)
+ self.name =
str
(name)
self.ctx = ctx
self.attrs = {}
self.children = []
def __call__(self, *children, **attrs):
for child in children:
self.ctx = ctx
self.attrs = {}
self.children = []
def __call__(self, *children, **attrs):
for child in children:
- self.c
hildren.append(self.ctx.nodefrom(child)
)
- for k, v in attrs.ite
rite
ms():
- self.
attrs[unicode(k)] = unicode(
v)
+ self.c
tx.addchild(self, child
)
+ for k, v in attrs.items():
+ self.
ctx.addattr(self, k,
v)
return self
def __todom__(self, doc):
el = doc.createElementNS(self.ns, self.name)
return self
def __todom__(self, doc):
el = doc.createElementNS(self.ns, self.name)
- for k, v in self.attrs.ite
rite
ms():
+ for k, v in self.attrs.items():
el.setAttribute(k, v)
for child in self.children:
el.appendChild(child.__todom__(doc))
return el
el.setAttribute(k, v)
for child in self.children:
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 = {}
- self.nodeconv[
str
] = lambda ob: text(ob, "utf-8")
- self.nodeconv[
unicode
] = text
+ self.nodeconv[
bytes
] = lambda ob: text(ob, "utf-8")
+ self.nodeconv[
str
] = text
self.nodeconv[int] = text
self.nodeconv[int] = text
- self.nodeconv[long] = text
self.nodeconv[float] = text
def nodefrom(self, ob):
self.nodeconv[float] = text
def nodefrom(self, ob):
@@
-54,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()