mirror of
https://github.com/denoland/std.git
synced 2024-11-22 04:59:05 +00:00
3a446538b1
* fix(semver): throw on invalid input in `parseRange()` * fix * fix * fix
46 lines
1.4 KiB
TypeScript
46 lines
1.4 KiB
TypeScript
// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
|
|
// This module is browser compatible.
|
|
import type { Comparator, Range } from "./types.ts";
|
|
import { OPERATORS } from "./_constants.ts";
|
|
import { ALL } from "./_constants.ts";
|
|
import { isSemVer } from "./is_semver.ts";
|
|
|
|
function isComparator(value: unknown): value is Comparator {
|
|
if (
|
|
value === null || value === undefined || Array.isArray(value) ||
|
|
typeof value !== "object"
|
|
) return false;
|
|
if (value === ALL) return true;
|
|
const { operator } = value as Comparator;
|
|
return (
|
|
(operator === undefined ||
|
|
OPERATORS.includes(operator)) &&
|
|
isSemVer(value)
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Does a deep check on the object to determine if its a valid range.
|
|
*
|
|
* Objects with extra fields are still considered valid if they have at
|
|
* least the correct fields.
|
|
*
|
|
* Adds a type assertion if true.
|
|
*
|
|
* @example Usage
|
|
* ```ts
|
|
* import { isRange } from "@std/semver/is-range";
|
|
* import { assert } from "@std/assert";
|
|
*
|
|
* const range = [[{ major: 1, minor: 2, patch: 3 }]];
|
|
* assert(isRange(range));
|
|
* assert(!isRange({}));
|
|
* ```
|
|
* @param value The value to check if its a valid Range
|
|
* @returns True if its a valid Range otherwise false.
|
|
*/
|
|
export function isRange(value: unknown): value is Range {
|
|
return Array.isArray(value) &&
|
|
value.every((r) => Array.isArray(r) && r.every((c) => isComparator(c)));
|
|
}
|