From 64ea14acca6f6420ea17c0c2126a71de2c3ef91d Mon Sep 17 00:00:00 2001 From: Aaron Bentley Date: Thu, 6 Apr 2006 14:05:47 -0400 Subject: Add ReST support to web front end --- beweb/beweb/controllers.py | 1 + beweb/beweb/formatting.py | 73 ++++++++++++++++++++++++++++++++++++++ beweb/beweb/templates/edit_bug.kid | 55 ++-------------------------- 3 files changed, 76 insertions(+), 53 deletions(-) create mode 100644 beweb/beweb/formatting.py (limited to 'beweb') diff --git a/beweb/beweb/controllers.py b/beweb/beweb/controllers.py index 74c6a7d..fc505ed 100644 --- a/beweb/beweb/controllers.py +++ b/beweb/beweb/controllers.py @@ -23,6 +23,7 @@ class Comment(PrestHandler): bug_tree = project_tree(comment_data['project']) bug = bug_tree.get_bug(comment_data['bug']) comment = new_comment(bug, "") + comment.content_type = "text/restructured" comment.save() raise cherrypy.HTTPRedirect(comment_url(comment=comment.uuid, **comment_data)) diff --git a/beweb/beweb/formatting.py b/beweb/beweb/formatting.py new file mode 100644 index 0000000..44ed849 --- /dev/null +++ b/beweb/beweb/formatting.py @@ -0,0 +1,73 @@ +from StringIO import StringIO + +from elementtree.ElementTree import XML +from libbe.restconvert import rest_xml + +def to_unix(text): + skip_newline = False + for ch in text: + if ch not in ('\r', '\n'): + yield ch + else: + if ch == '\n': + if skip_newline: + continue + else: + skip_newline = True + yield '\n' + + +def soft_text(text): + first_space = False + translations = {'\n': '
\n', '&': '&', '\x3c': '<', + '\x3e': '>'} + for ch in to_unix(text): + if ch == ' ' and first_space is True: + yield ' ' + first_space = ch in (' ') + try: + yield translations[ch] + except KeyError: + yield ch + + +def soft_pre(text): + return XML('
'+ + ''.join(soft_text(text))+'
') + + +def get_rest_body(rest): + xml, warnings = rest_xml(StringIO(rest)) + return xml.find('{http://www.w3.org/1999/xhtml}body'), warnings + + +def comment_body_xhtml(comment): + if comment.content_type == "text/restructured": + return get_rest_body(comment.body)[0] + else: + return soft_pre(comment.body) + + +def select_among(name, options, default, display_names=None): + output = ['") + return XML("".join(output)) diff --git a/beweb/beweb/templates/edit_bug.kid b/beweb/beweb/templates/edit_bug.kid index 960866d..c31d660 100644 --- a/beweb/beweb/templates/edit_bug.kid +++ b/beweb/beweb/templates/edit_bug.kid @@ -4,58 +4,7 @@ from libbe.bugdir import severity_levels, active_status, inactive_status, thread from libbe.utility import time_to_str from beweb.controllers import bug_list_url, comment_url from beweb.config import people -def select_among(name, options, default, display_names=None): - output = ['") - return XML("".join(output)) - -def to_unix(text): - skip_newline = False - for ch in text: - if ch not in ('\r', '\n'): - yield ch - else: - if ch == '\n': - if skip_newline: - continue - else: - skip_newline = True - yield '\n' - -def soft_text(text): - first_space = False - translations = {'\n': '
\n', '&': '&', '\x3c': '<', - '\x3e': '>'} - for ch in to_unix(text): - if ch == ' ' and first_space is True: - yield ' ' - first_space = ch in (' ') - try: - yield translations[ch] - except KeyError: - yield ch -def soft_pre(text): - return XML('
'+ - ''.join(soft_text(text))+'
') +from beweb.formatting import comment_body_xhtml, select_among ?> @@ -79,7 +28,7 @@ def soft_pre(text): From${comment.From} Date${time_to_str(comment.date)} -
+
Edit Reply -- cgit