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 | |
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')
-rwxr-xr-x | Demo/cgi/cgi3.py | 114 | ||||
-rw-r--r-- | Demo/cgi/wiki.py | 115 |
2 files changed, 116 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() 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) |