Mercurial > piecrust2
view piecrust/importing/piecrust.py @ 63:28958565a17b
In-place upgrade for PieCrust 1 sites.
author | Ludovic Chabant <ludovic@chabant.com> |
---|---|
date | Thu, 28 Aug 2014 16:48:31 -0700 |
parents | 52e4d9a1f917 |
children | 9ae3237365eb |
line wrap: on
line source
import os import os.path import re import shutil import logging from piecrust.importing.base import FileWalkingImporter logger = logging.getLogger(__name__) class PieCrust1Importer(FileWalkingImporter): def __init__(self): super(PieCrust1Importer, self).__init__() self.name = 'piecrust1' self.description = "Imports content from a PieCrust 1 website." self.requires_website = False def setupParser(self, parser, app): super(PieCrust1Importer, self).setupParser(parser, app) parser.add_argument('root_dir', nargs='?', help="The root directory of the PieCrust 1 website.") parser.add_argument('--upgrade', action='store_true', help="Upgrade the current website in place.") def importWebsite(self, app, args): if app.root_dir and args.upgrade: raise Exception("Can't specifiy both a root directory and `--upgrade`.") if app.root_dir is None and not args.upgrade: raise Exception("Need to specify either a root directory or `--upgrade`.") root_dir = os.getcwd() if args.upgrade else app.root_dir logger.debug("Importing PieCrust 1 site from: %s" % root_dir) exclude = args.exclude or [] exclude += ['_cache', '_counter'] self._startWalk(root_dir, exclude, root_dir, args.upgrade) if args.upgrade: content_dir = os.path.join(root_dir, '_content') file_count = 0 for _, __, filenames in os.walk(content_dir): file_count += len(filenames) if file_count == 0: shutil.rmtree(content_dir) else: logger.warning("Can't delete `_content` directory, files have been left.") logger.info("The PieCrust website was successfully imported.") def _importFile(self, full_fn, rel_fn, out_root_dir, is_move): logger.debug("- %s" % rel_fn) dest_path = rel_fn convert_func = None if rel_fn.replace('\\', '/') == '_content/config.yml': dest_path = 'config.yml' convert_func = self.convertConfig elif rel_fn.startswith('_content'): dest_path = rel_fn[len('_content/'):] fn_dirname = os.path.dirname(rel_fn) if not fn_dirname.endswith('-assets'): convert_func = self.convertPage else: dest_path = 'assets/' + rel_fn logger.debug(" %s -> %s" % (rel_fn, dest_path)) full_dest_path = os.path.join(out_root_dir, dest_path) os.makedirs(os.path.dirname(full_dest_path), 0o755, True) if convert_func is None: if is_move: shutil.move(full_fn, full_dest_path) else: shutil.copy2(full_fn, full_dest_path) else: with open(full_fn, 'r', encoding='utf8') as fp: content = fp.read() converted_content = convert_func(content) with open(full_dest_path, 'w', encoding='utf8') as fp: fp.write(converted_content) if converted_content != content: logger.warning("'%s' has been modified. The original version " "has been kept for reference." % rel_fn) shutil.copy2(full_fn, full_dest_path + '.orig') if is_move: os.remove(full_fn) def convertConfig(self, content): return content def convertPage(self, content): return content