com.helger.ubl21.UBL21WriterBuilder Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of ph-ubl21 Show documentation
Show all versions of ph-ubl21 Show documentation
Library for reading and writing UBL 2.1 documents
/*
* Copyright (C) 2014-2023 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.ubl21;
import javax.annotation.Nonnull;
import javax.annotation.concurrent.NotThreadSafe;
import com.helger.jaxb.builder.JAXBWriterBuilder;
import com.helger.xml.namespace.MapBasedNamespaceContext;
/**
* A writer builder for UBL 2.1 documents.
*
* @author Philip Helger
* @param
* The UBL 2.1 implementation class to be read
* @deprecated Use {@link UBL21Marshaller} instead
*/
@NotThreadSafe
@Deprecated (forRemoval = true, since = "8.0.0")
public class UBL21WriterBuilder extends JAXBWriterBuilder >
{
public UBL21WriterBuilder (@Nonnull final EUBL21DocumentType eDocType)
{
super (eDocType);
// Create a special namespace context for the passed document type
final MapBasedNamespaceContext aNSContext = UBL21NamespaceContext.getInstance ().getClone ();
// Avoid overwriting an already mapped context
if (!aNSContext.isNamespaceURIMapped (m_aDocType.getNamespaceURI ()))
aNSContext.addDefaultNamespaceURI (m_aDocType.getNamespaceURI ());
setNamespaceContext (aNSContext);
}
public UBL21WriterBuilder (@Nonnull final Class aClass)
{
this (UBL21DocumentTypes.getDocumentTypeOfImplementationClass (aClass));
}
/**
* Create a new writer builder.
*
* @param aClass
* The UBL class to be written. May not be null
.
* @return The new writer builder. Never null
.
* @param
* The UBL 2.1 document implementation type
*/
@Nonnull
public static UBL21WriterBuilder create (@Nonnull final Class aClass)
{
return new UBL21WriterBuilder <> (aClass);
}
}