Merge pull request #2817 from rusikf/patch-2

This commit is contained in:
Parker Moore 2014-08-25 10:36:53 -07:00
commit ac1f2e2049
1 changed files with 61 additions and 59 deletions

View File

@ -3,7 +3,8 @@ require 'erb'
module Jekyll module Jekyll
module Commands module Commands
class New < Command class New < Command
def self.init_with_program(prog) class << self
def init_with_program(prog)
prog.command(:new) do |c| prog.command(:new) do |c|
c.syntax 'new PATH' c.syntax 'new PATH'
c.description 'Creates a new Jekyll site scaffold in PATH' c.description 'Creates a new Jekyll site scaffold in PATH'
@ -17,7 +18,7 @@ module Jekyll
end end
end end
def self.process(args, options = {}) def process(args, options = {})
raise ArgumentError.new('You must specify a path.') if args.empty? raise ArgumentError.new('You must specify a path.') if args.empty?
new_blog_path = File.expand_path(args.join(" "), Dir.pwd) new_blog_path = File.expand_path(args.join(" "), Dir.pwd)
@ -39,42 +40,43 @@ module Jekyll
Jekyll.logger.info "New jekyll site installed in #{new_blog_path}." Jekyll.logger.info "New jekyll site installed in #{new_blog_path}."
end end
def self.create_blank_site(path) def create_blank_site(path)
Dir.chdir(path) do Dir.chdir(path) do
FileUtils.mkdir(%w(_layouts _posts _drafts)) FileUtils.mkdir(%w(_layouts _posts _drafts))
FileUtils.touch("index.html") FileUtils.touch("index.html")
end end
end end
def self.scaffold_post_content def scaffold_post_content
ERB.new(File.read(File.expand_path(scaffold_path, site_template))).result ERB.new(File.read(File.expand_path(scaffold_path, site_template))).result
end end
# Internal: Gets the filename of the sample post to be created # Internal: Gets the filename of the sample post to be created
# #
# Returns the filename of the sample post, as a String # Returns the filename of the sample post, as a String
def self.initialized_post_name def initialized_post_name
"_posts/#{Time.now.strftime('%Y-%m-%d')}-welcome-to-jekyll.markdown" "_posts/#{Time.now.strftime('%Y-%m-%d')}-welcome-to-jekyll.markdown"
end end
private private
def self.preserve_source_location?(path, options) def preserve_source_location?(path, options)
!options["force"] && !Dir["#{path}/**/*"].empty? !options["force"] && !Dir["#{path}/**/*"].empty?
end end
def self.create_sample_files(path) def create_sample_files(path)
FileUtils.cp_r site_template + '/.', path FileUtils.cp_r site_template + '/.', path
FileUtils.rm File.expand_path(scaffold_path, path) FileUtils.rm File.expand_path(scaffold_path, path)
end end
def self.site_template def site_template
File.expand_path("../../site_template", File.dirname(__FILE__)) File.expand_path("../../site_template", File.dirname(__FILE__))
end end
def self.scaffold_path def scaffold_path
"_posts/0000-00-00-welcome-to-jekyll.markdown.erb" "_posts/0000-00-00-welcome-to-jekyll.markdown.erb"
end end
end end
end end
end
end end