From c98a4df96da9c85da5a6e94a294a3d6f31822d76 Mon Sep 17 00:00:00 2001 From: Kovid Goyal Date: Fri, 20 Nov 2009 21:14:31 -0700 Subject: [PATCH] IGN: calibredb list with XML output: Fix entity escaping --- src/calibre/library/cli.py | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/src/calibre/library/cli.py b/src/calibre/library/cli.py index 280653b2c3..102ace97ba 100644 --- a/src/calibre/library/cli.py +++ b/src/calibre/library/cli.py @@ -9,7 +9,6 @@ Command line interface to the calibre database. import sys, os, cStringIO from textwrap import TextWrapper -from xml.sax.saxutils import escape from calibre import terminal_controller, preferred_encoding, prints from calibre.utils.config import OptionParser, prefs @@ -48,10 +47,10 @@ XML_TEMPLATE = '''\ ${record['comments']} ${record['series']} ${record['isbn']} - ${escape(record['cover'].replace(os.sep, '/'))} + ${record['cover'].replace(os.sep, '/')} - ${escape(path.replace(os.sep, '/'))} + ${path.replace(os.sep, '/')} @@ -186,15 +185,17 @@ def do_list(db, fields, sort_by, ascending, search_text, line_width, separator, return o.getvalue() elif output_format == 'xml': template = MarkupTemplate(XML_TEMPLATE) - return template.generate(data=data, os=os, escape=escape).render('xml') + return template.generate(data=data, os=os).render('xml') elif output_format == 'stanza': + def quote(raw): + return raw.replace('"', r'\"') data = [i for i in data if i.has_key('fmt_epub')] for x in data: if isinstance(x['fmt_epub'], unicode): x['fmt_epub'] = x['fmt_epub'].encode('utf-8') template = MarkupTemplate(STANZA_TEMPLATE) return template.generate(id="urn:calibre:main", data=data, subtitle=subtitle, - sep=os.sep, quote=escape, updated=db.last_modified()).render('xml') + sep=os.sep, quote=quote, updated=db.last_modified()).render('xml') def list_option_parser(): parser = get_parser(_(