Mercurial > sqlpython
changeset 146:d5917f02ae83
html output switched to genshi
author | catherine@Elli.myhome.westell.com |
---|---|
date | Thu, 25 Sep 2008 15:40:20 -0400 |
parents | 7e5105efa15d |
children | a2731c87b837 |
files | setup.py sqlpyPlus.py |
diffstat | 2 files changed, 40 insertions(+), 31 deletions(-) [+] |
line wrap: on
line diff
--- a/setup.py Tue Sep 23 07:43:11 2008 -0400 +++ b/setup.py Thu Sep 25 15:40:20 2008 -0400 @@ -18,7 +18,7 @@ packages=find_packages(), py_modules = ['mysqlpy','completion','sqlpyPlus','sqlpython','pexpecter'], include_package_data=True, - install_requires=['pyparsing','cmd2>=0.3.6','cx_Oracle'], + install_requires=['pyparsing','cmd2>=0.3.6','cx_Oracle','genshi'], keywords = 'client oracle database', license = 'MIT', platforms = ['any'],
--- a/sqlpyPlus.py Tue Sep 23 07:43:11 2008 -0400 +++ b/sqlpyPlus.py Thu Sep 25 15:40:20 2008 -0400 @@ -186,7 +186,7 @@ """ } -import sys, os, re, sqlpython, cx_Oracle, pyparsing, re, completion +import sys, os, re, sqlpython, cx_Oracle, pyparsing, re, completion, genshi from cmd2 import Cmd, make_option, options, Statekeeper if float(sys.version[:3]) < 2.3: @@ -408,55 +408,64 @@ for row in self.rows] return '\n'.join(result) + xml_template = genshi.template.MarkupTemplate(''' + <ul xmlns:py="http://genshi.edgewall.org/"> + <li py:for="item in items">${item}</li> + </ul>''') def output_row_as_xml(self, row): result = [' <%s>\n %s\n </%s>' % (colname.lower(), self.str_or_empty(itm), colname.lower()) for (itm, colname) in zip(row, self.colnames)] return '\n'.join(result) + ''' + xml_template = genshi.template.MarkupTemplate(""" +<xml xmlns:py="http://genshi.edgewall.org/"> + <relation py:attr="{'type':tblname}"> + <tuple py:for="row in rows" py:attr="{'type':> + </tuple> + </relation> + <tr> + <th py:for="colname in colnames"> + <span py:replace="colname">Column Name</span> + </th> + </tr> + <tr py:for="row in rows"> + <td py:for="itm in row"> + <span py:replace="str(itm)">Value</span> + </td> + </tr> + </table> + </body> +</html>""") +''' def output_as_xml(self): + return self.xml_template(**self.__dict__) result = ['<%s>\n%s\n</%s>' % (self.tblname, self.output_row_as_xml(row), self.tblname) for row in self.rows] return '\n'.join(result) - - html_template = """<html> + + html_template = genshi.template.MarkupTemplate(""" +<html xmlns:py="http://genshi.edgewall.org/"> <head> <title py:content="tblname">Table Name</title> </head> <body> - <table py:attr="{'id':tblname}"> + <table py:attrs="{'id':tblname}"> <tr> <th py:for="colname in colnames"> - <span py:replace="colname">Column Name</span> + <span py:replace="colname.lower()">Column Name</span> </th> </tr> <tr py:for="row in rows"> <td py:for="itm in row"> - <span py:replace="str_or_empty(itm)">Value</span> - </td> + <span py:replace="str(itm)">Value</span> + </td> </tr> </table> </body> -</html>""" - def output_as_html_table(self): - result = ''.join('<th>%s</th>' % c for c in self.colnames) - result = [' <tr>\n %s\n </tr>' % result] - for row in self.rows: - result.append(' <tr>\n %s\n </tr>' % - (''.join('<td>%s</td>' % - self.str_or_empty(itm) - for itm in row))) - result = '''<table id="%s"> -%s -</table>''' % (self.tblname, '\n'.join(result)) - return result - - #TODO: use serious templating to make these user-tweakable - - def output_as_markup(self, genshi_template): - return None - #self.tblname, self.colnames, self.rows - +</html>""") + def output_as_list(self, align): result = [] colnamelen = max(len(colname) for colname in self.colnames) + 1 @@ -488,7 +497,7 @@ result.append(','.join('"%s"' % self.str_or_empty(itm) for itm in row)) result = '\n'.join(result) elif outformat == '\\h': - result = self.output_as_html_table() + result = self.html_template.generate(**self.__dict__) elif outformat == '\\t': rows = [self.colnames] rows.extend(list(self.rows)) @@ -559,8 +568,8 @@ ^ pyparsing.Literal('\n/') ^ \ (pyparsing.Literal('\nEOF') + pyparsing.stringEnd)) \ ('terminator') + \ - pyparsing.Optional(rowlimitPattern) + \ - pyparsing.FollowedBy(pyparsing.LineEnd()) + pyparsing.Optional(rowlimitPattern) #+ \ + #pyparsing.FollowedBy(pyparsing.LineEnd()) def do_select(self, arg, bindVarsIn=None, override_terminator=None): """Fetch rows from a table.