retter 0.0.0 → 0.0.1
Sign up to get free protection for your applications and to get access to all the features.
- data/README.md +62 -0
- data/lib/generator/skel/Gemfile +1 -0
- data/lib/retter/command.rb +3 -3
- data/lib/retter/config.rb +49 -56
- data/lib/retter/stationery/binder.rb +30 -38
- data/lib/retter/stationery/previewer.rb +11 -7
- data/lib/retter/stationery/view.rb +3 -0
- data/lib/retter/stationery.rb +5 -5
- data/lib/retter/version.rb +1 -1
- data/lib/retter.rb +2 -1
- data/spec/command/preview_spec.rb +1 -1
- data/spec/command/rebind_spec.rb +1 -1
- metadata +27 -26
data/README.md
ADDED
@@ -0,0 +1,62 @@
|
|
1
|
+
# RETTER (レッター) Lightweight diary workflow.
|
2
|
+
|
3
|
+
コマンドラインで簡単に起動してブラウザですぐに確認できてデプロイがちょう楽そうな日記作成支援コマンドをつくる予定。
|
4
|
+
|
5
|
+
## Installation
|
6
|
+
|
7
|
+
*ruby-1.9.2* or later is required.
|
8
|
+
|
9
|
+
~~~~
|
10
|
+
gem install retter
|
11
|
+
~~~~
|
12
|
+
|
13
|
+
## Usage
|
14
|
+
|
15
|
+
To create new site, use `new` subcommand.
|
16
|
+
|
17
|
+
~~~~
|
18
|
+
$ retter new my_sweet_diary
|
19
|
+
~~~~
|
20
|
+
|
21
|
+
You can use `retter` command anywhere, If you set `$RETTER_HOME` variable.
|
22
|
+
|
23
|
+
~~~~
|
24
|
+
$ echo "export RETTER_HOME=/path/to/my_sweet_diary" >> ~/.bash_profile
|
25
|
+
$ . ~/.bash_profile
|
26
|
+
~~~~
|
27
|
+
|
28
|
+
`retter` command open `$EDITOR`. You can write an article with Markdown.
|
29
|
+
The article will be draft.
|
30
|
+
|
31
|
+
~~~~
|
32
|
+
$ cd /path/to/my_sweet_diary # You can skip this step if you already set $RETTER_HOME.
|
33
|
+
$ retter
|
34
|
+
~~~~
|
35
|
+
|
36
|
+
`preview` sub-command open the draft article by your default browser.
|
37
|
+
|
38
|
+
~~~~
|
39
|
+
$ retter preview
|
40
|
+
~~~~
|
41
|
+
|
42
|
+
`bind` and `rebind` sub-command save the draft article.
|
43
|
+
And generate actual web pages.
|
44
|
+
|
45
|
+
~~~~
|
46
|
+
$ retter bind
|
47
|
+
~~~~
|
48
|
+
|
49
|
+
`open` sub-command open your web site by your default browser.
|
50
|
+
|
51
|
+
~~~~
|
52
|
+
$ retter open
|
53
|
+
~~~~
|
54
|
+
|
55
|
+
You can use rack, if you needed.
|
56
|
+
|
57
|
+
~~~~
|
58
|
+
$ cd /path/to/my_sweet_diary
|
59
|
+
$ bundle exec rackup
|
60
|
+
~~~~
|
61
|
+
|
62
|
+
|
data/lib/generator/skel/Gemfile
CHANGED
data/lib/retter/command.rb
CHANGED
@@ -12,7 +12,7 @@ class Retter::Command < Thor
|
|
12
12
|
desc 'preview', 'Preview current entry'
|
13
13
|
method_options date: :string
|
14
14
|
def preview
|
15
|
-
preview = Retter::Stationery.previewer(
|
15
|
+
preview = Retter::Stationery.previewer(config, detected_date)
|
16
16
|
|
17
17
|
preview.print
|
18
18
|
Launchy.open preview.file_path.to_s
|
@@ -42,9 +42,9 @@ class Retter::Command < Thor
|
|
42
42
|
|
43
43
|
def detected_retter_file
|
44
44
|
if options[:date]
|
45
|
-
config.retter_file(Date.parse(options[:date])
|
45
|
+
config.retter_file(Date.parse(options[:date]))
|
46
46
|
else
|
47
|
-
todays_file = config.retter_file(Date.today
|
47
|
+
todays_file = config.retter_file(Date.today)
|
48
48
|
todays_file.exist? ? todays_file : config.wip_file
|
49
49
|
end
|
50
50
|
end
|
data/lib/retter/config.rb
CHANGED
@@ -1,7 +1,28 @@
|
|
1
1
|
# coding: utf-8
|
2
2
|
|
3
3
|
class Retter::Config
|
4
|
-
[
|
4
|
+
ATTRIBUTES = [
|
5
|
+
:editor,
|
6
|
+
:title,
|
7
|
+
:description,
|
8
|
+
:url,
|
9
|
+
:author,
|
10
|
+
:retters_dir,
|
11
|
+
:wip_file,
|
12
|
+
:layouts_dir,
|
13
|
+
:layout_file,
|
14
|
+
:profile_layout_file,
|
15
|
+
:entry_layout_file,
|
16
|
+
:entries_layout_file,
|
17
|
+
:index_layout_file,
|
18
|
+
:entries_dir,
|
19
|
+
:profile_file,
|
20
|
+
:index_file,
|
21
|
+
:entries_file,
|
22
|
+
:feed_file
|
23
|
+
]
|
24
|
+
|
25
|
+
ATTRIBUTES.each do |att|
|
5
26
|
class_eval <<-EOM
|
6
27
|
def #{att}(val = nil)
|
7
28
|
val ? @options[:#{att}] = val : @options[:#{att}]
|
@@ -9,81 +30,53 @@ class Retter::Config
|
|
9
30
|
EOM
|
10
31
|
end
|
11
32
|
|
33
|
+
attr_reader :retter_home
|
34
|
+
|
12
35
|
def initialize(env)
|
13
36
|
@env, @options = env, {}
|
14
37
|
|
15
38
|
detect_retter_home
|
16
39
|
raise Retter::EnvError unless env.values_at('EDITOR', 'RETTER_HOME').all?
|
17
40
|
|
18
|
-
|
19
|
-
|
20
|
-
url 'http://example.com'
|
41
|
+
@retter_home = Pathname.new(@env['RETTER_HOME'])
|
42
|
+
load_defaults
|
21
43
|
|
22
44
|
retterfile = retter_home.join('Retterfile')
|
23
45
|
instance_eval retterfile.read if retterfile.exist?
|
24
46
|
end
|
25
47
|
|
26
|
-
def
|
27
|
-
@env['
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
retter_home.join
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
48
|
+
def load_defaults
|
49
|
+
editor @env['EDITOR']
|
50
|
+
url 'http://example.com'
|
51
|
+
retters_dir retter_home.join('retters/')
|
52
|
+
wip_file retters_dir.join('today.md')
|
53
|
+
layouts_dir retter_home.join('layouts/')
|
54
|
+
layout_file layouts_dir.join('retter.html.haml')
|
55
|
+
profile_layout_file layouts_dir.join('profile.html.haml')
|
56
|
+
entry_layout_file layouts_dir.join('entry.html.haml')
|
57
|
+
entries_layout_file layouts_dir.join('entries.html.haml')
|
58
|
+
index_layout_file layouts_dir.join('index.html.haml')
|
59
|
+
entries_dir retter_home.join('entries/')
|
60
|
+
profile_file retter_home.join('profile.html')
|
61
|
+
index_file retter_home.join('index.html')
|
62
|
+
entries_file retter_home.join('entries.html')
|
63
|
+
feed_file retter_home.join('entries.rss')
|
36
64
|
end
|
37
65
|
|
38
|
-
def
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
def layouts_dir
|
43
|
-
retter_home.join 'layouts/'
|
44
|
-
end
|
45
|
-
|
46
|
-
def layout_file
|
47
|
-
layouts_dir.join 'retter.html.haml'
|
48
|
-
end
|
49
|
-
|
50
|
-
def profile_layout_file
|
51
|
-
layouts_dir.join 'profile.html.haml'
|
52
|
-
end
|
53
|
-
|
54
|
-
def entry_layout_file
|
55
|
-
layouts_dir.join 'entry.html.haml'
|
56
|
-
end
|
57
|
-
|
58
|
-
def entries_layout_file
|
59
|
-
layouts_dir.join 'entries.html.haml'
|
60
|
-
end
|
61
|
-
|
62
|
-
def index_layout_file
|
63
|
-
layouts_dir.join 'index.html.haml'
|
66
|
+
def detect_retter_home
|
67
|
+
# TODO こういうの上のディレクトリも見て判断するのを何か参考にして書く
|
68
|
+
@env['RETTER_HOME'] = Dir.pwd if File.exist? 'Retterfile'
|
64
69
|
end
|
65
70
|
|
66
|
-
def
|
67
|
-
|
71
|
+
def retter_file(date)
|
72
|
+
retters_dir.join(date ? date.strftime("%Y%m%d.md") : "today.md")
|
68
73
|
end
|
69
74
|
|
70
75
|
def entry_file(date)
|
71
76
|
entries_dir.join date.strftime('%Y%m%d.html')
|
72
77
|
end
|
73
78
|
|
74
|
-
def
|
75
|
-
|
76
|
-
end
|
77
|
-
|
78
|
-
def index_file
|
79
|
-
retter_home.join 'index.html'
|
80
|
-
end
|
81
|
-
|
82
|
-
def entries_file
|
83
|
-
retter_home.join 'entries.html'
|
84
|
-
end
|
85
|
-
|
86
|
-
def feed_file
|
87
|
-
retter_home.join 'entries.rss'
|
79
|
+
def self.delegatables
|
80
|
+
ATTRIBUTES + [:retter_file, :entry_file]
|
88
81
|
end
|
89
82
|
end
|
@@ -4,6 +4,10 @@ module Retter::Stationery
|
|
4
4
|
class Binder
|
5
5
|
attr_reader :config, :entries
|
6
6
|
|
7
|
+
extend Forwardable
|
8
|
+
|
9
|
+
def_delegators :@config, *Retter::Config.delegatables
|
10
|
+
|
7
11
|
def initialize(config)
|
8
12
|
@config = config
|
9
13
|
end
|
@@ -12,30 +16,18 @@ module Retter::Stationery
|
|
12
16
|
@view_scope ||= View::Scope.new(config, entries: entries)
|
13
17
|
end
|
14
18
|
|
15
|
-
def
|
16
|
-
Haml::Engine.new(
|
17
|
-
end
|
18
|
-
|
19
|
-
def entries_renderer
|
20
|
-
Haml::Engine.new(config.entries_layout_file.read, ugly: true)
|
19
|
+
def layout_renderer
|
20
|
+
@layout_renderer ||= Haml::Engine.new(layout_file.read, ugly: true)
|
21
21
|
end
|
22
22
|
|
23
23
|
def entry_renderer
|
24
|
-
Haml::Engine.new(
|
25
|
-
end
|
26
|
-
|
27
|
-
def index_renderer
|
28
|
-
Haml::Engine.new(config.index_layout_file.read, ugly: true)
|
29
|
-
end
|
30
|
-
|
31
|
-
def profile_renderer
|
32
|
-
Haml::Engine.new(config.profile_layout_file.read, ugly: true)
|
24
|
+
@entry_renderer ||= Haml::Engine.new(entry_layout_file.read, ugly: true)
|
33
25
|
end
|
34
26
|
|
35
27
|
def rebind!
|
36
28
|
commit_wip_file
|
37
29
|
|
38
|
-
@entries = Retter::Stationery.scan(
|
30
|
+
@entries = Retter::Stationery.scan(retters_dir)
|
39
31
|
|
40
32
|
bind_entries
|
41
33
|
print_index
|
@@ -44,10 +36,10 @@ module Retter::Stationery
|
|
44
36
|
end
|
45
37
|
|
46
38
|
def commit_wip_file
|
47
|
-
if
|
48
|
-
html =
|
49
|
-
|
50
|
-
|
39
|
+
if wip_file.exist?
|
40
|
+
html = wip_file.read
|
41
|
+
retter_file(Date.today).open('a') {|f| f.puts html }
|
42
|
+
wip_file.unlink
|
51
43
|
end
|
52
44
|
end
|
53
45
|
|
@@ -58,42 +50,42 @@ module Retter::Stationery
|
|
58
50
|
|
59
51
|
def print_entry(entry)
|
60
52
|
part = entry_renderer.render(view_scope, entry: entry)
|
61
|
-
html =
|
53
|
+
html = layout_renderer.render(view_scope, content: part)
|
62
54
|
|
63
|
-
|
55
|
+
entry_file(entry.date).open('w') do |f|
|
64
56
|
f.puts View::Helper.fix_path(html, '../')
|
65
57
|
end
|
66
58
|
end
|
67
59
|
|
68
60
|
def print_index
|
69
|
-
part =
|
70
|
-
html =
|
61
|
+
part = Haml::Engine.new(index_layout_file.read, ugly: true).render(view_scope)
|
62
|
+
html = layout_renderer.render(view_scope, content: part)
|
71
63
|
|
72
|
-
|
64
|
+
index_file.open('w') do |f|
|
73
65
|
f.puts View::Helper.fix_path(html, './')
|
74
66
|
end
|
75
67
|
end
|
76
68
|
|
77
69
|
def print_profile
|
78
|
-
part =
|
79
|
-
html =
|
70
|
+
part = Haml::Engine.new(profile_layout_file.read, ugly: true).render(view_scope)
|
71
|
+
html = layout_renderer.render(view_scope, content: part)
|
80
72
|
|
81
|
-
|
73
|
+
profile_file.open('w') do |f|
|
82
74
|
f.puts View::Helper.fix_path(html, './')
|
83
75
|
end
|
84
76
|
end
|
85
77
|
|
86
78
|
def print_toc
|
87
|
-
part =
|
88
|
-
html =
|
79
|
+
part = Haml::Engine.new(entries_layout_file.read, ugly: true).render(view_scope)
|
80
|
+
html = layout_renderer.render(view_scope, content: part)
|
89
81
|
|
90
|
-
|
82
|
+
entries_file.open('w') do |f|
|
91
83
|
f.puts View::Helper.fix_path(html, './')
|
92
84
|
end
|
93
85
|
end
|
94
86
|
|
95
87
|
def print_rss
|
96
|
-
|
88
|
+
feed_file.open('w') {|f| f.puts rss }
|
97
89
|
end
|
98
90
|
|
99
91
|
def rss
|
@@ -103,11 +95,11 @@ module Retter::Stationery
|
|
103
95
|
:'xmlns:rdf' => 'http://www.w3.org/1999/02/22-rdf-syntax-ns#',
|
104
96
|
:'xmlns:dc' => 'http://purl.org/dc/elements/1.1/',
|
105
97
|
:'xml:lang' => 'ja' do
|
106
|
-
xml.channel :'rdf:about' =>
|
107
|
-
xml.title
|
108
|
-
xml.link
|
98
|
+
xml.channel :'rdf:about' => url do
|
99
|
+
xml.title title
|
100
|
+
xml.link url
|
109
101
|
xml.dc:date, entries.first.date
|
110
|
-
xml.description
|
102
|
+
xml.description description
|
111
103
|
xml.items { xml.rdf(:Seq) { entries.each {|e| xml.rdf:li, :'rdf:resource' => entry_url(e.date) } } }
|
112
104
|
end
|
113
105
|
|
@@ -117,14 +109,14 @@ module Retter::Stationery
|
|
117
109
|
xml.description { xml.cdata! entry.body }
|
118
110
|
xml.dc:date, entry.date
|
119
111
|
xml.link entry_url(entry.date)
|
120
|
-
xml.author
|
112
|
+
xml.author author
|
121
113
|
end
|
122
114
|
end
|
123
115
|
end
|
124
116
|
end
|
125
117
|
|
126
118
|
def entry_url(date, id = nil)
|
127
|
-
(URI.parse(
|
119
|
+
(URI.parse(url) + date.strftime('/entries/%Y%m%d.html')).to_s
|
128
120
|
end
|
129
121
|
end
|
130
122
|
end
|
@@ -4,7 +4,11 @@ module Retter::Stationery
|
|
4
4
|
class Previewer
|
5
5
|
attr_reader :config
|
6
6
|
|
7
|
-
|
7
|
+
extend Forwardable
|
8
|
+
|
9
|
+
def_delegators :@config, *Retter::Config.delegatables
|
10
|
+
|
11
|
+
def initialize(config, date)
|
8
12
|
@config, @date = config, date
|
9
13
|
@body, @entry = *nil
|
10
14
|
|
@@ -17,11 +21,11 @@ module Retter::Stationery
|
|
17
21
|
end
|
18
22
|
|
19
23
|
def renderer
|
20
|
-
Haml::Engine.new(
|
24
|
+
Haml::Engine.new(layout_file.read, ugly: true)
|
21
25
|
end
|
22
26
|
|
23
27
|
def entry_renderer
|
24
|
-
Haml::Engine.new(
|
28
|
+
Haml::Engine.new(entry_layout_file.read, ugly: true)
|
25
29
|
end
|
26
30
|
|
27
31
|
def print
|
@@ -42,17 +46,17 @@ module Retter::Stationery
|
|
42
46
|
end
|
43
47
|
|
44
48
|
def build_entry
|
45
|
-
@entry = Retter::Entry.new(date: @date, body: Retter::Stationery.
|
49
|
+
@entry = Retter::Entry.new(date: @date, body: Retter::Stationery.markupper.render(@body))
|
46
50
|
end
|
47
51
|
|
48
52
|
def load_retter_file
|
49
|
-
retter_file =
|
53
|
+
retter_file = retter_file(@date)
|
50
54
|
@body = retter_file.exist? ? retter_file.read : ''
|
51
55
|
end
|
52
56
|
|
53
57
|
def load_wip_entry_if_needed
|
54
|
-
if @date == Date.today &&
|
55
|
-
@body = [@body,
|
58
|
+
if @date == Date.today && wip_file.exist?
|
59
|
+
@body = [@body, wip_file.read].join("\n")
|
56
60
|
end
|
57
61
|
end
|
58
62
|
end
|
data/lib/retter/stationery.rb
CHANGED
@@ -6,7 +6,7 @@ module Retter::Stationery
|
|
6
6
|
entries = find_markup_files(path).map {|file|
|
7
7
|
date = file.basename('.*').to_s
|
8
8
|
mkup = File.open(file, &:read)
|
9
|
-
Retter::Entry.new date: Date.parse(date), body:
|
9
|
+
Retter::Entry.new date: Date.parse(date), body: markupper.render(mkup)
|
10
10
|
}
|
11
11
|
|
12
12
|
entries.sort_by(&:date).reverse
|
@@ -17,8 +17,8 @@ module Retter::Stationery
|
|
17
17
|
Dir.open(path, &:to_a).grep(/^\d{4}(?:0[1-9]|1[012])(?:0[1-9]|[12][0-9]|3[01])\.(md)$/).map {|f| path.join f }
|
18
18
|
end
|
19
19
|
|
20
|
-
def
|
21
|
-
@
|
20
|
+
def markupper
|
21
|
+
@markupper ||= ::Redcarpet::Markdown.new(
|
22
22
|
Renderer,
|
23
23
|
autolink: true,
|
24
24
|
space_after_headers: true,
|
@@ -30,8 +30,8 @@ module Retter::Stationery
|
|
30
30
|
)
|
31
31
|
end
|
32
32
|
|
33
|
-
def previewer(
|
34
|
-
Previewer.new
|
33
|
+
def previewer(config, date)
|
34
|
+
Previewer.new config, date
|
35
35
|
end
|
36
36
|
|
37
37
|
def binder(config)
|
data/lib/retter/version.rb
CHANGED
data/lib/retter.rb
CHANGED
@@ -18,8 +18,9 @@ require 'nokogiri'
|
|
18
18
|
require 'launchy'
|
19
19
|
require 'haml'
|
20
20
|
require 'uri'
|
21
|
+
require 'forwardable'
|
21
22
|
require 'retter/version'
|
22
23
|
require 'retter/entry'
|
23
|
-
require 'retter/stationery'
|
24
24
|
require 'retter/config'
|
25
|
+
require 'retter/stationery'
|
25
26
|
require 'retter/command'
|
@@ -6,7 +6,7 @@ describe 'Retter::Command#preview', clean: :all do
|
|
6
6
|
let(:command) { Retter::Command.new }
|
7
7
|
let(:preview) { retter_config.retter_home.join('.preview.html').read }
|
8
8
|
let(:wip_file) { retter_config.wip_file }
|
9
|
-
let(:date_file) { retter_config.retter_file(Date.parse(date)
|
9
|
+
let(:date_file) { retter_config.retter_file(Date.parse(date)) }
|
10
10
|
|
11
11
|
before do
|
12
12
|
command.stub!(:config) { retter_config }
|
data/spec/command/rebind_spec.rb
CHANGED
@@ -5,7 +5,7 @@ require File.dirname(__FILE__) + '/../spec_helper'
|
|
5
5
|
describe 'Retter::Command#rebind', clean: :all do
|
6
6
|
let(:command) { Retter::Command.new }
|
7
7
|
let(:wip_file) { retter_config.wip_file }
|
8
|
-
let(:date_file) { retter_config.retter_file(Date.parse(date)
|
8
|
+
let(:date_file) { retter_config.retter_file(Date.parse(date)) }
|
9
9
|
let(:date_html) { retter_config.retter_home.join('entries', "#{date}.html") }
|
10
10
|
|
11
11
|
before do
|
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: retter
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.0.
|
4
|
+
version: 0.0.1
|
5
5
|
prerelease:
|
6
6
|
platform: ruby
|
7
7
|
authors:
|
@@ -9,11 +9,11 @@ authors:
|
|
9
9
|
autorequire:
|
10
10
|
bindir: bin
|
11
11
|
cert_chain: []
|
12
|
-
date: 2011-09-
|
12
|
+
date: 2011-09-09 00:00:00.000000000Z
|
13
13
|
dependencies:
|
14
14
|
- !ruby/object:Gem::Dependency
|
15
15
|
name: thor
|
16
|
-
requirement: &
|
16
|
+
requirement: &70276239686360 !ruby/object:Gem::Requirement
|
17
17
|
none: false
|
18
18
|
requirements:
|
19
19
|
- - ! '>='
|
@@ -21,10 +21,10 @@ dependencies:
|
|
21
21
|
version: '0'
|
22
22
|
type: :runtime
|
23
23
|
prerelease: false
|
24
|
-
version_requirements: *
|
24
|
+
version_requirements: *70276239686360
|
25
25
|
- !ruby/object:Gem::Dependency
|
26
26
|
name: builder
|
27
|
-
requirement: &
|
27
|
+
requirement: &70276239685920 !ruby/object:Gem::Requirement
|
28
28
|
none: false
|
29
29
|
requirements:
|
30
30
|
- - ! '>='
|
@@ -32,10 +32,10 @@ dependencies:
|
|
32
32
|
version: '0'
|
33
33
|
type: :runtime
|
34
34
|
prerelease: false
|
35
|
-
version_requirements: *
|
35
|
+
version_requirements: *70276239685920
|
36
36
|
- !ruby/object:Gem::Dependency
|
37
37
|
name: redcarpet
|
38
|
-
requirement: &
|
38
|
+
requirement: &70276239685400 !ruby/object:Gem::Requirement
|
39
39
|
none: false
|
40
40
|
requirements:
|
41
41
|
- - ! '>='
|
@@ -43,10 +43,10 @@ dependencies:
|
|
43
43
|
version: 2.0.0b3
|
44
44
|
type: :runtime
|
45
45
|
prerelease: false
|
46
|
-
version_requirements: *
|
46
|
+
version_requirements: *70276239685400
|
47
47
|
- !ruby/object:Gem::Dependency
|
48
48
|
name: coderay
|
49
|
-
requirement: &
|
49
|
+
requirement: &70276239684980 !ruby/object:Gem::Requirement
|
50
50
|
none: false
|
51
51
|
requirements:
|
52
52
|
- - ! '>='
|
@@ -54,10 +54,10 @@ dependencies:
|
|
54
54
|
version: '0'
|
55
55
|
type: :runtime
|
56
56
|
prerelease: false
|
57
|
-
version_requirements: *
|
57
|
+
version_requirements: *70276239684980
|
58
58
|
- !ruby/object:Gem::Dependency
|
59
59
|
name: nokogiri
|
60
|
-
requirement: &
|
60
|
+
requirement: &70276239684520 !ruby/object:Gem::Requirement
|
61
61
|
none: false
|
62
62
|
requirements:
|
63
63
|
- - ! '>='
|
@@ -65,10 +65,10 @@ dependencies:
|
|
65
65
|
version: '0'
|
66
66
|
type: :runtime
|
67
67
|
prerelease: false
|
68
|
-
version_requirements: *
|
68
|
+
version_requirements: *70276239684520
|
69
69
|
- !ruby/object:Gem::Dependency
|
70
70
|
name: launchy
|
71
|
-
requirement: &
|
71
|
+
requirement: &70276239684100 !ruby/object:Gem::Requirement
|
72
72
|
none: false
|
73
73
|
requirements:
|
74
74
|
- - ! '>='
|
@@ -76,10 +76,10 @@ dependencies:
|
|
76
76
|
version: '0'
|
77
77
|
type: :runtime
|
78
78
|
prerelease: false
|
79
|
-
version_requirements: *
|
79
|
+
version_requirements: *70276239684100
|
80
80
|
- !ruby/object:Gem::Dependency
|
81
81
|
name: haml
|
82
|
-
requirement: &
|
82
|
+
requirement: &70276239683680 !ruby/object:Gem::Requirement
|
83
83
|
none: false
|
84
84
|
requirements:
|
85
85
|
- - ! '>='
|
@@ -87,10 +87,10 @@ dependencies:
|
|
87
87
|
version: '0'
|
88
88
|
type: :runtime
|
89
89
|
prerelease: false
|
90
|
-
version_requirements: *
|
90
|
+
version_requirements: *70276239683680
|
91
91
|
- !ruby/object:Gem::Dependency
|
92
92
|
name: bundler
|
93
|
-
requirement: &
|
93
|
+
requirement: &70276239683260 !ruby/object:Gem::Requirement
|
94
94
|
none: false
|
95
95
|
requirements:
|
96
96
|
- - ! '>='
|
@@ -98,10 +98,10 @@ dependencies:
|
|
98
98
|
version: '0'
|
99
99
|
type: :runtime
|
100
100
|
prerelease: false
|
101
|
-
version_requirements: *
|
101
|
+
version_requirements: *70276239683260
|
102
102
|
- !ruby/object:Gem::Dependency
|
103
103
|
name: grit
|
104
|
-
requirement: &
|
104
|
+
requirement: &70276239682820 !ruby/object:Gem::Requirement
|
105
105
|
none: false
|
106
106
|
requirements:
|
107
107
|
- - ! '>='
|
@@ -109,10 +109,10 @@ dependencies:
|
|
109
109
|
version: '0'
|
110
110
|
type: :runtime
|
111
111
|
prerelease: false
|
112
|
-
version_requirements: *
|
112
|
+
version_requirements: *70276239682820
|
113
113
|
- !ruby/object:Gem::Dependency
|
114
114
|
name: ir_b
|
115
|
-
requirement: &
|
115
|
+
requirement: &70276239675480 !ruby/object:Gem::Requirement
|
116
116
|
none: false
|
117
117
|
requirements:
|
118
118
|
- - ! '>='
|
@@ -120,10 +120,10 @@ dependencies:
|
|
120
120
|
version: '0'
|
121
121
|
type: :development
|
122
122
|
prerelease: false
|
123
|
-
version_requirements: *
|
123
|
+
version_requirements: *70276239675480
|
124
124
|
- !ruby/object:Gem::Dependency
|
125
125
|
name: tapp
|
126
|
-
requirement: &
|
126
|
+
requirement: &70276239674960 !ruby/object:Gem::Requirement
|
127
127
|
none: false
|
128
128
|
requirements:
|
129
129
|
- - ! '>='
|
@@ -131,10 +131,10 @@ dependencies:
|
|
131
131
|
version: '0'
|
132
132
|
type: :development
|
133
133
|
prerelease: false
|
134
|
-
version_requirements: *
|
134
|
+
version_requirements: *70276239674960
|
135
135
|
- !ruby/object:Gem::Dependency
|
136
136
|
name: rspec
|
137
|
-
requirement: &
|
137
|
+
requirement: &70276239674540 !ruby/object:Gem::Requirement
|
138
138
|
none: false
|
139
139
|
requirements:
|
140
140
|
- - ! '>='
|
@@ -142,7 +142,7 @@ dependencies:
|
|
142
142
|
version: '0'
|
143
143
|
type: :development
|
144
144
|
prerelease: false
|
145
|
-
version_requirements: *
|
145
|
+
version_requirements: *70276239674540
|
146
146
|
description: Lightweight diary workflow
|
147
147
|
email:
|
148
148
|
- celluloid.key@gmail.com
|
@@ -153,6 +153,7 @@ extra_rdoc_files: []
|
|
153
153
|
files:
|
154
154
|
- .gitignore
|
155
155
|
- Gemfile
|
156
|
+
- README.md
|
156
157
|
- Rakefile
|
157
158
|
- bin/retter
|
158
159
|
- lib/generator/newretter.rb
|