nanoc 4.11.0 → 4.11.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/NEWS.md +6 -0
- data/lib/nanoc.rb +4 -7
- data/lib/nanoc/base.rb +3 -3
- data/lib/nanoc/base/assertions.rb +1 -1
- data/lib/nanoc/base/entities.rb +2 -20
- data/lib/nanoc/base/entities/action_sequence.rb +60 -64
- data/lib/nanoc/base/entities/checksum_collection.rb +23 -21
- data/lib/nanoc/base/entities/dependency.rb +24 -22
- data/lib/nanoc/base/entities/outdatedness_reasons.rb +74 -72
- data/lib/nanoc/base/entities/outdatedness_status.rb +19 -17
- data/lib/nanoc/base/entities/props.rb +119 -117
- data/lib/nanoc/base/entities/site.rb +46 -50
- data/lib/nanoc/base/errors.rb +183 -198
- data/lib/nanoc/base/repos.rb +4 -2
- data/lib/nanoc/base/repos/action_sequence_store.rb +44 -42
- data/lib/nanoc/base/repos/aggregate_data_source.rb +24 -22
- data/lib/nanoc/base/repos/checksum_store.rb +51 -49
- data/lib/nanoc/base/repos/compiled_content_cache.rb +47 -45
- data/lib/nanoc/base/repos/compiled_content_store.rb +76 -0
- data/lib/nanoc/base/repos/config_loader.rb +74 -72
- data/lib/nanoc/base/repos/dependency_store.rb +174 -172
- data/lib/nanoc/base/repos/in_mem_data_source.rb +17 -15
- data/lib/nanoc/base/repos/item_rep_repo.rb +26 -24
- data/lib/nanoc/base/repos/outdatedness_store.rb +50 -48
- data/lib/nanoc/base/repos/prefixed_data_source.rb +21 -19
- data/lib/nanoc/base/repos/site_loader.rb +75 -73
- data/lib/nanoc/base/repos/store.rb +93 -91
- data/lib/nanoc/base/services.rb +7 -3
- data/lib/nanoc/base/services/action_provider.rb +23 -21
- data/lib/nanoc/base/services/action_sequence_builder.rb +42 -34
- data/lib/nanoc/base/services/compilation_context.rb +49 -47
- data/lib/nanoc/base/services/compiler.rb +177 -170
- data/lib/nanoc/base/services/compiler/phases.rb +8 -1
- data/lib/nanoc/base/services/compiler/phases/abstract.rb +44 -38
- data/lib/nanoc/base/services/compiler/phases/cache.rb +34 -28
- data/lib/nanoc/base/services/compiler/phases/mark_done.rb +17 -11
- data/lib/nanoc/base/services/compiler/phases/notify.rb +21 -0
- data/lib/nanoc/base/services/compiler/phases/recalculate.rb +37 -31
- data/lib/nanoc/base/services/compiler/phases/resume.rb +47 -48
- data/lib/nanoc/base/services/compiler/phases/write.rb +65 -59
- data/lib/nanoc/base/services/compiler/stage.rb +27 -8
- data/lib/nanoc/base/services/compiler/stages.rb +7 -1
- data/lib/nanoc/base/services/compiler/stages/build_reps.rb +25 -19
- data/lib/nanoc/base/services/compiler/stages/calculate_checksums.rb +34 -28
- data/lib/nanoc/base/services/compiler/stages/cleanup.rb +33 -27
- data/lib/nanoc/base/services/compiler/stages/compile_reps.rb +79 -69
- data/lib/nanoc/base/services/compiler/stages/determine_outdatedness.rb +46 -40
- data/lib/nanoc/base/services/compiler/stages/forget_outdated_dependencies.rb +15 -9
- data/lib/nanoc/base/services/compiler/stages/load_stores.rb +28 -22
- data/lib/nanoc/base/services/compiler/stages/postprocess.rb +16 -10
- data/lib/nanoc/base/services/compiler/stages/preprocess.rb +25 -19
- data/lib/nanoc/base/services/compiler/stages/prune.rb +23 -17
- data/lib/nanoc/base/services/compiler/stages/store_post_compilation_state.rb +15 -9
- data/lib/nanoc/base/services/compiler/stages/store_pre_compilation_state.rb +26 -20
- data/lib/nanoc/base/services/compiler_loader.rb +26 -24
- data/lib/nanoc/base/services/dependency_tracker.rb +47 -45
- data/lib/nanoc/base/services/executor.rb +16 -15
- data/lib/nanoc/base/services/filter.rb +37 -5
- data/lib/nanoc/base/services/instrumentor.rb +12 -10
- data/lib/nanoc/base/services/item_rep_builder.rb +21 -19
- data/lib/nanoc/base/services/item_rep_router.rb +72 -70
- data/lib/nanoc/base/services/item_rep_selector.rb +48 -46
- data/lib/nanoc/base/services/item_rep_writer.rb +58 -53
- data/lib/nanoc/base/services/outdatedness_checker.rb +181 -179
- data/lib/nanoc/base/services/outdatedness_rule.rb +23 -21
- data/lib/nanoc/base/services/outdatedness_rules.rb +5 -3
- data/lib/nanoc/base/services/outdatedness_rules/attributes_modified.rb +28 -24
- data/lib/nanoc/base/services/outdatedness_rules/code_snippets_modified.rb +20 -16
- data/lib/nanoc/base/services/outdatedness_rules/content_modified.rb +13 -9
- data/lib/nanoc/base/services/outdatedness_rules/item_collection_extended.rb +12 -8
- data/lib/nanoc/base/services/outdatedness_rules/layout_collection_extended.rb +12 -8
- data/lib/nanoc/base/services/outdatedness_rules/not_written.rb +10 -6
- data/lib/nanoc/base/services/outdatedness_rules/rules_modified.rb +39 -35
- data/lib/nanoc/base/services/outdatedness_rules/uses_always_outdated_filter.rb +19 -15
- data/lib/nanoc/base/services/pruner.rb +2 -2
- data/lib/nanoc/base/views.rb +7 -0
- data/lib/nanoc/base/views/basic_item_view.rb +1 -1
- data/lib/nanoc/base/views/compilation_item_rep_view.rb +2 -2
- data/lib/nanoc/base/views/identifiable_collection_view.rb +2 -2
- data/lib/nanoc/base/views/mixins/document_view_mixin.rb +1 -1
- data/lib/nanoc/base/views/mixins/mutable_document_view_mixin.rb +5 -5
- data/lib/nanoc/base/views/mutable_item_collection_view.rb +3 -3
- data/lib/nanoc/base/views/mutable_layout_collection_view.rb +2 -2
- data/lib/nanoc/base/views/view_context_for_compilation.rb +6 -6
- data/lib/nanoc/base/views/view_context_for_pre_compilation.rb +2 -2
- data/lib/nanoc/base/views/view_context_for_shell.rb +2 -2
- data/lib/nanoc/checking/check.rb +1 -1
- data/lib/nanoc/cli/commands/compile_listeners/abstract.rb +24 -7
- data/lib/nanoc/cli/commands/compile_listeners/debug_printer.rb +79 -15
- data/lib/nanoc/cli/commands/compile_listeners/diff_generator.rb +4 -7
- data/lib/nanoc/cli/commands/compile_listeners/file_action_printer.rb +15 -24
- data/lib/nanoc/cli/commands/compile_listeners/timing_recorder.rb +22 -18
- data/lib/nanoc/cli/commands/create-site.rb +2 -7
- data/lib/nanoc/cli/commands/shell.rb +1 -1
- data/lib/nanoc/cli/commands/show-data.rb +9 -9
- data/lib/nanoc/cli/logger.rb +1 -1
- data/lib/nanoc/data_sources/filesystem.rb +8 -8
- data/lib/nanoc/filters/erb.rb +1 -1
- data/lib/nanoc/filters/erubi.rb +1 -1
- data/lib/nanoc/filters/erubis.rb +1 -1
- data/lib/nanoc/filters/haml.rb +1 -1
- data/lib/nanoc/filters/sass.rb +1 -1
- data/lib/nanoc/filters/slim.rb +1 -1
- data/lib/nanoc/helpers/breadcrumbs.rb +2 -2
- data/lib/nanoc/helpers/capturing.rb +9 -8
- data/lib/nanoc/helpers/filtering.rb +2 -2
- data/lib/nanoc/helpers/rendering.rb +1 -1
- data/lib/nanoc/rule_dsl.rb +10 -0
- data/lib/nanoc/rule_dsl/action_provider.rb +3 -3
- data/lib/nanoc/rule_dsl/action_recorder.rb +3 -3
- data/lib/nanoc/rule_dsl/action_sequence_calculator.rb +7 -7
- data/lib/nanoc/rule_dsl/compilation_rule.rb +2 -2
- data/lib/nanoc/rule_dsl/compilation_rule_context.rb +9 -9
- data/lib/nanoc/rule_dsl/compiler_dsl.rb +4 -4
- data/lib/nanoc/rule_dsl/routing_rule.rb +3 -3
- data/lib/nanoc/rule_dsl/rule.rb +5 -5
- data/lib/nanoc/rule_dsl/rule_context.rb +3 -3
- data/lib/nanoc/rule_dsl/rules_collection.rb +4 -4
- data/lib/nanoc/spec.rb +15 -15
- data/lib/nanoc/version.rb +1 -1
- metadata +10 -111
- data/lib/nanoc/base/contracts_support.rb +0 -130
- data/lib/nanoc/base/core_ext.rb +0 -5
- data/lib/nanoc/base/core_ext/array.rb +0 -50
- data/lib/nanoc/base/core_ext/hash.rb +0 -54
- data/lib/nanoc/base/core_ext/string.rb +0 -16
- data/lib/nanoc/base/entities/code_snippet.rb +0 -53
- data/lib/nanoc/base/entities/configuration-schema.json +0 -122
- data/lib/nanoc/base/entities/configuration.rb +0 -206
- data/lib/nanoc/base/entities/content.rb +0 -112
- data/lib/nanoc/base/entities/context.rb +0 -70
- data/lib/nanoc/base/entities/directed_graph.rb +0 -195
- data/lib/nanoc/base/entities/document.rb +0 -125
- data/lib/nanoc/base/entities/identifiable_collection.rb +0 -141
- data/lib/nanoc/base/entities/identifier.rb +0 -222
- data/lib/nanoc/base/entities/item.rb +0 -10
- data/lib/nanoc/base/entities/item_collection.rb +0 -14
- data/lib/nanoc/base/entities/item_rep.rb +0 -91
- data/lib/nanoc/base/entities/layout.rb +0 -10
- data/lib/nanoc/base/entities/layout_collection.rb +0 -14
- data/lib/nanoc/base/entities/lazy_value.rb +0 -43
- data/lib/nanoc/base/entities/pattern.rb +0 -85
- data/lib/nanoc/base/entities/processing_action.rb +0 -21
- data/lib/nanoc/base/entities/processing_actions.rb +0 -5
- data/lib/nanoc/base/entities/processing_actions/filter.rb +0 -36
- data/lib/nanoc/base/entities/processing_actions/layout.rb +0 -36
- data/lib/nanoc/base/entities/processing_actions/snapshot.rb +0 -46
- data/lib/nanoc/base/entities/snapshot_def.rb +0 -22
- data/lib/nanoc/base/repos/data_source.rb +0 -168
- data/lib/nanoc/base/repos/snapshot_repo.rb +0 -67
- data/lib/nanoc/base/services/checksummer.rb +0 -274
- data/lib/nanoc/base/services/notification_center.rb +0 -87
- data/lib/nanoc/base/services/temp_filename_factory.rb +0 -52
@@ -1,13 +1,32 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
3
|
+
module Nanoc
|
4
|
+
module Int
|
5
|
+
class Compiler
|
6
|
+
class Stage
|
7
|
+
def call(*args)
|
8
|
+
notify(:stage_started)
|
9
|
+
res = Nanoc::Int::Instrumentor.call(:stage_ran, self.class) do
|
10
|
+
run(*args)
|
11
|
+
end
|
12
|
+
notify(:stage_ended)
|
13
|
+
res
|
14
|
+
rescue
|
15
|
+
notify(:stage_aborted)
|
16
|
+
raise
|
17
|
+
end
|
18
|
+
|
19
|
+
def run(*)
|
20
|
+
raise NotImplementedError
|
21
|
+
end
|
9
22
|
|
10
|
-
|
11
|
-
|
23
|
+
private
|
24
|
+
|
25
|
+
def notify(sym)
|
26
|
+
name = self.class.to_s.sub(/^.*::/, '')
|
27
|
+
Nanoc::Core::NotificationCenter.post(sym, name)
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
12
31
|
end
|
13
32
|
end
|
@@ -1,29 +1,35 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
|
-
module Nanoc
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
3
|
+
module Nanoc
|
4
|
+
module Int
|
5
|
+
class Compiler
|
6
|
+
module Stages
|
7
|
+
class BuildReps < Nanoc::Int::Compiler::Stage
|
8
|
+
def initialize(site:, action_provider:)
|
9
|
+
@site = site
|
10
|
+
@action_provider = action_provider
|
11
|
+
end
|
9
12
|
|
10
|
-
|
11
|
-
|
13
|
+
def run
|
14
|
+
reps = Nanoc::Int::ItemRepRepo.new
|
12
15
|
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
+
builder = Nanoc::Int::ItemRepBuilder.new(
|
17
|
+
@site, @action_provider, reps
|
18
|
+
)
|
16
19
|
|
17
|
-
|
20
|
+
action_sequences = builder.run
|
18
21
|
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
+
@site.layouts.each do |layout|
|
23
|
+
action_sequences[layout] = @action_provider.action_sequence_for(layout)
|
24
|
+
end
|
22
25
|
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
26
|
+
{
|
27
|
+
reps: reps,
|
28
|
+
action_sequences: action_sequences,
|
29
|
+
}
|
30
|
+
end
|
31
|
+
end
|
32
|
+
end
|
27
33
|
end
|
28
34
|
end
|
29
35
|
end
|
@@ -1,38 +1,44 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
|
-
module Nanoc
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
3
|
+
module Nanoc
|
4
|
+
module Int
|
5
|
+
class Compiler
|
6
|
+
module Stages
|
7
|
+
class CalculateChecksums < Nanoc::Int::Compiler::Stage
|
8
|
+
def initialize(items:, layouts:, code_snippets:, config:)
|
9
|
+
@items = items
|
10
|
+
@layouts = layouts
|
11
|
+
@code_snippets = code_snippets
|
12
|
+
@config = config
|
13
|
+
end
|
11
14
|
|
12
|
-
|
13
|
-
|
15
|
+
def run
|
16
|
+
checksums = {}
|
14
17
|
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
18
|
+
[@items, @layouts].each do |documents|
|
19
|
+
documents.each do |document|
|
20
|
+
checksums[[document.reference, :content]] =
|
21
|
+
Nanoc::Core::Checksummer.calc_for_content_of(document)
|
22
|
+
checksums[[document.reference, :each_attribute]] =
|
23
|
+
Nanoc::Core::Checksummer.calc_for_each_attribute_of(document)
|
24
|
+
end
|
25
|
+
end
|
23
26
|
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
27
|
+
[@items, @layouts, @code_snippets].each do |objs|
|
28
|
+
objs.each do |obj|
|
29
|
+
checksums[obj.reference] = Nanoc::Core::Checksummer.calc(obj)
|
30
|
+
end
|
31
|
+
end
|
29
32
|
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
33
|
+
checksums[@config.reference] =
|
34
|
+
Nanoc::Core::Checksummer.calc(@config)
|
35
|
+
checksums[[@config.reference, :each_attribute]] =
|
36
|
+
Nanoc::Core::Checksummer.calc_for_each_attribute_of(@config)
|
34
37
|
|
35
|
-
|
38
|
+
Nanoc::Int::ChecksumCollection.new(checksums)
|
39
|
+
end
|
40
|
+
end
|
41
|
+
end
|
36
42
|
end
|
37
43
|
end
|
38
44
|
end
|
@@ -1,37 +1,43 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
|
-
module Nanoc
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
3
|
+
module Nanoc
|
4
|
+
module Int
|
5
|
+
class Compiler
|
6
|
+
module Stages
|
7
|
+
class Cleanup < Nanoc::Int::Compiler::Stage
|
8
|
+
def initialize(output_dirs)
|
9
|
+
@output_dirs = output_dirs
|
10
|
+
end
|
8
11
|
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
12
|
+
def run
|
13
|
+
cleanup_temps(Nanoc::Filter::TMP_BINARY_ITEMS_DIR)
|
14
|
+
cleanup_temps(Nanoc::Int::ItemRepWriter::TMP_TEXT_ITEMS_DIR)
|
15
|
+
cleanup_unused_stores
|
16
|
+
cleanup_old_stores
|
17
|
+
end
|
15
18
|
|
16
|
-
|
19
|
+
private
|
17
20
|
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
+
def cleanup_temps(dir)
|
22
|
+
Nanoc::Core::TempFilenameFactory.instance.cleanup(dir)
|
23
|
+
end
|
21
24
|
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
25
|
+
def cleanup_unused_stores
|
26
|
+
used_paths = @output_dirs.map { |d| Nanoc::Int::Store.tmp_path_prefix(d) }
|
27
|
+
all_paths = Dir.glob('tmp/nanoc/*')
|
28
|
+
(all_paths - used_paths).each do |obsolete_path|
|
29
|
+
FileUtils.rm_rf(obsolete_path)
|
30
|
+
end
|
31
|
+
end
|
29
32
|
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
33
|
+
def cleanup_old_stores
|
34
|
+
%w[checksums compiled_content dependencies outdatedness action_sequence].each do |fn|
|
35
|
+
full_fn = File.join('tmp', fn)
|
36
|
+
if File.file?(full_fn)
|
37
|
+
FileUtils.rm_f(full_fn)
|
38
|
+
end
|
39
|
+
end
|
40
|
+
end
|
35
41
|
end
|
36
42
|
end
|
37
43
|
end
|
@@ -1,88 +1,98 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
|
-
module Nanoc
|
4
|
-
|
5
|
-
|
6
|
-
|
3
|
+
module Nanoc
|
4
|
+
module Int
|
5
|
+
class Compiler
|
6
|
+
module Stages
|
7
|
+
class CompileReps < Nanoc::Int::Compiler::Stage
|
8
|
+
include Nanoc::Core::ContractsSupport
|
9
|
+
include Nanoc::Assertions::Mixin
|
7
10
|
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
11
|
+
def initialize(reps:, outdatedness_store:, dependency_store:, action_sequences:, compilation_context:, compiled_content_cache:)
|
12
|
+
@reps = reps
|
13
|
+
@outdatedness_store = outdatedness_store
|
14
|
+
@dependency_store = dependency_store
|
15
|
+
@action_sequences = action_sequences
|
16
|
+
@compilation_context = compilation_context
|
17
|
+
@compiled_content_cache = compiled_content_cache
|
18
|
+
end
|
16
19
|
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
20
|
+
def run
|
21
|
+
outdated_reps = @reps.select { |r| @outdatedness_store.include?(r) }
|
22
|
+
selector = Nanoc::Int::ItemRepSelector.new(outdated_reps)
|
23
|
+
run_phase_stack do |phase_stack|
|
24
|
+
selector.each do |rep|
|
25
|
+
handle_errors_while(rep) do
|
26
|
+
compile_rep(rep, phase_stack: phase_stack, is_outdated: @outdatedness_store.include?(rep))
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
30
|
+
|
31
|
+
assert Nanoc::Assertions::AllItemRepsHaveCompiledContent.new(
|
32
|
+
compiled_content_cache: @compiled_content_cache,
|
33
|
+
item_reps: @reps,
|
34
|
+
)
|
35
|
+
ensure
|
36
|
+
@outdatedness_store.store
|
37
|
+
@compiled_content_cache.prune(items: @reps.map(&:item).uniq)
|
38
|
+
@compiled_content_cache.store
|
24
39
|
end
|
25
|
-
end
|
26
|
-
end
|
27
40
|
|
28
|
-
|
29
|
-
compiled_content_cache: @compiled_content_cache,
|
30
|
-
item_reps: @reps,
|
31
|
-
)
|
32
|
-
ensure
|
33
|
-
@outdatedness_store.store
|
34
|
-
@compiled_content_cache.prune(items: @reps.map(&:item).uniq)
|
35
|
-
@compiled_content_cache.store
|
36
|
-
end
|
41
|
+
private
|
37
42
|
|
38
|
-
|
43
|
+
def handle_errors_while(item_rep)
|
44
|
+
yield
|
45
|
+
rescue Exception => e # rubocop:disable Lint/RescueException
|
46
|
+
raise Nanoc::Int::Errors::CompilationError.new(e, item_rep)
|
47
|
+
end
|
39
48
|
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
raise Nanoc::Int::Errors::CompilationError.new(e, item_rep)
|
44
|
-
end
|
49
|
+
def compile_rep(rep, phase_stack:, is_outdated:)
|
50
|
+
phase_stack.call(rep, is_outdated: is_outdated)
|
51
|
+
end
|
45
52
|
|
46
|
-
|
47
|
-
|
48
|
-
|
53
|
+
def run_phase_stack
|
54
|
+
phase_stack = build_phase_stack
|
55
|
+
phase_stack.start
|
56
|
+
yield(phase_stack)
|
57
|
+
ensure
|
58
|
+
phase_stack.stop
|
59
|
+
end
|
49
60
|
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
end
|
61
|
+
def build_phase_stack
|
62
|
+
recalculate_phase = Nanoc::Int::Compiler::Phases::Recalculate.new(
|
63
|
+
action_sequences: @action_sequences,
|
64
|
+
dependency_store: @dependency_store,
|
65
|
+
compilation_context: @compilation_context,
|
66
|
+
)
|
57
67
|
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
)
|
68
|
+
cache_phase = Nanoc::Int::Compiler::Phases::Cache.new(
|
69
|
+
compiled_content_cache: @compiled_content_cache,
|
70
|
+
compiled_content_store: @compilation_context.compiled_content_store,
|
71
|
+
wrapped: recalculate_phase,
|
72
|
+
)
|
64
73
|
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
wrapped: recalculate_phase,
|
69
|
-
)
|
74
|
+
resume_phase = Nanoc::Int::Compiler::Phases::Resume.new(
|
75
|
+
wrapped: cache_phase,
|
76
|
+
)
|
70
77
|
|
71
|
-
|
72
|
-
|
73
|
-
|
78
|
+
write_phase = Nanoc::Int::Compiler::Phases::Write.new(
|
79
|
+
compiled_content_store: @compilation_context.compiled_content_store,
|
80
|
+
wrapped: resume_phase,
|
81
|
+
)
|
74
82
|
|
75
|
-
|
76
|
-
|
77
|
-
|
78
|
-
|
83
|
+
mark_done_phase = Nanoc::Int::Compiler::Phases::MarkDone.new(
|
84
|
+
wrapped: write_phase,
|
85
|
+
outdatedness_store: @outdatedness_store,
|
86
|
+
)
|
79
87
|
|
80
|
-
|
81
|
-
|
82
|
-
|
83
|
-
)
|
88
|
+
notify_phrase = Nanoc::Int::Compiler::Phases::Notify.new(
|
89
|
+
wrapped: mark_done_phase,
|
90
|
+
)
|
84
91
|
|
85
|
-
|
92
|
+
notify_phrase
|
93
|
+
end
|
94
|
+
end
|
95
|
+
end
|
86
96
|
end
|
87
97
|
end
|
88
98
|
end
|
@@ -1,45 +1,51 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
|
-
module Nanoc
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
3
|
+
module Nanoc
|
4
|
+
module Int
|
5
|
+
class Compiler
|
6
|
+
module Stages
|
7
|
+
class DetermineOutdatedness < Nanoc::Int::Compiler::Stage
|
8
|
+
include Nanoc::Core::ContractsSupport
|
9
|
+
|
10
|
+
def initialize(reps:, outdatedness_checker:, outdatedness_store:)
|
11
|
+
@reps = reps
|
12
|
+
@outdatedness_checker = outdatedness_checker
|
13
|
+
@outdatedness_store = outdatedness_store
|
14
|
+
end
|
15
|
+
|
16
|
+
contract C::None => C::Any
|
17
|
+
def run
|
18
|
+
outdated_items = select_outdated_items
|
19
|
+
outdated_reps = reps_of_items(outdated_items)
|
20
|
+
|
21
|
+
store_outdated_reps(outdated_reps)
|
22
|
+
|
23
|
+
outdated_items
|
24
|
+
end
|
25
|
+
|
26
|
+
private
|
27
|
+
|
28
|
+
def store_outdated_reps(reps)
|
29
|
+
@outdatedness_store.clear
|
30
|
+
reps.each { |r| @outdatedness_store.add(r) }
|
31
|
+
end
|
32
|
+
|
33
|
+
def select_outdated_items
|
34
|
+
@reps
|
35
|
+
.select { |r| outdated?(r) }
|
36
|
+
.map(&:item)
|
37
|
+
.uniq
|
38
|
+
end
|
39
|
+
|
40
|
+
def reps_of_items(items)
|
41
|
+
Set.new(items.flat_map { |i| @reps[i] })
|
42
|
+
end
|
43
|
+
|
44
|
+
def outdated?(rep)
|
45
|
+
@outdatedness_store.include?(rep) || @outdatedness_checker.outdated?(rep)
|
46
|
+
end
|
47
|
+
end
|
48
|
+
end
|
43
49
|
end
|
44
50
|
end
|
45
51
|
end
|