std::vector< Result > AllowedChildrenValidator::ValidateAllowedChildren( const QName &parent_qname, const std::vector< QName > &allowed_children, const xc::DOMDocument &document ) { xc::DOMNodeList *parents_matching = document.getElementsByTagNameNS( toX( parent_qname.namespace_name ), toX( parent_qname.local_name ) ); std::vector< Result > results; if ( parents_matching->getLength() < 1 ) return results; xc::DOMElement* parent = static_cast< xc::DOMElement* >( parents_matching->item( 0 ) ); std::vector< xc::DOMElement* > children = xe::GetElementChildren( *parent ); for ( uint i = 0; i < children.size(); ++i ) { xc::DOMElement *child = children[ i ]; QName child_qname( fromX( child->getLocalName() ), fromX( child->getNamespaceURI() ) ); if ( !Util::Contains< QName >( allowed_children, child_qname ) ) results.push_back( NotAllowedChildResult( *children[ i ] ) ); } return results; }
std::vector< Result > ElementPresentValidator::VerifyElementPresent( const QName &element_qname, const std::vector< QName > &possible_parents, const xc::DOMDocument &document ) { xc::DOMNodeList *matching_elements = document.getElementsByTagNameNS( toX( element_qname.namespace_name ), toX( element_qname.local_name ) ); std::vector< Result > results; if ( matching_elements->getLength() < 1 ) { xc::DOMNode* parent = xe::GetFirstAvailableElement( possible_parents, document ); Result result = parent != NULL ? ResultWithNodeLocation( ERROR_XML_ELEMENT_NOT_PRESENT, *parent ) : Result( ERROR_XML_ELEMENT_NOT_PRESENT ); result.AddMessageArgument( element_qname.local_name ); results.push_back( result ); } return results; }