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

org.eclipse.aether.util.version.package-info Maven / Gradle / Ivy

// CHECKSTYLE_OFF: RegexpHeader
/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you 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.
 */
/**
 * Ready-to-use version scheme for parsing/comparing versions and utility classes.
 * 

* Contains the "generic" scheme {@link org.eclipse.aether.util.version.GenericVersionScheme} * that serves the purpose of "factory" (and/or parser) for all corresponding elements (all those are package private). *

* On the other hand, the {@link org.eclipse.aether.util.version.UnionVersionRange} is universal implementation of * "unions" of various {@link org.eclipse.aether.version.VersionRange} instances. *

* Below is the Generic Version Spec described: *

* Version string is parsed into version according to these rules below: *

    *
  • The version string is parsed into segments, from left to right.
  • *
  • Segments are explicitly delimited by single {@code "." (dot)}, {@code "-" (hyphen)} or {@code "_" (underscore)} character.
  • *
  • Segments are implicitly delimited by transition between digits and non-digits.
  • *
  • Segments are classified as numeric, string, qualifiers (special case of string) and min/max.
  • *
  • Numeric segments are sorted numerically, ascending.
  • *
  • Non-numeric segments may be qualifiers (predefined) or strings (non-empty letter sequence). All of them are interpreted as being case-insensitive in terms of the ROOT locale.
  • *
  • Qualifier segments (strings listed below) and their sort order (ascending) are: *
      *
    • "alpha" (== "a" when immediately followed by number)
    • *
    • "beta" (== "b" when immediately followed by number)
    • *
    • "milestone" (== "m" when immediately followed by number)
    • *
    • "rc" == "cr" (use of "cr" is discouraged)
    • *
    • "snapshot"
    • *
    • "ga" == "final" == "release"
    • *
    • "sp"
    • *
    *
  • *
  • String segments are sorted lexicographically and case-insensitively per ROOT locale, ascending.
  • *
  • There are two special segments, {@code "min"} and {@code "max"}, they represent absolute minimum and absolute maximum in comparisons. They can be used only as trailing segment.
  • *
  • As last step, trailing "zero segments" are trimmed. Similarly, "zero segments" positioned before numeric and non-numeric transitions (either explicitly or implicitly delimited) are trimmed.
  • *
  • When trimming, "zero segments" are qualifiers {@code "ga"}, {@code "final"}, {@code "release"} only if being last (right-most) segment, empty string and "0" always.
  • *
  • In comparison of same kind segments, the given type of segment determines comparison rules.
  • *
  • In comparison of different kind of segments, following applies: {@code max > numeric > string > qualifier > min}.
  • *
  • Any version can be considered to have an infinite number of invisible trailing "zero segments", for the purposes of comparison (in other words, "1" == "1.0.0.0.0.0.0.0.0....")
  • *
  • It is common that a version identifier starts with numeric segment (consider this "best practice").
  • *
*

* Note: this version spec does not document (nor cover) many corner cases, that we believe are "atypical" or not * used commonly. None of these are enforced, but in future implementations they probably will be. Some known examples are: *

    *
  • Using "min" or "max" special segments as non-trailing segment. This yields in "undefined" behaviour and should be avoided.
  • *
  • Having non-number as first segment of version. Versions are expected (but not enforced) to start with numbers.
  • *
* */ package org.eclipse.aether.util.version;




© 2015 - 2025 Weber Informatics LLC | Privacy Policy