forked from omichelsen/compare-versions
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.d.ts
59 lines (55 loc) · 2.18 KB
/
index.d.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
declare namespace compareVersions {
/**
* Allowed arithmetic operators
*/
type CompareOperator = '>' | '>=' | '=' | '<' | '<=';
}
declare const compareVersions: {
/**
* Compare [semver](https://semver.org/) version strings to find greater, equal or lesser.
* This library supports the full semver specification, including comparing versions with different number of digits like `1.0.0`, `1.0`, `1`, and pre-release versions like `1.0.0-alpha`.
* @param firstVersion - First version to compare
* @param secondVersion - Second version to compare
* @returns Numeric value compatible with the [Array.sort(fn) interface](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/sort#Parameters).
*/
(firstVersion: string, secondVersion: string): 1 | 0 | -1;
/**
* Compare [semver](https://semver.org/) version strings using the specified operator.
*
* @param firstVersion First version to compare
* @param secondVersion Second version to compare
* @param operator Allowed arithmetic operator to use
* @returns `true` if the comparison between the firstVersion and the secondVersion satisfies the operator, `false` otherwise.
*
* @example
* ```
* compareVersions.compare('10.1.8', '10.0.4', '>'); // return true
* compareVersions.compare('10.0.1', '10.0.1', '='); // return true
* compareVersions.compare('10.1.1', '10.2.2', '<'); // return true
* compareVersions.compare('10.1.1', '10.2.2', '<='); // return true
* compareVersions.compare('10.1.1', '10.2.2', '>='); // return false
* ```
*/
compare(
firstVersion: string,
secondVersion: string,
operator: compareVersions.CompareOperator
): boolean;
/**
* Validate [semver](https://semver.org/) version strings.
*
* @param version Version number to validate
* @returns `true` if the version number is a valid semver version number, `false` otherwise.
*
* @example
* ```
* compareVersions.validate('1.0.0-rc.1'); // return true
* compareVersions.validate('1.0-rc.1'); // return false
* compareVersions.validate('foo'); // return false
* ```
*/
validate(
version: string
): boolean;
};
export = compareVersions;