PHP's quoted_printable_decode in TypeScript

✓ Verified: PHP 8.3
Examples tested against actual runtime. CI re-verifies continuously. Only documented examples are tested.

How to use

Install via yarn add locutus and import: import { quoted_printable_decode } from 'locutus/php/strings/quoted_printable_decode'.

Or with CommonJS: const { quoted_printable_decode } = require('locutus/php/strings/quoted_printable_decode')

Use a bundler that supports tree-shaking so you only ship the functions you actually use. Vite, webpack, Rollup, and Parcel all handle this. For server-side use this is less of a concern.

Examples

These examples are extracted from test cases that automatically verify our functions against their native counterparts.

#codeexpected result
1quoted_printable_decode('a=3Db=3Dc')'a=b=c'
2quoted_printable_decode('abc =20\r\n123 =20\r\n')'abc \r\n123 \r\n'
3quoted_printable_decode('012345678901234567890123456789012345678901234567890123456789012345678901234=\r\n56789')'01234567890123456789012345678901234567890123456789012345678901234567890123456789'
4quoted_printable_decode("Lorem ipsum dolor sit amet=23, consectetur adipisicing elit")'Lorem ipsum dolor sit amet#, consectetur adipisicing elit'

Here's what our current TypeScript equivalent to PHP's quoted_printable_decode looks like.

export function quoted_printable_decode(str: string): string {
// discuss at: https://locutus.io/php/quoted_printable_decode/
// parity verified: PHP 8.3
// original by: Ole Vrijenhoek
// bugfixed by: Brett Zamir (https://brett-zamir.me)
// bugfixed by: Theriault (https://github.com/Theriault)
// reimplemented by: Theriault (https://github.com/Theriault)
// improved by: Brett Zamir (https://brett-zamir.me)
// example 1: quoted_printable_decode('a=3Db=3Dc')
// returns 1: 'a=b=c'
// example 2: quoted_printable_decode('abc =20\r\n123 =20\r\n')
// returns 2: 'abc \r\n123 \r\n'
// example 3: quoted_printable_decode('012345678901234567890123456789012345678901234567890123456789012345678901234=\r\n56789')
// returns 3: '01234567890123456789012345678901234567890123456789012345678901234567890123456789'
// example 4: quoted_printable_decode("Lorem ipsum dolor sit amet=23, consectetur adipisicing elit")
// returns 4: 'Lorem ipsum dolor sit amet#, consectetur adipisicing elit'

// Decodes all equal signs followed by two hex digits
const RFC2045Decode1 = /=\r\n/gm

// the RFC states against decoding lower case encodings, but following apparent PHP behavior
const RFC2045Decode2IN = /=([0-9A-F]{2})/gim
// RFC2045Decode2IN = /=([0-9A-F]{2})/gm,

const RFC2045Decode2OUT = function (_sMatch: string, sHex: string): string {
return String.fromCharCode(parseInt(sHex, 16))
}

return str.replace(RFC2045Decode1, '').replace(RFC2045Decode2IN, RFC2045Decode2OUT)
}

Improve this function

Locutus is a community effort following The McDonald's Theory: we ship first iterations, hoping others will improve them. If you see something that could be better, we'd love your contribution.

View on GitHub · Edit on GitHub · View Raw


« More PHP strings functions


Star