UNPKG

renovate

Version:

Automated dependency updates. Flexible so you don't need to be.

121 lines (120 loc) 4.67 kB
import type { SemVer } from 'semver'; import type { RangeStrategy } from '../../types'; export interface NewValueConfig { currentValue: string; rangeStrategy: RangeStrategy; currentVersion?: string; newVersion: string; isReplacement?: boolean; } export interface VersioningApi { /** * Check whether the `input` is the valid version or range. * * For some managers, ranges are called "constraints","specifiers", "requirements", etc. * We stick to the term "range" for all of it. */ isValid(input: string): boolean; /** * Check whether the `input` is a valid version. * * There is no direct way to determine whether the `input` is the range, * but combination of `isVersion` and `isValid` can be used for that: * * `isValid(input) && !isVersion(input)` */ isVersion(input: string | undefined | null): boolean; /** * Check whether the `input` is the: * * 1. Version, or * 2. Range with the special syntax of matching exactly one version: * - `==1.2.3` or `===1.2.3` for Python, * - `=1.2.3` for NPM, * - `[1.2.3]` for Maven or NuGet. * * This is used to provide pinning functionality. */ isSingleVersion(input: string): boolean; /** * Check whether the `version` is considered to be "stable". */ isStable(version: string): boolean; /** * Determines whether the version is compatible with the current one, * in some manager-dependent way. * * For most managers, all valid versions are compatible between each other. * * However, for example, Docker versions `1.2.3` and `1.2.4-alpine` are not compatible, * i.e. `1.2.4-alpine` is not a valid upgrade for `1.2.3`. */ isCompatible(version: string, current?: string): boolean; isBreaking?(current: string, version: string): boolean; getMajor(version: string | SemVer): null | number; getMinor(version: string | SemVer): null | number; getPatch(version: string | SemVer): null | number; /** * Check whether `version` and `other` are logically equivalent, even if * they're not the exact same string. * * For example, with Semver the build metadata should be ignored when comparing. */ equals(version: string, other: string): boolean; /** * Check whether `version` is "greater" than the `other` version. */ isGreaterThan(version: string, other: string): boolean; /** * Check whether the `version` is "less" than all the versions possible in * the `range`. */ isLessThanRange?(version: string, range: string): boolean; /** * Select the highest version from `versions` that is within the given * `range` constraint, or return `null` if there is no matching version. */ getSatisfyingVersion(versions: string[], range: string): string | null; /** * Select the lowest version from `versions` that is within the given * `range` constraint, or return `null` if there is no matching version. */ minSatisfyingVersion(versions: string[], range: string): string | null; /** * Calculate a new version constraint based on the current constraint, the * `rangeStrategy` option, and the current and new version. */ getNewValue(newValueConfig: NewValueConfig): string | null; /** * Compare two versions. Return `0` if `v1 == v2`, or `1` if `v1` is * greater, or `-1` if `v2` is greater. */ sortVersions(version: string, other: string): number; /** * Check whether the `version` satisfies the `range` constraint. */ matches(version: string, range: string): boolean; valueToVersion?(version: string): string; /** * @returns true if subRange is entirely contained by superRange, false otherwise, * and undefined if it cannot determine it. * * @param subRange - the sub range * @param superRange - the dom range */ subset?(subRange: string, superRange: string): boolean | undefined; /** * Checks whether subRange intersects superRange. */ intersects?(subRange: string, superRange: string): boolean; /** * Return whether unstable-to-unstable upgrades within the same major version are allowed. */ allowUnstableMajorUpgrades?: boolean; /** * Check whether the `type` in the `a` and `b` version numbers match. * Both `a` and `b` must pass `isVersion`. */ isSame?(type: 'major' | 'minor' | 'patch', a: string, b: string): boolean; } export type VersioningApiConstructor = new (config?: string) => VersioningApi;