From 7ad0f51d1a2ca177740e069b1ccfec9a68c6f445 Mon Sep 17 00:00:00 2001 From: Ben Hollis Date: Sat, 19 May 2012 13:27:38 -0700 Subject: [PATCH 1/2] Always return HashWithIndifferentAccess from frontmatter data --- .../lib/middleman-core/core_extensions/front_matter.rb | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) diff --git a/middleman-core/lib/middleman-core/core_extensions/front_matter.rb b/middleman-core/lib/middleman-core/core_extensions/front_matter.rb index b4c2d99f..94a3177e 100644 --- a/middleman-core/lib/middleman-core/core_extensions/front_matter.rb +++ b/middleman-core/lib/middleman-core/core_extensions/front_matter.rb @@ -115,15 +115,13 @@ module Middleman::CoreExtensions if result = parse_yaml_front_matter(content) data, content = result - data = ::Middleman::Util.recursively_enhance(data).freeze elsif result = parse_json_front_matter(content) data, content = result - data = ::Middleman::Util.recursively_enhance(data).freeze else data = {} end - [data, content] + [::Middleman::Util.recursively_enhance(data).freeze, content] end def normalize_path(path) @@ -185,4 +183,4 @@ module Middleman::CoreExtensions end end -end \ No newline at end of file +end From fc9c5e5fa25e6fd7d3b382d1911d88e521757be5 Mon Sep 17 00:00:00 2001 From: Ben Hollis Date: Sat, 19 May 2012 14:29:38 -0700 Subject: [PATCH 2/2] Properly clear frontmatter cache when files change, and calculate frontmatter in the right order so resource_list_manipulators can see it. --- .../frontmatter_page_settings.feature | 17 ++++++++++++- .../lib/middleman-core/application.rb | 7 +++--- .../core_extensions/front_matter.rb | 24 ++++++++++++------- 3 files changed, 36 insertions(+), 12 deletions(-) diff --git a/middleman-core/features/frontmatter_page_settings.feature b/middleman-core/features/frontmatter_page_settings.feature index 0ceed6ac..1a12cfd7 100644 --- a/middleman-core/features/frontmatter_page_settings.feature +++ b/middleman-core/features/frontmatter_page_settings.feature @@ -24,4 +24,19 @@ Feature: Setting page settings through frontmatter When I go to "/ignored/index.html" Then I should see "File Not Found" When I go to "/no_index/index.html" - Then I should see "File Not Found" \ No newline at end of file + Then I should see "File Not Found" + + Scenario: Changing frontmatter in preview server + Given the Server is running at "frontmatter-settings-app" + When I go to "/ignored/index.html" + Then I should see "File Not Found" + And the file "source/ignored.html.erb" has the contents + """ + --- + ignored: false + --- + + This file is no longer ignored. + """ + When I go to "/ignored/index.html" + Then I should see "This file is no longer ignored." diff --git a/middleman-core/lib/middleman-core/application.rb b/middleman-core/lib/middleman-core/application.rb index fe025677..aab667d7 100644 --- a/middleman-core/lib/middleman-core/application.rb +++ b/middleman-core/lib/middleman-core/application.rb @@ -140,6 +140,10 @@ module Middleman # Setup custom rendering register Middleman::CoreExtensions::Rendering + # Parse YAML from templates. Must be before sitemap so sitemap + # extensions see updated frontmatter! + register Middleman::CoreExtensions::FrontMatter + # Sitemap register Middleman::Sitemap @@ -158,9 +162,6 @@ module Middleman # i18n register Middleman::CoreExtensions::I18n - # Parse YAML from templates - register Middleman::CoreExtensions::FrontMatter - # Built-in Extensions # Provide Apache-style index.html files for directories diff --git a/middleman-core/lib/middleman-core/core_extensions/front_matter.rb b/middleman-core/lib/middleman-core/core_extensions/front_matter.rb index 94a3177e..86f95d12 100644 --- a/middleman-core/lib/middleman-core/core_extensions/front_matter.rb +++ b/middleman-core/lib/middleman-core/core_extensions/front_matter.rb @@ -15,14 +15,16 @@ module Middleman::CoreExtensions # Parsing JSON frontmatter require "active_support/json" - app.after_configuration do - ::Middleman::Sitemap::Resource.send :include, ResourceInstanceMethods - - app.send :include, InstanceMethods + app.send :include, InstanceMethods + app.before_configuration do files.changed { |file| frontmatter_manager.clear_data(file) } files.deleted { |file| frontmatter_manager.clear_data(file) } - + end + + app.after_configuration do + ::Middleman::Sitemap::Resource.send :include, ResourceInstanceMethods + sitemap.register_resource_list_manipulator( :frontmatter, frontmatter_manager @@ -54,9 +56,15 @@ module Middleman::CoreExtensions @cache[p] ||= frontmatter_and_content(p) end - def clear_data(path) - p = normalize_path(File.expand_path(path, @app.root)) - @cache.delete(p) + def clear_data(file) + # Copied from Sitemap::Store#file_to_path, but without + # removing the file extension + file = File.expand_path(file, @app.root) + prefix = @app.source_dir.sub(/\/$/, "") + "/" + return unless file.include?(prefix) + path = file.sub(prefix, "") + + @cache.delete(path) end # Parse YAML frontmatter out of a string