summaryrefslogtreecommitdiff
path: root/web
diff options
context:
space:
mode:
authorBen Longbons <b.r.longbons@gmail.com>2013-05-17 12:41:41 -0700
committerBen Longbons <b.r.longbons@gmail.com>2013-05-17 12:44:59 -0700
commit09e183bbe00971b57f29a88431e36ea7139c4e7a (patch)
tree880dc4795d89af7d2378d282021369b559a24c63 /web
parentf4237e0e4c265f92774230713b95d3d58bae0664 (diff)
downloadtools-09e183bbe00971b57f29a88431e36ea7139c4e7a.tar.gz
tools-09e183bbe00971b57f29a88431e36ea7139c4e7a.tar.bz2
tools-09e183bbe00971b57f29a88431e36ea7139c4e7a.tar.xz
tools-09e183bbe00971b57f29a88431e36ea7139c4e7a.zip
Make the tmx converter update resnametable.txt
If/when we use static instancing, we'll have to change this.
Diffstat (limited to 'web')
-rw-r--r--web/README3
-rwxr-xr-xweb/main.py28
-rw-r--r--web/with_xml.py71
3 files changed, 102 insertions, 0 deletions
diff --git a/web/README b/web/README
new file mode 100644
index 0000000..dc7bc55
--- /dev/null
+++ b/web/README
@@ -0,0 +1,3 @@
+This is a flask app to manage accounts.
+
+It implements a full-featured webserver, but is usually proxied by nginx.
diff --git a/web/main.py b/web/main.py
new file mode 100755
index 0000000..b7501c5
--- /dev/null
+++ b/web/main.py
@@ -0,0 +1,28 @@
+#!/usr/bin/env python2.6
+
+from flask import Flask
+
+from with_xml import Node
+
+app = Flask(__name__)
+
+@app.route('/')
+def index():
+ content = Node()
+ tag = content.tag
+ put = content.put
+ a = tag('a')
+ with tag('html'):
+ with tag('head'):
+ with tag('title'):
+ put('Title')
+ with tag('body'):
+ with tag('h1'):
+ put('Header')
+ put('This is ')
+ with a(href='http://google.com/'):
+ put('a link to Google.')
+ return str(content)
+
+if __name__ == '__main__':
+ app.run(debug=True)
diff --git a/web/with_xml.py b/web/with_xml.py
new file mode 100644
index 0000000..bc49a94
--- /dev/null
+++ b/web/with_xml.py
@@ -0,0 +1,71 @@
+''' A stupid little way of generating xml
+'''
+
+import re
+
+from flask import escape
+
+PRETTY = True
+
+class Context(object):
+ __slots__ = ('_node', '_name', '_kwargs')
+ pattern = re.compile(r'[A-Za-z]\w*')
+
+ def __init__(self, node, name, kwargs):
+ self._node = node
+ self._name = name
+ self._kwargs = kwargs
+
+ def __enter__(self):
+ _node = self._node
+ _buffer = _node._buffer
+ _node.nl()
+ _buffer.extend(['<', escape(self._name)])
+ for k, v in self._kwargs.iteritems():
+ assert Context.pattern.match(k)
+ _buffer.extend([' ', k, '="', escape(v), '"'])
+ _buffer.append('>')
+ _node._indent += 1
+ _node.nl()
+
+ def __exit__(self, exc_type, exc_value, traceback):
+ _node = self._node
+ _buffer = _node._buffer
+ _node._indent -= 1
+ _node.nl()
+ if _buffer[-1] == '>' and _buffer[-3] != '</':
+ _buffer[-1] = '/>'
+ else:
+ _buffer.extend(['</', escape(self._name), '>'])
+ _node.nl()
+
+ def __call__(_self, **kwargs):
+ new_kwargs = dict(_self._kwargs)
+ new_kwargs.update(kwargs)
+ return Context(_self._node, _self._name, new_kwargs)
+
+class Node(object):
+ __slots__ = ('_buffer', '_indent')
+
+ def __init__(self):
+ self._buffer = ['<?xml version="1.0" encoding="utf-8"?>', '\n', '']
+ self._indent = 0
+
+ def tag(_self, _name, **kwargs):
+ return Context(_self, _name, kwargs)
+
+
+ def put(self, text):
+ self._buffer.append(escape(text))
+
+ def __str__(self):
+ return ''.join(self._buffer)
+
+ def nl(self):
+ if PRETTY:
+ _buffer = self._buffer
+ if _buffer[-2] == '\n':
+ _buffer.pop()
+ else:
+ _buffer.append('\n')
+ _buffer.extend([' ' * self._indent])