mirror of
https://github.com/denoland/std.git
synced 2024-11-22 04:59:05 +00:00
71 lines
1.9 KiB
TypeScript
71 lines
1.9 KiB
TypeScript
// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
|
|
|
|
/** End-of-line character for POSIX platforms such as macOS and Linux. */
|
|
export const LF = "\n" as const;
|
|
|
|
/** End-of-line character for Windows platforms. */
|
|
export const CRLF = "\r\n" as const;
|
|
|
|
/**
|
|
* End-of-line character evaluated for the current platform.
|
|
*
|
|
* @example Usage
|
|
* ```ts no-eval
|
|
* import { EOL } from "@std/fs/eol";
|
|
*
|
|
* EOL; // "\n" on POSIX platforms and "\r\n" on Windows
|
|
* ```
|
|
*/
|
|
export const EOL: "\n" | "\r\n" = Deno?.build.os === "windows" ? CRLF : LF;
|
|
|
|
const regDetect = /(?:\r?\n)/g;
|
|
|
|
/**
|
|
* Returns the detected EOL character(s) detected in the input string. If no EOL
|
|
* character is detected, `null` is returned.
|
|
*
|
|
* @param content The input string to detect EOL characters.
|
|
*
|
|
* @returns The detected EOL character(s) or `null` if no EOL character is detected.
|
|
*
|
|
* @example Usage
|
|
* ```ts no-eval
|
|
* import { detect } from "@std/fs/eol";
|
|
*
|
|
* detect("deno\r\nis not\r\nnode"); // "\r\n"
|
|
* detect("deno\nis not\r\nnode"); // "\r\n"
|
|
* detect("deno\nis not\nnode"); // "\n"
|
|
* detect("deno is not node"); // null
|
|
* ```
|
|
*/
|
|
export function detect(content: string): typeof EOL | null {
|
|
const d = content.match(regDetect);
|
|
if (!d || d.length === 0) {
|
|
return null;
|
|
}
|
|
const hasCRLF = d.some((x: string): boolean => x === CRLF);
|
|
|
|
return hasCRLF ? CRLF : LF;
|
|
}
|
|
|
|
/**
|
|
* Normalize the input string to the targeted EOL.
|
|
*
|
|
* @param content The input string to normalize.
|
|
* @param eol The EOL character(s) to normalize the input string to.
|
|
*
|
|
* @returns The input string normalized to the targeted EOL.
|
|
*
|
|
* @example Usage
|
|
* ```ts no-eval
|
|
* import { LF, format } from "@std/fs/eol";
|
|
*
|
|
* const CRLFinput = "deno\r\nis not\r\nnode";
|
|
*
|
|
* format(CRLFinput, LF); // "deno\nis not\nnode"
|
|
* ```
|
|
*/
|
|
export function format(content: string, eol: typeof EOL): string {
|
|
return content.replace(regDetect, eol);
|
|
}
|