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

org.opencastproject.mediapackage.EName Maven / Gradle / Ivy

/*
 * Licensed to The Apereo Foundation under one or more contributor license
 * agreements. See the NOTICE file distributed with this work for additional
 * information regarding copyright ownership.
 *
 *
 * The Apereo Foundation licenses this file to you under the Educational
 * Community 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://opensource.org/licenses/ecl2.txt
 *
 * 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 org.opencastproject.mediapackage;

import static java.lang.String.format;
import static org.opencastproject.util.EqualsUtil.eq;
import static org.opencastproject.util.EqualsUtil.hash;

import org.opencastproject.util.RequireUtil;

import org.apache.commons.lang3.StringUtils;

import java.io.Serializable;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

import javax.xml.XMLConstants;

/**
 * An XML Expanded Name, cf. W3C definition.
 * 

* Expanded names in XML consists of a namespace name (URI) and a local part. In opposite to Qualified Names, * cf. W3C definition - which are made from an optional * prefix and the local part - expanded names are not subject to namespace interpretation. *

* Please see http://www.w3.org/TR/xml-names/ for a complete definition * and reference. */ public final class EName implements Serializable, Comparable { private static final long serialVersionUID = -5494762745288614634L; private final String namespaceURI; private final String localName; /** * A pattern to parse strings as ENames. A String representing an EName may start with a Namespace among curly braces * ("{" and "}") and then it must contain a local name *without* any curly braces. */ private static final Pattern pattern = Pattern.compile("^(?:\\{(?[^{}\\s]*)\\})?(?[^{}\\s]+)$"); /** * Create a new expanded name. * * @param namespaceURI * the name of the namespace this EName belongs to. If set to {@link javax.xml.XMLConstants#NULL_NS_URI}, * this name does not belong to any namespace. Use this option with care. * @param localName * the local part of the name. Must not be empty. */ public EName(String namespaceURI, String localName) { RequireUtil.notNull(namespaceURI, "namespaceURI"); RequireUtil.notEmpty(localName, "localName"); this.namespaceURI = namespaceURI; this.localName = localName; } public static EName mk(String namespaceURI, String localName) { return new EName(namespaceURI, localName); } /** * Create a new expanded name which does not belong to a namespace. The namespace name is set to * {@link javax.xml.XMLConstants#NULL_NS_URI}. */ public static EName mk(String localName) { return new EName(XMLConstants.NULL_NS_URI, localName); } /** * Return the namespace name. Usually the name will be a URI. * * @return the namespace name or {@link javax.xml.XMLConstants#NULL_NS_URI} if the name does not belong to a namespace */ public String getNamespaceURI() { return namespaceURI; } /** Return the local part of the name. */ public String getLocalName() { return localName; } /** * Check, if this name belongs to a namespace, i.e. its namespace URI is not * {@link javax.xml.XMLConstants#NULL_NS_URI}. */ public boolean hasNamespace() { return !XMLConstants.NULL_NS_URI.equals(namespaceURI); } @Override public int hashCode() { return hash(namespaceURI, localName); } @Override public boolean equals(Object that) { return (this == that) || (that instanceof EName && eqFields((EName) that)); } private boolean eqFields(EName that) { return eq(localName, that.localName) && eq(namespaceURI, that.namespaceURI); } /** Return a W3C compliant string representation {namespaceURI}localname. */ @Override public String toString() { return format("{%s}%s", namespaceURI, localName); } @Override public int compareTo(EName o) { final int r = getNamespaceURI().compareTo(o.getNamespaceURI()); if (r == 0) { return getLocalName().compareTo(o.getLocalName()); } else { return r; } } /** * Parse a W3C compliant string representation {namespaceURI}localname. * * A String representing an EName may start with a namespace among curly braces ("{" and "}") and then it must contain * a local name *without* any blank characters or curly braces. * * This is a superset of the character restrictions defined by the XML standard, where neither namespaces nor local * names may contain curly braces or spaces. * * Examples: * *

    *
  • {http://my-namespace}mylocalname *
  • {}localname-with-explicit-empty-namespace *
  • localname-without-namespace *
* * Incorrect examples: * *
    *
  • {namespace-only} *
  • contains{curly}braces *
* * @param strEName * A {@link java.lang.String} representing an {@code EName} * @param defaultNameSpace * A NameSpace to apply if the provided {@code String} does not have any. Please note that a explicit empty * NameSpace **is** a NameSpace. If this argument is blank or {@code null}, it has no effect. */ public static EName fromString(String strEName, String defaultNameSpace) throws IllegalArgumentException { if (strEName == null) { throw new IllegalArgumentException("Cannot parse 'null' as EName"); } Matcher m = pattern.matcher(strEName); if (m.matches()) { if (StringUtils.isNotBlank(defaultNameSpace) && m.group("namespace") == null) return new EName(defaultNameSpace, m.group("localname")); else return new EName(StringUtils.trimToEmpty(m.group("namespace")), m.group("localname")); } throw new IllegalArgumentException(format("Cannot parse '%s' as EName", strEName)); } /** * Parse a W3C compliant string representation {namespaceURI}localname. * * A String representing an EName may start with a namespace among curly braces ("{" and "}") and then it must contain * a local name *without* any curly braces. * * This is a superset of the character restrictions defined by the XML standard, where neither namespaces nor local * names may contain curly braces. * * Examples: * *
    *
  • {http://my-namespace}mylocalname *
  • localname-without-namespace *
* * Incorrect examples: * *
    *
  • {namespace-only} *
  • contains{curly}braces *
* * @param strEName * A {@link java.lang.String} representing an {@code EName} * */ public static EName fromString(String strEName) throws IllegalArgumentException { return EName.fromString(strEName, null); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy