com.phloc.css.decl.CSSNamespaceRule Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of phloc-css-jdk5 Show documentation
Show all versions of phloc-css-jdk5 Show documentation
phloc CSS parser an other components
/**
* Copyright (C) 2006-2014 phloc systems
* http://www.phloc.com
* office[at]phloc[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.phloc.css.decl;
import javax.annotation.Nonnegative;
import javax.annotation.Nonnull;
import javax.annotation.Nullable;
import javax.annotation.concurrent.NotThreadSafe;
import com.phloc.commons.annotations.Nonempty;
import com.phloc.commons.equals.EqualsUtils;
import com.phloc.commons.hash.HashCodeGenerator;
import com.phloc.commons.string.StringHelper;
import com.phloc.commons.string.ToStringGenerator;
import com.phloc.css.CSSSourceLocation;
import com.phloc.css.ICSSSourceLocationAware;
import com.phloc.css.ICSSWriteable;
import com.phloc.css.ICSSWriterSettings;
import com.phloc.css.utils.CSSURLHelper;
/**
* Represents a single namespace rule on top level.
* Example:
* @namespace Q "http://example.com/q-markup";
*
* @author Philip Helger
*/
@NotThreadSafe
public class CSSNamespaceRule implements ICSSWriteable, ICSSSourceLocationAware
{
private String m_sPrefix;
private String m_sURL;
private CSSSourceLocation m_aSourceLocation;
/**
* Constructor for the default namespace
*
* @param sURL
* The namespace URL to use. May not be null
.
*/
public CSSNamespaceRule (@Nonnull final String sURL)
{
this (null, sURL);
}
/**
* Constructor
*
* @param sNamespacePrefix
* The namespace prefix to use. May be null
or empty for
* the default namespace.
* @param sURL
* The namespace URL to use. May not be null
.
*/
public CSSNamespaceRule (@Nullable final String sNamespacePrefix, @Nonnull final String sURL)
{
setNamespacePrefix (sNamespacePrefix);
setNamespaceURL (sURL);
}
@Nullable
public String getNamespacePrefix ()
{
return m_sPrefix;
}
@Nonnull
public CSSNamespaceRule setNamespacePrefix (@Nullable final String sNamespacePrefix)
{
m_sPrefix = sNamespacePrefix;
return this;
}
/**
* @return The namespace URL. May not be null
but maybe empty!
*/
@Nonnull
public String getNamespaceURL ()
{
return m_sURL;
}
@Nonnull
public CSSNamespaceRule setNamespaceURL (@Nonnull final String sURL)
{
if (sURL == null)
throw new NullPointerException ("URL");
m_sURL = sURL;
return this;
}
@Nonnull
@Nonempty
public String getAsCSSString (@Nonnull final ICSSWriterSettings aSettings, @Nonnegative final int nIndentLevel)
{
// Always ignore namespace rules?
if (!aSettings.isWriteNamespaceRules ())
return "";
final StringBuilder aSB = new StringBuilder ();
aSB.append ("@namespace ");
if (StringHelper.hasText (m_sPrefix))
aSB.append (m_sPrefix).append (' ');
if (StringHelper.hasText (m_sURL))
aSB.append (CSSURLHelper.getAsCSSURL (m_sURL, false));
else
aSB.append ("\"\"");
return aSB.append (";\n").toString ();
}
/**
* Set the source location of the object, determined while parsing.
*
* @param aSourceLocation
* The source location to use. May be null
.
*/
public void setSourceLocation (@Nullable final CSSSourceLocation aSourceLocation)
{
m_aSourceLocation = aSourceLocation;
}
@Nullable
public CSSSourceLocation getSourceLocation ()
{
return m_aSourceLocation;
}
@Override
public boolean equals (final Object o)
{
if (o == this)
return true;
if (o == null || !getClass ().equals (o.getClass ()))
return false;
final CSSNamespaceRule rhs = (CSSNamespaceRule) o;
return EqualsUtils.equals (m_sPrefix, rhs.m_sPrefix) && m_sURL.equals (rhs.m_sURL);
}
@Override
public int hashCode ()
{
return new HashCodeGenerator (this).append (m_sPrefix).append (m_sURL).getHashCode ();
}
@Override
public String toString ()
{
return new ToStringGenerator (this).appendIfNotNull ("prefix", m_sPrefix)
.append ("URL", m_sURL)
.appendIfNotNull ("sourceLocation", m_aSourceLocation)
.toString ();
}
}