Dolda2000 GitWeb
/
wrw.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Create explicit python2 branch as a child of python3.
[wrw.git]
/
wrw
/
sp
/
cons.py
diff --git
a/wrw/sp/cons.py
b/wrw/sp/cons.py
index
d54c314
..
bc9bfa2
100644
(file)
--- a/
wrw/sp/cons.py
+++ b/
wrw/sp/cons.py
@@
-1,47
+1,53
@@
+import sys
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
):
+class text(node,
unicode
):
def __todom__(self, doc):
return doc.createTextNode(self)
def __todom__(self, doc):
return doc.createTextNode(self)
-class raw(node,
str
):
+class raw(node,
unicode
):
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 =
str
(name)
+ self.name =
unicode
(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.items():
- self.
attrs[str(k)] = str(
v)
+ self.c
tx.addchild(self, child
)
+ for k, v in attrs.ite
rite
ms():
+ 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.items():
+ for k, v in self.attrs.ite
rite
ms():
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):
class context(object):
+ charset = (sys.getfilesystemencoding() or "ascii")
+
def __init__(self):
self.nodeconv = {}
def __init__(self):
self.nodeconv = {}
- self.nodeconv[
bytes] = lambda ob: text(ob, "utf-8"
)
- self.nodeconv[
str
] = text
+ self.nodeconv[
str] = lambda ob: text(ob, self.charset
)
+ self.nodeconv[
unicode
] = 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):
@@
-53,8
+59,17
@@
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):
+ if child is None:
+ return
+ node.children.append(self.nodefrom(child))
+
+ def addattr(self, node, k, v):
+ if v is not None:
+ node.attrs[unicode(k)] = unicode(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()
@@
-62,3
+77,9
@@
class constructor(object):
def __getattr__(self, name):
return self._elcls(self._ns, name, self._ctx)
def __getattr__(self, name):
return self._elcls(self._ns, name, self._ctx)
+
+class doctype(node):
+ def __init__(self, rootname, pubid, dtdid):
+ self.rootname = rootname
+ self.pubid = pubid
+ self.dtdid = dtdid