From 3d8f4f4c31ac86f39e3677b8e1869bcef68562de Mon Sep 17 00:00:00 2001 From: stdlib-bot Date: Sun, 25 Feb 2024 22:38:05 +0000 Subject: [PATCH] Auto-generated commit --- .npmignore | 3 +- base/for-each-right/README.md | 150 ++++++++++++++++++ base/for-each-right/benchmark/benchmark.js | 61 ++++++++ base/for-each-right/docs/repl.txt | 38 +++++ base/for-each-right/docs/types/index.d.ts | 93 +++++++++++ base/for-each-right/docs/types/test.ts | 86 +++++++++++ base/for-each-right/examples/index.js | 30 ++++ base/for-each-right/lib/index.js | 43 ++++++ base/for-each-right/lib/main.js | 49 ++++++ base/for-each-right/package.json | 70 +++++++++ base/for-each-right/test/test.js | 170 +++++++++++++++++++++ 11 files changed, 792 insertions(+), 1 deletion(-) create mode 100644 base/for-each-right/README.md create mode 100644 base/for-each-right/benchmark/benchmark.js create mode 100644 base/for-each-right/docs/repl.txt create mode 100644 base/for-each-right/docs/types/index.d.ts create mode 100644 base/for-each-right/docs/types/test.ts create mode 100644 base/for-each-right/examples/index.js create mode 100644 base/for-each-right/lib/index.js create mode 100644 base/for-each-right/lib/main.js create mode 100644 base/for-each-right/package.json create mode 100644 base/for-each-right/test/test.js diff --git a/.npmignore b/.npmignore index 5c7f09d7..8eea7dc2 100644 --- a/.npmignore +++ b/.npmignore @@ -29,8 +29,9 @@ branches.md .postinstall.json Makefile -# Ignore `binding.gyp` file to avoid compilation of native addon when installing package: +# Ignore files to avoid compilation of native addon when installing package: binding.gyp +include.gypi # Directories # ############### diff --git a/base/for-each-right/README.md b/base/for-each-right/README.md new file mode 100644 index 00000000..5421713a --- /dev/null +++ b/base/for-each-right/README.md @@ -0,0 +1,150 @@ + + +# forEachRight + +> Invokes a function for each UTF-16 code unit in a string iterating from right to left. + + + +
+ +
+ + + + + +
+ +## Usage + +```javascript +var forEachRight = require( '@stdlib/string/base/for-each-right' ); +``` + +#### forEachRight( str, clbk\[, thisArg ] ) + +Invokes a function for each UTF-16 code unit in a string iterating from right to left. + +```javascript +function log( value, index ) { + console.log( '%d: %s', index, value ); +} + +forEachRight( 'Beep!', log ); +/* => + 4: ! + 3: p + 2: e + 1: e + 0: B +*/ +``` + +The invoked function is provided three arguments: + +- **value**: character. +- **index**: character index. +- **str**: input string. + +To set the function execution context, provide a `thisArg`. + +```javascript +function clbk() { + this.count += 1; +} + +var str = '👉🏿'; + +var ctx = { + 'count': 0 +}; + +forEachRight( str, clbk, ctx ); + +var cnt = ctx.count; +// returns 4 +``` + +
+ + + + + +
+ +
+ + + + + +
+ +## Examples + + + +```javascript +var forEachRight = require( '@stdlib/string/base/for-each-right' ); + +function log( value, index ) { + console.log( '%d: %s', index, value ); +} + +forEachRight( 'presidential election', log ); +forEachRight( 'Iñtërnâtiônàlizætiøn', log ); +forEachRight( '🌷🍕', log ); +forEachRight( '\uD834\uDD1E', log ); +``` + +
+ + + + + +
+ +
+ + + + + + + + + + + + + + diff --git a/base/for-each-right/benchmark/benchmark.js b/base/for-each-right/benchmark/benchmark.js new file mode 100644 index 00000000..4445af7c --- /dev/null +++ b/base/for-each-right/benchmark/benchmark.js @@ -0,0 +1,61 @@ +/** +* @license Apache-2.0 +* +* Copyright (c) 2024 The Stdlib Authors. +* +* Licensed under the Apache License, Version 2.0 (the "License"); +* you may not use this file except in compliance with the License. +* You may obtain a copy of the License at +* +* http://www.apache.org/licenses/LICENSE-2.0 +* +* Unless required by applicable law or agreed to in writing, software +* distributed under the License is distributed on an "AS IS" BASIS, +* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +* See the License for the specific language governing permissions and +* limitations under the License. +*/ + +'use strict'; + +// MODULES // + +var bench = require( '@stdlib/bench' ); +var isString = require( '@stdlib/assert/is-string' ).isPrimitive; +var pkg = require( './../package.json' ).name; +var forEachRight = require( './../lib' ); + + +// MAIN // + +bench( pkg, function benchmark( b ) { + var values; + var out; + var i; + + values = [ + 'Iñtërnâtiônàlizætiøn', + 'presidential election', + '🐶🐮🐷🐰🐸' + ]; + + b.tic(); + for ( i = 0; i < b.iterations; i++ ) { + out = forEachRight( values[ i%values.length ], clbk ); + if ( typeof out !== 'string' ) { + b.fail( 'should return a string' ); + } + } + b.toc(); + if ( !isString( out ) ) { + b.fail( 'should return a string' ); + } + b.pass( 'benchmark finished' ); + b.end(); + + function clbk( v ) { + if ( typeof v !== 'string' ) { + b.fail( 'unexpected value' ); + } + } +}); diff --git a/base/for-each-right/docs/repl.txt b/base/for-each-right/docs/repl.txt new file mode 100644 index 00000000..7e655900 --- /dev/null +++ b/base/for-each-right/docs/repl.txt @@ -0,0 +1,38 @@ + +{{alias}}( str, clbk[, thisArg] ) + Invokes a function for each UTF-16 code unit in a string, iterating from + right to left. + + When invoked, the provided function is provided three arguments: + + - value: character + - index: character index + - str: input string + + Parameters + ---------- + str: string + Input string over which to iterate. + + clbk: Function + Function to invoke for each UTF-16 code unit in the input string. + + thisArg: any (optional) + Execution context. + + Returns + ------- + out: string + Input string. + + Examples + -------- + > var n = 0; + > function fcn() { n += 1; }; + > {{alias}}( 'hello world!', fcn ); + > n + 12 + + See Also + -------- + diff --git a/base/for-each-right/docs/types/index.d.ts b/base/for-each-right/docs/types/index.d.ts new file mode 100644 index 00000000..53c9d720 --- /dev/null +++ b/base/for-each-right/docs/types/index.d.ts @@ -0,0 +1,93 @@ +/* +* @license Apache-2.0 +* +* Copyright (c) 2024 The Stdlib Authors. +* +* Licensed under the Apache License, Version 2.0 (the "License"); +* you may not use this file except in compliance with the License. +* You may obtain a copy of the License at +* +* http://www.apache.org/licenses/LICENSE-2.0 +* +* Unless required by applicable law or agreed to in writing, software +* distributed under the License is distributed on an "AS IS" BASIS, +* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +* See the License for the specific language governing permissions and +* limitations under the License. +*/ + +// TypeScript Version: 4.1 + +/** +* Callback invoked for each UTF-16 code unit in a string. +* +* @returns result +*/ +type Nullary = () => any; + +/** +* Callback invoked for each UTF-16 code unit in a string. +* +* @param value - character +* @returns result +*/ +type Unary = ( value: string ) => any; + +/** +* Callback invoked for each UTF-16 code unit in a string. +* +* @param value - character +* @param index - character index +* @returns result +*/ +type Binary = ( value: string, index: number ) => any; + +/** +* Callback invoked for each UTF-16 code unit in a string. +* +* @param value - character +* @param index - character index +* @param str - input string +* @returns result +*/ +type Ternary = ( value: string, index: number, str: string ) => any; + +/** +* Callback invoked for each UTF-16 code unit in a string. +* +* @param value - character +* @param index - character index +* @param str - input string +* @returns result +*/ +type Callback = Nullary | Unary | Binary | Ternary; + +/** +* Invokes a function for each UTF-16 code unit in a string iterating from right to left. +* +* ## Notes +* +* - When invoked, the provided function is provided three arguments: +* +* - **value**: character. +* - **index**: character index. +* - **str**: input string. +* +* @param str - input string +* @param clbk - function to invoke +* @param thisArg - execution context +* @returns input string +* +* @example +* function log( value, index ) { +* console.log( '%d: %s', index, value ); +* } +* +* forEach( 'Hello, World!', log ); +*/ +declare function forEachRight( str: string, clbk: Callback, thisArg?: any ): string; + + +// EXPORTS // + +export = forEachRight; diff --git a/base/for-each-right/docs/types/test.ts b/base/for-each-right/docs/types/test.ts new file mode 100644 index 00000000..17a3cc65 --- /dev/null +++ b/base/for-each-right/docs/types/test.ts @@ -0,0 +1,86 @@ +/* +* @license Apache-2.0 +* +* Copyright (c) 2024 The Stdlib Authors. +* +* Licensed under the Apache License, Version 2.0 (the "License"); +* you may not use this file except in compliance with the License. +* You may obtain a copy of the License at +* +* http://www.apache.org/licenses/LICENSE-2.0 +* +* Unless required by applicable law or agreed to in writing, software +* distributed under the License is distributed on an "AS IS" BASIS, +* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +* See the License for the specific language governing permissions and +* limitations under the License. +*/ + +import forEachRight = require( './index' ); + +/** +* Callback function. +* +* @param v - argument +* @returns result +*/ +function clbk( v: string ): string { + return v; +} + + +// TESTS // + +// The function returns a string... +{ + forEachRight( 'presidential election', clbk ); // $ExpectType string + forEachRight( 'Iñtërnâtiônàlizætiøn', clbk, {} ); // $ExpectType string +} + +// The compiler throws an error if the function is provided a first argument which is not a string... +{ + forEachRight( 1, clbk ); // $ExpectError + forEachRight( false, clbk ); // $ExpectError + forEachRight( true, clbk ); // $ExpectError + forEachRight( null, clbk ); // $ExpectError + forEachRight( [], clbk ); // $ExpectError + forEachRight( {}, clbk ); // $ExpectError + forEachRight( ( x: number ): number => x, clbk ); // $ExpectError + + forEachRight( 1, clbk, {} ); // $ExpectError + forEachRight( false, clbk, {} ); // $ExpectError + forEachRight( true, clbk, {} ); // $ExpectError + forEachRight( null, clbk, {} ); // $ExpectError + forEachRight( [], clbk, {} ); // $ExpectError + forEachRight( {}, clbk, {} ); // $ExpectError + forEachRight( ( x: number ): number => x, clbk, {} ); // $ExpectError +} + +// The compiler throws an error if the function is provided a second argument which is not a function having a supported signature... +{ + forEachRight( 'presidential election', 'abc' ); // $ExpectError + forEachRight( 'presidential election', 2 ); // $ExpectError + forEachRight( 'presidential election', true ); // $ExpectError + forEachRight( 'presidential election', false ); // $ExpectError + forEachRight( 'presidential election', null ); // $ExpectError + forEachRight( 'presidential election', {} ); // $ExpectError + forEachRight( 'presidential election', [] ); // $ExpectError + + forEachRight( 'presidential election', 'abc', {} ); // $ExpectError + forEachRight( 'presidential election', 2, {} ); // $ExpectError + forEachRight( 'presidential election', true, {} ); // $ExpectError + forEachRight( 'presidential election', false, {} ); // $ExpectError + forEachRight( 'presidential election', null, {} ); // $ExpectError + forEachRight( 'presidential election', {}, {} ); // $ExpectError + forEachRight( 'presidential election', [], {} ); // $ExpectError + + forEachRight( 'presidential election', ( x: number ): number => x ); // $ExpectError + forEachRight( 'presidential election', ( x: number ): number => x, {} ); // $ExpectError +} + +// The compiler throws an error if the function is provided an unsupported number of arguments... +{ + forEachRight(); // $ExpectError + forEachRight( 'presidential election' ); // $ExpectError + forEachRight( 'presidential election', clbk, {}, 3 ); // $ExpectError +} diff --git a/base/for-each-right/examples/index.js b/base/for-each-right/examples/index.js new file mode 100644 index 00000000..781f8a45 --- /dev/null +++ b/base/for-each-right/examples/index.js @@ -0,0 +1,30 @@ +/** +* @license Apache-2.0 +* +* Copyright (c) 2024 The Stdlib Authors. +* +* Licensed under the Apache License, Version 2.0 (the "License"); +* you may not use this file except in compliance with the License. +* You may obtain a copy of the License at +* +* http://www.apache.org/licenses/LICENSE-2.0 +* +* Unless required by applicable law or agreed to in writing, software +* distributed under the License is distributed on an "AS IS" BASIS, +* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +* See the License for the specific language governing permissions and +* limitations under the License. +*/ + +'use strict'; + +var forEachRight = require( './../lib' ); + +function log( value, index ) { + console.log( '%d: %s', index, value ); +} + +forEachRight( 'presidential election', log ); +forEachRight( 'Iñtërnâtiônàlizætiøn', log ); +forEachRight( '🌷🍕', log ); +forEachRight( '\uD834\uDD1E', log ); diff --git a/base/for-each-right/lib/index.js b/base/for-each-right/lib/index.js new file mode 100644 index 00000000..c09c0e56 --- /dev/null +++ b/base/for-each-right/lib/index.js @@ -0,0 +1,43 @@ +/** +* @license Apache-2.0 +* +* Copyright (c) 2024 The Stdlib Authors. +* +* Licensed under the Apache License, Version 2.0 (the "License"); +* you may not use this file except in compliance with the License. +* You may obtain a copy of the License at +* +* http://www.apache.org/licenses/LICENSE-2.0 +* +* Unless required by applicable law or agreed to in writing, software +* distributed under the License is distributed on an "AS IS" BASIS, +* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +* See the License for the specific language governing permissions and +* limitations under the License. +*/ + +'use strict'; + +/** +* Invoke a function for each UTF-16 code unit in a string iterating from right to left. +* +* @module @stdlib/string/base/for-each-right +* +* @example +* var forEachRight = require( '@stdlib/string/base/for-each-right' ); +* +* function log( value, index ) { +* console.log( '%d: %s', index, value ); +* } +* +* forEachRight( 'Hello', log ); +*/ + +// MODULES // + +var main = require( './main.js' ); + + +// EXPORTS // + +module.exports = main; diff --git a/base/for-each-right/lib/main.js b/base/for-each-right/lib/main.js new file mode 100644 index 00000000..dc7ca021 --- /dev/null +++ b/base/for-each-right/lib/main.js @@ -0,0 +1,49 @@ +/** +* @license Apache-2.0 +* +* Copyright (c) 2024 The Stdlib Authors. +* +* Licensed under the Apache License, Version 2.0 (the "License"); +* you may not use this file except in compliance with the License. +* You may obtain a copy of the License at +* +* http://www.apache.org/licenses/LICENSE-2.0 +* +* Unless required by applicable law or agreed to in writing, software +* distributed under the License is distributed on an "AS IS" BASIS, +* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +* See the License for the specific language governing permissions and +* limitations under the License. +*/ + +'use strict'; + +// MAIN // + +/** +* Invokes a function for each UTF-16 code unit in a string iterating from right to left. +* +* @param {string} str - input string +* @param {Function} clbk - function to invoke +* @param {*} [thisArg] - execution context +* @returns {string} input string +* +* @example +* function log( value, index ) { +* console.log( '%d: %s', index, value ); +* } +* +* forEachRight( 'Hello', log ); +*/ +function forEachRight( str, clbk, thisArg ) { + var i; + for ( i = str.length-1; i >= 0; i-- ) { + clbk.call( thisArg, str[ i ], i, str ); + } + return str; +} + + +// EXPORTS // + +module.exports = forEachRight; diff --git a/base/for-each-right/package.json b/base/for-each-right/package.json new file mode 100644 index 00000000..4230b362 --- /dev/null +++ b/base/for-each-right/package.json @@ -0,0 +1,70 @@ +{ + "name": "@stdlib/string/base/for-each-right", + "version": "0.0.0", + "description": "Invoke a function for each UTF-16 code unit in a string iterating from right to left.", + "license": "Apache-2.0", + "author": { + "name": "The Stdlib Authors", + "url": "https://github.com/stdlib-js/stdlib/graphs/contributors" + }, + "contributors": [ + { + "name": "The Stdlib Authors", + "url": "https://github.com/stdlib-js/stdlib/graphs/contributors" + } + ], + "main": "./lib", + "directories": { + "benchmark": "./benchmark", + "doc": "./docs", + "example": "./examples", + "lib": "./lib", + "test": "./test" + }, + "types": "./docs/types", + "scripts": {}, + "homepage": "https://github.com/stdlib-js/stdlib", + "repository": { + "type": "git", + "url": "git://github.com/stdlib-js/stdlib.git" + }, + "bugs": { + "url": "https://github.com/stdlib-js/stdlib/issues" + }, + "dependencies": {}, + "devDependencies": {}, + "engines": { + "node": ">=0.10.0", + "npm": ">2.7.0" + }, + "os": [ + "aix", + "darwin", + "freebsd", + "linux", + "macos", + "openbsd", + "sunos", + "win32", + "windows" + ], + "keywords": [ + "stdlib", + "stdutils", + "stdutil", + "utilities", + "utility", + "utils", + "util", + "for", + "each", + "foreachright", + "iterate", + "stdstring", + "string", + "str", + "utf16", + "utf-16", + "reverse" + ] +} diff --git a/base/for-each-right/test/test.js b/base/for-each-right/test/test.js new file mode 100644 index 00000000..03155a30 --- /dev/null +++ b/base/for-each-right/test/test.js @@ -0,0 +1,170 @@ +/** +* @license Apache-2.0 +* +* Copyright (c) 2024 The Stdlib Authors. +* +* Licensed under the Apache License, Version 2.0 (the "License"); +* you may not use this file except in compliance with the License. +* You may obtain a copy of the License at +* +* http://www.apache.org/licenses/LICENSE-2.0 +* +* Unless required by applicable law or agreed to in writing, software +* distributed under the License is distributed on an "AS IS" BASIS, +* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +* See the License for the specific language governing permissions and +* limitations under the License. +*/ + +'use strict'; + +// MODULES // + +var tape = require( 'tape' ); +var noop = require( '@stdlib/utils/noop' ); +var forEachRight = require( './../lib' ); + + +// TESTS // + +tape( 'main export is a function', function test( t ) { + t.ok( true, __filename ); + t.strictEqual( typeof forEachRight, 'function', 'main export is a function' ); + t.end(); +}); + +tape( 'if provided an empty string, the function never invokes a provided function', function test( t ) { + var out = forEachRight( '', fcn ); + t.strictEqual( out, '', 'returns expected value' ); + t.end(); + + function fcn() { + t.fail( 'should not be invoked' ); + } +}); + +tape( 'the function returns a provided string', function test( t ) { + var str; + var out; + + str = 'Hello, world'; + + out = forEachRight( str, noop ); + t.strictEqual( out, str, 'returns expected value' ); + + t.end(); +}); + +tape( 'the function invokes a provided function for each UTF-16 code unit in a provided string', function test( t ) { + var expected; + var actual; + var str; + + str = 'Hello, world'; + expected = [ + 'd', + 'l', + 'r', + 'o', + 'w', + ' ', + ',', + 'o', + 'l', + 'l', + 'e', + 'H' + ]; + + actual = []; + forEachRight( str, copy ); + + t.deepEqual( actual, expected, 'returns expected value' ); + t.end(); + + function copy( value ) { + actual.push( value ); + } +}); + +tape( 'the function invokes a provided function for each UTF-16 code unit in a provided string (Unicode)', function test( t ) { + var expected; + var actual; + var str; + + str = 'Hello, world \uD834\uDD1E'; + expected = [ + '\uDD1E', + '\uD834', + ' ', + 'd', + 'l', + 'r', + 'o', + 'w', + ' ', + ',', + 'o', + 'l', + 'l', + 'e', + 'H' + ]; + + actual = []; + forEachRight( str, copy ); + + t.deepEqual( actual, expected, 'returns expected value' ); + t.end(); + + function copy( value ) { + actual.push( value ); + } +}); + +tape( 'the function invokes a provided function for each UTF-16 code unit in a provided string (emoji)', function test( t ) { + var expected; + var actual; + var str; + + str = '🌷🍕👉🏿'; + expected = [ + '\uDFFF', + '\uD83C', + '\uDC49', + '\uD83D', + '\uDF55', + '\uD83C', + '\uDF37', + '\uD83C' + ]; + + actual = []; + forEachRight( str, copy ); + + t.deepEqual( actual, expected, 'returns expected value' ); + t.end(); + + function copy( value ) { + actual.push( value ); + } +}); + +tape( 'the function supports providing an execution context', function test( t ) { + var ctx; + var str; + + str = 'Hello, world'; + ctx = { + 'count': 0 + }; + + forEachRight( str, count, ctx ); + + t.strictEqual( ctx.count, 12, 'returns expected value' ); + t.end(); + + function count() { + this.count += 1; // eslint-disable-line no-invalid-this + } +});