class Jekyll::Commands::New

Public Class Methods

create_blank_site(path) click to toggle source
# File lib/jekyll/commands/new.rb, line 43
def create_blank_site(path)
  Dir.chdir(path) do
    FileUtils.mkdir(%w(_layouts _posts _drafts))
    FileUtils.touch("index.html")
  end
end
init_with_program(prog) click to toggle source
# File lib/jekyll/commands/new.rb, line 9
def init_with_program(prog)
  prog.command(:new) do |c|
    c.syntax "new PATH"
    c.description "Creates a new Jekyll site scaffold in PATH"

    c.option "force", "--force", "Force creation even if PATH already exists"
    c.option "blank", "--blank", "Creates scaffolding but with empty files"

    c.action do |args, options|
      Jekyll::Commands::New.process(args, options)
    end
  end
end
initialized_post_name() click to toggle source

Internal: Gets the filename of the sample post to be created

Returns the filename of the sample post, as a String

# File lib/jekyll/commands/new.rb, line 57
def initialized_post_name
  "_posts/#{Time.now.strftime("%Y-%m-%d")}-welcome-to-jekyll.markdown"
end
process(args, options = {}) click to toggle source
# File lib/jekyll/commands/new.rb, line 23
def process(args, options = {})
  raise ArgumentError, "You must specify a path." if args.empty?

  new_blog_path = File.expand_path(args.join(" "), Dir.pwd)
  FileUtils.mkdir_p new_blog_path
  if preserve_source_location?(new_blog_path, options)
    Jekyll.logger.error "Conflict:", "#{new_blog_path} exists and is not empty."
    Jekyll.logger.abort_with "", "Ensure #{new_blog_path} is empty or else " \
              "try again with `--force` to proceed and overwrite any files."
  end

  if options["blank"]
    create_blank_site new_blog_path
  else
    create_site new_blog_path
  end

  after_install(new_blog_path, options)
end
scaffold_post_content() click to toggle source
# File lib/jekyll/commands/new.rb, line 50
def scaffold_post_content
  ERB.new(File.read(File.expand_path(scaffold_path, site_template))).result
end

Private Class Methods

after_install(path, options = {}) click to toggle source

After a new blog has been created, print a success notification

# File lib/jekyll/commands/new.rb, line 133
def after_install(path, options = {})
  Jekyll.logger.info "New jekyll site installed in #{path.cyan}."
end
create_sample_files(path) click to toggle source
# File lib/jekyll/commands/new.rb, line 118
def create_sample_files(path)
  FileUtils.cp_r site_template + "/.", path
  FileUtils.chmod_R "u+w", path
  FileUtils.rm File.expand_path(scaffold_path, path)
end
create_site(new_blog_path) click to toggle source
# File lib/jekyll/commands/new.rb, line 102
def create_site(new_blog_path)
  create_sample_files new_blog_path

  File.open(File.expand_path(initialized_post_name, new_blog_path), "w") do |f|
    f.write(scaffold_post_content)
  end

  File.open(File.expand_path("Gemfile", new_blog_path), "w") do |f|
    f.write(gemfile_contents)
  end
end
gemfile_contents() click to toggle source
# File lib/jekyll/commands/new.rb, line 63
        def gemfile_contents
          <<-RUBY
source "https://rubygems.org"

# Hello! This is where you manage which Jekyll version is used to run.
# When you want to use a different version, change it below, save the
# file and run `bundle install`. Run Jekyll with `bundle exec`, like so:
#
#     bundle exec jekyll serve
#
# This will help ensure the proper Jekyll version is running.
# Happy Jekylling!
gem "jekyll", "~> #{Jekyll::VERSION}"

# This is the default theme for new Jekyll sites. You may change this to anything you like.
gem "minima", "~> 2.0"

# If you want to use GitHub Pages, remove the "gem "jekyll"" above and
# uncomment the line below. To upgrade, run `bundle update github-pages`.
# gem "github-pages", group: :jekyll_plugins

# If you have any plugins, put them here!
group :jekyll_plugins do
  gem "jekyll-feed", "~> 0.6"
end

# Windows does not include zoneinfo files, so bundle the tzinfo-data gem
# and associated library.
install_if -> { RUBY_PLATFORM =~ %r!mingw|mswin|java! } do
  gem "tzinfo", "~> 1.2"
  gem "tzinfo-data"
end

# Performance-booster for watching directories on Windows
gem "wdm", "~> 0.1.0", :install_if => Gem.win_platform?

RUBY
        end
preserve_source_location?(path, options) click to toggle source
# File lib/jekyll/commands/new.rb, line 114
def preserve_source_location?(path, options)
  !options["force"] && !Dir["#{path}/**/*"].empty?
end
scaffold_path() click to toggle source
# File lib/jekyll/commands/new.rb, line 128
def scaffold_path
  "_posts/0000-00-00-welcome-to-jekyll.markdown.erb"
end
site_template() click to toggle source
# File lib/jekyll/commands/new.rb, line 124
def site_template
  File.expand_path("../../site_template", __dir__)
end