lib/nanoc3/data_sources/filesystem_unified.rb in nanoc3-3.1.7 vs lib/nanoc3/data_sources/filesystem_unified.rb in nanoc3-3.1.8

- old
+ new

@@ -38,12 +38,12 @@ # foo.entry.html → /foo.entry/ # # (`allow_periods_in_identifiers` set to false) # foo.html.erb → /foo/ # - # Note that it is possible for two different, separate files to have the - # same identifier. It is recommended to avoid such situations. + # Note that each item must have an unique identifier. nanoc will display an + # error if two items with the same identifier are found. # # Some more examples: # # content/index.html → / # content/foo.html → /foo/ @@ -101,13 +101,13 @@ end # Returns the identifier derived from the given filename, first stripping # the given directory name off the filename. def identifier_for_filename(filename) - if filename =~ /index\.[^\/]+$/ - regex = ((@config && @config[:allow_periods_in_identifiers]) ? /index\.[^\/\.]+$/ : /index\.[^\/]+$/) + if filename =~ /(^|\/)index\.[^\/]+$/ + regex = ((@config && @config[:allow_periods_in_identifiers]) ? /\/?index\.[^\/\.]+$/ : /\/?index\.[^\/]+$/) else - regex = ((@config && @config[:allow_periods_in_identifiers]) ? /\.[^\/\.]+$/ : /\.[^\/]+$/) + regex = ((@config && @config[:allow_periods_in_identifiers]) ? /\.[^\/\.]+$/ : /\.[^\/]+$/) end filename.sub(regex, '').cleaned_identifier end end