Skip to content

Commit

Permalink
feat: allow strip filter with specified char, closes #390
Browse files Browse the repository at this point in the history
  • Loading branch information
harttle committed Mar 5, 2022
1 parent 01014ed commit c503cb2
Show file tree
Hide file tree
Showing 3 changed files with 33 additions and 10 deletions.
22 changes: 18 additions & 4 deletions src/builtin/filters/string.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
*
* * prefer stringify() to String() since `undefined`, `null` should eval ''
*/
import { stringify } from '../../util/underscore'
import { escapeRegExp, stringify } from '../../util/underscore'
import { assert } from '../../util/assert'

export function append (v: string, arg: string) {
Expand All @@ -16,7 +16,11 @@ export function prepend (v: string, arg: string) {
return stringify(arg) + stringify(v)
}

export function lstrip (v: string) {
export function lstrip (v: string, chars?: string) {
if (chars) {
chars = escapeRegExp(stringify(chars))
return stringify(v).replace(new RegExp(`^[${chars}]+`, 'g'), '')
}
return stringify(v).replace(/^\s+/, '')
}

Expand All @@ -36,7 +40,11 @@ export function removeFirst (v: string, l: string) {
return stringify(v).replace(String(l), '')
}

export function rstrip (str: string) {
export function rstrip (str: string, chars?: string) {
if (chars) {
chars = escapeRegExp(stringify(chars))
return stringify(str).replace(new RegExp(`[${chars}]+$`, 'g'), '')
}
return stringify(str).replace(/\s+$/, '')
}

Expand All @@ -48,7 +56,13 @@ export function split (v: string, arg: string) {
return arr
}

export function strip (v: string) {
export function strip (v: string, chars?: string) {
if (chars) {
chars = escapeRegExp(stringify(chars))
return stringify(v)
.replace(new RegExp(`^[${chars}]+`, 'g'), '')
.replace(new RegExp(`[${chars}]+$`, 'g'), '')
}
return stringify(v).trim()
}

Expand Down
4 changes: 4 additions & 0 deletions src/util/underscore.ts
Original file line number Diff line number Diff line change
Expand Up @@ -156,3 +156,7 @@ export function caseInsensitiveCompare (a: any, b: any) {
export function argumentsToValue<F extends (...args: any) => any> (fn: F) {
return (...args: Parameters<F>) => fn(...args.map(toValue))
}

export function escapeRegExp (text: string) {
return text.replace(/[-[\]{}()*+?.,\\^$|#\s]/g, '\\$&')
}
17 changes: 11 additions & 6 deletions test/integration/builtin/filters/string.ts
Original file line number Diff line number Diff line change
Expand Up @@ -86,9 +86,10 @@ describe('filters/string', function () {
it('should support upcase', () => test('{{ "Parker Moore" | upcase }}', 'PARKER MOORE'))
it('should return empty for undefined', () => test('{{ foo | upcase }}', ''))
})
it('should support lstrip', function () {
it('should support lstrip', async () => {
const src = '{{ " So much room for activities! " | lstrip }}'
return test(src, 'So much room for activities! ')
await test(src, 'So much room for activities! ')
await test('{{ "foobarcoo" | lstrip: "fo" }}', 'barcoo')
})
it('should support prepend', function () {
return test('{% assign url = "liquidmarkup.com" %}' +
Expand All @@ -115,9 +116,10 @@ describe('filters/string', function () {
'{{ my_string | replace_first: "my", "your" }}',
'\nTake your protein pills and put my helmet on')
})
it('should support rstrip', function () {
return test('{{ " So much room for activities! " | rstrip }}',
it('should support rstrip', async () => {
await test('{{ " So much room for activities! " | rstrip }}',
' So much room for activities!')
await test('{{ "foobarcoo" | rstrip: "fco" }}', 'foobar')
})
it('should support split', function () {
return test('{% assign beatles = "John, Paul, George, Ringo" | split: ", " %}' +
Expand All @@ -126,9 +128,12 @@ describe('filters/string', function () {
'{% endfor %}',
'John Paul George Ringo ')
})
it('should support strip', function () {
return test('{{ " So much room for activities! " | strip }}',
it('should support strip', async () => {
await test('{{ " So much room for activities! " | strip }}',
'So much room for activities!')
await test('{{ " So much room for activities! " | strip: "So " }}',
'much room for activities!')
await test('{{ "&[]{}" | strip: "&[]{}" }}', '')
})
it('should support strip_newlines', function () {
return test('{% capture string_with_newlines %}\n' +
Expand Down

0 comments on commit c503cb2

Please sign in to comment.