diff --git a/lib/mustache.ex b/lib/mustache.ex index 09ac528..1833f8f 100644 --- a/lib/mustache.ex +++ b/lib/mustache.ex @@ -75,11 +75,11 @@ defmodule Mustache do defp scan_for_dot(template, data) do regex = regex("{{", "}}", "\\w+(\\.\\w+)+") - scans = Regex.scan(regex, template) |> List.flatten - case scans do - [] -> template + matches = Regex.run(regex, template) + case matches do + nil -> template _ -> - path = List.first(scans) |> clean(["{{", "}}"]) + path = List.first(matches) |> clean(["{{", "}}"]) scan_for_dot(interpolate(template, data, path), data) end end @@ -151,7 +151,7 @@ defmodule Mustache do fn(template, data) -> process_section(template, data) end }, { fn(template) -> Regex.match?(triple_regex(), template) end, fn(template, data) -> triple_mustaches(template, data) end}, - { fn(template) -> Regex.match?(regex("{{", "}}", "\\w+\\.\\w+"), template) end, + { fn(template) -> Regex.match?(regex("{{", "}}", "\\w+(\\.\\w+)+"), template) end, fn(template, data) -> scan_for_dot(template, data) end }, { fn(template) -> Regex.match?(double_regex(), template) end, fn(template, data) -> double_mustaches(template, data) end}] diff --git a/test/mustache_feature_test.exs b/test/mustache_feature_test.exs index 8a708db..d797e28 100644 --- a/test/mustache_feature_test.exs +++ b/test/mustache_feature_test.exs @@ -61,7 +61,9 @@ defmodule MustacheFeatureTest do test "Dotted Names" do assert Mustache.render("\"{{person.name}}\" == \"Joe\"", - %{person: %{name: "Joe"}}) == "\"Joe\" == \"Joe\"" + %{person: %{name: "Joe"}}) == "\"Joe\" == \"Joe\"" + assert Mustache.render("\"{{person.name.first}}\" == \"Joe\"", + %{person: %{name: %{first: "Joe"}}}) == "\"Joe\" == \"Joe\"" end #Sections