1
0
Fork 0
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:
Behnam Mohammadi 2020-11-14 02:51:11 +03:30 committed by GitHub
parent d5661f677e
commit a59f5eadd8
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
10 changed files with 27 additions and 28 deletions

18
std/_util/os.ts Normal file
View 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";

View file

@ -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 {
/** /**

View file

@ -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.

View file

@ -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;

View file

@ -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;

View file

@ -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;

View file

@ -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 };

View file

@ -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 == "") {

View file

@ -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";

View file

@ -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 ? /[\\/]+/ : /\/+/;