diff options
author | Eelco Dolstra <eelco.dolstra@logicblox.com> | 2018-02-27T11·53+0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-02-27T11·53+0100 |
commit | 8a5da93841db745e7254860b00ca1a693fb829c9 (patch) | |
tree | 26178762b948c9c64812a3aad90164de4f8a0df2 /src | |
parent | 24ec7500032c2434e450b7bc3f77ff4c1f12c41c (diff) | |
parent | 77e9e1ed91182cb8409d325e225a99decb49b3d5 (diff) |
Merge pull request #1912 from dezgeg/replacestrings-take-2
libexpr: Fix prim_replaceStrings() to work on an empty source string, take 2
Diffstat (limited to 'src')
-rw-r--r-- | src/libexpr/primops.cc | 17 |
1 files changed, 14 insertions, 3 deletions
diff --git a/src/libexpr/primops.cc b/src/libexpr/primops.cc index a800d24290ae..db258ea186e1 100644 --- a/src/libexpr/primops.cc +++ b/src/libexpr/primops.cc @@ -1913,21 +1913,32 @@ static void prim_replaceStrings(EvalState & state, const Pos & pos, Value * * ar auto s = state.forceString(*args[2], context, pos); string res; - for (size_t p = 0; p < s.size(); ) { + // Loops one past last character to handle the case where 'from' contains an empty string. + for (size_t p = 0; p <= s.size(); ) { bool found = false; auto i = from.begin(); auto j = to.begin(); for (; i != from.end(); ++i, ++j) if (s.compare(p, i->size(), *i) == 0) { found = true; - p += i->size(); res += j->first; + if (i->empty()) { + if (p < s.size()) + res += s[p]; + p++; + } else { + p += i->size(); + } for (auto& path : j->second) context.insert(path); j->second.clear(); break; } - if (!found) res += s[p++]; + if (!found) { + if (p < s.size()) + res += s[p]; + p++; + } } mkString(v, res, context); |