diff options
author | Guido van Rossum <guido@python.org> | 2002-10-17 15:53:02 (GMT) |
---|---|---|
committer | Guido van Rossum <guido@python.org> | 2002-10-17 15:53:02 (GMT) |
commit | f66cccf506b935b2a38355f86ff676a8b6326faa (patch) | |
tree | aef3b8608ef519859d306759baf185eea9b3803f /Demo/cgi/wiki.py | |
parent | 26a1ac462ce07405845675222a66eba2b5bed132 (diff) | |
download | cpython-f66cccf506b935b2a38355f86ff676a8b6326faa.zip cpython-f66cccf506b935b2a38355f86ff676a8b6326faa.tar.gz cpython-f66cccf506b935b2a38355f86ff676a8b6326faa.tar.bz2 |
Restructure: move all wiki code into a separate module.
Diffstat (limited to 'Demo/cgi/wiki.py')
-rw-r--r-- | Demo/cgi/wiki.py | 115 |
1 files changed, 115 insertions, 0 deletions
diff --git a/Demo/cgi/wiki.py b/Demo/cgi/wiki.py new file mode 100644 index 0000000..f0208a4 --- /dev/null +++ b/Demo/cgi/wiki.py @@ -0,0 +1,115 @@ +"""Wiki main program. Imported and run by cgi3.py.""" + +import os, re, cgi, sys +escape = cgi.escape + +def main(): + form = cgi.FieldStorage() + print "Content-type: text/html" + print + cmd = form.getvalue("cmd", "view") + page = form.getvalue("page", "FrontPage") + wiki = WikiPage(page) + wiki.load() + method = getattr(wiki, 'cmd_' + cmd, None) or wiki.cmd_view + method(form) + +class WikiPage: + + homedir = "/tmp" + scripturl = os.path.basename(sys.argv[0]) + + def __init__(self, name): + if not self.iswikiword(name): + raise ValueError, "page name is not a wiki word" + self.name = name + self.load() + + def cmd_view(self, form): + print "<h1>", escape(self.splitwikiword(self.name)), "</h1>" + print "<p>" + for line in self.data.splitlines(): + line = line.rstrip() + if not line: + print "<p>" + continue + words = re.split('(\W+)', line) + for i in range(len(words)): + word = words[i] + if self.iswikiword(word): + if os.path.isfile(self.mkfile(word)): + word = self.mklink("view", word, word) + else: + word = self.mklink("new", word, word + "*") + else: + word = escape(word) + words[i] = word + print "".join(words) + print "<hr>" + print "<p>", self.mklink("edit", self.name, "Edit this page") + ";" + print self.mklink("view", "FrontPage", "go to front page") + "." + + def cmd_edit(self, form, label="Change"): + print "<h1>", label, self.name, "</h1>" + print '<form method="POST" action="%s">' % self.scripturl + s = '<textarea cols="70" rows="20" name="text">%s</textarea>' + print s % self.data + print '<input type="hidden" name="cmd" value="create">' + print '<input type="hidden" name="page" value="%s">' % self.name + print '<br>' + print '<input type="submit" value="%s Page">' % label + print "</form>" + + def cmd_create(self, form): + self.data = form.getvalue("text", "").strip() + error = self.store() + if error: + print "<h1>I'm sorry. That didn't work</h1>" + print "<p>An error occurred while attempting to write the file:" + print "<p>", escape(error) + else: + self.cmd_view(form) + + def cmd_new(self, form): + self.cmd_edit(form, label="Create Page") + + def iswikiword(self, word): + return re.match("[A-Z][a-z]+([A-Z][a-z]*)+", word) + + def splitwikiword(self, word): + chars = [] + for c in word: + if chars and c.isupper(): + chars.append(' ') + chars.append(c) + return "".join(chars) + + def mkfile(self, name=None): + if name is None: + name = self.name + return os.path.join(self.homedir, name + ".txt") + + def mklink(self, cmd, page, text): + link = self.scripturl + "?cmd=" + cmd + "&page=" + page + return '<a href="%s">%s</a>' % (link, text) + + def load(self): + try: + f = open(self.mkfile()) + data = f.read().strip() + f.close() + except IOError: + data = "" + self.data = data + + def store(self): + data = self.data + try: + f = open(self.mkfile(), "w") + f.write(data) + if data and not data.endswith('\n'): + f.write('\n') + f.close() + return "" + except IOError, err: + return "IOError: %s" % str(err) |