@dodona/papyros 0.1.8-rc → 0.1.12-rc

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,556 @@
1
+ "use strict";
2
+ exports.id = 114;
3
+ exports.ids = [114];
4
+ exports.modules = {
5
+
6
+ /***/ 872:
7
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
8
+
9
+
10
+ // EXPORTS
11
+ __webpack_require__.d(__webpack_exports__, {
12
+ "z": () => (/* binding */ Backend)
13
+ });
14
+
15
+ ;// CONCATENATED MODULE: ./src/ProgrammingLanguage.ts
16
+ var ProgrammingLanguage;
17
+ (function (ProgrammingLanguage) {
18
+ ProgrammingLanguage["Python"] = "Python";
19
+ ProgrammingLanguage["JavaScript"] = "JavaScript";
20
+ })(ProgrammingLanguage || (ProgrammingLanguage = {}));
21
+ var PROGRAMMING_LANGUAGES = [
22
+ ProgrammingLanguage.Python,
23
+ ProgrammingLanguage.JavaScript
24
+ ];
25
+ var LANGUAGE_MAP = new Map([
26
+ ["python", ProgrammingLanguage.Python],
27
+ ["javascript", ProgrammingLanguage.JavaScript]
28
+ ]);
29
+ function plFromString(language) {
30
+ var langLC = language.toLowerCase();
31
+ if (LANGUAGE_MAP.has(langLC)) {
32
+ return LANGUAGE_MAP.get(langLC);
33
+ }
34
+ else {
35
+ throw new Error("Unsupported language: " + language);
36
+ }
37
+ }
38
+
39
+ ;// CONCATENATED MODULE: ./src/Constants.ts
40
+
41
+ var MAIN_APP_ID = "papyros";
42
+ var OUTPUT_TA_ID = "code-output-area";
43
+ var INPUT_TA_ID = "code-input-area";
44
+ var EDITOR_WRAPPER_ID = "code-area";
45
+ var STATE_SPINNER_ID = "state-spinner";
46
+ var APPLICATION_STATE_TEXT_ID = "application-state-text";
47
+ var RUN_BTN_ID = "run-code-btn";
48
+ var TERMINATE_BTN_ID = "terminate-btn";
49
+ var PROGRAMMING_LANGUAGE_SELECT_ID = "programming-language-select";
50
+ var DEFAULT_PROGRAMMING_LANGUAGE = ProgrammingLanguage.Python;
51
+ var LOCALE_SELECT_ID = "locale-select";
52
+ var DEFAULT_LOCALE = "nl";
53
+ var INPUT_RELATIVE_URL = "/__papyros_input";
54
+ var SERVICE_WORKER_PATH = "./inputServiceWorker.js";
55
+
56
+ ;// CONCATENATED MODULE: ./src/util/Logging.ts
57
+ var __read = (undefined && undefined.__read) || function (o, n) {
58
+ var m = typeof Symbol === "function" && o[Symbol.iterator];
59
+ if (!m) return o;
60
+ var i = m.call(o), r, ar = [], e;
61
+ try {
62
+ while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
63
+ }
64
+ catch (error) { e = { error: error }; }
65
+ finally {
66
+ try {
67
+ if (r && !r.done && (m = i["return"])) m.call(i);
68
+ }
69
+ finally { if (e) throw e.error; }
70
+ }
71
+ return ar;
72
+ };
73
+ var __spreadArray = (undefined && undefined.__spreadArray) || function (to, from, pack) {
74
+ if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
75
+ if (ar || !(i in from)) {
76
+ if (!ar) ar = Array.prototype.slice.call(from, 0, i);
77
+ ar[i] = from[i];
78
+ }
79
+ }
80
+ return to.concat(ar || Array.prototype.slice.call(from));
81
+ };
82
+ var LogType;
83
+ (function (LogType) {
84
+ LogType[LogType["Debug"] = 0] = "Debug";
85
+ LogType[LogType["Error"] = 1] = "Error";
86
+ LogType[LogType["Important"] = 2] = "Important";
87
+ })(LogType || (LogType = {}));
88
+ var ENVIRONMENT = "production" || 0;
89
+ function papyrosLog(logType) {
90
+ var args = [];
91
+ for (var _i = 1; _i < arguments.length; _i++) {
92
+ args[_i - 1] = arguments[_i];
93
+ }
94
+ var doLog = ENVIRONMENT !== "production" || logType !== LogType.Debug;
95
+ if (doLog) {
96
+ if (logType === LogType.Error) {
97
+ console.error.apply(console, __spreadArray([], __read(args), false));
98
+ }
99
+ else {
100
+ console.log.apply(console, __spreadArray([], __read(args), false));
101
+ }
102
+ }
103
+ }
104
+
105
+ ;// CONCATENATED MODULE: ./src/Backend.ts
106
+ var __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {
107
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
108
+ return new (P || (P = Promise))(function (resolve, reject) {
109
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
110
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
111
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
112
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
113
+ });
114
+ };
115
+ var __generator = (undefined && undefined.__generator) || function (thisArg, body) {
116
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
117
+ return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
118
+ function verb(n) { return function (v) { return step([n, v]); }; }
119
+ function step(op) {
120
+ if (f) throw new TypeError("Generator is already executing.");
121
+ while (_) try {
122
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
123
+ if (y = 0, t) op = [op[0] & 2, t.value];
124
+ switch (op[0]) {
125
+ case 0: case 1: t = op; break;
126
+ case 4: _.label++; return { value: op[1], done: false };
127
+ case 5: _.label++; y = op[1]; op = [0]; continue;
128
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
129
+ default:
130
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
131
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
132
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
133
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
134
+ if (t[2]) _.ops.pop();
135
+ _.trys.pop(); continue;
136
+ }
137
+ op = body.call(thisArg, _);
138
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
139
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
140
+ }
141
+ };
142
+
143
+
144
+ function getInputCallback(inputTextArray, inputMetaData) {
145
+ if (inputTextArray && inputMetaData) {
146
+ var textDecoder_1 = new TextDecoder();
147
+ return function () {
148
+ // eslint-disable-next-line no-constant-condition
149
+ while (true) {
150
+ if (Atomics.wait(inputMetaData, 0, 0, 100) === "timed-out") {
151
+ // papyrosLog.log("waiting on input");
152
+ // if (interruptBuffer[0] === 2) {
153
+ // return null;
154
+ // }
155
+ }
156
+ else {
157
+ break;
158
+ }
159
+ }
160
+ Atomics.store(inputMetaData, 0, 0);
161
+ var size = Atomics.exchange(inputMetaData, 1, 0);
162
+ var bytes = inputTextArray.slice(0, size);
163
+ return textDecoder_1.decode(bytes);
164
+ };
165
+ }
166
+ else {
167
+ return function () {
168
+ var request = new XMLHttpRequest();
169
+ do {
170
+ // `false` makes the request synchronous
171
+ request.open("GET", INPUT_RELATIVE_URL, false);
172
+ request.send(null);
173
+ } while (request.status >= 400); // todo better error handling
174
+ return request.responseText;
175
+ };
176
+ }
177
+ }
178
+ var Backend = /** @class */ (function () {
179
+ function Backend() {
180
+ // eslint-disable-next-line @typescript-eslint/no-empty-function
181
+ this.onEvent = function () { };
182
+ this.runId = 0;
183
+ }
184
+ /**
185
+ * Initialize the backend, setting up any globals required
186
+ * @param {function(PapyrosEvent):void} onEvent Callback for when events occur
187
+ * @param {Uint8Array} inputTextArray Optional shared buffer for input
188
+ * @param {Int32Array} inputMetaData Optional shared buffer for metadata about input
189
+ * @return {Promise<void>} Promise of launching
190
+ */
191
+ Backend.prototype.launch = function (onEvent, inputTextArray, inputMetaData) {
192
+ var _this = this;
193
+ var inputCallback = getInputCallback(inputTextArray, inputMetaData);
194
+ this.onEvent = function (e) {
195
+ e.runId = _this.runId;
196
+ onEvent(e);
197
+ if (e.type === "input") {
198
+ return inputCallback();
199
+ }
200
+ };
201
+ return Promise.resolve();
202
+ };
203
+ /**
204
+ * Validate and run arbitrary code
205
+ * @param {string} code The code to run
206
+ * @param {string} runId The uuid for this execution
207
+ * @return {Promise<void>} Promise of execution
208
+ */
209
+ Backend.prototype.runCode = function (code, runId) {
210
+ return __awaiter(this, void 0, void 0, function () {
211
+ var data, error_1, errorString;
212
+ return __generator(this, function (_a) {
213
+ switch (_a.label) {
214
+ case 0:
215
+ this.runId = runId;
216
+ papyrosLog(LogType.Debug, "Running code in worker: ", code);
217
+ _a.label = 1;
218
+ case 1:
219
+ _a.trys.push([1, 3, , 4]);
220
+ return [4 /*yield*/, this._runCodeInternal(code)];
221
+ case 2:
222
+ data = _a.sent();
223
+ papyrosLog(LogType.Important, "ran code: " + code + " and received: ", data);
224
+ return [2 /*return*/, this.onEvent({ type: "success", data: data, runId: runId })];
225
+ case 3:
226
+ error_1 = _a.sent();
227
+ errorString = "toString" in error_1 ? error_1.toString() : JSON.stringify(error_1);
228
+ papyrosLog(LogType.Error, "Error during execution: ", error_1, errorString);
229
+ return [2 /*return*/, this.onEvent({ type: "error", data: errorString, runId: runId })];
230
+ case 4: return [2 /*return*/];
231
+ }
232
+ });
233
+ });
234
+ };
235
+ return Backend;
236
+ }());
237
+
238
+
239
+
240
+ /***/ }),
241
+
242
+ /***/ 375:
243
+ /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
244
+
245
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
246
+ /* harmony export */ "Jj": () => (/* binding */ expose)
247
+ /* harmony export */ });
248
+ /* unused harmony exports createEndpoint, proxy, proxyMarker, releaseProxy, transfer, transferHandlers, windowEndpoint, wrap */
249
+ /**
250
+ * Copyright 2019 Google Inc. All Rights Reserved.
251
+ * Licensed under the Apache License, Version 2.0 (the "License");
252
+ * you may not use this file except in compliance with the License.
253
+ * You may obtain a copy of the License at
254
+ * http://www.apache.org/licenses/LICENSE-2.0
255
+ * Unless required by applicable law or agreed to in writing, software
256
+ * distributed under the License is distributed on an "AS IS" BASIS,
257
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
258
+ * See the License for the specific language governing permissions and
259
+ * limitations under the License.
260
+ */
261
+ const proxyMarker = Symbol("Comlink.proxy");
262
+ const createEndpoint = Symbol("Comlink.endpoint");
263
+ const releaseProxy = Symbol("Comlink.releaseProxy");
264
+ const throwMarker = Symbol("Comlink.thrown");
265
+ const isObject = (val) => (typeof val === "object" && val !== null) || typeof val === "function";
266
+ /**
267
+ * Internal transfer handle to handle objects marked to proxy.
268
+ */
269
+ const proxyTransferHandler = {
270
+ canHandle: (val) => isObject(val) && val[proxyMarker],
271
+ serialize(obj) {
272
+ const { port1, port2 } = new MessageChannel();
273
+ expose(obj, port1);
274
+ return [port2, [port2]];
275
+ },
276
+ deserialize(port) {
277
+ port.start();
278
+ return wrap(port);
279
+ },
280
+ };
281
+ /**
282
+ * Internal transfer handler to handle thrown exceptions.
283
+ */
284
+ const throwTransferHandler = {
285
+ canHandle: (value) => isObject(value) && throwMarker in value,
286
+ serialize({ value }) {
287
+ let serialized;
288
+ if (value instanceof Error) {
289
+ serialized = {
290
+ isError: true,
291
+ value: {
292
+ message: value.message,
293
+ name: value.name,
294
+ stack: value.stack,
295
+ },
296
+ };
297
+ }
298
+ else {
299
+ serialized = { isError: false, value };
300
+ }
301
+ return [serialized, []];
302
+ },
303
+ deserialize(serialized) {
304
+ if (serialized.isError) {
305
+ throw Object.assign(new Error(serialized.value.message), serialized.value);
306
+ }
307
+ throw serialized.value;
308
+ },
309
+ };
310
+ /**
311
+ * Allows customizing the serialization of certain values.
312
+ */
313
+ const transferHandlers = new Map([
314
+ ["proxy", proxyTransferHandler],
315
+ ["throw", throwTransferHandler],
316
+ ]);
317
+ function expose(obj, ep = self) {
318
+ ep.addEventListener("message", function callback(ev) {
319
+ if (!ev || !ev.data) {
320
+ return;
321
+ }
322
+ const { id, type, path } = Object.assign({ path: [] }, ev.data);
323
+ const argumentList = (ev.data.argumentList || []).map(fromWireValue);
324
+ let returnValue;
325
+ try {
326
+ const parent = path.slice(0, -1).reduce((obj, prop) => obj[prop], obj);
327
+ const rawValue = path.reduce((obj, prop) => obj[prop], obj);
328
+ switch (type) {
329
+ case "GET" /* GET */:
330
+ {
331
+ returnValue = rawValue;
332
+ }
333
+ break;
334
+ case "SET" /* SET */:
335
+ {
336
+ parent[path.slice(-1)[0]] = fromWireValue(ev.data.value);
337
+ returnValue = true;
338
+ }
339
+ break;
340
+ case "APPLY" /* APPLY */:
341
+ {
342
+ returnValue = rawValue.apply(parent, argumentList);
343
+ }
344
+ break;
345
+ case "CONSTRUCT" /* CONSTRUCT */:
346
+ {
347
+ const value = new rawValue(...argumentList);
348
+ returnValue = proxy(value);
349
+ }
350
+ break;
351
+ case "ENDPOINT" /* ENDPOINT */:
352
+ {
353
+ const { port1, port2 } = new MessageChannel();
354
+ expose(obj, port2);
355
+ returnValue = transfer(port1, [port1]);
356
+ }
357
+ break;
358
+ case "RELEASE" /* RELEASE */:
359
+ {
360
+ returnValue = undefined;
361
+ }
362
+ break;
363
+ default:
364
+ return;
365
+ }
366
+ }
367
+ catch (value) {
368
+ returnValue = { value, [throwMarker]: 0 };
369
+ }
370
+ Promise.resolve(returnValue)
371
+ .catch((value) => {
372
+ return { value, [throwMarker]: 0 };
373
+ })
374
+ .then((returnValue) => {
375
+ const [wireValue, transferables] = toWireValue(returnValue);
376
+ ep.postMessage(Object.assign(Object.assign({}, wireValue), { id }), transferables);
377
+ if (type === "RELEASE" /* RELEASE */) {
378
+ // detach and deactive after sending release response above.
379
+ ep.removeEventListener("message", callback);
380
+ closeEndPoint(ep);
381
+ }
382
+ });
383
+ });
384
+ if (ep.start) {
385
+ ep.start();
386
+ }
387
+ }
388
+ function isMessagePort(endpoint) {
389
+ return endpoint.constructor.name === "MessagePort";
390
+ }
391
+ function closeEndPoint(endpoint) {
392
+ if (isMessagePort(endpoint))
393
+ endpoint.close();
394
+ }
395
+ function wrap(ep, target) {
396
+ return createProxy(ep, [], target);
397
+ }
398
+ function throwIfProxyReleased(isReleased) {
399
+ if (isReleased) {
400
+ throw new Error("Proxy has been released and is not useable");
401
+ }
402
+ }
403
+ function createProxy(ep, path = [], target = function () { }) {
404
+ let isProxyReleased = false;
405
+ const proxy = new Proxy(target, {
406
+ get(_target, prop) {
407
+ throwIfProxyReleased(isProxyReleased);
408
+ if (prop === releaseProxy) {
409
+ return () => {
410
+ return requestResponseMessage(ep, {
411
+ type: "RELEASE" /* RELEASE */,
412
+ path: path.map((p) => p.toString()),
413
+ }).then(() => {
414
+ closeEndPoint(ep);
415
+ isProxyReleased = true;
416
+ });
417
+ };
418
+ }
419
+ if (prop === "then") {
420
+ if (path.length === 0) {
421
+ return { then: () => proxy };
422
+ }
423
+ const r = requestResponseMessage(ep, {
424
+ type: "GET" /* GET */,
425
+ path: path.map((p) => p.toString()),
426
+ }).then(fromWireValue);
427
+ return r.then.bind(r);
428
+ }
429
+ return createProxy(ep, [...path, prop]);
430
+ },
431
+ set(_target, prop, rawValue) {
432
+ throwIfProxyReleased(isProxyReleased);
433
+ // FIXME: ES6 Proxy Handler `set` methods are supposed to return a
434
+ // boolean. To show good will, we return true asynchronously ¯\_(ツ)_/¯
435
+ const [value, transferables] = toWireValue(rawValue);
436
+ return requestResponseMessage(ep, {
437
+ type: "SET" /* SET */,
438
+ path: [...path, prop].map((p) => p.toString()),
439
+ value,
440
+ }, transferables).then(fromWireValue);
441
+ },
442
+ apply(_target, _thisArg, rawArgumentList) {
443
+ throwIfProxyReleased(isProxyReleased);
444
+ const last = path[path.length - 1];
445
+ if (last === createEndpoint) {
446
+ return requestResponseMessage(ep, {
447
+ type: "ENDPOINT" /* ENDPOINT */,
448
+ }).then(fromWireValue);
449
+ }
450
+ // We just pretend that `bind()` didn’t happen.
451
+ if (last === "bind") {
452
+ return createProxy(ep, path.slice(0, -1));
453
+ }
454
+ const [argumentList, transferables] = processArguments(rawArgumentList);
455
+ return requestResponseMessage(ep, {
456
+ type: "APPLY" /* APPLY */,
457
+ path: path.map((p) => p.toString()),
458
+ argumentList,
459
+ }, transferables).then(fromWireValue);
460
+ },
461
+ construct(_target, rawArgumentList) {
462
+ throwIfProxyReleased(isProxyReleased);
463
+ const [argumentList, transferables] = processArguments(rawArgumentList);
464
+ return requestResponseMessage(ep, {
465
+ type: "CONSTRUCT" /* CONSTRUCT */,
466
+ path: path.map((p) => p.toString()),
467
+ argumentList,
468
+ }, transferables).then(fromWireValue);
469
+ },
470
+ });
471
+ return proxy;
472
+ }
473
+ function myFlat(arr) {
474
+ return Array.prototype.concat.apply([], arr);
475
+ }
476
+ function processArguments(argumentList) {
477
+ const processed = argumentList.map(toWireValue);
478
+ return [processed.map((v) => v[0]), myFlat(processed.map((v) => v[1]))];
479
+ }
480
+ const transferCache = new WeakMap();
481
+ function transfer(obj, transfers) {
482
+ transferCache.set(obj, transfers);
483
+ return obj;
484
+ }
485
+ function proxy(obj) {
486
+ return Object.assign(obj, { [proxyMarker]: true });
487
+ }
488
+ function windowEndpoint(w, context = self, targetOrigin = "*") {
489
+ return {
490
+ postMessage: (msg, transferables) => w.postMessage(msg, targetOrigin, transferables),
491
+ addEventListener: context.addEventListener.bind(context),
492
+ removeEventListener: context.removeEventListener.bind(context),
493
+ };
494
+ }
495
+ function toWireValue(value) {
496
+ for (const [name, handler] of transferHandlers) {
497
+ if (handler.canHandle(value)) {
498
+ const [serializedValue, transferables] = handler.serialize(value);
499
+ return [
500
+ {
501
+ type: "HANDLER" /* HANDLER */,
502
+ name,
503
+ value: serializedValue,
504
+ },
505
+ transferables,
506
+ ];
507
+ }
508
+ }
509
+ return [
510
+ {
511
+ type: "RAW" /* RAW */,
512
+ value,
513
+ },
514
+ transferCache.get(value) || [],
515
+ ];
516
+ }
517
+ function fromWireValue(value) {
518
+ switch (value.type) {
519
+ case "HANDLER" /* HANDLER */:
520
+ return transferHandlers.get(value.name).deserialize(value.value);
521
+ case "RAW" /* RAW */:
522
+ return value.value;
523
+ }
524
+ }
525
+ function requestResponseMessage(ep, msg, transfers) {
526
+ return new Promise((resolve) => {
527
+ const id = generateUUID();
528
+ ep.addEventListener("message", function l(ev) {
529
+ if (!ev.data || !ev.data.id || ev.data.id !== id) {
530
+ return;
531
+ }
532
+ ep.removeEventListener("message", l);
533
+ resolve(ev.data);
534
+ });
535
+ if (ep.start) {
536
+ ep.start();
537
+ }
538
+ ep.postMessage(Object.assign({ id }, msg), transfers);
539
+ });
540
+ }
541
+ function generateUUID() {
542
+ return new Array(4)
543
+ .fill(0)
544
+ .map(() => Math.floor(Math.random() * Number.MAX_SAFE_INTEGER).toString(16))
545
+ .join("-");
546
+ }
547
+
548
+
549
+ //# sourceMappingURL=comlink.mjs.map
550
+
551
+
552
+ /***/ })
553
+
554
+ };
555
+ ;
556
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"114.index.js","mappings":"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AAO,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,WAAW,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,EAAC;;;;;KAE/E;IACL,cAAC;AAAD,CAAC;;;;;;;;;;;;;ACxFD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB,eAAe;AAC/B;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB,OAAO;AACvB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA,2BAA2B;AAC3B;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB,iBAAiB,kBAAkB,UAAU;AAC7D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gCAAgC,eAAe;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4BAA4B;AAC5B;AACA;AACA;AACA,qBAAqB;AACrB,SAAS;AACT;AACA;AACA,yDAAyD,gBAAgB,IAAI;AAC7E;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4DAA4D;AAC5D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA;AACA,6BAA6B;AAC7B;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gCAAgC,qBAAqB;AACrD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,uCAAuC,IAAI;AAC3C,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;;AAEsH;AACtH","sources":["webpack://Papyros/./src/ProgrammingLanguage.ts","webpack://Papyros/./src/Constants.ts","webpack://Papyros/./src/util/Logging.ts","webpack://Papyros/./src/Backend.ts","webpack://Papyros/./node_modules/comlink/dist/esm/comlink.mjs"],"sourcesContent":["export enum ProgrammingLanguage {\n    Python = \"Python\",\n    JavaScript = \"JavaScript\"\n}\n\nexport const PROGRAMMING_LANGUAGES = [\n    ProgrammingLanguage.Python,\n    ProgrammingLanguage.JavaScript\n];\n\nconst LANGUAGE_MAP = new Map([\n    [\"python\", ProgrammingLanguage.Python],\n    [\"javascript\", ProgrammingLanguage.JavaScript]\n]);\n\nexport function plFromString(language: string): ProgrammingLanguage {\n    const langLC = language.toLowerCase();\n    if (LANGUAGE_MAP.has(langLC)) {\n        return LANGUAGE_MAP.get(langLC)!;\n    } else {\n        throw new Error(`Unsupported language: ${language}`);\n    }\n}\n","import { ProgrammingLanguage } from \"./ProgrammingLanguage\";\n\nexport const MAIN_APP_ID = \"papyros\";\n\nexport const OUTPUT_TA_ID = \"code-output-area\";\nexport const INPUT_TA_ID = \"code-input-area\";\nexport const EDITOR_WRAPPER_ID = \"code-area\";\n\nexport const STATE_SPINNER_ID = \"state-spinner\";\nexport const APPLICATION_STATE_TEXT_ID = \"application-state-text\";\n\nexport const RUN_BTN_ID = \"run-code-btn\";\nexport const TERMINATE_BTN_ID = \"terminate-btn\";\n\nexport const PROGRAMMING_LANGUAGE_SELECT_ID = \"programming-language-select\";\nexport const DEFAULT_PROGRAMMING_LANGUAGE = ProgrammingLanguage.Python;\n\nexport const LOCALE_SELECT_ID = \"locale-select\";\nexport const DEFAULT_LOCALE = \"nl\";\n\nexport const INPUT_RELATIVE_URL = \"/__papyros_input\";\nexport const SERVICE_WORKER_PATH = \"./inputServiceWorker.js\";\n","export enum LogType {\n    Debug, Error, Important\n}\n\nconst ENVIRONMENT: string = process.env.NODE_ENV || \"development\";\nexport function papyrosLog(logType: LogType, ...args: any[]): void {\n    const doLog = ENVIRONMENT !== \"production\" || logType !== LogType.Debug;\n    if (doLog) {\n        if (logType === LogType.Error) {\n            console.error(...args);\n        } else {\n            console.log(...args);\n        }\n    }\n}\n","import { INPUT_RELATIVE_URL } from \"./Constants\";\nimport { PapyrosEvent } from \"./PapyrosEvent\";\nimport { LogType, papyrosLog } from \"./util/Logging\";\n\nfunction getInputCallback(inputTextArray?: Uint8Array, inputMetaData?: Int32Array): () => string {\n    if (inputTextArray && inputMetaData) {\n        const textDecoder = new TextDecoder();\n        return () => {\n            // eslint-disable-next-line no-constant-condition\n            while (true) {\n                if (Atomics.wait(inputMetaData, 0, 0, 100) === \"timed-out\") {\n                    // papyrosLog.log(\"waiting on input\");\n                    // if (interruptBuffer[0] === 2) {\n                    //  return null;\n                    // }\n                } else {\n                    break;\n                }\n            }\n            Atomics.store(inputMetaData, 0, 0);\n            const size = Atomics.exchange(inputMetaData, 1, 0);\n            const bytes = inputTextArray.slice(0, size);\n            return textDecoder.decode(bytes);\n        };\n    } else {\n        return () => {\n            const request = new XMLHttpRequest();\n            do {\n                // `false` makes the request synchronous\n                request.open(\"GET\", INPUT_RELATIVE_URL, false);\n                request.send(null);\n            } while (request.status >= 400); // todo better error handling\n            return request.responseText;\n        };\n    }\n}\n\nexport abstract class Backend {\n    onEvent: (e: PapyrosEvent) => any;\n    runId: number;\n\n    constructor() {\n        // eslint-disable-next-line @typescript-eslint/no-empty-function\n        this.onEvent = () => { };\n        this.runId = 0;\n    }\n\n    /**\n     * Initialize the backend, setting up any globals required\n     * @param {function(PapyrosEvent):void} onEvent Callback for when events occur\n     * @param {Uint8Array} inputTextArray Optional shared buffer for input\n     * @param {Int32Array} inputMetaData Optional shared buffer for metadata about input\n     * @return {Promise<void>} Promise of launching\n     */\n    launch(onEvent: (e: PapyrosEvent) => void,\n        inputTextArray?: Uint8Array, inputMetaData?: Int32Array): Promise<void> {\n        const inputCallback = getInputCallback(inputTextArray, inputMetaData);\n        this.onEvent = (e: PapyrosEvent) => {\n            e.runId = this.runId;\n            onEvent(e);\n            if (e.type === \"input\") {\n                return inputCallback();\n            }\n        };\n        return Promise.resolve();\n    }\n\n    abstract _runCodeInternal(code: string): Promise<any>;\n\n    /**\n     * Validate and run arbitrary code\n     * @param {string} code The code to run\n     * @param {string} runId The uuid for this execution\n     * @return {Promise<void>} Promise of execution\n     */\n    async runCode(code: string, runId: number): Promise<void> {\n        this.runId = runId;\n        papyrosLog(LogType.Debug, \"Running code in worker: \", code);\n        try {\n            const data = await this._runCodeInternal(code);\n            papyrosLog(LogType.Important, \"ran code: \" + code + \" and received: \", data);\n            return this.onEvent({ type: \"success\", data: data, runId: runId });\n        } catch (error: any) {\n            const errorString = \"toString\" in error ? error.toString() : JSON.stringify(error);\n            papyrosLog(LogType.Error, \"Error during execution: \", error, errorString);\n            return this.onEvent({ type: \"error\", data: errorString, runId: runId });\n        }\n    }\n}\n","/**\r\n * Copyright 2019 Google Inc. All Rights Reserved.\r\n * Licensed under the Apache License, Version 2.0 (the \"License\");\r\n * you may not use this file except in compliance with the License.\r\n * You may obtain a copy of the License at\r\n *     http://www.apache.org/licenses/LICENSE-2.0\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\nconst proxyMarker = Symbol(\"Comlink.proxy\");\r\nconst createEndpoint = Symbol(\"Comlink.endpoint\");\r\nconst releaseProxy = Symbol(\"Comlink.releaseProxy\");\r\nconst throwMarker = Symbol(\"Comlink.thrown\");\r\nconst isObject = (val) => (typeof val === \"object\" && val !== null) || typeof val === \"function\";\r\n/**\r\n * Internal transfer handle to handle objects marked to proxy.\r\n */\r\nconst proxyTransferHandler = {\r\n    canHandle: (val) => isObject(val) && val[proxyMarker],\r\n    serialize(obj) {\r\n        const { port1, port2 } = new MessageChannel();\r\n        expose(obj, port1);\r\n        return [port2, [port2]];\r\n    },\r\n    deserialize(port) {\r\n        port.start();\r\n        return wrap(port);\r\n    },\r\n};\r\n/**\r\n * Internal transfer handler to handle thrown exceptions.\r\n */\r\nconst throwTransferHandler = {\r\n    canHandle: (value) => isObject(value) && throwMarker in value,\r\n    serialize({ value }) {\r\n        let serialized;\r\n        if (value instanceof Error) {\r\n            serialized = {\r\n                isError: true,\r\n                value: {\r\n                    message: value.message,\r\n                    name: value.name,\r\n                    stack: value.stack,\r\n                },\r\n            };\r\n        }\r\n        else {\r\n            serialized = { isError: false, value };\r\n        }\r\n        return [serialized, []];\r\n    },\r\n    deserialize(serialized) {\r\n        if (serialized.isError) {\r\n            throw Object.assign(new Error(serialized.value.message), serialized.value);\r\n        }\r\n        throw serialized.value;\r\n    },\r\n};\r\n/**\r\n * Allows customizing the serialization of certain values.\r\n */\r\nconst transferHandlers = new Map([\r\n    [\"proxy\", proxyTransferHandler],\r\n    [\"throw\", throwTransferHandler],\r\n]);\r\nfunction expose(obj, ep = self) {\r\n    ep.addEventListener(\"message\", function callback(ev) {\r\n        if (!ev || !ev.data) {\r\n            return;\r\n        }\r\n        const { id, type, path } = Object.assign({ path: [] }, ev.data);\r\n        const argumentList = (ev.data.argumentList || []).map(fromWireValue);\r\n        let returnValue;\r\n        try {\r\n            const parent = path.slice(0, -1).reduce((obj, prop) => obj[prop], obj);\r\n            const rawValue = path.reduce((obj, prop) => obj[prop], obj);\r\n            switch (type) {\r\n                case \"GET\" /* GET */:\r\n                    {\r\n                        returnValue = rawValue;\r\n                    }\r\n                    break;\r\n                case \"SET\" /* SET */:\r\n                    {\r\n                        parent[path.slice(-1)[0]] = fromWireValue(ev.data.value);\r\n                        returnValue = true;\r\n                    }\r\n                    break;\r\n                case \"APPLY\" /* APPLY */:\r\n                    {\r\n                        returnValue = rawValue.apply(parent, argumentList);\r\n                    }\r\n                    break;\r\n                case \"CONSTRUCT\" /* CONSTRUCT */:\r\n                    {\r\n                        const value = new rawValue(...argumentList);\r\n                        returnValue = proxy(value);\r\n                    }\r\n                    break;\r\n                case \"ENDPOINT\" /* ENDPOINT */:\r\n                    {\r\n                        const { port1, port2 } = new MessageChannel();\r\n                        expose(obj, port2);\r\n                        returnValue = transfer(port1, [port1]);\r\n                    }\r\n                    break;\r\n                case \"RELEASE\" /* RELEASE */:\r\n                    {\r\n                        returnValue = undefined;\r\n                    }\r\n                    break;\r\n                default:\r\n                    return;\r\n            }\r\n        }\r\n        catch (value) {\r\n            returnValue = { value, [throwMarker]: 0 };\r\n        }\r\n        Promise.resolve(returnValue)\r\n            .catch((value) => {\r\n            return { value, [throwMarker]: 0 };\r\n        })\r\n            .then((returnValue) => {\r\n            const [wireValue, transferables] = toWireValue(returnValue);\r\n            ep.postMessage(Object.assign(Object.assign({}, wireValue), { id }), transferables);\r\n            if (type === \"RELEASE\" /* RELEASE */) {\r\n                // detach and deactive after sending release response above.\r\n                ep.removeEventListener(\"message\", callback);\r\n                closeEndPoint(ep);\r\n            }\r\n        });\r\n    });\r\n    if (ep.start) {\r\n        ep.start();\r\n    }\r\n}\r\nfunction isMessagePort(endpoint) {\r\n    return endpoint.constructor.name === \"MessagePort\";\r\n}\r\nfunction closeEndPoint(endpoint) {\r\n    if (isMessagePort(endpoint))\r\n        endpoint.close();\r\n}\r\nfunction wrap(ep, target) {\r\n    return createProxy(ep, [], target);\r\n}\r\nfunction throwIfProxyReleased(isReleased) {\r\n    if (isReleased) {\r\n        throw new Error(\"Proxy has been released and is not useable\");\r\n    }\r\n}\r\nfunction createProxy(ep, path = [], target = function () { }) {\r\n    let isProxyReleased = false;\r\n    const proxy = new Proxy(target, {\r\n        get(_target, prop) {\r\n            throwIfProxyReleased(isProxyReleased);\r\n            if (prop === releaseProxy) {\r\n                return () => {\r\n                    return requestResponseMessage(ep, {\r\n                        type: \"RELEASE\" /* RELEASE */,\r\n                        path: path.map((p) => p.toString()),\r\n                    }).then(() => {\r\n                        closeEndPoint(ep);\r\n                        isProxyReleased = true;\r\n                    });\r\n                };\r\n            }\r\n            if (prop === \"then\") {\r\n                if (path.length === 0) {\r\n                    return { then: () => proxy };\r\n                }\r\n                const r = requestResponseMessage(ep, {\r\n                    type: \"GET\" /* GET */,\r\n                    path: path.map((p) => p.toString()),\r\n                }).then(fromWireValue);\r\n                return r.then.bind(r);\r\n            }\r\n            return createProxy(ep, [...path, prop]);\r\n        },\r\n        set(_target, prop, rawValue) {\r\n            throwIfProxyReleased(isProxyReleased);\r\n            // FIXME: ES6 Proxy Handler `set` methods are supposed to return a\r\n            // boolean. To show good will, we return true asynchronously ¯\\_(ツ)_/¯\r\n            const [value, transferables] = toWireValue(rawValue);\r\n            return requestResponseMessage(ep, {\r\n                type: \"SET\" /* SET */,\r\n                path: [...path, prop].map((p) => p.toString()),\r\n                value,\r\n            }, transferables).then(fromWireValue);\r\n        },\r\n        apply(_target, _thisArg, rawArgumentList) {\r\n            throwIfProxyReleased(isProxyReleased);\r\n            const last = path[path.length - 1];\r\n            if (last === createEndpoint) {\r\n                return requestResponseMessage(ep, {\r\n                    type: \"ENDPOINT\" /* ENDPOINT */,\r\n                }).then(fromWireValue);\r\n            }\r\n            // We just pretend that `bind()` didn’t happen.\r\n            if (last === \"bind\") {\r\n                return createProxy(ep, path.slice(0, -1));\r\n            }\r\n            const [argumentList, transferables] = processArguments(rawArgumentList);\r\n            return requestResponseMessage(ep, {\r\n                type: \"APPLY\" /* APPLY */,\r\n                path: path.map((p) => p.toString()),\r\n                argumentList,\r\n            }, transferables).then(fromWireValue);\r\n        },\r\n        construct(_target, rawArgumentList) {\r\n            throwIfProxyReleased(isProxyReleased);\r\n            const [argumentList, transferables] = processArguments(rawArgumentList);\r\n            return requestResponseMessage(ep, {\r\n                type: \"CONSTRUCT\" /* CONSTRUCT */,\r\n                path: path.map((p) => p.toString()),\r\n                argumentList,\r\n            }, transferables).then(fromWireValue);\r\n        },\r\n    });\r\n    return proxy;\r\n}\r\nfunction myFlat(arr) {\r\n    return Array.prototype.concat.apply([], arr);\r\n}\r\nfunction processArguments(argumentList) {\r\n    const processed = argumentList.map(toWireValue);\r\n    return [processed.map((v) => v[0]), myFlat(processed.map((v) => v[1]))];\r\n}\r\nconst transferCache = new WeakMap();\r\nfunction transfer(obj, transfers) {\r\n    transferCache.set(obj, transfers);\r\n    return obj;\r\n}\r\nfunction proxy(obj) {\r\n    return Object.assign(obj, { [proxyMarker]: true });\r\n}\r\nfunction windowEndpoint(w, context = self, targetOrigin = \"*\") {\r\n    return {\r\n        postMessage: (msg, transferables) => w.postMessage(msg, targetOrigin, transferables),\r\n        addEventListener: context.addEventListener.bind(context),\r\n        removeEventListener: context.removeEventListener.bind(context),\r\n    };\r\n}\r\nfunction toWireValue(value) {\r\n    for (const [name, handler] of transferHandlers) {\r\n        if (handler.canHandle(value)) {\r\n            const [serializedValue, transferables] = handler.serialize(value);\r\n            return [\r\n                {\r\n                    type: \"HANDLER\" /* HANDLER */,\r\n                    name,\r\n                    value: serializedValue,\r\n                },\r\n                transferables,\r\n            ];\r\n        }\r\n    }\r\n    return [\r\n        {\r\n            type: \"RAW\" /* RAW */,\r\n            value,\r\n        },\r\n        transferCache.get(value) || [],\r\n    ];\r\n}\r\nfunction fromWireValue(value) {\r\n    switch (value.type) {\r\n        case \"HANDLER\" /* HANDLER */:\r\n            return transferHandlers.get(value.name).deserialize(value.value);\r\n        case \"RAW\" /* RAW */:\r\n            return value.value;\r\n    }\r\n}\r\nfunction requestResponseMessage(ep, msg, transfers) {\r\n    return new Promise((resolve) => {\r\n        const id = generateUUID();\r\n        ep.addEventListener(\"message\", function l(ev) {\r\n            if (!ev.data || !ev.data.id || ev.data.id !== id) {\r\n                return;\r\n            }\r\n            ep.removeEventListener(\"message\", l);\r\n            resolve(ev.data);\r\n        });\r\n        if (ep.start) {\r\n            ep.start();\r\n        }\r\n        ep.postMessage(Object.assign({ id }, msg), transfers);\r\n    });\r\n}\r\nfunction generateUUID() {\r\n    return new Array(4)\r\n        .fill(0)\r\n        .map(() => Math.floor(Math.random() * Number.MAX_SAFE_INTEGER).toString(16))\r\n        .join(\"-\");\r\n}\n\nexport { createEndpoint, expose, proxy, proxyMarker, releaseProxy, transfer, transferHandlers, windowEndpoint, wrap };\n//# sourceMappingURL=comlink.mjs.map\n"],"names":[],"sourceRoot":""}