summaryrefslogtreecommitdiffstats
path: root/node_modules/@webassemblyjs/utf8/lib/encoder.js
diff options
context:
space:
mode:
authorGravatar Piotr Russ <mail@pruss.it> 2020-11-16 00:10:28 +0100
committerGravatar Piotr Russ <mail@pruss.it> 2020-11-16 00:10:28 +0100
commite06ec920f7a5d784e674c4c4b4e6d1da3dc7391d (patch)
tree55713f725f77b44ebfec86e4eec3ce33e71458ca /node_modules/@webassemblyjs/utf8/lib/encoder.js
downloadwebsite_creator-e06ec920f7a5d784e674c4c4b4e6d1da3dc7391d.tar.gz
website_creator-e06ec920f7a5d784e674c4c4b4e6d1da3dc7391d.tar.bz2
website_creator-e06ec920f7a5d784e674c4c4b4e6d1da3dc7391d.zip
api, login, auth
Diffstat (limited to 'node_modules/@webassemblyjs/utf8/lib/encoder.js')
-rw-r--r--node_modules/@webassemblyjs/utf8/lib/encoder.js53
1 files changed, 53 insertions, 0 deletions
diff --git a/node_modules/@webassemblyjs/utf8/lib/encoder.js b/node_modules/@webassemblyjs/utf8/lib/encoder.js
new file mode 100644
index 0000000..0606b56
--- /dev/null
+++ b/node_modules/@webassemblyjs/utf8/lib/encoder.js
@@ -0,0 +1,53 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.encode = encode;
+
+function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = new Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }
+
+function _toArray(arr) { return Array.isArray(arr) ? arr : Array.from(arr); }
+
+function con(n) {
+ return 0x80 | n & 0x3f;
+}
+
+function encode(str) {
+ var arr = str.split("").map(function (x) {
+ return x.charCodeAt(0);
+ });
+ return _encode(arr);
+}
+
+function _encode(arr) {
+ if (arr.length === 0) {
+ return [];
+ }
+
+ var _arr = _toArray(arr),
+ n = _arr[0],
+ ns = _arr.slice(1);
+
+ if (n < 0) {
+ throw new Error("utf8");
+ }
+
+ if (n < 0x80) {
+ return [n].concat(_toConsumableArray(_encode(ns)));
+ }
+
+ if (n < 0x800) {
+ return [0xc0 | n >>> 6, con(n)].concat(_toConsumableArray(_encode(ns)));
+ }
+
+ if (n < 0x10000) {
+ return [0xe0 | n >>> 12, con(n >>> 6), con(n)].concat(_toConsumableArray(_encode(ns)));
+ }
+
+ if (n < 0x110000) {
+ return [0xf0 | n >>> 18, con(n >>> 12), con(n >>> 6), con(n)].concat(_toConsumableArray(_encode(ns)));
+ }
+
+ throw new Error("utf8");
+} \ No newline at end of file