Skip to content

Commit

Permalink
fixed performance regression in endsWith()
Browse files Browse the repository at this point in the history
  • Loading branch information
firewave committed Nov 14, 2023
1 parent cfef803 commit f02a68a
Showing 1 changed file with 4 additions and 1 deletion.
5 changes: 4 additions & 1 deletion simplecpp.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -154,7 +154,10 @@ static unsigned long long stringToULL(const std::string &s)

static bool endsWith(const std::string &s, const std::string &e)
{
return (s.size() >= e.size()) && std::equal(e.rbegin(), e.rend(), s.rbegin());
// TODO: std::equal() is much faster than std::string::compare() in a benchmark
// but in our case it leads to a big performance regression
//return (s.size() >= e.size()) && std::equal(e.rbegin(), e.rend(), s.rbegin());
return (s.size() >= e.size() && s.compare(s.size() - e.size(), e.size(), e) == 0);
}

static bool sameline(const simplecpp::Token *tok1, const simplecpp::Token *tok2)
Expand Down

0 comments on commit f02a68a

Please sign in to comment.