optimizations

This commit is contained in:
Daniel Sipka 2015-04-16 11:41:57 +02:00
parent dc513839bd
commit 25bbbfdbcc
8 changed files with 22 additions and 26 deletions

View file

@ -20,6 +20,7 @@ namespace mstch {
private: private:
render_context& context; render_context& context;
}; };
render_context( render_context(
const mstch::object& object, const mstch::object& object,
const std::map<std::string,template_type>& partials); const std::map<std::string,template_type>& partials);

View file

@ -18,8 +18,7 @@ std::string state::in_section::render(render_context& ctx, const token& token) {
std::string out; std::string out;
if (!boost::apply_visitor(visitor::is_node_empty(), section_node)) if (!boost::apply_visitor(visitor::is_node_empty(), section_node))
out = boost::apply_visitor( out = boost::apply_visitor(
visitor::render_section(ctx, section), visitor::render_section(ctx, section), section_node);
section_node);
ctx.set_state<outside_section>(); ctx.set_state<outside_section>();
return out; return out;
} else { } else {

View file

@ -5,6 +5,7 @@
#include "render_context.hpp" #include "render_context.hpp"
using namespace mstch; using namespace mstch;
using flag = visitor::render_node::flag;
std::string state::outside_section::render( std::string state::outside_section::render(
render_context& ctx, const token& token) render_context& ctx, const token& token)
@ -17,13 +18,10 @@ std::string state::outside_section::render(
ctx.set_state<in_inverted_section>(token.content()); ctx.set_state<in_inverted_section>(token.content());
break; break;
case token::type::variable: case token::type::variable:
case token::type::unescaped_variable: { case token::type::unescaped_variable:
std::set<visitor::render_node::flag> flags{}; return boost::apply_visitor(visitor::render_node((token.token_type() ==
if (token.token_type() == token::type::variable) token::type::variable)?flag::escape_html:flag::none),
flags.insert(visitor::render_node::flag::escape_html); ctx.get_node(token.content()));
return boost::apply_visitor(
visitor::render_node(flags), ctx.get_node(token.content()));
}
case token::type::comment: break; case token::type::comment: break;
case token::type::text: case token::type::text:
return token.content(); return token.content();

View file

@ -33,14 +33,12 @@ void template_type::tokenize(const std::string& t) {
else else
pstate = parse_state::start; pstate = parse_state::start;
} else if(pstate == parse_state::in_del) { } else if(pstate == parse_state::in_del) {
if (*it == '{') { if (*it == '{')
pstate = parse_state::in_esccontent; pstate = parse_state::in_esccontent;
} else if (*it == delim_end[0]) { else if (*it == delim_end[0] && (del_pos = 1))
pstate = parse_state::in_del_end; pstate = parse_state::in_del_end;
del_pos = 1; else
} else {
pstate = parse_state::in_content; pstate = parse_state::in_content;
}
} else if(pstate == parse_state::in_esccontent && *it == '}') { } else if(pstate == parse_state::in_esccontent && *it == '}') {
pstate = parse_state::in_content; pstate = parse_state::in_content;
} else if(pstate == parse_state::in_content && *it == delim_end[0]) { } else if(pstate == parse_state::in_content && *it == delim_end[0]) {

View file

@ -3,7 +3,7 @@
using namespace mstch; using namespace mstch;
visitor::render_node::render_node(std::set<flag> flags): flags(flags) { visitor::render_node::render_node(flag p_flag): m_flag(p_flag) {
} }
std::string visitor::render_node::operator()(const boost::blank& blank) const { std::string visitor::render_node::operator()(const boost::blank& blank) const {
@ -19,7 +19,7 @@ std::string visitor::render_node::operator()(const bool& b) const {
} }
std::string visitor::render_node::operator()(const std::string& str) const { std::string visitor::render_node::operator()(const std::string& str) const {
return (flags.find(flag::escape_html) != flags.end())?html_escape(str):str; return (m_flag == flag::escape_html)?html_escape(str):str;
} }
std::string visitor::render_node::operator()(const array& arr) const { std::string visitor::render_node::operator()(const array& arr) const {

View file

@ -10,8 +10,8 @@ namespace mstch {
namespace visitor { namespace visitor {
class render_node: public boost::static_visitor<std::string> { class render_node: public boost::static_visitor<std::string> {
public: public:
enum class flag { escape_html }; enum class flag { none, escape_html };
render_node(std::set<flag> flags = {}); render_node(flag p_flag = flag::none);
std::string operator()(const boost::blank& blank) const; std::string operator()(const boost::blank& blank) const;
std::string operator()(const int& i) const; std::string operator()(const int& i) const;
std::string operator()(const bool& b) const; std::string operator()(const bool& b) const;
@ -21,7 +21,7 @@ namespace mstch {
std::string operator()(const string_lambda& lambda) const; std::string operator()(const string_lambda& lambda) const;
std::string operator()(const renderer_lambda& lambda) const; std::string operator()(const renderer_lambda& lambda) const;
private: private:
std::set<flag> flags; flag m_flag;
}; };
} }
} }

View file

@ -3,8 +3,8 @@
using namespace mstch; using namespace mstch;
visitor::render_section::render_section( visitor::render_section::render_section(
render_context& ctx, const template_type& section,std::set<flag> flags): render_context& ctx, const template_type& section, flag p_flag):
ctx(ctx), section(section), flags(flags) ctx(ctx), section(section), m_flag(p_flag)
{ {
} }
@ -32,12 +32,12 @@ std::string visitor::render_section::operator()(const object& obj) const {
std::string visitor::render_section::operator()(const array& a) const { std::string visitor::render_section::operator()(const array& a) const {
std::string out; std::string out;
if(flags.find(flag::keep_array) != flags.end()) if(m_flag == flag::keep_array)
out += render_context::push(ctx, {{".", a}}).render(section); out += render_context::push(ctx, {{".", a}}).render(section);
else else
for (auto& item: a) for (auto& item: a)
out += boost::apply_visitor( out += boost::apply_visitor(
render_section(ctx, section, {flag::keep_array}), item); render_section(ctx, section, flag::keep_array), item);
return out; return out;
} }

View file

@ -11,11 +11,11 @@ namespace mstch {
namespace visitor { namespace visitor {
class render_section: public boost::static_visitor<std::string> { class render_section: public boost::static_visitor<std::string> {
public: public:
enum class flag { keep_array }; enum class flag { none, keep_array };
render_section( render_section(
render_context& ctx, render_context& ctx,
const template_type& section, const template_type& section,
std::set<flag> flags = {}); flag p_flag = flag::none);
std::string operator()(const boost::blank& blank) const; std::string operator()(const boost::blank& blank) const;
std::string operator()(const int& i) const; std::string operator()(const int& i) const;
std::string operator()(const bool& b) const; std::string operator()(const bool& b) const;
@ -27,7 +27,7 @@ namespace mstch {
private: private:
render_context& ctx; render_context& ctx;
const template_type& section; const template_type& section;
std::set<flag> flags; flag m_flag;
}; };
} }
} }