-# -*- coding: utf-8 -*-
-# This file is part of Wolnelektury, licensed under GNU Affero GPLv3 or later.
-# Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information.
+# This file is part of Wolne Lektury, licensed under GNU Affero GPLv3 or later.
+# Copyright © Fundacja Wolne Lektury. See NOTICE for more information.
#
from errno import ENOENT
import os
:param dict add_files: a dictionary of additional files XeTeX will need
"""
- from StringIO import StringIO
+ from io import BytesIO
import shutil
from tempfile import mkdtemp
import subprocess
from django.template.loader import render_to_string
rendered = render_to_string(template, context)
- texml = StringIO(rendered.encode('utf-8'))
+ texml = BytesIO(rendered.encode('utf-8'))
tempdir = mkdtemp(prefix="render_to_pdf-")
tex_path = os.path.join(tempdir, "doc.tex")
- with open(tex_path, 'w') as tex_file:
+ with open(tex_path, 'wb') as tex_file:
Texml.processor.process(texml, tex_file, encoding="utf-8")
if add_files:
makedirs(os.path.dirname(output_path))
rendered = render_to_string(template, context)
- with open(output_path, 'w') as csv_file:
+ with open(output_path, 'wb') as csv_file:
csv_file.write(rendered.encode('utf-8'))
response = HttpResponse(content_type=mime_type)
response['Content-Disposition'] = 'attachment; filename=%s' % name
- with open(file_path) as f:
+ with open(file_path, 'rb') as f:
for chunk in read_chunks(f):
response.write(chunk)
return response