Skip to content

Latest commit

 

History

History
66 lines (51 loc) · 4.02 KB

README.md

File metadata and controls

66 lines (51 loc) · 4.02 KB

EmVer

This module was designed to address the problem of releasing updates to StartOS Packages where the upstream project was either unaware of or apathetic towards supporting their application on the StartOS platform. In most cases, the original package will support semver2. This leaves us with the problem where we would like to preserve the original package's version, since one of the goals of the StartOS platform is transparency. However, on occasion, a package's metadata or maintainer scripts may need to be updated without a corresponding update of the upstream service, so, a 4th digit has been added to indicate the package REVISION number.

Additionally, we have decided to add a FLAVOR prefix to the version, indicating a version of a package that can be updated to, but may not have an ordinal relationship with other packages of a different FLAVOR.

Usage

Add this to your Cargo.toml

[dependencies]
emver = "0.2.0"

Operations

A Version contains 4-6 components: flavor (optional), major, minor, patch, revision, and prerelease (optional). The meaning of major, minor, and patch can be found in the Semver2 specification. The fourth is also given patch semantics but is intended to be incremented by package distributors when they are not themselves authors.

A Version can also be parsed from a dot separated string like flavor-0.1.2.3. They can also be serialized to strings, but in cases where the last digit is zero, the last dot and the zero are omitted. Parsing will still work over a triple. The relevant parse function for Version is Version::from_str. It can be applied to a &str and will produce a Result<Version, ParseError>.

The other half of this library deals with the type VersionRange. A VersionRange is a set that is either anchored at a particular Version with some sort of comparison operator: = >= <= > < or it is described as a conjunction, disjunction, or inversion of other VersionRanges. For convenience we also provide two constructors (Any, None) to serve as identity elements on the And and Or constructors respectively. As a result, to gain maximum performance, you should use the and and or smart constructors as opposed to their dumb counterparts And and Or. This will immediately evaluate the identities and annihilators as opposed to building up the AST further, saving peak memory.

For convenience, there are two Monoid wrappers exposed: (AnyRange, AllRange). This allows you to fold an Iterable with the combine operation seeded with the empty value. The semantic differences are whether or not combine uses and or or respectively.

Most of the time you will want to parse these values from strings, but the internals are exposed for the rarer cases. Some of the grammar from semver is supported (^1.2.3, ~2.3.4, 1.*) as well.

Finally, the most useful operation in this package is the satisfies operation on Version with the argument of a VersionRange. This is simply a predicate that tells you whether the Version falls inside the VersionRange.

Laws

All laws listed below are equality of observation, not a literal Eq instance giving representational Equality. The only observer that this library has is the satisfies operation. When you read "a === b", you should interpret that as obs.satisfies(a) === obs.satisfies(b). These laws simply mean that it is always safe to do a substitution of a term on the LHS for a term on the RHS without changing the meaning of your program.

  • And is commutative: and(a,b) === and(b,a)
  • Or is commutative: and(a,b) === or(b,a)
  • And is associative: and(and(a,b),c) === and(a,and(b,c))
  • Or is associative: or(or(a,b),c) === or(a,or(b,c))
  • Any is identity of And: and(a, Any) === a
  • None is identity of Or: or(a, None) === a
  • Any annihilates Or: or(a, Any) === Any
  • None annihilates And: and(a, None) === None
  • And distributes over Or: and(a,or(b,c)) === or(and(a,b),and(a,c))
  • Or distributes over And: or(a,and(b,c)) === and(or(a,b),or(a,c))