[gxml/gsoc2013: 99/150] Implementation.vala: factor out error checks into check_ functions



commit ca5c363ca2e5ae3fe7b5d5891c3c34e75fb1582b
Author: Richard Schwarting <aquarichy gmail com>
Date:   Sat Jul 27 00:01:55 2013 -0400

    Implementation.vala: factor out error checks into check_ functions

 gxml/Implementation.vala |   52 +++++++++++++++++++++++++++------------------
 1 files changed, 31 insertions(+), 21 deletions(-)
---
diff --git a/gxml/Implementation.vala b/gxml/Implementation.vala
index 10e0064..6daa496 100644
--- a/gxml/Implementation.vala
+++ b/gxml/Implementation.vala
@@ -39,21 +39,9 @@ namespace GXml {
                internal Implementation () {
                }
 
-               /**
-                * Creates a Document according to this { link GXml.Implementation}.
-                *
-                * Version: DOM Level 3 Core
-                * URL: [[http://www.w3.org/TR/DOM-Level-3-Core/core.html#Level-2-Core-DOM-createDocument]]
-
-                * @param namespace_uri URI for the namespace in which this Document belongs, or `null`.
-                * @param qualified_name A qualified name for the Document, or `null`.
-                * @param doctype The type of the document, or `null`.
-                *
-                * @return The new document.
-                */
-               public Document create_document (string? namespace_uri, string? qualified_name, DocumentType? 
doctype) {
+               private void check_namespace (string? namespace_uri, string? qualified_name) {
                        if (qualified_name == null && namespace_uri != null) {
-                               GLib.warning ("NAMESPACE_ERR: qualified_name is null but namespace_uri [%s] 
is not.  Both should either be null or not null.", namespace_uri);
+                               GXml.warning (DomException.NAMESPACE, "qualified_name is null but 
namespace_uri [%s] is not.  Both should either be null or not null.".printf (namespace_uri));
                        }
                        if (qualified_name != null) {
                                Document.check_invalid_characters (qualified_name, "new Document's root");
@@ -63,28 +51,50 @@ namespace GXml {
                                        // we have a prefix!
                                        if (namespace_uri == null) {
                                                // but we don't have a namespace :|
-                                               GLib.warning ("NAMESPACE_ERR: qualified_name is null but 
namespace_uri [%s] is not.  Both should either be null or not null.", namespace_uri);
+                                               GXml.warning (DomException.NAMESPACE, "namespace_uri is null 
but qualified_name [%s] has prefixed part.  Both should either be null or not null.".printf (qualified_name));
                                        }
 
                                        string expected_uri = "http://www.w3.org/XML/1998/namespace";;
                                        if (parts[0] == "xml" && namespace_uri != expected_uri) {
-                                               GLib.warning ("NAMESPACE_ERR: qualified_name '%s' specifies 
namespace 'xml' but namespace_uri is '%s' and not '%s'",
-                                                             qualified_name, namespace_uri, expected_uri);
+                                               GXml.warning (DomException.NAMESPACE, "qualified_name '%s' 
specifies namespace 'xml' but namespace_uri is '%s' and not '%s'".printf (qualified_name, namespace_uri, 
expected_uri));
                                        }
                                }
                        }
                        // TODO: We should apparently also report a NAMESPACE_ERR if "the qualifiedName is 
malformed"; find out what that means
                        if (namespace_uri != null && ! this.has_feature ("XML")) {
                                // Right now, has_feature should always return true for 'XML' so we shouldn't 
trip this error
-                               GLib.warning ("NAMESPACE_ERR: Implementation lacks feature 'XML' but a 
namespace_uri ('%s') was specified anyway.", namespace_uri);
+                               GXml.warning (DomException.NAMESPACE, "Implementation lacks feature 'XML' but 
a namespace_uri ('%s') was specified anyway.".printf (namespace_uri));
                        }
+               }
 
-                       if (doctype.owner_document != null) {
-                               GLib.warning ("WRONG_DOCUMENT_ERR: The supplied doctype is already connected 
to an existing document.");
+               // Not using DomNode's, because this doctype shouldn't have ANY owner yet
+               protected void check_wrong_document (DocumentType? doctype) {
+                       if (doctype != null && doctype.owner_document != null) {
+                               GXml.warning (DomException.WRONG_DOCUMENT, "The supplied doctype is already 
connected to an existing document.");
                        }
+
+               }
+
+               /**
+                * Creates a Document according to this { link GXml.Implementation}.
+                *
+                * Version: DOM Level 3 Core
+                * URL: [[http://www.w3.org/TR/DOM-Level-3-Core/core.html#Level-2-Core-DOM-createDocument]]
+
+                * @param namespace_uri URI for the namespace in which this Document belongs, or `null`.
+                * @param qualified_name A qualified name for the Document, or `null`.
+                * @param doctype The type of the document, or `null`.
+                *
+                * @return The new document.
+                */
+               public Document create_document (string? namespace_uri, string? qualified_name, DocumentType? 
doctype) {
+                       Document doc;
+
+                       check_namespace (namespace_uri, qualified_name);
+                       check_wrong_document (doctype);
                        // TODO: also want to report if the doctype was created by a different 
implementation; of which we have no way of determining right now
 
-                       Document doc = new Document.with_implementation (this, namespace_uri, qualified_name, 
doctype);
+                       doc = new Document.with_implementation (this, namespace_uri, qualified_name, doctype);
                        return doc;
                }
 


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]