From fccb952bf960ca937af70bca90be4b5739389b7d Mon Sep 17 00:00:00 2001 From: maimu Date: Sun, 12 Nov 2023 14:54:08 +0900 Subject: [PATCH] =?UTF-8?q?Rakefile=E3=81=AE=E5=86=85=E5=AE=B9=E3=82=92?= =?UTF-8?q?=E4=BF=AE=E6=AD=A3=E3=81=97=E3=80=81README=E3=82=82=E5=90=88?= =?UTF-8?q?=E3=82=8F=E3=81=9B=E3=81=A6=E4=BF=AE=E6=AD=A3=E3=81=97=E3=81=9F?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit ガイドを作成するrakeコマンドが `post` を指定する形になっていて何を作成するコマンドかが判断しにくくなっていたため、明示的に`guide`を指定するように修正しました。 ``` bundle exec rake guide title="my fabulous guide" ``` `CoC` や `About` のようなドメイン直下のページを新規で作成するコマンドがなかったため追加しました。 ``` $ bundle exec rake original_content title="new original content" ``` `_pages-jp` 配下に新規ファイルが作成されます。 ファイル作成時には以下の項目がデフォルトで追加されるようにしてあります。 ``` --- layout: original_content title: "my fabulous post" permalink: --- ``` 独立したページを作成するコマンドを実行すると、「ディレクトリ+ファイル」が生成されるため、コマンド名もそれが明示的にわかるように修正しました。 ``` $ bundle exec rake directory_with_page name="something" ``` 1~3に合わせてREADMEを修正しました。 --- README.md | 21 ++++++++++---- Rakefile | 84 ++++++++++++++++++++++++++++++++++++++++--------------- 2 files changed, 77 insertions(+), 28 deletions(-) diff --git a/README.md b/README.md index 0ad1c609..83fba236 100644 --- a/README.md +++ b/README.md @@ -37,20 +37,31 @@ $ bundle exec jekyll serve --watch ## ガイドを追加 ``` -$ bundle exec rake post title="my fabulous post" +$ bundle exec rake guide title="my fabulous guide" ``` -を実行すると、`YYYY-MM-DD-my-fabulous-post.markdown` というテンプレートが `_pages` ディレクトリに作られるので、これを編集します。`_pages` ディレクトリ以下のファイルは最初の部分に permalink の記述がなければ、ブログポストして扱われます。permalink がある場合は、どこかのページから permalink で指定した URL へリンクします。 +を実行すると、`YYYY-MM-DD-my-fabulous-guide.markdown` というテンプレートが `_pages` ディレクトリに作られるので、これを編集します。`_pages` ディレクトリ以下のファイルは最初の部分に permalink の記述がなければ、ブログポストして扱われます。permalink がある場合は、どこかのページから permalink で指定した URL へリンクします。 ## 独自コンテンツを追加 -このサイトの About や Event のような独立したページを作りたい場合は +独立したページを作成する場合以下の2通りの方法があります。 + +### Event のような独自ディレクトリ配下にページを作りたい場合 + +``` +$ bundle exec rake directory_with_page name="something" +``` + +を実行します。この場合、`something/index.html` という名前でテンプレートが作られるので、これを編集します。編集完了後、Homeなどのページからリンクさせます。 + +### CoC や About のようなドメイン直下のページを作りたい場合 ``` -$ bundle exec rake page name="something" +$ bundle exec rake original_content title="new original content" ``` -を実行します。この場合、`something/index.html` という名前でテンプレートが作られるので、これを編集します。このファイルも、どこかのページからリンクします。 +を実行します。 +`YYYY-MM-DD-new_original_content.markdown` というテンプレートが `_pages-jp` ディレクトリに作られるので、これを編集します。Homeなどのページから permalink で指定した URL へリンクさせます。 ## ブログを書く diff --git a/Rakefile b/Rakefile index 572b622b..38bc4a9c 100644 --- a/Rakefile +++ b/Rakefile @@ -9,15 +9,18 @@ CONFIG = { 'layouts' => File.join(SOURCE, "_layouts"), 'pages' => File.join(SOURCE, "_pages"), 'posts' => File.join(SOURCE, "_posts"), + 'pages-jp' => File.join(SOURCE, "_pages-jp"), 'post_ext' => "markdown", 'page_ext' => "markdown" } -# Usage: rake post title="A Title" [date="2012-02-09"] -desc "Begin a new post in #{CONFIG['pages']}" -task :post do +desc <<~DESK + Begin a new guide in #{CONFIG['pages']} + Usage: rake guide title="A Title" [date="2012-02-09"] +DESK +task :guide do abort("rake aborted: '#{CONFIG['pages']}' directory not found.") unless FileTest.directory?(CONFIG['pages']) - title = ENV["title"] || "new-post" + title = ENV["title"] || "new-guide" slug = title.downcase.strip.gsub(' ', '-').gsub(/[^\w-]/, '') begin date = (ENV['date'] ? Time.parse(ENV['date']) : Time.now).strftime('%Y-%m-%d') @@ -30,21 +33,23 @@ task :post do abort("rake aborted!") if ask("#{filename} already exists. Do you want to overwrite?", ['y', 'n']) == 'n' end - puts "Creating new post: #{filename}" - open(filename, 'w') do |post| - post.puts "---" - post.puts "layout: page" - post.puts "title: \"#{title.gsub(/-/,' ')}\"" - post.puts 'description: ""' - post.puts "category: " - post.puts "tags: []" - post.puts "---" - post.puts "" + puts "Creating new guide: #{filename}" + open(filename, 'w') do |guide| + guide.puts "---" + guide.puts "layout: page" + guide.puts "title: \"#{title.gsub(/-/,' ')}\"" + guide.puts 'description: ""' + guide.puts "category: " + guide.puts "tags: []" + guide.puts "---" + guide.puts "" end -end # task :post +end # task :guide -# Usage: rake blog title="A Title" [date="2012-02-09"] [post_ext="html"] -desc "Begin a new post in #{CONFIG['posts']}/blog" +desc <<~DESK + Begin a new post in #{CONFIG['posts']}/blog + Usage: rake blog title="A Title" [date="2012-02-09"] [post_ext="html"] +DESK task :blog do abort("rake aborted: '#{CONFIG['posts']}' directory not found.") unless FileTest.directory?(CONFIG['posts']) title = ENV["title"] || "new-post" @@ -73,11 +78,44 @@ task :blog do end end # task :blog -# Usage: rake page name="about.html" -# You can also specify a sub-directory path. -# If you don't specify a file extension we create an index.markdown at the path specified -desc "Create a new page." -task :page do +desc <<~DESK + Begin a new original_content in #{CONFIG['pages-jp']} + Usage: rake original_content title="A Title" [date="2012-02-09"] +DESK +task :original_content do + abort("rake aborted: '#{CONFIG['pages-jp']}' directory not found.") unless FileTest.directory?(CONFIG['pages-jp']) + title = ENV["title"] || "new-oroginal_contents" + slug = title.downcase.strip.gsub(' ', '-').gsub(/[^\w-]/, '') + begin + date = (ENV['date'] ? Time.parse(ENV['date']) : Time.now).strftime('%Y-%m-%d') + rescue Exception => e + puts "Error - date format must be YYYY-MM-DD, please check you typed it correctly!" + exit -1 + end + post_ext = ENV['post_ext'] || CONFIG['post_ext'] + filename = File.join(CONFIG['pages-jp'], "#{date}-#{slug}.#{post_ext}") + if File.exist?(filename) + abort("rake aborted!") if ask("#{filename} already exists. Do you want to overwrite?", ['y', 'n']) == 'n' + end + + puts "Creating new post: #{filename}" + open(filename, 'w') do |original_content| + original_content.puts "---" + original_content.puts "layout: original_content" + original_content.puts "title: \"#{title.gsub(/-/,' ')}\"" + original_content.puts "permalink: " + original_content.puts "---" + original_content.puts "" + end +end # task :original_contents + +desc <<~DESK + Create a new directory and page. + Usage: rake page name="about.html" + You can also specify a sub-directory path. + If you don't specify a file extension we create an index.markdown at the path specified +DESK +task :directory_with_page do name = ENV["name"] || "new-page.md" filename = File.join(SOURCE, "#{name}") filename = File.join(filename, "index.markdown") if File.extname(filename) == "" @@ -96,7 +134,7 @@ task :page do post.puts "---" post.puts "" end -end # task :page +end # task :directory_with_page desc "Launch preview environment" task :preview do