-/**
- * Tests pattern from the vector in order and executes recipe on
- the first match.
- */
-const std::string yf::HttpRewrite::Rules::test_patterns(
- std::map<std::string, std::string> & vars,
- const std::string & txt) const
+yf::HttpRewrite::Event::Event(const Content *p,
+ std::map<std::string, std::string> & vars
+ ) : m_content(p), m_vars(vars)
+{
+ m_w = wrbuf_alloc();
+}
+
+yf::HttpRewrite::Event::~Event()
+{
+ wrbuf_destroy(m_w);
+}
+
+const char *yf::HttpRewrite::Event::result()
+{
+ return wrbuf_cstr(m_w);
+}
+
+void yf::HttpRewrite::Event::openTagStart(const char *tag, int tag_len)
+{
+ wrbuf_putc(m_w, '<');
+ wrbuf_write(m_w, tag, tag_len);
+
+ std::string t(tag, tag_len);
+ std::list<Within>::const_iterator it = m_content->within_list.begin();
+ for (; it != m_content->within_list.end(); it++)
+ {
+ if (it->tag.length() > 0 && yaz_strcasecmp(it->tag.c_str(),
+ t.c_str()) == 0)
+ {
+ std::vector<std::string> attr;
+ boost::split(attr, it->attr, boost::is_any_of(","));
+ size_t i;
+ for (i = 0; i < attr.size(); i++)
+ {
+ if (attr[i].compare("#text") == 0)
+ {
+ s_within.push(it);
+ return;
+ }
+ }
+ }
+ }
+}
+
+void yf::HttpRewrite::Event::anyTagEnd(const char *tag, int tag_len,
+ int close_it)
+{
+ if (close_it)
+ {
+ if (!s_within.empty())
+ {
+ std::list<Within>::const_iterator it = s_within.top();
+ std::string t(tag, tag_len);
+ if (yaz_strcasecmp(it->tag.c_str(), t.c_str()) == 0)
+ s_within.pop();
+ }
+ }
+ if (close_it)
+ wrbuf_putc(m_w, '/');
+ wrbuf_putc(m_w, '>');
+}
+
+void yf::HttpRewrite::Event::attribute(const char *tag, int tag_len,
+ const char *attr, int attr_len,
+ const char *value, int val_len,
+ const char *sep)