arabica/include/XSLT/impl/xslt_inline_element.hpp

95 lines
2.5 KiB
C++
Raw Normal View History

2007-07-19 19:01:42 +02:00
#ifndef ARABICA_XSLT_INLINE_ELEMENT_HPP
#define ARABICA_XSLT_INLINE_ELEMENT_HPP
#include "xslt_item.hpp"
2007-09-05 00:55:47 +02:00
#include <SAX/helpers/AttributesImpl.hpp>
2007-07-19 19:01:42 +02:00
namespace Arabica
{
namespace XSLT
{
2012-11-04 18:22:47 +01:00
template<class string_type, class string_adaptor>
2007-07-19 19:01:42 +02:00
class InlineAttribute
{
public:
2012-11-04 18:22:47 +01:00
InlineAttribute(const string_type& name,
const string_type& name_space,
Arabica::XPath::XPathExpressionPtr<string_type, string_adaptor> value) :
2007-07-19 19:01:42 +02:00
name_(name),
namespace_(name_space),
value_(value)
{
} // InlineAttribute
InlineAttribute(const InlineAttribute& rhs) :
name_(rhs.name_),
namespace_(rhs.namespace_),
value_(rhs.value_)
{
} // InlineAttribute
InlineAttribute& operator==(const InlineAttribute& rhs)
{
name_ = rhs.name_;
namespace_ = rhs.namespace_;
value_ = rhs.value_;
return *this;
} // operator==
2012-11-04 18:22:47 +01:00
void execute(const DOM::Node<string_type, string_adaptor>& node, ExecutionContext& context) const
2007-07-19 19:01:42 +02:00
{
context.sink().start_attribute(name_, namespace_);
context.sink().characters(value_->evaluateAsString(node, context.xpathContext()));
context.sink().end_attribute();
} // execute
private:
2012-11-04 18:22:47 +01:00
string_type name_;
string_type namespace_;
Arabica::XPath::XPathExpressionPtr<string_type, string_adaptor> value_;
2007-07-19 19:01:42 +02:00
}; // class InlineAttribute
2012-11-04 23:34:40 +01:00
template<class stringT, class adaptorT>
2007-07-19 19:01:42 +02:00
class InlineElement : public ItemContainer
{
public:
2012-11-04 23:34:40 +01:00
typedef stringT string_type;
typedef adaptorT string_adaptor;
2012-11-04 18:22:47 +01:00
InlineElement(const string_type& name,
const string_type& name_space,
const std::vector<InlineAttribute<string_type, string_adaptor> >& attrs) :
2007-07-19 19:01:42 +02:00
name_(name),
namespace_(name_space),
attrs_(attrs)
{
} // InlineElement
virtual ~InlineElement() { }
2012-11-04 18:22:47 +01:00
virtual void execute(const DOM::Node<string_type, string_adaptor>& node, ExecutionContext& context) const
2007-07-19 19:01:42 +02:00
{
if(context.sink().start_element(name_, namespace_))
{
2012-11-04 18:22:47 +01:00
for(typename std::vector<InlineAttribute<string_type, string_adaptor> >::const_iterator a = attrs_.begin(), ae = attrs_.end(); a != ae; ++a)
2007-07-19 19:01:42 +02:00
a->execute(node, context);
ChainStackFrame frame(context);
2007-07-19 19:01:42 +02:00
execute_children(node, context);
context.sink().end_element(name_, namespace_);
}
} // execute
private:
2012-11-04 18:22:47 +01:00
string_type name_;
string_type namespace_;
std::vector<InlineAttribute<string_type, string_adaptor> > attrs_;
2007-07-19 19:01:42 +02:00
}; // class InlineElement
} // namespace XSLT
} // namespace Arabica
#endif