# Copyright (c) 2012 Roberto Alsina y otros. # Permission is hereby granted, free of charge, to any # person obtaining a copy of this software and associated # documentation files (the "Software"), to deal in the # Software without restriction, including without limitation # the rights to use, copy, modify, merge, publish, # distribute, sublicense, and/or sell copies of the # Software, and to permit persons to whom the Software is # furnished to do so, subject to the following conditions: # # The above copyright notice and this permission notice # shall be included in all copies or substantial portions of # the Software. # # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY # KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE # WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR # PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS # OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR # OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR # OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE # SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. from __future__ import print_function from optparse import OptionParser, OptionGroup import os import shutil import codecs from mako.template import Template import nikola from nikola.plugin_categories import Command class CommandInit(Command): """Create a new site.""" name = "init" usage = """Usage: nikola init folder [options]. That will create a sample site in the specified folder. The destination folder must not exist. """ SAMPLE_CONF = { 'BLOG_AUTHOR': "Your Name", 'BLOG_TITLE': "Demo Site", 'BLOG_URL': "http://nikola.ralsina.com.ar", 'BLOG_EMAIL': "joe@demo.site", 'BLOG_DESCRIPTION': "This is a demo site for Nikola.", 'DEFAULT_LANG': "en", 'POST_PAGES': """( ("posts/*.txt", "posts", "post.tmpl", True), ("stories/*.txt", "stories", "story.tmpl", False), )""", 'POST_COMPILERS': """{ "rest": ('.txt', '.rst'), "markdown": ('.md', '.mdown', '.markdown'), "textile": ('.textile',), "txt2tags": ('.t2t',), "bbcode": ('.bb',), "wiki": ('.wiki',), "ipynb": ('.ipynb',), "html": ('.html', '.htm') }""", 'REDIRECTIONS': '[]', } @classmethod def copy_sample_site(cls, target): lib_path = cls.get_path_to_nikola_modules() src = os.path.join(lib_path, 'data', 'samplesite') shutil.copytree(src, target) @classmethod def create_configuration(cls, target): lib_path = cls.get_path_to_nikola_modules() template_path = os.path.join(lib_path, 'conf.py.in') conf_template = Template(filename=template_path) conf_path = os.path.join(target, 'conf.py') with codecs.open(conf_path, 'w+', 'utf8') as fd: fd.write(conf_template.render(**cls.SAMPLE_CONF)) @classmethod def create_empty_site(cls, target): for folder in ('files', 'galleries', 'listings', 'posts', 'stories'): os.makedirs(os.path.join(target, folder)) @staticmethod def get_path_to_nikola_modules(): return os.path.dirname(nikola.__file__) def run(self, *args): """Create a new site.""" parser = OptionParser(usage=self.usage) group = OptionGroup(parser, "Site Options") group.add_option( "--empty", action="store_true", dest='empty', default=True, help="Create an empty site with only a config.") group.add_option("--demo", action="store_false", dest='empty', help="Create a site filled with example data.") parser.add_option_group(group) (options, args) = parser.parse_args(list(args)) if not args: print("Usage: nikola init folder [options]") return target = args[0] if target is None: print(self.usage) else: if options.empty: self.create_empty_site(target) print('Created empty site at %s.' % target) else: self.copy_sample_site(target) print("A new site with example data has been created at %s." % target) print("See README.txt in that folder for more information.") self.create_configuration(target)