mirror of
https://github.com/denoland/deno.git
synced 2025-01-22 06:09:25 -05:00
refactor(std): add std/_util/os.ts module (#8370)
This commit adds "std/_util/os.ts" module which contains common os detection logic and is browser compatible. Co-authored-by: Nayeem Rahman <nayeemrmn99@gmail.com>
This commit is contained in:
parent
d5661f677e
commit
a59f5eadd8
10 changed files with 27 additions and 28 deletions
18
std/_util/os.ts
Normal file
18
std/_util/os.ts
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
// Copyright 2018-2020 the Deno authors. All rights reserved. MIT license.
|
||||||
|
// This module is browser compatible.
|
||||||
|
|
||||||
|
export const osType = (() => {
|
||||||
|
if (globalThis.Deno != null) {
|
||||||
|
return Deno.build.os;
|
||||||
|
}
|
||||||
|
|
||||||
|
// deno-lint-ignore no-explicit-any
|
||||||
|
const navigator = (globalThis as any).navigator;
|
||||||
|
if (navigator?.appVersion?.includes?.("Win") ?? false) {
|
||||||
|
return "windows";
|
||||||
|
}
|
||||||
|
|
||||||
|
return "linux";
|
||||||
|
})();
|
||||||
|
|
||||||
|
export const isWindows = osType === "windows";
|
|
@ -3,8 +3,7 @@ import * as path from "../path/mod.ts";
|
||||||
import { ensureDir, ensureDirSync } from "./ensure_dir.ts";
|
import { ensureDir, ensureDirSync } from "./ensure_dir.ts";
|
||||||
import { getFileInfoType, isSubdir } from "./_util.ts";
|
import { getFileInfoType, isSubdir } from "./_util.ts";
|
||||||
import { assert } from "../_util/assert.ts";
|
import { assert } from "../_util/assert.ts";
|
||||||
|
import { isWindows } from "../_util/os.ts";
|
||||||
const isWindows = Deno.build.os === "windows";
|
|
||||||
|
|
||||||
export interface CopyOptions {
|
export interface CopyOptions {
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -3,8 +3,7 @@ import * as path from "../path/mod.ts";
|
||||||
import { ensureDir, ensureDirSync } from "./ensure_dir.ts";
|
import { ensureDir, ensureDirSync } from "./ensure_dir.ts";
|
||||||
import { exists, existsSync } from "./exists.ts";
|
import { exists, existsSync } from "./exists.ts";
|
||||||
import { getFileInfoType } from "./_util.ts";
|
import { getFileInfoType } from "./_util.ts";
|
||||||
|
import { isWindows } from "../_util/os.ts";
|
||||||
const isWindows = Deno.build.os == "windows";
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Ensures that the link exists.
|
* Ensures that the link exists.
|
||||||
|
|
|
@ -16,8 +16,7 @@ import {
|
||||||
walkSync,
|
walkSync,
|
||||||
} from "./walk.ts";
|
} from "./walk.ts";
|
||||||
import { assert } from "../_util/assert.ts";
|
import { assert } from "../_util/assert.ts";
|
||||||
|
import { isWindows } from "../_util/os.ts";
|
||||||
const isWindows = Deno.build.os == "windows";
|
|
||||||
|
|
||||||
export interface ExpandGlobOptions extends Omit<GlobOptions, "os"> {
|
export interface ExpandGlobOptions extends Omit<GlobOptions, "os"> {
|
||||||
root?: string;
|
root?: string;
|
||||||
|
|
|
@ -26,8 +26,7 @@ import {
|
||||||
CHAR_LOWERCASE_Z,
|
CHAR_LOWERCASE_Z,
|
||||||
} from "../path/_constants.ts";
|
} from "../path/_constants.ts";
|
||||||
import * as path from "./path.ts";
|
import * as path from "./path.ts";
|
||||||
|
import { isWindows } from "../_util/os.ts";
|
||||||
const isWindows = Deno.build.os === "windows";
|
|
||||||
|
|
||||||
const forwardSlashRegEx = /\//g;
|
const forwardSlashRegEx = /\//g;
|
||||||
const percentRegEx = /%/g;
|
const percentRegEx = /%/g;
|
||||||
|
|
|
@ -34,13 +34,12 @@ import * as nodeUtil from "./util.ts";
|
||||||
import * as path from "../path/mod.ts";
|
import * as path from "../path/mod.ts";
|
||||||
import { assert } from "../_util/assert.ts";
|
import { assert } from "../_util/assert.ts";
|
||||||
import { fileURLToPath, pathToFileURL } from "./url.ts";
|
import { fileURLToPath, pathToFileURL } from "./url.ts";
|
||||||
|
import { isWindows } from "../_util/os.ts";
|
||||||
|
|
||||||
const CHAR_FORWARD_SLASH = "/".charCodeAt(0);
|
const CHAR_FORWARD_SLASH = "/".charCodeAt(0);
|
||||||
const CHAR_BACKWARD_SLASH = "\\".charCodeAt(0);
|
const CHAR_BACKWARD_SLASH = "\\".charCodeAt(0);
|
||||||
const CHAR_COLON = ":".charCodeAt(0);
|
const CHAR_COLON = ":".charCodeAt(0);
|
||||||
|
|
||||||
const isWindows = Deno.build.os == "windows";
|
|
||||||
|
|
||||||
const relativeResolveCache = Object.create(null);
|
const relativeResolveCache = Object.create(null);
|
||||||
|
|
||||||
let requireDepth = 0;
|
let requireDepth = 0;
|
||||||
|
|
|
@ -46,17 +46,3 @@ export const CHAR_EQUAL = 61; /* = */
|
||||||
// Digits
|
// Digits
|
||||||
export const CHAR_0 = 48; /* 0 */
|
export const CHAR_0 = 48; /* 0 */
|
||||||
export const CHAR_9 = 57; /* 9 */
|
export const CHAR_9 = 57; /* 9 */
|
||||||
|
|
||||||
let NATIVE_OS: typeof Deno.build.os = "linux";
|
|
||||||
// deno-lint-ignore no-explicit-any
|
|
||||||
const navigator = (globalThis as any).navigator;
|
|
||||||
if (globalThis.Deno != null) {
|
|
||||||
NATIVE_OS = Deno.build.os;
|
|
||||||
} else if (navigator?.appVersion?.includes?.("Win") ?? false) {
|
|
||||||
NATIVE_OS = "windows";
|
|
||||||
}
|
|
||||||
// TODO(nayeemrmn): Improve OS detection in browsers beyond Windows.
|
|
||||||
|
|
||||||
export const isWindows = NATIVE_OS == "windows";
|
|
||||||
|
|
||||||
export { NATIVE_OS };
|
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
// Copyright 2018-2020 the Deno authors. All rights reserved. MIT license.
|
// Copyright 2018-2020 the Deno authors. All rights reserved. MIT license.
|
||||||
// This module is browser compatible.
|
// This module is browser compatible.
|
||||||
|
|
||||||
import { NATIVE_OS } from "./_constants.ts";
|
import { osType } from "../_util/os.ts";
|
||||||
import { join, normalize } from "./mod.ts";
|
import { join, normalize } from "./mod.ts";
|
||||||
import { SEP, SEP_PATTERN } from "./separator.ts";
|
import { SEP, SEP_PATTERN } from "./separator.ts";
|
||||||
|
|
||||||
|
@ -80,7 +80,7 @@ const rangeEscapeChars = ["-", "\\", "]"];
|
||||||
* the group occurs not nested at the end of the segment. */
|
* the group occurs not nested at the end of the segment. */
|
||||||
export function globToRegExp(
|
export function globToRegExp(
|
||||||
glob: string,
|
glob: string,
|
||||||
{ extended = true, globstar: globstarOption = true, os = NATIVE_OS }:
|
{ extended = true, globstar: globstarOption = true, os = osType }:
|
||||||
GlobToRegExpOptions = {},
|
GlobToRegExpOptions = {},
|
||||||
): RegExp {
|
): RegExp {
|
||||||
if (glob == "") {
|
if (glob == "") {
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
// Ported mostly from https://github.com/browserify/path-browserify/
|
// Ported mostly from https://github.com/browserify/path-browserify/
|
||||||
/** This module is browser compatible. */
|
/** This module is browser compatible. */
|
||||||
|
|
||||||
import { isWindows } from "./_constants.ts";
|
import { isWindows } from "../_util/os.ts";
|
||||||
import * as _win32 from "./win32.ts";
|
import * as _win32 from "./win32.ts";
|
||||||
import * as _posix from "./posix.ts";
|
import * as _posix from "./posix.ts";
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
// Copyright 2018-2020 the Deno authors. All rights reserved. MIT license.
|
// Copyright 2018-2020 the Deno authors. All rights reserved. MIT license.
|
||||||
/** This module is browser compatible. */
|
/** This module is browser compatible. */
|
||||||
|
|
||||||
import { isWindows } from "./_constants.ts";
|
import { isWindows } from "../_util/os.ts";
|
||||||
|
|
||||||
export const SEP = isWindows ? "\\" : "/";
|
export const SEP = isWindows ? "\\" : "/";
|
||||||
export const SEP_PATTERN = isWindows ? /[\\/]+/ : /\/+/;
|
export const SEP_PATTERN = isWindows ? /[\\/]+/ : /\/+/;
|
||||||
|
|
Loading…
Add table
Reference in a new issue