1 | 'use strict';
|
---|
2 |
|
---|
3 | var $TypeError = require('es-errors/type');
|
---|
4 | var callBound = require('call-bound');
|
---|
5 | var isInteger = require('math-intrinsics/isInteger');
|
---|
6 |
|
---|
7 | var $strSlice = callBound('String.prototype.slice');
|
---|
8 |
|
---|
9 | // https://262.ecma-international.org/15.0/#sec-stringpad
|
---|
10 |
|
---|
11 | module.exports = function StringPad(S, maxLength, fillString, placement) {
|
---|
12 | if (typeof S !== 'string') {
|
---|
13 | throw new $TypeError('Assertion failed: `S` must be a String');
|
---|
14 | }
|
---|
15 | if (!isInteger(maxLength) || maxLength < 0) {
|
---|
16 | throw new $TypeError('Assertion failed: `maxLength` must be a non-negative integer');
|
---|
17 | }
|
---|
18 | if (typeof fillString !== 'string') {
|
---|
19 | throw new $TypeError('Assertion failed: `fillString` must be a String');
|
---|
20 | }
|
---|
21 | if (placement !== 'start' && placement !== 'end' && placement !== 'START' && placement !== 'END') {
|
---|
22 | throw new $TypeError('Assertion failed: `placement` must be ~START~ or ~END~');
|
---|
23 | }
|
---|
24 |
|
---|
25 | var stringLength = S.length; // step 1
|
---|
26 |
|
---|
27 | if (maxLength <= stringLength) { return S; } // step 2
|
---|
28 |
|
---|
29 | if (fillString === '') { return S; } // step 3
|
---|
30 |
|
---|
31 | var fillLen = maxLength - stringLength; // step 4
|
---|
32 |
|
---|
33 | // 5. Let _truncatedStringFiller_ be the String value consisting of repeated concatenations of _fillString_ truncated to length _fillLen_.
|
---|
34 | var truncatedStringFiller = '';
|
---|
35 | while (truncatedStringFiller.length < fillLen) {
|
---|
36 | truncatedStringFiller += fillString;
|
---|
37 | }
|
---|
38 | truncatedStringFiller = $strSlice(truncatedStringFiller, 0, fillLen);
|
---|
39 |
|
---|
40 | if (placement === 'start' || placement === 'START') { return truncatedStringFiller + S; } // step 6
|
---|
41 |
|
---|
42 | return S + truncatedStringFiller; // step 7
|
---|
43 | };
|
---|