diff orpg/orpg_xml.py @ 0:4385a7d0efd1 grumpy-goblin

Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
author sirebral
date Tue, 14 Jul 2009 16:41:58 -0500
parents
children 211ac836b6a0
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/orpg/orpg_xml.py	Tue Jul 14 16:41:58 2009 -0500
@@ -0,0 +1,74 @@
+# Copyright (C) 2000-2001 The OpenRPG Project
+#
+#        openrpg-dev@lists.sourceforge.net
+#
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 2 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+# --
+#
+# File: orpg_xml.py
+# Author: Chris Davis
+# Maintainer:
+# Version:
+#   $Id: orpg_xml.py,v 1.12 2007/07/19 20:33:10 digitalxero Exp $
+#
+# Description: xml utilies
+#
+
+from orpg import minidom
+import string
+
+def toxml(root,pretty=0):
+    return root.toxml(pretty)
+
+def parseXml(s):
+    "parse and return doc"
+    try:
+        doc = minidom.parseString(s)
+        doc.normalize()
+        return doc
+    except Exception, e:
+        print e
+        return None
+
+def safe_get_text_node(xml_dom):
+    """ returns the child text node or creates one if doesnt exist """
+    t_node = xml_dom._get_firstChild()
+    if t_node == None:
+        t_node = minidom.Text("")
+        t_node = xml_dom.appendChild(t_node)
+    return t_node
+
+def strip_unicode(txt):
+    for i in xrange(len(txt)):
+        if txt[i] not in string.printable:
+            try:
+                txt = txt.replace(txt[i], '&#' + str(ord(txt[i])) + ';')
+            except:
+                txt = txt.replace(txt[i], '{?}')
+    return txt
+
+def strip_text(txt):
+    #  The following block strips out 8-bit characters
+    u_txt = ""
+    bad_txt_found = 0
+    txt = strip_unicode(txt)
+    for c in txt:
+        if ord(c) < 128:
+            u_txt += c
+        else:
+            bad_txt_found = 1
+    if bad_txt_found:
+        print "Some non 7-bit ASCII characters found and stripped"
+    return u_txt