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/cgi3.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/cgi3.py')
-rwxr-xr-x | Demo/cgi/cgi3.py | 114 |
1 files changed, 1 insertions, 113 deletions
diff --git a/Demo/cgi/cgi3.py b/Demo/cgi/cgi3.py index 205f63d..a3421b5 100755 --- a/Demo/cgi/cgi3.py +++ b/Demo/cgi/cgi3.py @@ -4,119 +4,7 @@ import cgitb; cgitb.enable() -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) - - 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) +from wiki import main if __name__ == "__main__": main() |