[tryton-debian-vcs] relatorio branch upstream updated. upstream/0.6.0-1-gb82aa79
Mathias Behrle
tryton-debian-vcs at alioth.debian.org
Fri Sep 12 16:58:21 UTC 2014
The following commit has been merged in the upstream branch:
https://alioth.debian.org/plugins/scmgit/cgi-bin/gitweb.cgi/?p=tryton/relatorio.git;a=commitdiff;h=upstream/0.6.0-1-gb82aa79
commit b82aa79d849774b5edf97136632856bb45617fd5
Author: Mathias Behrle <mathiasb at m9s.biz>
Date: Fri Sep 12 12:45:46 2014 +0200
Adding upstream version 0.6.1.
diff --git a/CHANGES b/CHANGES
index 15bec1b..e1b9edd 100644
--- a/CHANGES
+++ b/CHANGES
@@ -1,3 +1,7 @@
+0.6.1 - 20140909
+* Use io module instead of StringIO
+* Explicitly close ZipFile
+
0.6.0 - 20130810
* Add support for Python 3
* Allow to pass only source to Template
diff --git a/PKG-INFO b/PKG-INFO
index e112e9f..e1723a7 100644
--- a/PKG-INFO
+++ b/PKG-INFO
@@ -1,8 +1,8 @@
Metadata-Version: 1.1
Name: relatorio
-Version: 0.6.0
+Version: 0.6.1
Summary: A templating library able to output odt and pdf files
-Home-page: http://relatorio.openhex.org/
+Home-page: http://code.google.com/p/python-relatorio/
Author: Cedric Krier
Author-email: cedric.krier at b2ck.com
License: GPL License
diff --git a/relatorio.egg-info/PKG-INFO b/relatorio.egg-info/PKG-INFO
index e112e9f..e1723a7 100644
--- a/relatorio.egg-info/PKG-INFO
+++ b/relatorio.egg-info/PKG-INFO
@@ -1,8 +1,8 @@
Metadata-Version: 1.1
Name: relatorio
-Version: 0.6.0
+Version: 0.6.1
Summary: A templating library able to output odt and pdf files
-Home-page: http://relatorio.openhex.org/
+Home-page: http://code.google.com/p/python-relatorio/
Author: Cedric Krier
Author-email: cedric.krier at b2ck.com
License: GPL License
diff --git a/relatorio/__init__.py b/relatorio/__init__.py
index 09888e1..34f35d1 100644
--- a/relatorio/__init__.py
+++ b/relatorio/__init__.py
@@ -9,7 +9,8 @@ easy: you just have to create a plugin for this.
relatorio also provides a report repository allowing you to link python objects
and report together, find reports by mimetypes/name/python objects.
"""
-from relatorio.reporting import MIMETemplateLoader, ReportRepository, Report
-import templates
+from .reporting import MIMETemplateLoader, ReportRepository, Report
+from . import templates
-__version__ = '0.6.0'
+__version__ = '0.6.1'
+__all__ = ['MIMETemplateLoader', 'ReportRepository', 'Report', 'templates']
diff --git a/relatorio/templates/__init__.py b/relatorio/templates/__init__.py
index a4bbb60..c514f00 100644
--- a/relatorio/templates/__init__.py
+++ b/relatorio/templates/__init__.py
@@ -18,26 +18,12 @@
#
###############################################################################
-import traceback
import warnings
-try:
- from cStringIO import StringIO
-except ImportError:
- from StringIO import StringIO
plugins = ['base', 'opendocument', 'pdf', 'chart']
for name in plugins:
try:
__import__('relatorio.templates.%s' % name)
- except Exception, e:
- tb_file = StringIO()
-
- print >> tb_file, ("Unable to load plugin '%s', you will not be able "
- "to use it" % name)
- print >> tb_file
- print >> tb_file, 'Original traceback:'
- print >> tb_file, '-------------------'
- traceback.print_exc(file=tb_file)
- print >> tb_file
- warnings.warn(tb_file.getvalue())
+ except ImportError:
+ warnings.warn("Unable to load plugin '%s'" % name)
diff --git a/relatorio/templates/chart.py b/relatorio/templates/chart.py
index 34d0770..b937fd9 100644
--- a/relatorio/templates/chart.py
+++ b/relatorio/templates/chart.py
@@ -1,5 +1,6 @@
###############################################################################
#
+# Copyright (c) 2014 Cedric Krier.
# Copyright (c) 2007, 2008 OpenHex SPRL. (http://openhex.com) All Rights
# Reserved.
#
@@ -20,10 +21,7 @@
__metaclass__ = type
-try:
- from cStringIO import StringIO
-except ImportError:
- from StringIO import StringIO
+from io import BytesIO
import yaml
import genshi
@@ -67,8 +65,8 @@ class CairoSerializer:
self.text_serializer = genshi.output.TextSerializer()
def __call__(self, stream):
- result = StringIO()
- yml = StringIO(_encode(self.text_serializer(stream)))
+ result = BytesIO()
+ yml = BytesIO(_encode(self.text_serializer(stream)))
chart_yaml = yaml.load(yml.read())
chart_info = chart_yaml['chart']
chart_type = chart_info['output_type']
diff --git a/relatorio/templates/opendocument.py b/relatorio/templates/opendocument.py
index 159eff0..01e9778 100644
--- a/relatorio/templates/opendocument.py
+++ b/relatorio/templates/opendocument.py
@@ -1,6 +1,6 @@
###############################################################################
#
-# Copyright (c) 2009-2013 Cedric Krier.
+# Copyright (c) 2009-2014 Cedric Krier.
# Copyright (c) 2007, 2008 OpenHex SPRL. (http://openhex.com) All Rights
# Reserved.
#
@@ -31,13 +31,7 @@ except ImportError:
import time
import urllib
import zipfile
-try:
- from io import BytesIO
-except ImportError:
- try:
- from cStringIO import StringIO as BytesIO
- except ImportError:
- from StringIO import StringIO as BytesIO
+from io import BytesIO
from copy import deepcopy
import datetime
from decimal import Decimal
@@ -225,7 +219,7 @@ def update_py_attrs(node, value):
if not value:
return
py_attrs_attr = '{%s}attrs' % GENSHI_URI
- if not py_attrs_attr in node.attrib:
+ if py_attrs_attr not in node.attrib:
node.attrib[py_attrs_attr] = value
else:
node.attrib[py_attrs_attr] = \
@@ -240,7 +234,7 @@ class Template(MarkupTemplate):
self.namespaces = {}
self.inner_docs = []
self.has_col_loop = False
- self._zip_source = None
+ self._source = None
super(Template, self).__init__(source, filepath, filename, loader,
encoding, lookup, allow_exec)
@@ -261,7 +255,9 @@ class Template(MarkupTemplate):
source = BytesIO(source.read())
else:
source = self.filepath
- self._zip_source = zf = zipfile.ZipFile(source)
+ self._source = source
+ self.filepath = None # Prevent zip content in traceback
+ zf = zipfile.ZipFile(source)
content = zf.read('content.xml')
styles = zf.read('styles.xml')
@@ -283,6 +279,7 @@ class Template(MarkupTemplate):
encoding)
content_files.append((c_path, c_parsed))
styles_files.append((s_path, s_parsed))
+ zf.close()
parsed = []
for fpath, fparsed in content_files + styles_files:
@@ -361,7 +358,7 @@ class Template(MarkupTemplate):
raise OOTemplateError("No expression in the tag",
self.filepath)
closing, directive, attr, attr_val = \
- GENSHI_EXPR.match(expr).groups()
+ GENSHI_EXPR.match(expr).groups()
is_opening = closing != '/'
warn_msg = None
@@ -436,7 +433,7 @@ class Template(MarkupTemplate):
pass
o_ancestors.append(node)
assert ancestor is not None, \
- "No common ancestor found for opening and closing tag"
+ "No common ancestor found for opening and closing tag"
outermost_o_ancestor = o_ancestors[-1]
outermost_c_ancestor = c_ancestors[-1]
@@ -577,7 +574,7 @@ class Template(MarkupTemplate):
for tag in to_split:
tag_pos = table_node.index(tag)
num = int(tag.attrib.pop(table_num_col_attr))
- new_tags = [deepcopy(tag) for _ in range(num)]
+ new_tags = [deepcopy(tag) for i in range(num)]
table_node[tag_pos:tag_pos + 1] = new_tags
# compute the column header nodes corresponding to
@@ -588,10 +585,10 @@ class Template(MarkupTemplate):
# add a <relatorio:repeat> node around the column
# definitions nodes
attribs = {
- "opening": str(opening_pos),
- "closing": str(closing_pos),
- "table": table_name
- }
+ "opening": str(opening_pos),
+ "closing": str(closing_pos),
+ "table": table_name,
+ }
repeat_node = EtreeElement(repeat_tag, attrib=attribs,
nsmap={'relatorio': RELATORIO_URI})
wrap_nodes_between(first, last, repeat_node)
@@ -707,7 +704,7 @@ class Template(MarkupTemplate):
def generate(self, *args, **kwargs):
"creates the RelatorioStream."
- serializer = OOSerializer(self._zip_source)
+ serializer = OOSerializer(self._source)
kwargs['__relatorio_make_href'] = ImageHref(serializer.outzip,
serializer.manifest,
kwargs)
@@ -812,7 +809,7 @@ class Meta(object):
meta = self.office_meta.find('{%s}%s' % (namespace, name))
if meta is None:
meta = EtreeElement('{%s}%s' % (namespace, name),
- nsmap={'meta': namespace})
+ nsmap={'meta': namespace})
self.office_meta.append(meta)
meta.text = value
@@ -845,8 +842,8 @@ class Meta(object):
class OOSerializer:
- def __init__(self, inzip):
- self.inzip = inzip
+ def __init__(self, source):
+ self.inzip = zipfile.ZipFile(source)
self.manifest = Manifest(self.inzip.read(MANIFEST))
self.meta = Meta(self.inzip.read(META))
self.new_oo = BytesIO()
@@ -887,6 +884,7 @@ class OOSerializer:
self.manifest.remove_file_entry(THUMBNAILS + '/')
if manifest_info:
self.outzip.writestr(manifest_info, str(self.manifest))
+ self.inzip.close()
self.outzip.close()
return self.new_oo
diff --git a/relatorio/templates/pdf.py b/relatorio/templates/pdf.py
index c99024c..f21945b 100644
--- a/relatorio/templates/pdf.py
+++ b/relatorio/templates/pdf.py
@@ -1,5 +1,6 @@
###############################################################################
#
+# Copyright (c) 2014 Cedric Krier.
# Copyright (c) 2007, 2008 OpenHex SPRL. (http://openhex.com) All Rights
# Reserved.
#
@@ -24,10 +25,7 @@ import os
import shutil
import tempfile
import subprocess
-try:
- from cStringIO import StringIO
-except ImportError:
- from StringIO import StringIO
+from io import BytesIO
import genshi
import genshi.output
@@ -63,7 +61,7 @@ class PDFSerializer:
subprocess.check_call([TEXEXEC, '--purge', 'report.tex'],
cwd=self.working_dir)
- pdf = StringIO()
+ pdf = BytesIO()
pdf.write(open(self.pdf_file, 'r').read())
shutil.rmtree(self.working_dir, ignore_errors=True)
diff --git a/relatorio/tests/test_api.py b/relatorio/tests/test_api.py
index 11e8993..8f89762 100644
--- a/relatorio/tests/test_api.py
+++ b/relatorio/tests/test_api.py
@@ -1,5 +1,6 @@
###############################################################################
#
+# Copyright (c) 2014 Cedric Krier.
# Copyright (c) 2007, 2008 OpenHex SPRL. (http://openhex.com) All Rights
# Reserved.
#
@@ -20,7 +21,7 @@
import os
-from nose.tools import *
+from nose.tools import assert_true, eq_, assert_raises
from relatorio.reporting import (ReportRepository, Report, MIMETemplateLoader,
DefaultFactory, _absolute, _guess_type)
diff --git a/relatorio/tests/test_odt.py b/relatorio/tests/test_odt.py
index 2d982ff..c665aad 100644
--- a/relatorio/tests/test_odt.py
+++ b/relatorio/tests/test_odt.py
@@ -1,6 +1,7 @@
# -*- encoding: utf-8 -*-
###############################################################################
#
+# Copyright (c) 2014 Cedric Krier.
# Copyright (c) 2007, 2008 OpenHex SPRL. (http://openhex.com) All Rights
# Reserved.
#
@@ -21,13 +22,10 @@
import os
-try:
- from cStringIO import StringIO
-except ImportError:
- from StringIO import StringIO
+from io import StringIO
import lxml.etree
-from nose.tools import *
+from nose.tools import ok_, eq_, assert_raises
from genshi.filters import Translator
from genshi.core import PI
from genshi.template.eval import UndefinedError
@@ -42,16 +40,17 @@ def pseudo_gettext(string):
catalog = {'Mes collègues sont:': 'My colleagues are:',
'Bonjour,': 'Hello,',
'Je suis un test de templating en odt.':
- 'I am an odt templating test',
+ 'I am an odt templating test',
'Felix da housecat': u'Félix le chat de la maison',
'We sell stuff': u'On vend des choses',
}
return catalog.get(string, string)
+
def stream_to_string(stream):
# In Python 3, stream will be bytes
- if not isinstance(stream, str):
- return str(stream, 'utf-8')
+ if not isinstance(stream, unicode):
+ return unicode(stream, 'utf-8')
return stream
@@ -254,7 +253,7 @@ class TestOOTemplating(object):
rendered = stream_to_string(stream.events.render(encoding='utf-8'))
ok_('Bonjour,' in rendered)
ok_('Trente' in rendered)
- ok_('Møller' in rendered)
+ ok_(u'Møller' in rendered)
ok_('Dog eat Dog' in rendered)
ok_('Felix da housecat' in rendered)
@@ -267,7 +266,7 @@ class TestOOTemplating(object):
ok_("Hello," in translated_xml)
ok_("I am an odt templating test" in translated_xml)
ok_('Felix da housecat' not in translated_xml)
- ok_('Félix le chat de la maison' in translated_xml)
+ ok_(u'Félix le chat de la maison' in translated_xml)
ok_('We sell stuff' not in translated_xml)
ok_('On vend des choses' in translated_xml)
diff --git a/setup.py b/setup.py
index f342bf6..a0052a6 100644
--- a/setup.py
+++ b/setup.py
@@ -2,6 +2,7 @@ import os
import re
from setuptools import setup, find_packages
+
def get_version():
init = open(os.path.join(os.path.dirname(__file__), 'relatorio',
'__init__.py')).read()
@@ -9,9 +10,9 @@ def get_version():
setup(
name="relatorio",
- url="http://relatorio.openhex.org/",
+ url="http://code.google.com/p/python-relatorio/",
author="Nicolas Evrard",
- author_email="nicoe at openhex.org",
+ author_email="nicolas.evrard at b2ck.com",
maintainer="Cedric Krier",
maintainer_email="cedric.krier at b2ck.com",
description="A templating library able to output odt and pdf files",
--
relatorio
More information about the tryton-debian-vcs
mailing list