2 * Copyright (c) 2013 Cisco Systems, Inc. and others. All rights reserved.
4 * This program and the accompanying materials are made available under the
5 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6 * and is available at http://www.eclipse.org/legal/epl-v10.html
8 package org.opendaylight.yangtools.yang.common;
10 import java.io.Serializable;
12 import java.net.URISyntaxException;
13 import java.util.Date;
15 import org.opendaylight.yangtools.concepts.Immutable;
16 import org.slf4j.Logger;
17 import org.slf4j.LoggerFactory;
19 public final class QNameModule implements Immutable, Serializable {
20 private static final Logger LOG = LoggerFactory.getLogger(QNameModule.class);
21 private static final QNameModule NULL_INSTANCE = new QNameModule(null, null);
22 private static final long serialVersionUID = 1L;
25 private final URI namespace;
28 private final Date revision;
31 private String formattedRevision;
33 private QNameModule(final URI namespace, final Date revision) {
34 this.namespace = namespace;
35 this.revision = revision;
38 public static QNameModule create(final URI namespace, final Date revision) {
39 if (namespace == null && revision == null) {
43 return new QNameModule(namespace, revision);
46 public String getFormattedRevision() {
47 if (revision == null) {
51 if (formattedRevision == null) {
53 if (formattedRevision == null) {
54 formattedRevision = SimpleDateFormatUtil.getRevisionFormat().format(revision);
59 return formattedRevision;
63 * Returns the namespace of the module which is specified as argument of
64 * YANG {@link Module <b><font color="#00FF00">namespace</font></b>}
67 * @return URI format of the namespace of the module
69 public URI getNamespace() {
74 * Returns the revision date for the module.
76 * @return date of the module revision which is specified as argument of
77 * YANG {@link Module <b><font color="#339900">revison</font></b>}
80 public Date getRevision() {
85 public int hashCode() {
87 int result = (namespace == null) ? 0 : namespace.hashCode();
88 result = prime * result + ((revision == null) ? 0 : revision.hashCode());
93 public boolean equals(final Object obj) {
97 if (!(obj instanceof QNameModule)) {
100 final QNameModule other = (QNameModule) obj;
101 if (namespace == null) {
102 if (other.namespace != null) {
105 } else if (!namespace.equals(other.namespace)) {
108 if (revision == null) {
109 if (other.revision != null) {
112 } else if (!revision.equals(other.revision)) {
119 * Returns a namespace in form defined by section 5.6.4. of {@link https
120 * ://tools.ietf.org/html/rfc6020}, if namespace is not correctly defined,
121 * the method will return <code>null</code> <br>
122 * example "http://example.acme.com/system?revision=2008-04-01"
124 * @return namespace in form defined by section 5.6.4. of {@link https
125 * ://tools.ietf.org/html/rfc6020}, if namespace is not correctly
126 * defined, the method will return <code>null</code>
129 URI getRevisionNamespace() {
131 if (namespace == null) {
136 if (revision != null) {
137 query = "revision=" + getFormattedRevision();
140 URI compositeURI = null;
142 compositeURI = new URI(namespace.getScheme(), namespace.getUserInfo(), namespace.getHost(),
143 namespace.getPort(), namespace.getPath(), query, namespace.getFragment());
144 } catch (URISyntaxException e) {