com.helger.xml.serialize.write.EXMLSerializeIndent Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of ph-xml Show documentation
Show all versions of ph-xml Show documentation
Java 1.8+ Library with XML handling routines
/*
* 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.xml.serialize.write;
import javax.annotation.Nonnull;
import javax.annotation.Nullable;
import com.helger.commons.annotation.Nonempty;
import com.helger.commons.id.IHasID;
import com.helger.commons.lang.EnumHelper;
/**
* Determines the indentation and alignment mode of XML serialization. Alignment
* means: newlines after certain elements. Indent means: adding blanks at the
* beginning of the line to reflect the tree structure of an XML document more
* visibly.
*
* @author Philip Helger
*/
public enum EXMLSerializeIndent implements IHasID
{
/** Neither indent nor align */
NONE ("none", false, false),
/** No indent but align */
ALIGN_ONLY ("align", false, true),
/** Indent but no align. */
INDENT_ONLY ("indent", true, false),
/** Both indent and align. */
INDENT_AND_ALIGN ("indentalign", true, true);
private final String m_sID;
private final boolean m_bIndent;
private final boolean m_bAlign;
EXMLSerializeIndent (@Nonnull @Nonempty final String sID, final boolean bIndent, final boolean bAlign)
{
m_sID = sID;
m_bAlign = bAlign;
m_bIndent = bIndent;
}
@Nonnull
@Nonempty
public String getID ()
{
return m_sID;
}
/**
* @return true
if the XML output should be formatted nicely
*/
public boolean isIndent ()
{
return m_bIndent;
}
/**
* @return true
if newlines should be emitted
*/
public boolean isAlign ()
{
return m_bAlign;
}
@Nonnull
public EXMLSerializeIndent getWithoutIndent ()
{
return m_bAlign ? ALIGN_ONLY : NONE;
}
@Nonnull
public EXMLSerializeIndent getWithIndent ()
{
return m_bAlign ? INDENT_AND_ALIGN : INDENT_ONLY;
}
@Nonnull
public EXMLSerializeIndent getWithoutAlign ()
{
return m_bIndent ? INDENT_ONLY : NONE;
}
@Nonnull
public EXMLSerializeIndent getWithAlign ()
{
return m_bIndent ? INDENT_AND_ALIGN : ALIGN_ONLY;
}
@Nullable
public static EXMLSerializeIndent getFromIDOrNull (@Nullable final String sID)
{
return EnumHelper.getFromIDOrNull (EXMLSerializeIndent.class, sID);
}
}