From 001b6a3bc4f2ee1818deefe2fa729ec9de175f05 Mon Sep 17 00:00:00 2001 From: mdesalvo Date: Fri, 16 Oct 2020 20:31:05 +0200 Subject: [PATCH] More robust detection of subject node element --- RDFSharp/Model/Serializers/RDFXml.cs | 51 ++++++++-------------------- 1 file changed, 15 insertions(+), 36 deletions(-) diff --git a/RDFSharp/Model/Serializers/RDFXml.cs b/RDFSharp/Model/Serializers/RDFXml.cs index d18b009a..ee00d6a5 100644 --- a/RDFSharp/Model/Serializers/RDFXml.cs +++ b/RDFSharp/Model/Serializers/RDFXml.cs @@ -823,11 +823,11 @@ private static RDFResource GetSubjectNode(XmlNode subjNode, Uri xmlBase, RDFGrap { RDFResource subj = null; - //If there are attributes, search them for the one representing the subj + //If there are attributes, search for the one describing the subject if (subjNode.Attributes != null && subjNode.Attributes.Count > 0) { - //We are interested in finding the "rdf:about" or "rdf:resource" node for the subj + //We are interested in finding the "rdf:about" or "rdf:resource" XmlAttribute rdfAbout = (GetRdfAboutAttribute(subjNode) ?? GetRdfResourceAttribute(subjNode)); @@ -839,45 +839,24 @@ private static RDFResource GetSubjectNode(XmlNode subjNode, Uri xmlBase, RDFGrap subj = new RDFResource(rdfAboutValue); } - //If "rdf:about" attribute has been found for the subj, we must - //check if the node is not a standard "rdf:Description": this is - //the case we can directly build a triple with "rdf:type" pred - if (subj != null && !CheckIfRdfDescriptionNode(subjNode)) - { - RDFResource obj = null; - if (subjNode.NamespaceURI == String.Empty) - { - obj = new RDFResource(xmlBase + subjNode.LocalName); - } - else - { - obj = new RDFResource(subjNode.NamespaceURI + subjNode.LocalName); - } - result.AddTriple(new RDFTriple(subj, RDFVocabulary.RDF.TYPE, obj)); - } - } - - //Otherwise make the subj a blank node - else - { + if (subj == null) subj = new RDFResource(); - //We must check if the node is not a standard "rdf:Description": this is - //the case we can directly build a triple with "rdf:type" pred - if (!CheckIfRdfDescriptionNode(subjNode)) + //We must check if the node is not a standard "rdf:Description": this is + //the case we can directly build a triple with "rdf:type" pred + if (!CheckIfRdfDescriptionNode(subjNode)) + { + RDFResource obj = null; + if (subjNode.NamespaceURI == String.Empty) { - RDFResource obj = null; - if (subjNode.NamespaceURI == String.Empty) - { - obj = new RDFResource(xmlBase + subjNode.LocalName); - } - else - { - obj = new RDFResource(subjNode.NamespaceURI + subjNode.LocalName); - } - result.AddTriple(new RDFTriple(subj, RDFVocabulary.RDF.TYPE, obj)); + obj = new RDFResource(xmlBase + subjNode.LocalName); + } + else + { + obj = new RDFResource(subjNode.NamespaceURI + subjNode.LocalName); } + result.AddTriple(new RDFTriple(subj, RDFVocabulary.RDF.TYPE, obj)); } return subj;