summaryrefslogtreecommitdiff
path: root/src/node_modules/es-abstract/2020/UTF16DecodeSurrogatePair.js
diff options
context:
space:
mode:
Diffstat (limited to 'src/node_modules/es-abstract/2020/UTF16DecodeSurrogatePair.js')
-rw-r--r--src/node_modules/es-abstract/2020/UTF16DecodeSurrogatePair.js19
1 files changed, 19 insertions, 0 deletions
diff --git a/src/node_modules/es-abstract/2020/UTF16DecodeSurrogatePair.js b/src/node_modules/es-abstract/2020/UTF16DecodeSurrogatePair.js
new file mode 100644
index 0000000..6302a1b
--- /dev/null
+++ b/src/node_modules/es-abstract/2020/UTF16DecodeSurrogatePair.js
@@ -0,0 +1,19 @@
+'use strict';
+
+var GetIntrinsic = require('../GetIntrinsic');
+
+var $TypeError = GetIntrinsic('%TypeError%');
+var $fromCharCode = GetIntrinsic('%String.fromCharCode%');
+
+var isLeadingSurrogate = require('../helpers/isLeadingSurrogate');
+var isTrailingSurrogate = require('../helpers/isTrailingSurrogate');
+
+// https://tc39.es/ecma262/2020/#sec-utf16decodesurrogatepair
+
+module.exports = function UTF16DecodeSurrogatePair(lead, trail) {
+ if (!isLeadingSurrogate(lead) || !isTrailingSurrogate(trail)) {
+ throw new $TypeError('Assertion failed: `lead` must be a leading surrogate char code, and `trail` must be a trailing surrogate char code');
+ }
+ // var cp = (lead - 0xD800) * 0x400 + (trail - 0xDC00) + 0x10000;
+ return $fromCharCode(lead) + $fromCharCode(trail);
+};