com.mooltiverse.oss.nyx.version.CoreIdentifiers Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of java Show documentation
Show all versions of java Show documentation
com.mooltiverse.oss.nyx:java:3.0.6 All the Nyx Java artifacts
The newest version!
/*
* Copyright 2020 Mooltiverse
*
* 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.mooltiverse.oss.nyx.version;
/**
* The identifiers used for core version numbers.
*/
public enum CoreIdentifiers {
/**
* The major number.
*/
MAJOR("major", 0),
/**
* The minor number.
*/
MINOR("minor", 1),
/**
* The patch number.
*/
PATCH("patch", 2);
/**
* The name of the identifier.
*/
private final String name;
/**
* The relative position of this identifier (starting from {@code 0}).
*/
private final int position;
/**
* Constructor.
*
* @param name the identifier name.
* @param position the relative position of this identifier (starting from {@code 0}).
*/
private CoreIdentifiers(String name, int position) {
this.name = name;
this.position = position;
}
/**
* Returns the name of the identifier.
*
* @return the name of the identifier.
*/
public String getName() {
return name;
}
/**
* Returns the relative position of this identifier (starting from {@code 0}).
*
* @return the relative position of this identifier.
*/
int getPosition() {
return position;
}
/**
* Returns the value with the given name. This method differs from {@link #valueOf(String)} as it also takes into
* account the internal names returned by {@link #getName()}, not just the enum value.
*
* @param name the name of the identifier to search
*
* @return the value with the given name.
*
* @throws NullPointerException if {@code null} is passed
* @throws IllegalArgumentException if there is no identifier with the given name
*
* @see #getName()
* @see #hasName(String)
*/
static CoreIdentifiers byName(String name) {
for (CoreIdentifiers ci: CoreIdentifiers.values())
if (ci.getName().equals(name))
return ci;
// if none is found fall back to valueOf()
return CoreIdentifiers.valueOf(name);
}
/**
* Returns {@code true} if there is a value with the given name. This method can be used to invoke
* {@link #byName(String)} or {@link #valueOf(String)} safely.
*
* @param name the name of the identifier to search
*
* @return {@code true} if there is a value with the given name.
*
* @throws NullPointerException if {@code null} is passed
*
* @see #getName()
* @see #hasName(String)
* @see #valueOf(String)
*/
static boolean hasName(String name) {
for (CoreIdentifiers ci: CoreIdentifiers.values())
if (ci.getName().equals(name) || ci.toString().equals(name))
return true;
return false;
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy