std/fs/eol.ts
2024-06-07 15:54:50 +12:00

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