lib/nanoc3/data_sources/filesystem_unified.rb in nanoc3-3.1.9 vs lib/nanoc3/data_sources/filesystem_unified.rb in nanoc3-3.2.0a1
- old
+ new
@@ -12,48 +12,48 @@
# the same base name but with the `.yaml` extension. If such a file is
# found, metadata is read from that file. Alternatively, the content file
# itself can start with a metadata section: it can be stored at the top of
# the file, between `---` (three dashes) separators. For example:
#
- # ---
- # title: "Moo!"
- # ---
- # h1. Hello!
+ # ---
+ # title: "Moo!"
+ # ---
+ # h1. Hello!
#
# The metadata section can be omitted. If the file does not start with
# three or five dashes, the entire file will be considered as content.
#
# The identifier of items and layouts is determined as follows. A file with
# an `index.*` filename, such as `index.txt`, will have the filesystem path
# with the `index.*` part stripped as a identifier. For example:
#
- # foo/bar/index.html → /foo/bar/
+ # foo/bar/index.html → /foo/bar/
#
# In other cases, the identifier is calculated by stripping the extension.
# If the `allow_periods_in_identifiers` attribute in the configuration is
# true, only the last extension will be stripped if the file has multiple
# extensions; if it is false or unset, all extensions will be stripped.
# For example:
#
- # (`allow_periods_in_identifiers` set to true)
- # foo.entry.html → /foo.entry/
- #
- # (`allow_periods_in_identifiers` set to false)
- # foo.html.erb → /foo/
+ # (`allow_periods_in_identifiers` set to true)
+ # foo.entry.html → /foo.entry/
+ #
+ # (`allow_periods_in_identifiers` set to false)
+ # foo.html.erb → /foo/
#
- # Note that each item must have an unique identifier. nanoc will display an
- # error if two items with the same identifier are found.
+ # Note that it is possible for two different, separate files to have the
+ # same identifier. It is recommended to avoid such situations.
#
# Some more examples:
#
- # content/index.html → /
- # content/foo.html → /foo/
- # content/foo/index.html → /foo/
- # content/foo/bar.html → /foo/bar/
- # content/foo/bar.baz.html → /foo/bar/ OR /foo/bar.baz/
- # content/foo/bar/index.html → /foo/bar/
- # content/foo.bar/index.html → /foo.bar/
+ # content/index.html → /
+ # content/foo.html → /foo/
+ # content/foo/index.html → /foo/
+ # content/foo/bar.html → /foo/bar/
+ # content/foo/bar.baz.html → /foo/bar/ OR /foo/bar.baz/
+ # content/foo/bar/index.html → /foo/bar/
+ # content/foo.bar/index.html → /foo.bar/
#
# The file extension does not determine the filters to run on items; the
# Rules file is used to specify processing instructors for each item.
class FilesystemUnified < Nanoc3::DataSource
@@ -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