From: Lady Date: Sat, 4 Jun 2022 23:12:17 +0000 (-0700) Subject: Add string functions X-Git-Tag: 0.1.0~10 X-Git-Url: https://git.ladys.computer/Pisces/commitdiff_plain/15a0a4d62a2816fc55f98064a81034ae2fc13404 Add string functions --- diff --git a/mod.js b/mod.js index dc8d6fc..9dd8fd1 100644 --- a/mod.js +++ b/mod.js @@ -12,3 +12,4 @@ export * from "./collection.js"; export * from "./iri.js"; export * from "./numeric.js"; export * from "./object.js"; +export * from "./string.js"; diff --git a/string.js b/string.js new file mode 100644 index 0000000..17e8736 --- /dev/null +++ b/string.js @@ -0,0 +1,81 @@ +// ♓🌟 Piscēs ∷ string.js +// ==================================================================== +// +// Copyright © 2022 Lady [@ Lady’s Computer]. +// +// This Source Code Form is subject to the terms of the Mozilla Public +// License, v. 2.0. If a copy of the MPL was not distributed with this +// file, You can obtain one at . + +/** + * Returns the result of converting the provided value to A·S·C·I·I + * lowercase. + */ +export const asciiLowercase = ($) => + `${$}`.replaceAll( + /[A-Z]/gu, + Function.prototype.call.bind(String.prototype.toLowerCase), + ); + +/** + * Returns the result of converting the provided value to A·S·C·I·I + * uppercase. + */ +export const asciiUppercase = ($) => + `${$}`.replaceAll( + /[a-z]/gu, + Function.prototype.call.bind(String.prototype.toUpperCase), + ); + +/** + * Returns the result of converting the provided value to a string of + * scalar values by replacing (unpaired) surrogate values with U+FFFD. + */ +export const scalarValueString = ($) => + String.fromCodePoint( + ...function* () { + for (const char of `${$}`) { + const scalar = char.codePointAt(0); + yield scalar >= 0xD800 && scalar <= 0xDFFF ? 0xFFFD : scalar; + } + }(), + ); + +/** + * Returns the result of splitting the provided value on A·S·C·I·I + * whitespace. + */ +export const splitOnASCIIWhitespace = ($) => + stripAndCollapseASCIIWhitespace($).split(" "); + +/** + * Returns the result of splitting the provided value on commas, + * trimming A·S·C·I·I whitespace from the resulting tokens. + */ +export const splitOnCommas = ($) => + stripLeadingAndTrailingASCIIWhitespace( + `${$}`.replaceAll( + /[\n\r\t\f ]*,[\n\r\t\f ]*/gu, + ",", + ), + ).split(","); + +/** + * Returns the result of stripping leading and trailing A·S·C·I·I + * whitespace from the provided value. + */ +export const stripLeadingAndTrailingASCIIWhitespace = ($) => + /^[\n\r\t\f ]*([^]*?)[\n\r\t\f ]*$/u.exec($)[1]; + +/** + * Returns the result of stripping leading and trailing A·S·C·I·I + * whitespace from the provided value and collapsing other A·S·C·I·I + * whitespace in the provided value. + */ +export const stripAndCollapseASCIIWhitespace = ($) => + stripLeadingAndTrailingASCIIWhitespace( + `${$}`.replaceAll( + /[\n\r\t\f ]+/gu, + " ", + ), + );