1. /*
  2. * The Apache Software License, Version 1.1
  3. *
  4. *
  5. * Copyright (c) 2003 The Apache Software Foundation. All rights
  6. * reserved.
  7. *
  8. * Redistribution and use in source and binary forms, with or without
  9. * modification, are permitted provided that the following conditions
  10. * are met:
  11. *
  12. * 1. Redistributions of source code must retain the above copyright
  13. * notice, this list of conditions and the following disclaimer.
  14. *
  15. * 2. Redistributions in binary form must reproduce the above copyright
  16. * notice, this list of conditions and the following disclaimer in
  17. * the documentation and/or other materials provided with the
  18. * distribution.
  19. *
  20. * 3. The end-user documentation included with the redistribution,
  21. * if any, must include the following acknowledgment:
  22. * "This product includes software developed by the
  23. * Apache Software Foundation (http://www.apache.org/)."
  24. * Alternately, this acknowledgment may appear in the software itself,
  25. * if and wherever such third-party acknowledgments normally appear.
  26. *
  27. * 4. The names "Xerces" and "Apache Software Foundation" must
  28. * not be used to endorse or promote products derived from this
  29. * software without prior written permission. For written
  30. * permission, please contact apache@apache.org.
  31. *
  32. * 5. Products derived from this software may not be called "Apache",
  33. * nor may "Apache" appear in their name, without prior written
  34. * permission of the Apache Software Foundation.
  35. *
  36. * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
  37. * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
  38. * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
  39. * DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
  40. * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  41. * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  42. * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
  43. * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
  44. * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
  45. * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
  46. * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  47. * SUCH DAMAGE.
  48. * ====================================================================
  49. *
  50. * This software consists of voluntary contributions made by many
  51. * individuals on behalf of the Apache Software Foundation and was
  52. * originally based on software copyright (c) 2003, International
  53. * Business Machines, Inc., http://www.apache.org. For more
  54. * information on the Apache Software Foundation, please see
  55. * <http://www.apache.org/>.
  56. */
  57. package com.sun.org.apache.xerces.internal.xs;
  58. import org.w3c.dom.DOMConfiguration;
  59. import org.w3c.dom.ls.LSInput;
  60. /**
  61. * An interface that provides a method to load XML Schema documents. This
  62. * interface uses the DOM Level 3 Core and Load and Save interfaces.
  63. */
  64. public interface XSLoader {
  65. /**
  66. * The configuration of a document. It maintains a table of recognized
  67. * parameters. Using the configuration, it is possible to change the
  68. * behavior of the load methods. The configuration may support the
  69. * setting of and the retrieval of the following non-boolean parameters
  70. * defined on the <code>DOMConfiguration</code> interface:
  71. * <code>error-handler</code> (<code>DOMErrorHandler</code>) and
  72. * <code>resource-resolver</code> (<code>LSResourceResolver</code>).
  73. * <br> The following list of boolean parameters is defined:
  74. * <dl>
  75. * <dt>
  76. * <code>"validate"</code></dt>
  77. * <dd>
  78. * <dl>
  79. * <dt><code>true</code></dt>
  80. * <dd>[required] (default) Validate an XML
  81. * Schema during loading. If validation errors are found, the error
  82. * handler is notified. </dd>
  83. * <dt><code>false</code></dt>
  84. * <dd>[optional] Do not
  85. * report errors during the loading of an XML Schema document. </dd>
  86. * </dl></dd>
  87. * </dl>
  88. */
  89. public DOMConfiguration getConfig();
  90. /**
  91. * Parses the content of XML Schema documents specified as the list of URI
  92. * references. If the URI contains a fragment identifier, the behavior
  93. * is not defined by this specification.
  94. * @param uri The list of URI locations.
  95. * @return An XSModel representing the schema documents.
  96. */
  97. public XSModel loadURIList(StringList uriList);
  98. /**
  99. * Parses the content of XML Schema documents specified as a list of
  100. * <code>LSInput</code>s.
  101. * @param is The list of <code>LSInput</code>s from which the XML
  102. * Schema documents are to be read.
  103. * @return An XSModel representing schema documents.
  104. */
  105. public XSModel loadInputList(LSInputList is);
  106. /**
  107. * Parse an XML Schema document from a location identified by a URI
  108. * reference. If the URI contains a fragment identifier, the behavior is
  109. * not defined by this specification.
  110. * @param uri The location of the XML Schema document to be read.
  111. * @return An XSModel representing this schema.
  112. */
  113. public XSModel loadURI(String uri);
  114. /**
  115. * Parse an XML Schema document from a resource identified by a
  116. * <code>LSInput</code> .
  117. * @param is The <code>DOMInputSource</code> from which the source
  118. * document is to be read.
  119. * @return An XSModel representing this schema.
  120. */
  121. public XSModel load(LSInput is);
  122. }