All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.helger.bdve.source.IValidationSource Maven / Gradle / Ivy

There is a newer version: 5.2.11
Show newest version
/**
 * Copyright (C) 2014-2018 Philip Helger (www.helger.com)
 * philip[at]helger[dot]com
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *         http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package com.helger.bdve.source;

import java.io.Serializable;

import javax.annotation.Nonnull;
import javax.annotation.Nullable;
import javax.xml.transform.Source;

import org.w3c.dom.Node;

import com.helger.xml.XMLHelper;
import com.helger.xml.transform.TransformSourceFactory;

/**
 * Abstract validation source.
 *
 * @author Philip Helger
 */
public interface IValidationSource extends Serializable
{
  /**
   * @return The system ID (e.g. filename) of the source to be validated. May be
   *         null.
   */
  @Nullable
  String getSystemID ();

  /**
   * @return The source node to be validated. May be null.
   */
  @Nullable
  Node getNode ();

  /**
   * @return true if this source is partial and false
   *         if the whole Document should be used.
   */
  boolean isPartialSource ();

  /**
   * @return This validation source as a `javax.xml.transform.Source`. Never
   *         null.
   * @throws IllegalStateException
   *         If no transform source object can be created.
   */
  @Nonnull
  default Source getAsTransformSource ()
  {
    Source ret = null;
    final Node aNode = getNode ();
    if (aNode != null)
    {
      if (isPartialSource ())
        ret = TransformSourceFactory.create (aNode);
      else
      {
        // Always use the Document node! Otherwise this may lead to weird XSLT
        // errors
        ret = TransformSourceFactory.create (XMLHelper.getOwnerDocument (aNode));
      }
    }
    if (ret == null)
      throw new IllegalStateException ("No valid input object is present!");

    ret.setSystemId (getSystemID ());
    return ret;
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy