2020-01-02 15:13:47 -05:00
|
|
|
// Copyright 2018-2020 the Deno authors. All rights reserved. MIT license.
|
2019-04-07 03:06:07 +02:00
|
|
|
|
|
|
|
/** EndOfLine character enum */
|
|
|
|
export enum EOL {
|
|
|
|
LF = "\n",
|
|
|
|
CRLF = "\r\n"
|
|
|
|
}
|
|
|
|
|
|
|
|
const regDetect = /(?:\r?\n)/g;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Detect the EOL character for string input.
|
|
|
|
* returns null if no newline
|
|
|
|
*/
|
|
|
|
export function detect(content: string): EOL | null {
|
|
|
|
const d = content.match(regDetect);
|
|
|
|
if (!d || d.length === 0) {
|
|
|
|
return null;
|
|
|
|
}
|
2019-04-24 13:41:23 +02:00
|
|
|
const crlf = d.filter((x: string): boolean => x === EOL.CRLF);
|
2019-04-07 03:06:07 +02:00
|
|
|
if (crlf.length > 0) {
|
|
|
|
return EOL.CRLF;
|
|
|
|
} else {
|
|
|
|
return EOL.LF;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Format the file to the targeted EOL */
|
|
|
|
export function format(content: string, eol: EOL): string {
|
|
|
|
return content.replace(regDetect, eol);
|
|
|
|
}
|