View Javadoc
1   /**
2    * Copyright (C) 2014-2015 Philip Helger (www.helger.com)
3    * philip[at]helger[dot]com
4    *
5    * Licensed under the Apache License, Version 2.0 (the "License");
6    * you may not use this file except in compliance with the License.
7    * You may obtain a copy of the License at
8    *
9    *         http://www.apache.org/licenses/LICENSE-2.0
10   *
11   * Unless required by applicable law or agreed to in writing, software
12   * distributed under the License is distributed on an "AS IS" BASIS,
13   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14   * See the License for the specific language governing permissions and
15   * limitations under the License.
16   */
17  package com.helger.schematron.svrl;
18  
19  import javax.annotation.Nonnull;
20  import javax.annotation.Nullable;
21  import javax.annotation.concurrent.Immutable;
22  import javax.xml.transform.Result;
23  
24  import org.oclc.purl.dsdl.svrl.SchematronOutputType;
25  import org.w3c.dom.Document;
26  
27  import com.helger.commons.annotation.PresentForCodeCoverage;
28  import com.helger.commons.state.ESuccess;
29  
30  /**
31   * This is the XML writer for Schematron SVRL documents. It reads
32   * {@link SchematronOutputType} elements and converts them to W3C nodes. The
33   * writing itself is done with JAXB.
34   *
35   * @author Philip Helger
36   */
37  @Immutable
38  public final class SVRLWriter
39  {
40    @PresentForCodeCoverage
41    private static final SVRLWriter s_aInstance = new SVRLWriter ();
42  
43    private SVRLWriter ()
44    {}
45  
46    /**
47     * Convert the passed schematron output element into an W3C Document node.
48     *
49     * @param aSchematronOutput
50     *        The schematron output to be converted. May not be <code>null</code>.
51     * @param aResult
52     *        The result object to write to.
53     * @return {@link ESuccess}
54     */
55    @Nonnull
56    public static ESuccess writeSVRL (@Nonnull final SchematronOutputType aSchematronOutput, @Nonnull final Result aResult)
57    {
58      return new SVRLMarshaller ().write (aSchematronOutput, aResult);
59    }
60  
61    /**
62     * Convert the passed schematron output element into an W3C Document node.
63     *
64     * @param aSchematronOutput
65     *        The schematron output to be converted. May not be <code>null</code>.
66     * @return <code>null</code> if conversion failed.
67     */
68    @Nullable
69    public static Document createXML (@Nonnull final SchematronOutputType aSchematronOutput)
70    {
71      return new SVRLMarshaller ().write (aSchematronOutput);
72    }
73  
74    /**
75     * Utility method to directly convert the passed SVRL domain object to an XML
76     * string.
77     *
78     * @param aSchematronOutput
79     *        The SVRL domain object to be converted. May not be null.
80     * @return <code>null</code> if the passed domain object could not be
81     *         converted because of validation errors.
82     */
83    @Nullable
84    public static String createXMLString (@Nonnull final SchematronOutputType aSchematronOutput)
85    {
86      return new SVRLMarshaller ().getAsXMLString (aSchematronOutput);
87    }
88  }