Skip to content

Commit

Permalink
Rakefileの内容を修正し、READMEも合わせて修正した
Browse files Browse the repository at this point in the history
ガイドを作成する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を修正しました。
  • Loading branch information
maimu authored and maimux2x committed Nov 20, 2023
1 parent cf99c4b commit fccb952
Show file tree
Hide file tree
Showing 2 changed files with 77 additions and 28 deletions.
21 changes: 16 additions & 5 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -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 へリンクさせます。

## ブログを書く

Expand Down
84 changes: 61 additions & 23 deletions Rakefile
Original file line number Diff line number Diff line change
Expand Up @@ -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')
Expand All @@ -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"
Expand Down Expand Up @@ -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) == ""
Expand All @@ -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
Expand Down

0 comments on commit fccb952

Please sign in to comment.