jekyll 4.2.1 → 4.2.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/.rubocop.yml +350 -350
- data/LICENSE +21 -21
- data/README.markdown +86 -86
- data/exe/jekyll +57 -57
- data/lib/blank_template/_config.yml +3 -3
- data/lib/blank_template/_layouts/default.html +12 -12
- data/lib/blank_template/_sass/main.scss +9 -9
- data/lib/blank_template/assets/css/main.scss +4 -4
- data/lib/blank_template/index.md +8 -8
- data/lib/jekyll/cache.rb +190 -190
- data/lib/jekyll/cleaner.rb +111 -111
- data/lib/jekyll/collection.rb +309 -309
- data/lib/jekyll/command.rb +105 -105
- data/lib/jekyll/commands/build.rb +93 -93
- data/lib/jekyll/commands/clean.rb +45 -45
- data/lib/jekyll/commands/doctor.rb +177 -177
- data/lib/jekyll/commands/help.rb +34 -34
- data/lib/jekyll/commands/new.rb +172 -169
- data/lib/jekyll/commands/new_theme.rb +40 -40
- data/lib/jekyll/commands/serve/live_reload_reactor.rb +122 -122
- data/lib/jekyll/commands/serve/livereload_assets/livereload.js +1183 -1183
- data/lib/jekyll/commands/serve/servlet.rb +202 -202
- data/lib/jekyll/commands/serve/websockets.rb +81 -81
- data/lib/jekyll/commands/serve.rb +362 -362
- data/lib/jekyll/configuration.rb +313 -313
- data/lib/jekyll/converter.rb +54 -54
- data/lib/jekyll/converters/identity.rb +41 -41
- data/lib/jekyll/converters/markdown/kramdown_parser.rb +199 -199
- data/lib/jekyll/converters/markdown.rb +113 -113
- data/lib/jekyll/converters/smartypants.rb +70 -70
- data/lib/jekyll/convertible.rb +257 -257
- data/lib/jekyll/deprecator.rb +50 -50
- data/lib/jekyll/document.rb +544 -544
- data/lib/jekyll/drops/collection_drop.rb +20 -20
- data/lib/jekyll/drops/document_drop.rb +70 -70
- data/lib/jekyll/drops/drop.rb +293 -293
- data/lib/jekyll/drops/excerpt_drop.rb +19 -19
- data/lib/jekyll/drops/jekyll_drop.rb +32 -32
- data/lib/jekyll/drops/site_drop.rb +66 -66
- data/lib/jekyll/drops/static_file_drop.rb +14 -14
- data/lib/jekyll/drops/unified_payload_drop.rb +26 -26
- data/lib/jekyll/drops/url_drop.rb +140 -140
- data/lib/jekyll/entry_filter.rb +121 -121
- data/lib/jekyll/errors.rb +20 -20
- data/lib/jekyll/excerpt.rb +201 -201
- data/lib/jekyll/external.rb +79 -79
- data/lib/jekyll/filters/date_filters.rb +110 -110
- data/lib/jekyll/filters/grouping_filters.rb +64 -64
- data/lib/jekyll/filters/url_filters.rb +98 -98
- data/lib/jekyll/filters.rb +535 -535
- data/lib/jekyll/frontmatter_defaults.rb +240 -240
- data/lib/jekyll/generator.rb +5 -5
- data/lib/jekyll/hooks.rb +107 -107
- data/lib/jekyll/inclusion.rb +32 -32
- data/lib/jekyll/layout.rb +67 -67
- data/lib/jekyll/liquid_extensions.rb +22 -22
- data/lib/jekyll/liquid_renderer/file.rb +77 -77
- data/lib/jekyll/liquid_renderer/table.rb +55 -55
- data/lib/jekyll/liquid_renderer.rb +80 -80
- data/lib/jekyll/log_adapter.rb +151 -151
- data/lib/jekyll/mime.types +866 -866
- data/lib/jekyll/page.rb +217 -217
- data/lib/jekyll/page_excerpt.rb +25 -25
- data/lib/jekyll/page_without_a_file.rb +14 -14
- data/lib/jekyll/path_manager.rb +74 -74
- data/lib/jekyll/plugin.rb +92 -92
- data/lib/jekyll/plugin_manager.rb +115 -115
- data/lib/jekyll/profiler.rb +58 -58
- data/lib/jekyll/publisher.rb +23 -23
- data/lib/jekyll/reader.rb +192 -192
- data/lib/jekyll/readers/collection_reader.rb +23 -23
- data/lib/jekyll/readers/data_reader.rb +79 -79
- data/lib/jekyll/readers/layout_reader.rb +62 -62
- data/lib/jekyll/readers/page_reader.rb +25 -25
- data/lib/jekyll/readers/post_reader.rb +85 -85
- data/lib/jekyll/readers/static_file_reader.rb +25 -25
- data/lib/jekyll/readers/theme_assets_reader.rb +52 -52
- data/lib/jekyll/regenerator.rb +195 -195
- data/lib/jekyll/related_posts.rb +52 -52
- data/lib/jekyll/renderer.rb +265 -265
- data/lib/jekyll/site.rb +551 -551
- data/lib/jekyll/static_file.rb +208 -208
- data/lib/jekyll/stevenson.rb +60 -60
- data/lib/jekyll/tags/highlight.rb +110 -110
- data/lib/jekyll/tags/include.rb +275 -275
- data/lib/jekyll/tags/link.rb +42 -42
- data/lib/jekyll/tags/post_url.rb +106 -106
- data/lib/jekyll/theme.rb +86 -86
- data/lib/jekyll/theme_builder.rb +121 -121
- data/lib/jekyll/url.rb +167 -167
- data/lib/jekyll/utils/ansi.rb +57 -57
- data/lib/jekyll/utils/exec.rb +26 -26
- data/lib/jekyll/utils/internet.rb +37 -37
- data/lib/jekyll/utils/platforms.rb +67 -67
- data/lib/jekyll/utils/thread_event.rb +31 -31
- data/lib/jekyll/utils/win_tz.rb +75 -75
- data/lib/jekyll/utils.rb +367 -367
- data/lib/jekyll/version.rb +5 -5
- data/lib/jekyll.rb +195 -195
- data/lib/site_template/.gitignore +5 -5
- data/lib/site_template/404.html +25 -25
- data/lib/site_template/_config.yml +55 -55
- data/lib/site_template/_posts/0000-00-00-welcome-to-jekyll.markdown.erb +29 -29
- data/lib/site_template/about.markdown +18 -18
- data/lib/site_template/index.markdown +6 -6
- data/lib/theme_template/CODE_OF_CONDUCT.md.erb +74 -74
- data/lib/theme_template/Gemfile +4 -4
- data/lib/theme_template/LICENSE.txt.erb +21 -21
- data/lib/theme_template/README.md.erb +52 -52
- data/lib/theme_template/_layouts/default.html +1 -1
- data/lib/theme_template/_layouts/page.html +5 -5
- data/lib/theme_template/_layouts/post.html +5 -5
- data/lib/theme_template/example/_config.yml.erb +1 -1
- data/lib/theme_template/example/_post.md +12 -12
- data/lib/theme_template/example/index.html +14 -14
- data/lib/theme_template/example/style.scss +7 -7
- data/lib/theme_template/gitignore.erb +6 -6
- data/lib/theme_template/theme.gemspec.erb +16 -16
- data/rubocop/jekyll/assert_equal_literal_actual.rb +149 -149
- data/rubocop/jekyll/no_p_allowed.rb +23 -23
- data/rubocop/jekyll/no_puts_allowed.rb +23 -23
- data/rubocop/jekyll.rb +5 -5
- metadata +3 -3
data/lib/jekyll/drops/drop.rb
CHANGED
|
@@ -1,293 +1,293 @@
|
|
|
1
|
-
# frozen_string_literal: true
|
|
2
|
-
|
|
3
|
-
module Jekyll
|
|
4
|
-
module Drops
|
|
5
|
-
class Drop < Liquid::Drop
|
|
6
|
-
include Enumerable
|
|
7
|
-
|
|
8
|
-
NON_CONTENT_METHODS = [:fallback_data, :collapse_document].freeze
|
|
9
|
-
NON_CONTENT_METHOD_NAMES = NON_CONTENT_METHODS.map(&:to_s).freeze
|
|
10
|
-
private_constant :NON_CONTENT_METHOD_NAMES
|
|
11
|
-
|
|
12
|
-
# A private stash to avoid repeatedly generating the setter method name string for
|
|
13
|
-
# a call to `Drops::Drop#[]=`.
|
|
14
|
-
# The keys of the stash below have a very high probability of being called upon during
|
|
15
|
-
# the course of various `Jekyll::Renderer#run` calls.
|
|
16
|
-
SETTER_KEYS_STASH = {
|
|
17
|
-
"content" => "content=",
|
|
18
|
-
"layout" => "layout=",
|
|
19
|
-
"page" => "page=",
|
|
20
|
-
"paginator" => "paginator=",
|
|
21
|
-
"highlighter_prefix" => "highlighter_prefix=",
|
|
22
|
-
"highlighter_suffix" => "highlighter_suffix=",
|
|
23
|
-
}.freeze
|
|
24
|
-
private_constant :SETTER_KEYS_STASH
|
|
25
|
-
|
|
26
|
-
class << self
|
|
27
|
-
# Get or set whether the drop class is mutable.
|
|
28
|
-
# Mutability determines whether or not pre-defined fields may be
|
|
29
|
-
# overwritten.
|
|
30
|
-
#
|
|
31
|
-
# is_mutable - Boolean set mutability of the class (default: nil)
|
|
32
|
-
#
|
|
33
|
-
# Returns the mutability of the class
|
|
34
|
-
def mutable(is_mutable = nil)
|
|
35
|
-
@is_mutable = is_mutable || false
|
|
36
|
-
end
|
|
37
|
-
|
|
38
|
-
def mutable?
|
|
39
|
-
@is_mutable
|
|
40
|
-
end
|
|
41
|
-
|
|
42
|
-
# public delegation helper methods that calls onto Drop's instance
|
|
43
|
-
# variable `@obj`.
|
|
44
|
-
|
|
45
|
-
# Generate private Drop instance_methods for each symbol in the given list.
|
|
46
|
-
#
|
|
47
|
-
# Returns nothing.
|
|
48
|
-
def private_delegate_methods(*symbols)
|
|
49
|
-
symbols.each { |symbol| private delegate_method(symbol) }
|
|
50
|
-
nil
|
|
51
|
-
end
|
|
52
|
-
|
|
53
|
-
# Generate public Drop instance_methods for each symbol in the given list.
|
|
54
|
-
#
|
|
55
|
-
# Returns nothing.
|
|
56
|
-
def delegate_methods(*symbols)
|
|
57
|
-
symbols.each { |symbol| delegate_method(symbol) }
|
|
58
|
-
nil
|
|
59
|
-
end
|
|
60
|
-
|
|
61
|
-
# Generate public Drop instance_method for given symbol that calls `@obj.<sym>`.
|
|
62
|
-
#
|
|
63
|
-
# Returns delegated method symbol.
|
|
64
|
-
def delegate_method(symbol)
|
|
65
|
-
define_method(symbol) { @obj.send(symbol) }
|
|
66
|
-
end
|
|
67
|
-
|
|
68
|
-
# Generate public Drop instance_method named `delegate` that calls `@obj.<original>`.
|
|
69
|
-
#
|
|
70
|
-
# Returns delegated method symbol.
|
|
71
|
-
def delegate_method_as(original, delegate)
|
|
72
|
-
define_method(delegate) { @obj.send(original) }
|
|
73
|
-
end
|
|
74
|
-
|
|
75
|
-
# Generate public Drop instance_methods for each string entry in the given list.
|
|
76
|
-
# The generated method(s) access(es) `@obj`'s data hash.
|
|
77
|
-
#
|
|
78
|
-
# Returns nothing.
|
|
79
|
-
def data_delegators(*strings)
|
|
80
|
-
strings.each do |key|
|
|
81
|
-
data_delegator(key) if key.is_a?(String)
|
|
82
|
-
end
|
|
83
|
-
nil
|
|
84
|
-
end
|
|
85
|
-
|
|
86
|
-
# Generate public Drop instance_methods for given string `key`.
|
|
87
|
-
# The generated method access(es) `@obj`'s data hash.
|
|
88
|
-
#
|
|
89
|
-
# Returns method symbol.
|
|
90
|
-
def data_delegator(key)
|
|
91
|
-
define_method(key.to_sym) { @obj.data[key] }
|
|
92
|
-
end
|
|
93
|
-
|
|
94
|
-
# Array of stringified instance methods that do not end with the assignment operator.
|
|
95
|
-
#
|
|
96
|
-
# (<klass>.instance_methods always generates a new Array object so it can be mutated)
|
|
97
|
-
#
|
|
98
|
-
# Returns array of strings.
|
|
99
|
-
def getter_method_names
|
|
100
|
-
@getter_method_names ||= instance_methods.map!(&:to_s).tap do |list|
|
|
101
|
-
list.reject! { |item| item.end_with?("=") }
|
|
102
|
-
end
|
|
103
|
-
end
|
|
104
|
-
end
|
|
105
|
-
|
|
106
|
-
# Create a new Drop
|
|
107
|
-
#
|
|
108
|
-
# obj - the Jekyll Site, Collection, or Document required by the
|
|
109
|
-
# drop.
|
|
110
|
-
#
|
|
111
|
-
# Returns nothing
|
|
112
|
-
def initialize(obj)
|
|
113
|
-
@obj = obj
|
|
114
|
-
end
|
|
115
|
-
|
|
116
|
-
# Access a method in the Drop or a field in the underlying hash data.
|
|
117
|
-
# If mutable, checks the mutations first. Then checks the methods,
|
|
118
|
-
# and finally check the underlying hash (e.g. document front matter)
|
|
119
|
-
# if all the previous places didn't match.
|
|
120
|
-
#
|
|
121
|
-
# key - the string key whose value to fetch
|
|
122
|
-
#
|
|
123
|
-
# Returns the value for the given key, or nil if none exists
|
|
124
|
-
def [](key)
|
|
125
|
-
if self.class.mutable? && mutations.key?(key)
|
|
126
|
-
mutations[key]
|
|
127
|
-
elsif self.class.invokable? key
|
|
128
|
-
public_send key
|
|
129
|
-
else
|
|
130
|
-
fallback_data[key]
|
|
131
|
-
end
|
|
132
|
-
end
|
|
133
|
-
alias_method :invoke_drop, :[]
|
|
134
|
-
|
|
135
|
-
# Set a field in the Drop. If mutable, sets in the mutations and
|
|
136
|
-
# returns. If not mutable, checks first if it's trying to override a
|
|
137
|
-
# Drop method and raises a DropMutationException if so. If not
|
|
138
|
-
# mutable and the key is not a method on the Drop, then it sets the
|
|
139
|
-
# key to the value in the underlying hash (e.g. document front
|
|
140
|
-
# matter)
|
|
141
|
-
#
|
|
142
|
-
# key - the String key whose value to set
|
|
143
|
-
# val - the Object to set the key's value to
|
|
144
|
-
#
|
|
145
|
-
# Returns the value the key was set to unless the Drop is not mutable
|
|
146
|
-
# and the key matches a method in which case it raises a
|
|
147
|
-
# DropMutationException.
|
|
148
|
-
def []=(key, val)
|
|
149
|
-
setter = SETTER_KEYS_STASH[key] || "#{key}="
|
|
150
|
-
if respond_to?(setter)
|
|
151
|
-
public_send(setter, val)
|
|
152
|
-
elsif respond_to?(key.to_s)
|
|
153
|
-
if self.class.mutable?
|
|
154
|
-
mutations[key] = val
|
|
155
|
-
else
|
|
156
|
-
raise Errors::DropMutationException, "Key #{key} cannot be set in the drop."
|
|
157
|
-
end
|
|
158
|
-
else
|
|
159
|
-
fallback_data[key] = val
|
|
160
|
-
end
|
|
161
|
-
end
|
|
162
|
-
|
|
163
|
-
# Generates a list of strings which correspond to content getter
|
|
164
|
-
# methods.
|
|
165
|
-
#
|
|
166
|
-
# Returns an Array of strings which represent method-specific keys.
|
|
167
|
-
def content_methods
|
|
168
|
-
@content_methods ||= \
|
|
169
|
-
self.class.getter_method_names \
|
|
170
|
-
- Jekyll::Drops::Drop.getter_method_names \
|
|
171
|
-
- NON_CONTENT_METHOD_NAMES
|
|
172
|
-
end
|
|
173
|
-
|
|
174
|
-
# Check if key exists in Drop
|
|
175
|
-
#
|
|
176
|
-
# key - the string key whose value to fetch
|
|
177
|
-
#
|
|
178
|
-
# Returns true if the given key is present
|
|
179
|
-
def key?(key)
|
|
180
|
-
return false if key.nil?
|
|
181
|
-
return true if self.class.mutable? && mutations.key?(key)
|
|
182
|
-
|
|
183
|
-
respond_to?(key) || fallback_data.key?(key)
|
|
184
|
-
end
|
|
185
|
-
|
|
186
|
-
# Generates a list of keys with user content as their values.
|
|
187
|
-
# This gathers up the Drop methods and keys of the mutations and
|
|
188
|
-
# underlying data hashes and performs a set union to ensure a list
|
|
189
|
-
# of unique keys for the Drop.
|
|
190
|
-
#
|
|
191
|
-
# Returns an Array of unique keys for content for the Drop.
|
|
192
|
-
def keys
|
|
193
|
-
(content_methods |
|
|
194
|
-
mutations.keys |
|
|
195
|
-
fallback_data.keys).flatten
|
|
196
|
-
end
|
|
197
|
-
|
|
198
|
-
# Generate a Hash representation of the Drop by resolving each key's
|
|
199
|
-
# value. It includes Drop methods, mutations, and the underlying object's
|
|
200
|
-
# data. See the documentation for Drop#keys for more.
|
|
201
|
-
#
|
|
202
|
-
# Returns a Hash with all the keys and values resolved.
|
|
203
|
-
def to_h
|
|
204
|
-
keys.each_with_object({}) do |(key, _), result|
|
|
205
|
-
result[key] = self[key]
|
|
206
|
-
end
|
|
207
|
-
end
|
|
208
|
-
alias_method :to_hash, :to_h
|
|
209
|
-
|
|
210
|
-
# Inspect the drop's keys and values through a JSON representation
|
|
211
|
-
# of its keys and values.
|
|
212
|
-
#
|
|
213
|
-
# Returns a pretty generation of the hash representation of the Drop.
|
|
214
|
-
def inspect
|
|
215
|
-
JSON.pretty_generate to_h
|
|
216
|
-
end
|
|
217
|
-
|
|
218
|
-
# Generate a Hash for use in generating JSON.
|
|
219
|
-
# This is useful if fields need to be cleared before the JSON can generate.
|
|
220
|
-
#
|
|
221
|
-
# Returns a Hash ready for JSON generation.
|
|
222
|
-
def hash_for_json(*)
|
|
223
|
-
to_h
|
|
224
|
-
end
|
|
225
|
-
|
|
226
|
-
# Generate a JSON representation of the Drop.
|
|
227
|
-
#
|
|
228
|
-
# state - the JSON::State object which determines the state of current processing.
|
|
229
|
-
#
|
|
230
|
-
# Returns a JSON representation of the Drop in a String.
|
|
231
|
-
def to_json(state = nil)
|
|
232
|
-
JSON.generate(hash_for_json(state), state)
|
|
233
|
-
end
|
|
234
|
-
|
|
235
|
-
# Collects all the keys and passes each to the block in turn.
|
|
236
|
-
#
|
|
237
|
-
# block - a block which accepts one argument, the key
|
|
238
|
-
#
|
|
239
|
-
# Returns nothing.
|
|
240
|
-
def each_key(&block)
|
|
241
|
-
keys.each(&block)
|
|
242
|
-
end
|
|
243
|
-
|
|
244
|
-
def each
|
|
245
|
-
each_key.each do |key|
|
|
246
|
-
yield key, self[key]
|
|
247
|
-
end
|
|
248
|
-
end
|
|
249
|
-
|
|
250
|
-
def merge(other, &block)
|
|
251
|
-
dup.tap do |me|
|
|
252
|
-
if block.nil?
|
|
253
|
-
me.merge!(other)
|
|
254
|
-
else
|
|
255
|
-
me.merge!(other, block)
|
|
256
|
-
end
|
|
257
|
-
end
|
|
258
|
-
end
|
|
259
|
-
|
|
260
|
-
def merge!(other)
|
|
261
|
-
other.each_key do |key|
|
|
262
|
-
if block_given?
|
|
263
|
-
self[key] = yield key, self[key], other[key]
|
|
264
|
-
else
|
|
265
|
-
if Utils.mergable?(self[key]) && Utils.mergable?(other[key])
|
|
266
|
-
self[key] = Utils.deep_merge_hashes(self[key], other[key])
|
|
267
|
-
next
|
|
268
|
-
end
|
|
269
|
-
|
|
270
|
-
self[key] = other[key] unless other[key].nil?
|
|
271
|
-
end
|
|
272
|
-
end
|
|
273
|
-
end
|
|
274
|
-
|
|
275
|
-
# Imitate Hash.fetch method in Drop
|
|
276
|
-
#
|
|
277
|
-
# Returns value if key is present in Drop, otherwise returns default value
|
|
278
|
-
# KeyError is raised if key is not present and no default value given
|
|
279
|
-
def fetch(key, default = nil, &block)
|
|
280
|
-
return self[key] if key?(key)
|
|
281
|
-
raise KeyError, %(key not found: "#{key}") if default.nil? && block.nil?
|
|
282
|
-
return yield(key) unless block.nil?
|
|
283
|
-
return default unless default.nil?
|
|
284
|
-
end
|
|
285
|
-
|
|
286
|
-
private
|
|
287
|
-
|
|
288
|
-
def mutations
|
|
289
|
-
@mutations ||= {}
|
|
290
|
-
end
|
|
291
|
-
end
|
|
292
|
-
end
|
|
293
|
-
end
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
module Jekyll
|
|
4
|
+
module Drops
|
|
5
|
+
class Drop < Liquid::Drop
|
|
6
|
+
include Enumerable
|
|
7
|
+
|
|
8
|
+
NON_CONTENT_METHODS = [:fallback_data, :collapse_document].freeze
|
|
9
|
+
NON_CONTENT_METHOD_NAMES = NON_CONTENT_METHODS.map(&:to_s).freeze
|
|
10
|
+
private_constant :NON_CONTENT_METHOD_NAMES
|
|
11
|
+
|
|
12
|
+
# A private stash to avoid repeatedly generating the setter method name string for
|
|
13
|
+
# a call to `Drops::Drop#[]=`.
|
|
14
|
+
# The keys of the stash below have a very high probability of being called upon during
|
|
15
|
+
# the course of various `Jekyll::Renderer#run` calls.
|
|
16
|
+
SETTER_KEYS_STASH = {
|
|
17
|
+
"content" => "content=",
|
|
18
|
+
"layout" => "layout=",
|
|
19
|
+
"page" => "page=",
|
|
20
|
+
"paginator" => "paginator=",
|
|
21
|
+
"highlighter_prefix" => "highlighter_prefix=",
|
|
22
|
+
"highlighter_suffix" => "highlighter_suffix=",
|
|
23
|
+
}.freeze
|
|
24
|
+
private_constant :SETTER_KEYS_STASH
|
|
25
|
+
|
|
26
|
+
class << self
|
|
27
|
+
# Get or set whether the drop class is mutable.
|
|
28
|
+
# Mutability determines whether or not pre-defined fields may be
|
|
29
|
+
# overwritten.
|
|
30
|
+
#
|
|
31
|
+
# is_mutable - Boolean set mutability of the class (default: nil)
|
|
32
|
+
#
|
|
33
|
+
# Returns the mutability of the class
|
|
34
|
+
def mutable(is_mutable = nil)
|
|
35
|
+
@is_mutable = is_mutable || false
|
|
36
|
+
end
|
|
37
|
+
|
|
38
|
+
def mutable?
|
|
39
|
+
@is_mutable
|
|
40
|
+
end
|
|
41
|
+
|
|
42
|
+
# public delegation helper methods that calls onto Drop's instance
|
|
43
|
+
# variable `@obj`.
|
|
44
|
+
|
|
45
|
+
# Generate private Drop instance_methods for each symbol in the given list.
|
|
46
|
+
#
|
|
47
|
+
# Returns nothing.
|
|
48
|
+
def private_delegate_methods(*symbols)
|
|
49
|
+
symbols.each { |symbol| private delegate_method(symbol) }
|
|
50
|
+
nil
|
|
51
|
+
end
|
|
52
|
+
|
|
53
|
+
# Generate public Drop instance_methods for each symbol in the given list.
|
|
54
|
+
#
|
|
55
|
+
# Returns nothing.
|
|
56
|
+
def delegate_methods(*symbols)
|
|
57
|
+
symbols.each { |symbol| delegate_method(symbol) }
|
|
58
|
+
nil
|
|
59
|
+
end
|
|
60
|
+
|
|
61
|
+
# Generate public Drop instance_method for given symbol that calls `@obj.<sym>`.
|
|
62
|
+
#
|
|
63
|
+
# Returns delegated method symbol.
|
|
64
|
+
def delegate_method(symbol)
|
|
65
|
+
define_method(symbol) { @obj.send(symbol) }
|
|
66
|
+
end
|
|
67
|
+
|
|
68
|
+
# Generate public Drop instance_method named `delegate` that calls `@obj.<original>`.
|
|
69
|
+
#
|
|
70
|
+
# Returns delegated method symbol.
|
|
71
|
+
def delegate_method_as(original, delegate)
|
|
72
|
+
define_method(delegate) { @obj.send(original) }
|
|
73
|
+
end
|
|
74
|
+
|
|
75
|
+
# Generate public Drop instance_methods for each string entry in the given list.
|
|
76
|
+
# The generated method(s) access(es) `@obj`'s data hash.
|
|
77
|
+
#
|
|
78
|
+
# Returns nothing.
|
|
79
|
+
def data_delegators(*strings)
|
|
80
|
+
strings.each do |key|
|
|
81
|
+
data_delegator(key) if key.is_a?(String)
|
|
82
|
+
end
|
|
83
|
+
nil
|
|
84
|
+
end
|
|
85
|
+
|
|
86
|
+
# Generate public Drop instance_methods for given string `key`.
|
|
87
|
+
# The generated method access(es) `@obj`'s data hash.
|
|
88
|
+
#
|
|
89
|
+
# Returns method symbol.
|
|
90
|
+
def data_delegator(key)
|
|
91
|
+
define_method(key.to_sym) { @obj.data[key] }
|
|
92
|
+
end
|
|
93
|
+
|
|
94
|
+
# Array of stringified instance methods that do not end with the assignment operator.
|
|
95
|
+
#
|
|
96
|
+
# (<klass>.instance_methods always generates a new Array object so it can be mutated)
|
|
97
|
+
#
|
|
98
|
+
# Returns array of strings.
|
|
99
|
+
def getter_method_names
|
|
100
|
+
@getter_method_names ||= instance_methods.map!(&:to_s).tap do |list|
|
|
101
|
+
list.reject! { |item| item.end_with?("=") }
|
|
102
|
+
end
|
|
103
|
+
end
|
|
104
|
+
end
|
|
105
|
+
|
|
106
|
+
# Create a new Drop
|
|
107
|
+
#
|
|
108
|
+
# obj - the Jekyll Site, Collection, or Document required by the
|
|
109
|
+
# drop.
|
|
110
|
+
#
|
|
111
|
+
# Returns nothing
|
|
112
|
+
def initialize(obj)
|
|
113
|
+
@obj = obj
|
|
114
|
+
end
|
|
115
|
+
|
|
116
|
+
# Access a method in the Drop or a field in the underlying hash data.
|
|
117
|
+
# If mutable, checks the mutations first. Then checks the methods,
|
|
118
|
+
# and finally check the underlying hash (e.g. document front matter)
|
|
119
|
+
# if all the previous places didn't match.
|
|
120
|
+
#
|
|
121
|
+
# key - the string key whose value to fetch
|
|
122
|
+
#
|
|
123
|
+
# Returns the value for the given key, or nil if none exists
|
|
124
|
+
def [](key)
|
|
125
|
+
if self.class.mutable? && mutations.key?(key)
|
|
126
|
+
mutations[key]
|
|
127
|
+
elsif self.class.invokable? key
|
|
128
|
+
public_send key
|
|
129
|
+
else
|
|
130
|
+
fallback_data[key]
|
|
131
|
+
end
|
|
132
|
+
end
|
|
133
|
+
alias_method :invoke_drop, :[]
|
|
134
|
+
|
|
135
|
+
# Set a field in the Drop. If mutable, sets in the mutations and
|
|
136
|
+
# returns. If not mutable, checks first if it's trying to override a
|
|
137
|
+
# Drop method and raises a DropMutationException if so. If not
|
|
138
|
+
# mutable and the key is not a method on the Drop, then it sets the
|
|
139
|
+
# key to the value in the underlying hash (e.g. document front
|
|
140
|
+
# matter)
|
|
141
|
+
#
|
|
142
|
+
# key - the String key whose value to set
|
|
143
|
+
# val - the Object to set the key's value to
|
|
144
|
+
#
|
|
145
|
+
# Returns the value the key was set to unless the Drop is not mutable
|
|
146
|
+
# and the key matches a method in which case it raises a
|
|
147
|
+
# DropMutationException.
|
|
148
|
+
def []=(key, val)
|
|
149
|
+
setter = SETTER_KEYS_STASH[key] || "#{key}="
|
|
150
|
+
if respond_to?(setter)
|
|
151
|
+
public_send(setter, val)
|
|
152
|
+
elsif respond_to?(key.to_s)
|
|
153
|
+
if self.class.mutable?
|
|
154
|
+
mutations[key] = val
|
|
155
|
+
else
|
|
156
|
+
raise Errors::DropMutationException, "Key #{key} cannot be set in the drop."
|
|
157
|
+
end
|
|
158
|
+
else
|
|
159
|
+
fallback_data[key] = val
|
|
160
|
+
end
|
|
161
|
+
end
|
|
162
|
+
|
|
163
|
+
# Generates a list of strings which correspond to content getter
|
|
164
|
+
# methods.
|
|
165
|
+
#
|
|
166
|
+
# Returns an Array of strings which represent method-specific keys.
|
|
167
|
+
def content_methods
|
|
168
|
+
@content_methods ||= \
|
|
169
|
+
self.class.getter_method_names \
|
|
170
|
+
- Jekyll::Drops::Drop.getter_method_names \
|
|
171
|
+
- NON_CONTENT_METHOD_NAMES
|
|
172
|
+
end
|
|
173
|
+
|
|
174
|
+
# Check if key exists in Drop
|
|
175
|
+
#
|
|
176
|
+
# key - the string key whose value to fetch
|
|
177
|
+
#
|
|
178
|
+
# Returns true if the given key is present
|
|
179
|
+
def key?(key)
|
|
180
|
+
return false if key.nil?
|
|
181
|
+
return true if self.class.mutable? && mutations.key?(key)
|
|
182
|
+
|
|
183
|
+
respond_to?(key) || fallback_data.key?(key)
|
|
184
|
+
end
|
|
185
|
+
|
|
186
|
+
# Generates a list of keys with user content as their values.
|
|
187
|
+
# This gathers up the Drop methods and keys of the mutations and
|
|
188
|
+
# underlying data hashes and performs a set union to ensure a list
|
|
189
|
+
# of unique keys for the Drop.
|
|
190
|
+
#
|
|
191
|
+
# Returns an Array of unique keys for content for the Drop.
|
|
192
|
+
def keys
|
|
193
|
+
(content_methods |
|
|
194
|
+
mutations.keys |
|
|
195
|
+
fallback_data.keys).flatten
|
|
196
|
+
end
|
|
197
|
+
|
|
198
|
+
# Generate a Hash representation of the Drop by resolving each key's
|
|
199
|
+
# value. It includes Drop methods, mutations, and the underlying object's
|
|
200
|
+
# data. See the documentation for Drop#keys for more.
|
|
201
|
+
#
|
|
202
|
+
# Returns a Hash with all the keys and values resolved.
|
|
203
|
+
def to_h
|
|
204
|
+
keys.each_with_object({}) do |(key, _), result|
|
|
205
|
+
result[key] = self[key]
|
|
206
|
+
end
|
|
207
|
+
end
|
|
208
|
+
alias_method :to_hash, :to_h
|
|
209
|
+
|
|
210
|
+
# Inspect the drop's keys and values through a JSON representation
|
|
211
|
+
# of its keys and values.
|
|
212
|
+
#
|
|
213
|
+
# Returns a pretty generation of the hash representation of the Drop.
|
|
214
|
+
def inspect
|
|
215
|
+
JSON.pretty_generate to_h
|
|
216
|
+
end
|
|
217
|
+
|
|
218
|
+
# Generate a Hash for use in generating JSON.
|
|
219
|
+
# This is useful if fields need to be cleared before the JSON can generate.
|
|
220
|
+
#
|
|
221
|
+
# Returns a Hash ready for JSON generation.
|
|
222
|
+
def hash_for_json(*)
|
|
223
|
+
to_h
|
|
224
|
+
end
|
|
225
|
+
|
|
226
|
+
# Generate a JSON representation of the Drop.
|
|
227
|
+
#
|
|
228
|
+
# state - the JSON::State object which determines the state of current processing.
|
|
229
|
+
#
|
|
230
|
+
# Returns a JSON representation of the Drop in a String.
|
|
231
|
+
def to_json(state = nil)
|
|
232
|
+
JSON.generate(hash_for_json(state), state)
|
|
233
|
+
end
|
|
234
|
+
|
|
235
|
+
# Collects all the keys and passes each to the block in turn.
|
|
236
|
+
#
|
|
237
|
+
# block - a block which accepts one argument, the key
|
|
238
|
+
#
|
|
239
|
+
# Returns nothing.
|
|
240
|
+
def each_key(&block)
|
|
241
|
+
keys.each(&block)
|
|
242
|
+
end
|
|
243
|
+
|
|
244
|
+
def each
|
|
245
|
+
each_key.each do |key|
|
|
246
|
+
yield key, self[key]
|
|
247
|
+
end
|
|
248
|
+
end
|
|
249
|
+
|
|
250
|
+
def merge(other, &block)
|
|
251
|
+
dup.tap do |me|
|
|
252
|
+
if block.nil?
|
|
253
|
+
me.merge!(other)
|
|
254
|
+
else
|
|
255
|
+
me.merge!(other, block)
|
|
256
|
+
end
|
|
257
|
+
end
|
|
258
|
+
end
|
|
259
|
+
|
|
260
|
+
def merge!(other)
|
|
261
|
+
other.each_key do |key|
|
|
262
|
+
if block_given?
|
|
263
|
+
self[key] = yield key, self[key], other[key]
|
|
264
|
+
else
|
|
265
|
+
if Utils.mergable?(self[key]) && Utils.mergable?(other[key])
|
|
266
|
+
self[key] = Utils.deep_merge_hashes(self[key], other[key])
|
|
267
|
+
next
|
|
268
|
+
end
|
|
269
|
+
|
|
270
|
+
self[key] = other[key] unless other[key].nil?
|
|
271
|
+
end
|
|
272
|
+
end
|
|
273
|
+
end
|
|
274
|
+
|
|
275
|
+
# Imitate Hash.fetch method in Drop
|
|
276
|
+
#
|
|
277
|
+
# Returns value if key is present in Drop, otherwise returns default value
|
|
278
|
+
# KeyError is raised if key is not present and no default value given
|
|
279
|
+
def fetch(key, default = nil, &block)
|
|
280
|
+
return self[key] if key?(key)
|
|
281
|
+
raise KeyError, %(key not found: "#{key}") if default.nil? && block.nil?
|
|
282
|
+
return yield(key) unless block.nil?
|
|
283
|
+
return default unless default.nil?
|
|
284
|
+
end
|
|
285
|
+
|
|
286
|
+
private
|
|
287
|
+
|
|
288
|
+
def mutations
|
|
289
|
+
@mutations ||= {}
|
|
290
|
+
end
|
|
291
|
+
end
|
|
292
|
+
end
|
|
293
|
+
end
|
|
@@ -1,19 +1,19 @@
|
|
|
1
|
-
# frozen_string_literal: true
|
|
2
|
-
|
|
3
|
-
module Jekyll
|
|
4
|
-
module Drops
|
|
5
|
-
class ExcerptDrop < DocumentDrop
|
|
6
|
-
def layout
|
|
7
|
-
@obj.doc.data["layout"]
|
|
8
|
-
end
|
|
9
|
-
|
|
10
|
-
def date
|
|
11
|
-
@obj.doc.date
|
|
12
|
-
end
|
|
13
|
-
|
|
14
|
-
def excerpt
|
|
15
|
-
nil
|
|
16
|
-
end
|
|
17
|
-
end
|
|
18
|
-
end
|
|
19
|
-
end
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
module Jekyll
|
|
4
|
+
module Drops
|
|
5
|
+
class ExcerptDrop < DocumentDrop
|
|
6
|
+
def layout
|
|
7
|
+
@obj.doc.data["layout"]
|
|
8
|
+
end
|
|
9
|
+
|
|
10
|
+
def date
|
|
11
|
+
@obj.doc.date
|
|
12
|
+
end
|
|
13
|
+
|
|
14
|
+
def excerpt
|
|
15
|
+
nil
|
|
16
|
+
end
|
|
17
|
+
end
|
|
18
|
+
end
|
|
19
|
+
end
|