summaryrefslogtreecommitdiff
path: root/modules/extra/webcpanel/template_fileserver.cpp
diff options
context:
space:
mode:
authorMatthewM <mcm@they-got.us>2012-12-15 21:46:14 -0500
committerMatthewM <mcm@they-got.us>2012-12-15 21:46:14 -0500
commit6b5f583ff36b7719e6358b92a9a35c59090a3011 (patch)
treec86164a4bd579914a1339326d0a0f8c35e187d0d /modules/extra/webcpanel/template_fileserver.cpp
parenta049092526b6ff53899f09176c7c8b76a9b90c80 (diff)
parentc49f03f985a4f142d4b050cbe57fc548e88207e4 (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.cpp7
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);