aboutsummaryrefslogtreecommitdiffstats
path: root/nikola/plugins/basic_import.py
diff options
context:
space:
mode:
Diffstat (limited to 'nikola/plugins/basic_import.py')
-rw-r--r--nikola/plugins/basic_import.py37
1 files changed, 30 insertions, 7 deletions
diff --git a/nikola/plugins/basic_import.py b/nikola/plugins/basic_import.py
index 04f1091..cf98ebc 100644
--- a/nikola/plugins/basic_import.py
+++ b/nikola/plugins/basic_import.py
@@ -1,6 +1,6 @@
# -*- coding: utf-8 -*-
-# Copyright © 2012-2015 Roberto Alsina and others.
+# Copyright © 2012-2016 Roberto Alsina and others.
# Permission is hereby granted, free of charge, to any
# person obtaining a copy of this software and associated
@@ -76,8 +76,11 @@ class ImportMixin(object):
return channel
@staticmethod
- def configure_redirections(url_map):
+ def configure_redirections(url_map, base_dir=''):
"""Configure redirections from an url_map."""
+ index = base_dir + 'index.html'
+ if index.startswith('/'):
+ index = index[1:]
redirections = []
for k, v in url_map.items():
if not k[-1] == '/':
@@ -86,11 +89,10 @@ class ImportMixin(object):
# remove the initial "/" because src is a relative file path
src = (urlparse(k).path + 'index.html')[1:]
dst = (urlparse(v).path)
- if src == 'index.html':
+ if src == index:
utils.LOGGER.warn("Can't do a redirect for: {0!r}".format(k))
else:
redirections.append((src, dst))
-
return redirections
def generate_base_site(self):
@@ -125,9 +127,12 @@ class ImportMixin(object):
def write_content(cls, filename, content, rewrite_html=True):
"""Write content to file."""
if rewrite_html:
- doc = html.document_fromstring(content)
- doc.rewrite_links(replacer)
- content = html.tostring(doc, encoding='utf8')
+ try:
+ doc = html.document_fromstring(content)
+ doc.rewrite_links(replacer)
+ content = html.tostring(doc, encoding='utf8')
+ except etree.ParserError:
+ content = content.encode('utf-8')
else:
content = content.encode('utf-8')
@@ -135,6 +140,24 @@ class ImportMixin(object):
with open(filename, "wb+") as fd:
fd.write(content)
+ @classmethod
+ def write_post(cls, filename, content, headers, compiler, rewrite_html=True):
+ """Ask the specified compiler to write the post to disk."""
+ if rewrite_html:
+ try:
+ doc = html.document_fromstring(content)
+ doc.rewrite_links(replacer)
+ content = html.tostring(doc, encoding='utf8')
+ except etree.ParserError:
+ pass
+ if isinstance(content, utils.bytes_str):
+ content = content.decode('utf-8')
+ compiler.create_post(
+ filename,
+ content=content,
+ onefile=True,
+ **headers)
+
@staticmethod
def write_metadata(filename, title, slug, post_date, description, tags, **kwargs):
"""Write metadata to meta file."""