Class: Middleman::Sitemap::Extensions::OnDisk

Inherits:
Object
  • Object
show all
Defined in:
lib/middleman-core/sitemap/extensions/on_disk.rb

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(sitemap) ⇒ OnDisk

Returns a new instance of OnDisk.



10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
# File 'lib/middleman-core/sitemap/extensions/on_disk.rb', line 10

def initialize(sitemap)
  @sitemap = sitemap
  @app     = @sitemap.app
  @file_paths_on_disk = Set.new

  scoped_self = self
  @waiting_for_ready = true

  # Register file change callback
  @app.files.changed do |file|
    scoped_self.touch_file(file)
  end

  # Register file delete callback
  @app.files.deleted do |file|
    scoped_self.remove_file(file)
  end

  @app.ready do
    scoped_self.waiting_for_ready = false
    # Make sure the sitemap is ready for the first request
    sitemap.ensure_resource_list_updated!
  end
end

Instance Attribute Details

#sitemapObject

Returns the value of attribute sitemap.



7
8
9
# File 'lib/middleman-core/sitemap/extensions/on_disk.rb', line 7

def sitemap
  @sitemap
end

#waiting_for_readyObject

Returns the value of attribute waiting_for_ready.



8
9
10
# File 'lib/middleman-core/sitemap/extensions/on_disk.rb', line 8

def waiting_for_ready
  @waiting_for_ready
end

Instance Method Details

#manipulate_resource_list(resources)

This method returns an undefined value.

Update the main sitemap resource list



80
81
82
83
84
85
86
87
88
# File 'lib/middleman-core/sitemap/extensions/on_disk.rb', line 80

def manipulate_resource_list(resources)
  resources + @file_paths_on_disk.map do |file|
    ::Middleman::Sitemap::Resource.new(
      @sitemap,
      @sitemap.file_to_path(file),
      File.join(@app.root, file)
    )
  end
end

#remove_file(file)

This method returns an undefined value.

Remove a file from the store

Parameters:

  • file (String)


68
69
70
71
72
73
74
75
76
# File 'lib/middleman-core/sitemap/extensions/on_disk.rb', line 68

def remove_file(file)
  return unless @file_paths_on_disk.delete?(file)

  @sitemap.rebuild_resource_list!(:removed_file)

  # Force sitemap rebuild so the next request is ready to go.
  # Skip this during build because the builder will control sitemap refresh.
  @sitemap.ensure_resource_list_updated! unless waiting_for_ready || @app.build?
end

#touch_file(file) ⇒ Boolean

Update or add an on-disk file path

Parameters:

  • file (String)

Returns:

  • (Boolean)


38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
# File 'lib/middleman-core/sitemap/extensions/on_disk.rb', line 38

def touch_file(file)
  return false if File.directory?(file)

  path = @sitemap.file_to_path(file)
  return false unless path

  ignored = @app.config[:ignored_sitemap_matchers].any? do |_, callback|
    if callback.arity == 1
      callback.call(file)
    else
      callback.call(file, @app)
    end
  end

  @file_paths_on_disk << file unless ignored

  # Rebuild the sitemap any time a file is touched
  # in case one of the other manipulators
  # (like asset_hash) cares about the contents of this file,
  # whether or not it belongs in the sitemap (like a partial)
  @sitemap.rebuild_resource_list!(:touched_file)

  # Force sitemap rebuild so the next request is ready to go.
  # Skip this during build because the builder will control sitemap refresh.
  @sitemap.ensure_resource_list_updated! unless waiting_for_ready || @app.build?
end