diff options
author | MatthewM <mcm@they-got.us> | 2012-12-15 21:46:14 -0500 |
---|---|---|
committer | MatthewM <mcm@they-got.us> | 2012-12-15 21:46:14 -0500 |
commit | 6b5f583ff36b7719e6358b92a9a35c59090a3011 (patch) | |
tree | c86164a4bd579914a1339326d0a0f8c35e187d0d /modules/extra/webcpanel/template_fileserver.cpp | |
parent | a049092526b6ff53899f09176c7c8b76a9b90c80 (diff) | |
parent | c49f03f985a4f142d4b050cbe57fc548e88207e4 (diff) |
Merge Adams commit to allow escaping of brackets
Diffstat (limited to 'modules/extra/webcpanel/template_fileserver.cpp')
-rw-r--r-- | modules/extra/webcpanel/template_fileserver.cpp | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/modules/extra/webcpanel/template_fileserver.cpp b/modules/extra/webcpanel/template_fileserver.cpp index ca2ff034f..79e583388 100644 --- a/modules/extra/webcpanel/template_fileserver.cpp +++ b/modules/extra/webcpanel/template_fileserver.cpp @@ -115,9 +115,12 @@ void TemplateFileServer::Serve(HTTPProvider *server, const Anope::string &page_n Anope::string finished; + bool escaped = false; for (unsigned j = 0; j < buf.length(); ++j) { - if (buf[j] == '{') + if (buf[j] == '\\' && j + 1 < buf.length() && (buf[j + 1] == '{' || buf[j + 1] == '}')) + escaped = true; + else if (buf[j] == '{' && !escaped) { size_t f = buf.substr(j).find('}'); if (f == Anope::string::npos) @@ -241,6 +244,8 @@ void TemplateFileServer::Serve(HTTPProvider *server, const Anope::string &page_n } else { + escaped = false; + // If the if stack is empty or we are in a true statement bool ifok = IfStack.empty() || IfStack.top(); bool forok = ForLoop::Stack.empty() || !ForLoop::Stack.back().finished(r); |