arshjaved commited on
Commit
f9f1a35
·
verified ·
1 Parent(s): 99ba3bb

normal Model Upload (teja)

Browse files
This view is limited to 50 files because it contains too many changes.   See raw diff
Files changed (50) hide show
  1. .gitattributes +2 -0
  2. datalab/run.sh +75 -0
  3. datalab/web/app.js +78 -0
  4. datalab/web/appSettings.js +144 -0
  5. datalab/web/config/basePath.json +1 -0
  6. datalab/web/config/settings.json +8 -0
  7. datalab/web/json_rpc.js +137 -0
  8. datalab/web/jupyter.js +213 -0
  9. datalab/web/logging.js +129 -0
  10. datalab/web/lsp/capabilities_node.js +3 -0
  11. datalab/web/lsp/extensions_node.js +14 -0
  12. datalab/web/lsp/protocol_node.js +191 -0
  13. datalab/web/lsp/settings_node.js +44 -0
  14. datalab/web/lsp/text_document_node.js +0 -0
  15. datalab/web/lsp/window_node.js +24 -0
  16. datalab/web/lsp/workspace_node.js +41 -0
  17. datalab/web/node_modules/.bin/bunyan +3 -0
  18. datalab/web/node_modules/.bin/mkdirp +3 -0
  19. datalab/web/node_modules/.bin/ncp +3 -0
  20. datalab/web/node_modules/.bin/rimraf +3 -0
  21. datalab/web/node_modules/.bin/semver +3 -0
  22. datalab/web/node_modules/.package-lock.json +634 -0
  23. datalab/web/node_modules/accepts/HISTORY.md +224 -0
  24. datalab/web/node_modules/accepts/LICENSE +23 -0
  25. datalab/web/node_modules/accepts/README.md +143 -0
  26. datalab/web/node_modules/accepts/index.js +238 -0
  27. datalab/web/node_modules/accepts/package.json +46 -0
  28. datalab/web/node_modules/after/.npmignore +2 -0
  29. datalab/web/node_modules/after/.travis.yml +12 -0
  30. datalab/web/node_modules/after/LICENCE +19 -0
  31. datalab/web/node_modules/after/README.md +115 -0
  32. datalab/web/node_modules/after/index.js +28 -0
  33. datalab/web/node_modules/after/package.json +28 -0
  34. datalab/web/node_modules/after/test/after-test.js +120 -0
  35. datalab/web/node_modules/arraybuffer.slice/.npmignore +17 -0
  36. datalab/web/node_modules/arraybuffer.slice/LICENCE +18 -0
  37. datalab/web/node_modules/arraybuffer.slice/Makefile +8 -0
  38. datalab/web/node_modules/arraybuffer.slice/README.md +17 -0
  39. datalab/web/node_modules/arraybuffer.slice/index.js +29 -0
  40. datalab/web/node_modules/arraybuffer.slice/package.json +16 -0
  41. datalab/web/node_modules/arraybuffer.slice/test/slice-buffer.js +227 -0
  42. datalab/web/node_modules/async-limiter/.travis.yml +7 -0
  43. datalab/web/node_modules/async-limiter/LICENSE +8 -0
  44. datalab/web/node_modules/async-limiter/coverage/coverage.json +1 -0
  45. datalab/web/node_modules/async-limiter/coverage/lcov-report/async-throttle/index.html +73 -0
  46. datalab/web/node_modules/async-limiter/coverage/lcov-report/async-throttle/index.js.html +246 -0
  47. datalab/web/node_modules/async-limiter/coverage/lcov-report/base.css +182 -0
  48. datalab/web/node_modules/async-limiter/coverage/lcov-report/index.html +73 -0
  49. datalab/web/node_modules/async-limiter/coverage/lcov-report/prettify.css +1 -0
  50. datalab/web/node_modules/async-limiter/coverage/lcov-report/prettify.js +1 -0
.gitattributes CHANGED
@@ -37,3 +37,5 @@ sample_data/mnist_test.csv filter=lfs diff=lfs merge=lfs -text
37
  sample_data/mnist_train_small.csv filter=lfs diff=lfs merge=lfs -text
38
  updated_data.csv filter=lfs diff=lfs merge=lfs -text
39
  updated_data_train.csv filter=lfs diff=lfs merge=lfs -text
 
 
 
37
  sample_data/mnist_train_small.csv filter=lfs diff=lfs merge=lfs -text
38
  updated_data.csv filter=lfs diff=lfs merge=lfs -text
39
  updated_data_train.csv filter=lfs diff=lfs merge=lfs -text
40
+ datalab/web/node_modules/dtrace-provider/build/node_gyp_bins/python3 filter=lfs diff=lfs merge=lfs -text
41
+ datalab/web/node_modules/node-pty/build/node_gyp_bins/python3 filter=lfs diff=lfs merge=lfs -text
datalab/run.sh ADDED
@@ -0,0 +1,75 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ #!/bin/bash -e
2
+
3
+ # Copyright 2017 Google Inc. All rights reserved.
4
+ #
5
+ # Licensed under the Apache License, Version 2.0 (the "License");
6
+ # you may not use this file except in compliance with the License.
7
+ # You may obtain a copy of the License at
8
+ #
9
+ # http://www.apache.org/licenses/LICENSE-2.0
10
+ #
11
+ # Unless required by applicable law or agreed to in writing, software
12
+ # distributed under the License is distributed on an "AS IS" BASIS,
13
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
+ # See the License for the specific language governing permissions and
15
+ # limitations under the License.
16
+
17
+ # At least one GPU is considered available iff COLAB_GPU=1.
18
+ export COLAB_GPU="$([[ -c /dev/nvidiactl ]] && echo 1)"
19
+
20
+ /usr/local/colab/bin/oom_monitor.sh &
21
+
22
+ # Start the Colab proxy to the Jupyter kernel manager.
23
+ # TODO(b/267667580): Evaluate use of tcmalloc here and possibly other places.
24
+ ( while true; do
25
+ GCE_METADATA_HOST="${VM_GCE_METADATA_HOST}" \
26
+ LD_PRELOAD='/usr/lib/x86_64-linux-gnu/libtcmalloc.so.4' \
27
+ /usr/colab/bin/kernel_manager_proxy \
28
+ --listen_port="${KMP_LISTEN_PORT}" \
29
+ --target_port="${KMP_TARGET_PORT}" \
30
+ ${KMP_EXTRA_ARGS} || true
31
+ sleep 1
32
+ done & )
33
+
34
+ # Start fresh to isolate user-initiated actions from VM build & startup events.
35
+ for f in /var/log/apt/history.log /var/log/pip.log; do
36
+ mv "$f" "${f}.bak-run.sh" 2>/dev/null || true # Ignore missing files.
37
+ done
38
+
39
+ # Warm disk buffers for modules we need for kernel startup. (cf: b/116536906)
40
+ if [[ "${COLAB_WARMUP_DEFAULTS}" == "1" ]]; then
41
+ python3 -c "import google.colab._kernel"
42
+ python3 -c "import matplotlib"
43
+ # importing tensorflow on a TPU VM causes the process to acquire the TPU for
44
+ # the duration of the import. This makes the TPU effectively unacquirable for
45
+ # the duration of the warmup, which can break things like probers.
46
+ if [[ "${COLAB_TPU_1VM}" == "1" ]]; then
47
+ python3 -c "import tensorflow"
48
+ else
49
+ python3 -c "import tensorflow" &
50
+ fi
51
+ fi
52
+
53
+ # Start the server to handle /files and /api/contents requests.
54
+ /usr/local/bin/colab-fileshim.py ${COLAB_FILESHIM_EXTRA_ARGS} &
55
+
56
+ # Link NVidia tools from a read-only volume mount.
57
+ for f in $(ls /opt/bin/.nvidia 2>/dev/null); do
58
+ ln -st /opt/bin "/opt/bin/.nvidia/${f}"
59
+ ln -st /usr/bin "/opt/bin/.nvidia/${f}"
60
+ done
61
+
62
+ cd /
63
+
64
+ # Start the node server.
65
+ if [[ "${COLAB_HUMAN_READABLE_NODE_LOGS}" == "1" ]]; then
66
+ PIPE=/tmp/.node.out
67
+ if ! [[ -p "${PIPE}" ]]; then
68
+ mkfifo "${PIPE}"
69
+ fi
70
+ /datalab/web/node_modules/bunyan/bin/bunyan \
71
+ -l "${COLAB_NODE_LOG_LEVEL:-info}" < "${PIPE}" &
72
+ exec >& "${PIPE}"
73
+ fi
74
+ exec /tools/node/bin/node /datalab/web/app.js
75
+
datalab/web/app.js ADDED
@@ -0,0 +1,78 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ "use strict";
2
+ /*
3
+ * Copyright 2015 Google Inc. All rights reserved.
4
+ *
5
+ * Licensed under the Apache License, Version 2.0 (the "License"); you may not
6
+ * use this file except in compliance with the License. You may obtain a copy of
7
+ * the License at
8
+ *
9
+ * http://www.apache.org/licenses/LICENSE-2.0
10
+ *
11
+ * Unless required by applicable law or agreed to in writing, software
12
+ * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
13
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
14
+ * License for the specific language governing permissions and limitations under
15
+ * the License.
16
+ */
17
+ Object.defineProperty(exports, "__esModule", { value: true });
18
+ var fs = require("fs");
19
+ var path = require("path");
20
+ var appSettings_1 = require("./appSettings");
21
+ var logging = require("./logging");
22
+ var server = require("./server");
23
+ /**
24
+ * Loads the configuration settings for the application to use.
25
+ * On first run, this generates any dynamic settings and merges them into the
26
+ * settings result.
27
+ * @return the settings object for the application to use.
28
+ */
29
+ function loadAppSettings() {
30
+ var settingsPath = path.join(__dirname, 'config', 'settings.json');
31
+ if (!fs.existsSync(settingsPath)) {
32
+ var msg = "App settings file \"".concat(settingsPath, "\" not found.");
33
+ console.error(msg);
34
+ throw new Error(msg);
35
+ }
36
+ try {
37
+ var settings = JSON.parse(fs.readFileSync(settingsPath, 'utf8') || '{}');
38
+ (0, appSettings_1.applyEnvironmentVariables)(settings);
39
+ return settings;
40
+ }
41
+ catch (e) {
42
+ console.error(e);
43
+ throw new Error("Error parsing settings overrides: ".concat(e));
44
+ }
45
+ }
46
+ /**
47
+ * Load the configuration settings, and then start the server, which
48
+ * runs indefinitely, listening to and processing incoming HTTP requests.
49
+ */
50
+ var appSettings = loadAppSettings();
51
+ if (appSettings != null) {
52
+ logging.initializeLoggers(appSettings);
53
+ logging.getLogger().info('app: starting with settings: %s', JSON.stringify(appSettings));
54
+ server.run(appSettings);
55
+ }
56
+ /**
57
+ * Handle shutdown of this process, to also stop the server, which will in turn
58
+ * stop the associated Jupyter server process.
59
+ */
60
+ function exit() {
61
+ logging.getLogger().info('app: exit');
62
+ server.stop();
63
+ logging.getLogger().info('app: exit: stopped');
64
+ process.exit(0);
65
+ }
66
+ /**
67
+ * Handle uncaught exceptions to log them.
68
+ */
69
+ function errorHandler(e) {
70
+ console.error(e.stack);
71
+ logging.getLogger().error(e, 'Unhandled exception');
72
+ process.exit(1);
73
+ }
74
+ process.on('uncaughtException', errorHandler);
75
+ process.on('exit', exit);
76
+ process.on('SIGINT', exit);
77
+ process.on('SIGTERM', exit);
78
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vdGhpcmRfcGFydHkvY29sYWIvc291cmNlcy9hcHAudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7Ozs7Ozs7Ozs7OztHQWNHOztBQUVILHVCQUF5QjtBQUN6QiwyQkFBNkI7QUFFN0IsNkNBQXFFO0FBQ3JFLG1DQUFxQztBQUNyQyxpQ0FBbUM7QUFFbkM7Ozs7O0dBS0c7QUFDSCxTQUFTLGVBQWU7SUFDdEIsSUFBTSxZQUFZLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsUUFBUSxFQUFFLGVBQWUsQ0FBQyxDQUFDO0lBRXJFLElBQUksQ0FBQyxFQUFFLENBQUMsVUFBVSxDQUFDLFlBQVksQ0FBQyxFQUFFLENBQUM7UUFDakMsSUFBTSxHQUFHLEdBQUcsOEJBQXNCLFlBQVksa0JBQWMsQ0FBQztRQUM3RCxPQUFPLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ25CLE1BQU0sSUFBSSxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDdkIsQ0FBQztJQUVELElBQUksQ0FBQztRQUNILElBQU0sUUFBUSxHQUNWLElBQUksQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLFlBQVksQ0FBQyxZQUFZLEVBQUUsTUFBTSxDQUFDLElBQUksSUFBSSxDQUM3QyxDQUFDO1FBQ2hCLElBQUEsdUNBQXlCLEVBQUMsUUFBUSxDQUFDLENBQUM7UUFDcEMsT0FBTyxRQUFRLENBQUM7SUFDbEIsQ0FBQztJQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUM7UUFDWCxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ2pCLE1BQU0sSUFBSSxLQUFLLENBQUMsNENBQXFDLENBQUMsQ0FBRSxDQUFDLENBQUM7SUFDNUQsQ0FBQztBQUNILENBQUM7QUFFRDs7O0dBR0c7QUFDSCxJQUFNLFdBQVcsR0FBRyxlQUFlLEVBQUUsQ0FBQztBQUN0QyxJQUFJLFdBQVcsSUFBSSxJQUFJLEVBQUUsQ0FBQztJQUN4QixPQUFPLENBQUMsaUJBQWlCLENBQUMsV0FBVyxDQUFDLENBQUM7SUFDdkMsT0FBTyxDQUFDLFNBQVMsRUFBRSxDQUFDLElBQUksQ0FDcEIsaUNBQWlDLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDO0lBQ3BFLE1BQU0sQ0FBQyxHQUFHLENBQUMsV0FBVyxDQUFDLENBQUM7QUFDMUIsQ0FBQztBQUdEOzs7R0FHRztBQUNILFNBQVMsSUFBSTtJQUNYLE9BQU8sQ0FBQyxTQUFTLEVBQUUsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUM7SUFDdEMsTUFBTSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ2QsT0FBTyxDQUFDLFNBQVMsRUFBRSxDQUFDLElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDO0lBQy9DLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7QUFDbEIsQ0FBQztBQUVEOztHQUVHO0FBQ0gsU0FBUyxZQUFZLENBQUMsQ0FBUTtJQUM1QixPQUFPLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUV2QixPQUFPLENBQUMsU0FBUyxFQUFFLENBQUMsS0FBSyxDQUFDLENBQUMsRUFBRSxxQkFBcUIsQ0FBQyxDQUFDO0lBQ3BELE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7QUFDbEIsQ0FBQztBQUVELE9BQU8sQ0FBQyxFQUFFLENBQUMsbUJBQW1CLEVBQUUsWUFBWSxDQUFDLENBQUM7QUFDOUMsT0FBTyxDQUFDLEVBQUUsQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLENBQUM7QUFDekIsT0FBTyxDQUFDLEVBQUUsQ0FBQyxRQUFRLEVBQUUsSUFBSSxDQUFDLENBQUM7QUFDM0IsT0FBTyxDQUFDLEVBQUUsQ0FBQyxTQUFTLEVBQUUsSUFBSSxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogQ29weXJpZ2h0IDIwMTUgR29vZ2xlIEluYy4gQWxsIHJpZ2h0cyByZXNlcnZlZC5cbiAqXG4gKiBMaWNlbnNlZCB1bmRlciB0aGUgQXBhY2hlIExpY2Vuc2UsIFZlcnNpb24gMi4wICh0aGUgXCJMaWNlbnNlXCIpOyB5b3UgbWF5IG5vdFxuICogdXNlIHRoaXMgZmlsZSBleGNlcHQgaW4gY29tcGxpYW5jZSB3aXRoIHRoZSBMaWNlbnNlLiBZb3UgbWF5IG9idGFpbiBhIGNvcHkgb2ZcbiAqIHRoZSBMaWNlbnNlIGF0XG4gKlxuICogaHR0cDovL3d3dy5hcGFjaGUub3JnL2xpY2Vuc2VzL0xJQ0VOU0UtMi4wXG4gKlxuICogVW5sZXNzIHJlcXVpcmVkIGJ5IGFwcGxpY2FibGUgbGF3IG9yIGFncmVlZCB0byBpbiB3cml0aW5nLCBzb2Z0d2FyZVxuICogZGlzdHJpYnV0ZWQgdW5kZXIgdGhlIExpY2Vuc2UgaXMgZGlzdHJpYnV0ZWQgb24gYW4gXCJBUyBJU1wiIEJBU0lTLCBXSVRIT1VUXG4gKiBXQVJSQU5USUVTIE9SIENPTkRJVElPTlMgT0YgQU5ZIEtJTkQsIGVpdGhlciBleHByZXNzIG9yIGltcGxpZWQuIFNlZSB0aGVcbiAqIExpY2Vuc2UgZm9yIHRoZSBzcGVjaWZpYyBsYW5ndWFnZSBnb3Zlcm5pbmcgcGVybWlzc2lvbnMgYW5kIGxpbWl0YXRpb25zIHVuZGVyXG4gKiB0aGUgTGljZW5zZS5cbiAqL1xuXG5pbXBvcnQgKiBhcyBmcyBmcm9tICdmcyc7XG5pbXBvcnQgKiBhcyBwYXRoIGZyb20gJ3BhdGgnO1xuXG5pbXBvcnQge2FwcGx5RW52aXJvbm1lbnRWYXJpYWJsZXMsIEFwcFNldHRpbmdzfSBmcm9tICcuL2FwcFNldHRpbmdzJztcbmltcG9ydCAqIGFzIGxvZ2dpbmcgZnJvbSAnLi9sb2dnaW5nJztcbmltcG9ydCAqIGFzIHNlcnZlciBmcm9tICcuL3NlcnZlcic7XG5cbi8qKlxuICogTG9hZHMgdGhlIGNvbmZpZ3VyYXRpb24gc2V0dGluZ3MgZm9yIHRoZSBhcHBsaWNhdGlvbiB0byB1c2UuXG4gKiBPbiBmaXJzdCBydW4sIHRoaXMgZ2VuZXJhdGVzIGFueSBkeW5hbWljIHNldHRpbmdzIGFuZCBtZXJnZXMgdGhlbSBpbnRvIHRoZVxuICogc2V0dGluZ3MgcmVzdWx0LlxuICogQHJldHVybiB0aGUgc2V0dGluZ3Mgb2JqZWN0IGZvciB0aGUgYXBwbGljYXRpb24gdG8gdXNlLlxuICovXG5mdW5jdGlvbiBsb2FkQXBwU2V0dGluZ3MoKTogQXBwU2V0dGluZ3Mge1xuICBjb25zdCBzZXR0aW5nc1BhdGggPSBwYXRoLmpvaW4oX19kaXJuYW1lLCAnY29uZmlnJywgJ3NldHRpbmdzLmpzb24nKTtcblxuICBpZiAoIWZzLmV4aXN0c1N5bmMoc2V0dGluZ3NQYXRoKSkge1xuICAgIGNvbnN0IG1zZyA9IGBBcHAgc2V0dGluZ3MgZmlsZSBcIiR7c2V0dGluZ3NQYXRofVwiIG5vdCBmb3VuZC5gO1xuICAgIGNvbnNvbGUuZXJyb3IobXNnKTtcbiAgICB0aHJvdyBuZXcgRXJyb3IobXNnKTtcbiAgfVxuXG4gIHRyeSB7XG4gICAgY29uc3Qgc2V0dGluZ3MgPVxuICAgICAgICBKU09OLnBhcnNlKGZzLnJlYWRGaWxlU3luYyhzZXR0aW5nc1BhdGgsICd1dGY4JykgfHwgJ3t9JykgYXNcbiAgICAgICAgQXBwU2V0dGluZ3M7XG4gICAgYXBwbHlFbnZpcm9ubWVudFZhcmlhYmxlcyhzZXR0aW5ncyk7XG4gICAgcmV0dXJuIHNldHRpbmdzO1xuICB9IGNhdGNoIChlKSB7XG4gICAgY29uc29sZS5lcnJvcihlKTtcbiAgICB0aHJvdyBuZXcgRXJyb3IoYEVycm9yIHBhcnNpbmcgc2V0dGluZ3Mgb3ZlcnJpZGVzOiAke2V9YCk7XG4gIH1cbn1cblxuLyoqXG4gKiBMb2FkIHRoZSBjb25maWd1cmF0aW9uIHNldHRpbmdzLCBhbmQgdGhlbiBzdGFydCB0aGUgc2VydmVyLCB3aGljaFxuICogcnVucyBpbmRlZmluaXRlbHksIGxpc3RlbmluZyB0byBhbmQgcHJvY2Vzc2luZyBpbmNvbWluZyBIVFRQIHJlcXVlc3RzLlxuICovXG5jb25zdCBhcHBTZXR0aW5ncyA9IGxvYWRBcHBTZXR0aW5ncygpO1xuaWYgKGFwcFNldHRpbmdzICE9IG51bGwpIHtcbiAgbG9nZ2luZy5pbml0aWFsaXplTG9nZ2VycyhhcHBTZXR0aW5ncyk7XG4gIGxvZ2dpbmcuZ2V0TG9nZ2VyKCkuaW5mbyhcbiAgICAgICdhcHA6IHN0YXJ0aW5nIHdpdGggc2V0dGluZ3M6ICVzJywgSlNPTi5zdHJpbmdpZnkoYXBwU2V0dGluZ3MpKTtcbiAgc2VydmVyLnJ1bihhcHBTZXR0aW5ncyk7XG59XG5cblxuLyoqXG4gKiBIYW5kbGUgc2h1dGRvd24gb2YgdGhpcyBwcm9jZXNzLCB0byBhbHNvIHN0b3AgdGhlIHNlcnZlciwgd2hpY2ggd2lsbCBpbiB0dXJuXG4gKiBzdG9wIHRoZSBhc3NvY2lhdGVkIEp1cHl0ZXIgc2VydmVyIHByb2Nlc3MuXG4gKi9cbmZ1bmN0aW9uIGV4aXQoKSB7XG4gIGxvZ2dpbmcuZ2V0TG9nZ2VyKCkuaW5mbygnYXBwOiBleGl0Jyk7XG4gIHNlcnZlci5zdG9wKCk7XG4gIGxvZ2dpbmcuZ2V0TG9nZ2VyKCkuaW5mbygnYXBwOiBleGl0OiBzdG9wcGVkJyk7XG4gIHByb2Nlc3MuZXhpdCgwKTtcbn1cblxuLyoqXG4gKiBIYW5kbGUgdW5jYXVnaHQgZXhjZXB0aW9ucyB0byBsb2cgdGhlbS5cbiAqL1xuZnVuY3Rpb24gZXJyb3JIYW5kbGVyKGU6IEVycm9yKTogdm9pZCB7XG4gIGNvbnNvbGUuZXJyb3IoZS5zdGFjayk7XG5cbiAgbG9nZ2luZy5nZXRMb2dnZXIoKS5lcnJvcihlLCAnVW5oYW5kbGVkIGV4Y2VwdGlvbicpO1xuICBwcm9jZXNzLmV4aXQoMSk7XG59XG5cbnByb2Nlc3Mub24oJ3VuY2F1Z2h0RXhjZXB0aW9uJywgZXJyb3JIYW5kbGVyKTtcbnByb2Nlc3Mub24oJ2V4aXQnLCBleGl0KTtcbnByb2Nlc3Mub24oJ1NJR0lOVCcsIGV4aXQpO1xucHJvY2Vzcy5vbignU0lHVEVSTScsIGV4aXQpO1xuIl19
datalab/web/appSettings.js ADDED
@@ -0,0 +1,144 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ "use strict";
2
+ /*
3
+ * Copyright 2018 Google Inc. All rights reserved.
4
+ *
5
+ * Licensed under the Apache License, Version 2.0 (the "License"); you may not
6
+ * use this file except in compliance with the License. You may obtain a copy of
7
+ * the License at
8
+ *
9
+ * http://www.apache.org/licenses/LICENSE-2.0
10
+ *
11
+ * Unless required by applicable law or agreed to in writing, software
12
+ * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
13
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
14
+ * License for the specific language governing permissions and limitations under
15
+ * the License.
16
+ */
17
+ var __values = (this && this.__values) || function(o) {
18
+ var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
19
+ if (m) return m.call(o);
20
+ if (o && typeof o.length === "number") return {
21
+ next: function () {
22
+ if (o && i >= o.length) o = void 0;
23
+ return { value: o && o[i++], done: !o };
24
+ }
25
+ };
26
+ throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
27
+ };
28
+ var __read = (this && this.__read) || function (o, n) {
29
+ var m = typeof Symbol === "function" && o[Symbol.iterator];
30
+ if (!m) return o;
31
+ var i = m.call(o), r, ar = [], e;
32
+ try {
33
+ while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
34
+ }
35
+ catch (error) { e = { error: error }; }
36
+ finally {
37
+ try {
38
+ if (r && !r.done && (m = i["return"])) m.call(i);
39
+ }
40
+ finally { if (e) throw e.error; }
41
+ }
42
+ return ar;
43
+ };
44
+ Object.defineProperty(exports, "__esModule", { value: true });
45
+ exports.applyEnvironmentVariables = applyEnvironmentVariables;
46
+ var environmentVariables = {
47
+ 'COLAB_ROOT_REDIRECT': function (settings, value) {
48
+ settings.colabRedirect = value;
49
+ },
50
+ 'COLAB_SERVER_PORT': function (settings, value) {
51
+ settings.serverPort = Number(value);
52
+ },
53
+ 'COLAB_LANGUAGE_SERVER_PROXY': function (settings, value) {
54
+ settings.languageServerProxy = value;
55
+ },
56
+ 'COLAB_SERVER_HOST': function (settings, value) {
57
+ settings.serverHost = value;
58
+ },
59
+ 'COLAB_NEXT_JUPYTER_PORT': function (settings, value) {
60
+ settings.nextJupyterPort = Number(value);
61
+ },
62
+ 'COLAB_DEBUG_ADAPTER_MUX_PATH': function (settings, value) {
63
+ settings.debugAdapterMultiplexerPath = value;
64
+ },
65
+ 'COLAB_DATALAB_ROOT': function (settings, value) {
66
+ settings.datalabRoot = value;
67
+ },
68
+ 'COLAB_KERNEL_MANAGER_PROXY_PORT': function (settings, value) {
69
+ settings.kernelManagerProxyPort = Number(value);
70
+ },
71
+ 'COLAB_KERNEL_MANAGER_PROXY_HOST': function (settings, value) {
72
+ settings.kernelManagerProxyHost = value;
73
+ },
74
+ 'COLAB_LANGUAGE_SERVER_PROXY_LSP_DIRS': function (settings, value) {
75
+ settings.languageServerProxyArgs = settings.languageServerProxyArgs || [];
76
+ settings.languageServerProxyArgs.push("--lsp_search_dirs=".concat(value));
77
+ },
78
+ 'COLAB_LANGUAGE_SERVER_PROXY_ROOT_URL': function (settings, value) {
79
+ settings.languageServerProxyArgs = settings.languageServerProxyArgs || [];
80
+ settings.languageServerProxyArgs.push("--language_services_request_root_url=".concat(value));
81
+ },
82
+ 'COLAB_LANGUAGE_SERVER_PROXY_REQUEST_TIMEOUT': function (settings, value) {
83
+ settings.languageServerProxyArgs = settings.languageServerProxyArgs || [];
84
+ settings.languageServerProxyArgs.push("--language_services_request_timeout=".concat(value));
85
+ },
86
+ 'COLAB_JUPYTER_ALLOW_ORIGIN_PAT': function (settings, value) {
87
+ settings.jupyterArgs = settings.jupyterArgs || [];
88
+ settings.jupyterArgs.push("--NotebookApp.allow_origin_pat=\"".concat(value, "\""));
89
+ settings.jupyterArgs.push("--NotebookApp.allow_origin=");
90
+ settings.jupyterArgs.push("--NotebookApp.allow_credentials=True");
91
+ },
92
+ 'COLAB_JUPYTER_DEBUG': function (settings) {
93
+ settings.jupyterArgs = settings.jupyterArgs || [];
94
+ settings.jupyterArgs.push("--debug");
95
+ },
96
+ 'COLAB_JUPYTER_TRANSPORT': function (settings, value) {
97
+ settings.jupyterArgs = settings.jupyterArgs || [];
98
+ settings.jupyterArgs.push("--transport=\"".concat(value, "\""));
99
+ },
100
+ 'COLAB_JUPYTER_IP': function (settings, value) {
101
+ settings.jupyterArgs = settings.jupyterArgs || [];
102
+ settings.jupyterArgs.push("--ip=".concat(value));
103
+ },
104
+ 'COLAB_GATEWAY_CLIENT_URL': function (settings, value) {
105
+ settings.jupyterArgs = settings.jupyterArgs || [];
106
+ settings.jupyterArgs.push("--GatewayClient.url=".concat(value));
107
+ },
108
+ 'COLAB_JUPYTER_ALLOW_REMOTE_ACCESS': function (settings, value) {
109
+ settings.jupyterArgs = settings.jupyterArgs || [];
110
+ settings.jupyterArgs.push("--NotebookApp.allow_remote_access=".concat(value));
111
+ },
112
+ 'COLAB_JUPYTER_TOKEN': function (settings, value) {
113
+ settings.jupyterArgs = settings.jupyterArgs || [];
114
+ settings.jupyterArgs.push("--NotebookApp.token=".concat(value));
115
+ },
116
+ 'COLAB_JUPYTER_DISABLE_CHECK_XSRF': function (settings, value) {
117
+ settings.jupyterArgs = settings.jupyterArgs || [];
118
+ settings.jupyterArgs.push("--NotebookApp.disable_check_xsrf=".concat(value));
119
+ },
120
+ 'COLAB_FILE_HANDLER_ADDR': function (settings, value) {
121
+ settings.fileHandlerAddr = value;
122
+ },
123
+ };
124
+ /** Applies any environment variable overrides. */
125
+ function applyEnvironmentVariables(settings) {
126
+ var e_1, _a;
127
+ try {
128
+ for (var _b = __values(Object.entries(environmentVariables)), _c = _b.next(); !_c.done; _c = _b.next()) {
129
+ var _d = __read(_c.value, 2), key = _d[0], apply = _d[1];
130
+ var override = process.env[key];
131
+ if (override !== undefined) {
132
+ apply(settings, override);
133
+ }
134
+ }
135
+ }
136
+ catch (e_1_1) { e_1 = { error: e_1_1 }; }
137
+ finally {
138
+ try {
139
+ if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
140
+ }
141
+ finally { if (e_1) throw e_1.error; }
142
+ }
143
+ }
144
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"appSettings.js","sourceRoot":"","sources":["../../../../../../third_party/colab/sources/appSettings.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2018 Google Inc. All rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\"); you may not\n * use this file except in compliance with the License. You may obtain a copy of\n * the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS, WITHOUT\n * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the\n * License for the specific language governing permissions and limitations under\n * the License.\n */\n\n\n/** Configuration values shared across the whole app. */\nexport declare interface AppSettings {\n  /**\n   * The port that the server should listen to.\n   */\n  serverPort: number;\n\n  /**\n   * If set, listen on this hostname.\n   */\n  serverHost?: string;\n\n  /**\n   * The list of static arguments to be used when launching `jupyter notebook`.\n   */\n  jupyterArgs?: string[];\n\n  /**\n   * If provided, use this as a prefix to all file paths opened on the\n   * server side. Useful for testing outside a Docker container.\n   */\n  datalabRoot: string;\n\n  /**\n   * Initial port to use when searching for a free Jupyter port.\n   */\n  nextJupyterPort: number;\n\n  /**\n   * Local directory where kernels are started.\n   */\n  contentDir: string;\n\n  /**\n   * The port to use to proxy kernel manager websocket requests. A value of 0\n   * disables proxying.\n   */\n  kernelManagerProxyPort: number;\n\n  /**\n   * The hostname (or IP) to use to proxy kernel manager websocket requests.\n   * An empty value uses localhost.\n   */\n  kernelManagerProxyHost: string;\n\n  /**\n   * If set, the path to the DAP multiplexer.\n   */\n  debugAdapterMultiplexerPath: string;\n\n  /**\n   * If set, redirect / requests to Colab, with {jupyter_host} replaced with the\n   * server host.\n   */\n  colabRedirect?: string;\n\n  /**\n   * If set, the path a language server proxy which can extend the capabilities\n   * of the default language server.\n   */\n  languageServerProxy?: string;\n\n  /**\n   * If set, the args to pass to the language server proxy.\n   * This is only consumed if a non-empty path is set for the\n   * languageServerProxy setting.\n   */\n  languageServerProxyArgs?: string[];\n\n  /**\n   * The host:port address to use for serving file requests. An empty value uses\n   * Jupyter's file server.\n   */\n  fileHandlerAddr: string;\n}\n\nconst environmentVariables = {\n  'COLAB_ROOT_REDIRECT': (settings: AppSettings, value: string) => {\n    settings.colabRedirect = value;\n  },\n  'COLAB_SERVER_PORT': (settings: AppSettings, value: string) => {\n    settings.serverPort = Number(value);\n  },\n  'COLAB_LANGUAGE_SERVER_PROXY': (settings: AppSettings, value: string) => {\n    settings.languageServerProxy = value;\n  },\n  'COLAB_SERVER_HOST': (settings: AppSettings, value: string) => {\n    settings.serverHost = value;\n  },\n  'COLAB_NEXT_JUPYTER_PORT': (settings: AppSettings, value: string) => {\n    settings.nextJupyterPort = Number(value);\n  },\n  'COLAB_DEBUG_ADAPTER_MUX_PATH': (settings: AppSettings, value: string) => {\n    settings.debugAdapterMultiplexerPath = value;\n  },\n  'COLAB_DATALAB_ROOT': (settings: AppSettings, value: string) => {\n    settings.datalabRoot = value;\n  },\n  'COLAB_KERNEL_MANAGER_PROXY_PORT': (settings: AppSettings, value: string) => {\n    settings.kernelManagerProxyPort = Number(value);\n  },\n  'COLAB_KERNEL_MANAGER_PROXY_HOST': (settings: AppSettings, value: string) => {\n    settings.kernelManagerProxyHost = value;\n  },\n  'COLAB_LANGUAGE_SERVER_PROXY_LSP_DIRS': (\n      settings: AppSettings, value: string) => {\n    settings.languageServerProxyArgs = settings.languageServerProxyArgs || [];\n    settings.languageServerProxyArgs.push(`--lsp_search_dirs=${value}`);\n  },\n  'COLAB_LANGUAGE_SERVER_PROXY_ROOT_URL': (\n      settings: AppSettings, value: string) => {\n    settings.languageServerProxyArgs = settings.languageServerProxyArgs || [];\n    settings.languageServerProxyArgs.push(\n        `--language_services_request_root_url=${value}`);\n  },\n  'COLAB_LANGUAGE_SERVER_PROXY_REQUEST_TIMEOUT': (\n      settings: AppSettings, value: string) => {\n    settings.languageServerProxyArgs = settings.languageServerProxyArgs || [];\n    settings.languageServerProxyArgs.push(\n        `--language_services_request_timeout=${value}`);\n  },\n  'COLAB_JUPYTER_ALLOW_ORIGIN_PAT': (settings: AppSettings, value: string) => {\n    settings.jupyterArgs = settings.jupyterArgs || [];\n    settings.jupyterArgs.push(`--NotebookApp.allow_origin_pat=\"${value}\"`);\n    settings.jupyterArgs.push(`--NotebookApp.allow_origin=`);\n    settings.jupyterArgs.push(`--NotebookApp.allow_credentials=True`);\n  },\n  'COLAB_JUPYTER_DEBUG': (settings: AppSettings) => {\n    settings.jupyterArgs = settings.jupyterArgs || [];\n    settings.jupyterArgs.push(`--debug`);\n  },\n  'COLAB_JUPYTER_TRANSPORT': (settings: AppSettings, value: string) => {\n    settings.jupyterArgs = settings.jupyterArgs || [];\n    settings.jupyterArgs.push(`--transport=\"${value}\"`);\n  },\n  'COLAB_JUPYTER_IP': (settings: AppSettings, value: string) => {\n    settings.jupyterArgs = settings.jupyterArgs || [];\n    settings.jupyterArgs.push(`--ip=${value}`);\n  },\n  'COLAB_GATEWAY_CLIENT_URL': (settings: AppSettings, value: string) => {\n    settings.jupyterArgs = settings.jupyterArgs || [];\n    settings.jupyterArgs.push(`--GatewayClient.url=${value}`);\n  },\n  'COLAB_JUPYTER_ALLOW_REMOTE_ACCESS':\n      (settings: AppSettings, value: string) => {\n        settings.jupyterArgs = settings.jupyterArgs || [];\n        settings.jupyterArgs.push(`--NotebookApp.allow_remote_access=${value}`);\n      },\n  'COLAB_JUPYTER_TOKEN': (settings: AppSettings, value: string) => {\n    settings.jupyterArgs = settings.jupyterArgs || [];\n    settings.jupyterArgs.push(`--NotebookApp.token=${value}`);\n  },\n  'COLAB_JUPYTER_DISABLE_CHECK_XSRF':\n      (settings: AppSettings, value: string) => {\n        settings.jupyterArgs = settings.jupyterArgs || [];\n        settings.jupyterArgs.push(`--NotebookApp.disable_check_xsrf=${value}`);\n      },\n  'COLAB_FILE_HANDLER_ADDR': (settings: AppSettings, value: string) => {\n    settings.fileHandlerAddr = value;\n  },\n};\n\n/** Applies any environment variable overrides. */\nexport function applyEnvironmentVariables(settings: AppSettings) {\n  for (const [key, apply] of Object.entries(environmentVariables)) {\n    const override = process.env[key];\n    if (override !== undefined) {\n      apply(settings, override);\n    }\n  }\n}\n"]}
datalab/web/config/basePath.json ADDED
@@ -0,0 +1 @@
 
 
1
+ ""
datalab/web/config/settings.json ADDED
@@ -0,0 +1,8 @@
 
 
 
 
 
 
 
 
 
1
+ {
2
+ "contentDir": "/content",
3
+ "datalabRoot": "",
4
+ "jupyterArgs": ["--debug"],
5
+ "nextJupyterPort": 9000,
6
+ "serverHost": "",
7
+ "serverPort": 8080
8
+ }
datalab/web/json_rpc.js ADDED
@@ -0,0 +1,137 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ "use strict";
2
+ var __values = (this && this.__values) || function(o) {
3
+ var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
4
+ if (m) return m.call(o);
5
+ if (o && typeof o.length === "number") return {
6
+ next: function () {
7
+ if (o && i >= o.length) o = void 0;
8
+ return { value: o && o[i++], done: !o };
9
+ }
10
+ };
11
+ throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
12
+ };
13
+ Object.defineProperty(exports, "__esModule", { value: true });
14
+ exports.JsonRpcReader = void 0;
15
+ exports.encodeJsonRpc = encodeJsonRpc;
16
+ var CR = 13;
17
+ var LF = 10;
18
+ /**
19
+ * JSON RPC reader following the Debug Adapter Protocol message
20
+ * format which itself follows Chrome's V8 debugger protocol, originally
21
+ * documented at
22
+ * https://github.com/buggerjs/bugger-v8-client/blob/master/PROTOCOL.md#v8-debugger-protocol
23
+ */
24
+ var JsonRpcReader = /** @class */ (function () {
25
+ function JsonRpcReader(callback) {
26
+ this.callback = callback;
27
+ this.position = 0;
28
+ this.allocationSize = 4096;
29
+ this.decoder = new TextDecoder();
30
+ this.buffer = new Uint8Array(this.allocationSize);
31
+ }
32
+ JsonRpcReader.prototype.append = function (data) {
33
+ // Grow the buffer if necessary to hold the data.
34
+ if (data.byteLength > (this.buffer.byteLength - this.position)) {
35
+ var requiredSize = this.position + data.byteLength;
36
+ var newSize = Math.ceil(requiredSize / this.allocationSize) * this.allocationSize;
37
+ var newBuffer = new Uint8Array(newSize);
38
+ newBuffer.set(this.buffer, 0);
39
+ this.buffer = newBuffer;
40
+ }
41
+ // Push new data onto end of the buffer.
42
+ this.buffer.set(data, this.position);
43
+ this.position += data.byteLength;
44
+ var parsedMessages = [];
45
+ while (true) {
46
+ // Parse all messages out of the buffer.
47
+ var message = this.tryReadMessage();
48
+ if (!message) {
49
+ break;
50
+ }
51
+ parsedMessages.push(message);
52
+ this.callback(message);
53
+ }
54
+ return parsedMessages;
55
+ };
56
+ JsonRpcReader.prototype.tryReadMessage = function () {
57
+ var e_1, _a;
58
+ // Loop through looking for \r\n\r\n in the buffer.
59
+ for (var i = 0; i < this.position - 4; ++i) {
60
+ // First \r\n indicates the end of the headers.
61
+ if (this.buffer[i] === CR && this.buffer[i + 1] === LF &&
62
+ this.buffer[i + 2] === CR && this.buffer[i + 3] === LF) {
63
+ // Parse each of the header lines out of the header block.
64
+ var headerLength = i + 4;
65
+ var headerBytes = this.buffer.subarray(0, headerLength);
66
+ var headerString = this.decoder.decode(headerBytes);
67
+ var headerLines = headerString.split('\r\n');
68
+ var headers = {};
69
+ try {
70
+ for (var headerLines_1 = (e_1 = void 0, __values(headerLines)), headerLines_1_1 = headerLines_1.next(); !headerLines_1_1.done; headerLines_1_1 = headerLines_1.next()) {
71
+ var line = headerLines_1_1.value;
72
+ if (!line.trim()) {
73
+ continue;
74
+ }
75
+ var pair = line.split(':');
76
+ if (pair.length !== 2) {
77
+ throw new Error("Illegal header value: ".concat(line));
78
+ }
79
+ headers[pair[0]] = pair[1].trim();
80
+ }
81
+ }
82
+ catch (e_1_1) { e_1 = { error: e_1_1 }; }
83
+ finally {
84
+ try {
85
+ if (headerLines_1_1 && !headerLines_1_1.done && (_a = headerLines_1.return)) _a.call(headerLines_1);
86
+ }
87
+ finally { if (e_1) throw e_1.error; }
88
+ }
89
+ var contentLengthString = headers['Content-Length'];
90
+ if (!contentLengthString) {
91
+ throw new Error('Missing Content-Length header.');
92
+ }
93
+ var contentLength = Number(contentLengthString);
94
+ if (isNaN(contentLength)) {
95
+ throw new Error("Header Content-Length not a number: ".concat(contentLengthString, "."));
96
+ }
97
+ var requiredLength = headerLength + contentLength;
98
+ if (requiredLength <= this.position) {
99
+ // This is just a view onto the current buffer.
100
+ var contentBytes = this.buffer.subarray(headerLength, headerLength + contentLength);
101
+ var content = this.decoder.decode(contentBytes);
102
+ this.buffer.copyWithin(0, headerLength + contentLength, this.position);
103
+ this.position = this.position - (headerLength + contentLength);
104
+ return { headers: headers, content: content };
105
+ }
106
+ }
107
+ }
108
+ return null;
109
+ };
110
+ return JsonRpcReader;
111
+ }());
112
+ exports.JsonRpcReader = JsonRpcReader;
113
+ /** Encodes the string content to a JSON RPC message. */
114
+ function encodeJsonRpc(content) {
115
+ var e_2, _a;
116
+ var headers = {
117
+ 'Content-Length': String(new TextEncoder().encode(content).byteLength),
118
+ };
119
+ var requestString = '';
120
+ try {
121
+ for (var _b = __values(Object.keys(headers)), _c = _b.next(); !_c.done; _c = _b.next()) {
122
+ var key = _c.value;
123
+ requestString += "".concat(key, ": ").concat(headers[key], "\r\n");
124
+ }
125
+ }
126
+ catch (e_2_1) { e_2 = { error: e_2_1 }; }
127
+ finally {
128
+ try {
129
+ if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
130
+ }
131
+ finally { if (e_2) throw e_2.error; }
132
+ }
133
+ requestString += '\r\n';
134
+ requestString += content;
135
+ return requestString;
136
+ }
137
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"json_rpc.js","sourceRoot":"","sources":["../../../../../../third_party/colab/sources/json_rpc.ts"],"names":[],"mappings":"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","sourcesContent":["const CR = 13;\nconst LF = 10;\n\n/** Messages received via the reader. */\nexport interface JsonRpcMessage {\n  readonly headers: {[key: string]: string};\n  readonly content: string;\n}\n\n/**\n * JSON RPC reader following the Debug Adapter Protocol message\n * format which itself follows Chrome's V8 debugger protocol, originally\n * documented at\n * https://github.com/buggerjs/bugger-v8-client/blob/master/PROTOCOL.md#v8-debugger-protocol\n */\nexport class JsonRpcReader {\n  private buffer: Uint8Array;\n  private position: number = 0;\n  private readonly allocationSize = 4096;\n  private readonly decoder = new TextDecoder();\n\n  constructor(readonly callback: (message: JsonRpcMessage) => void) {\n    this.buffer = new Uint8Array(this.allocationSize);\n  }\n\n  append(data: Uint8Array): JsonRpcMessage[] {\n    // Grow the buffer if necessary to hold the data.\n    if (data.byteLength > (this.buffer.byteLength - this.position)) {\n      const requiredSize = this.position + data.byteLength;\n      const newSize =\n          Math.ceil(requiredSize / this.allocationSize) * this.allocationSize;\n      const newBuffer = new Uint8Array(newSize);\n      newBuffer.set(this.buffer, 0);\n      this.buffer = newBuffer;\n    }\n    // Push new data onto end of the buffer.\n    this.buffer.set(data, this.position);\n    this.position += data.byteLength;\n\n    const parsedMessages = [];\n    while (true) {\n      // Parse all messages out of the buffer.\n      const message = this.tryReadMessage();\n      if (!message) {\n        break;\n      }\n      parsedMessages.push(message);\n      this.callback(message);\n    }\n    return parsedMessages;\n  }\n\n  tryReadMessage(): JsonRpcMessage|null {\n    // Loop through looking for \\r\\n\\r\\n in the buffer.\n    for (let i = 0; i < this.position - 4; ++i) {\n      // First \\r\\n indicates the end of the headers.\n      if (this.buffer[i] === CR && this.buffer[i + 1] === LF &&\n          this.buffer[i + 2] === CR && this.buffer[i + 3] === LF) {\n        // Parse each of the header lines out of the header block.\n        const headerLength = i + 4;\n        const headerBytes = this.buffer.subarray(0, headerLength);\n        const headerString = this.decoder.decode(headerBytes);\n        const headerLines = headerString.split('\\r\\n');\n        const headers: {[key: string]: string} = {};\n        for (const line of headerLines) {\n          if (!line.trim()) {\n            continue;\n          }\n          const pair = line.split(':');\n          if (pair.length !== 2) {\n            throw new Error(`Illegal header value: ${line}`);\n          }\n          headers[pair[0]] = pair[1].trim();\n        }\n        const contentLengthString = headers['Content-Length'];\n        if (!contentLengthString) {\n          throw new Error('Missing Content-Length header.');\n        }\n        const contentLength = Number(contentLengthString);\n        if (isNaN(contentLength)) {\n          throw new Error(\n              `Header Content-Length not a number: ${contentLengthString}.`);\n        }\n        const requiredLength = headerLength + contentLength;\n        if (requiredLength <= this.position) {\n          // This is just a view onto the current buffer.\n          const contentBytes =\n              this.buffer.subarray(headerLength, headerLength + contentLength);\n          const content = this.decoder.decode(contentBytes);\n          this.buffer.copyWithin(\n              0, headerLength + contentLength, this.position);\n          this.position = this.position - (headerLength + contentLength);\n          return {headers, content};\n        }\n      }\n    }\n    return null;\n  }\n}\n\n/** Encodes the string content to a JSON RPC message. */\nexport function encodeJsonRpc(content: string): string {\n  const headers: {[key: string]: string} = {\n    'Content-Length': String(new TextEncoder().encode(content).byteLength),\n  };\n  let requestString = '';\n  for (const key of Object.keys(headers)) {\n    requestString += `${key}: ${headers[key]}\\r\\n`;\n  }\n  requestString += '\\r\\n';\n  requestString += content;\n  return requestString;\n}\n"]}
datalab/web/jupyter.js ADDED
@@ -0,0 +1,213 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ "use strict";
2
+ /*
3
+ * Copyright 2015 Google Inc. All rights reserved.
4
+ *
5
+ * Licensed under the Apache License, Version 2.0 (the "License"); you may not
6
+ * use this file except in compliance with the License. You may obtain a copy of
7
+ * the License at
8
+ *
9
+ * http://www.apache.org/licenses/LICENSE-2.0
10
+ *
11
+ * Unless required by applicable law or agreed to in writing, software
12
+ * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
13
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
14
+ * License for the specific language governing permissions and limitations under
15
+ * the License.
16
+ */
17
+ var __values = (this && this.__values) || function(o) {
18
+ var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
19
+ if (m) return m.call(o);
20
+ if (o && typeof o.length === "number") return {
21
+ next: function () {
22
+ if (o && i >= o.length) o = void 0;
23
+ return { value: o && o[i++], done: !o };
24
+ }
25
+ };
26
+ throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
27
+ };
28
+ Object.defineProperty(exports, "__esModule", { value: true });
29
+ exports.init = init;
30
+ exports.close = close;
31
+ exports.handleSocket = handleSocket;
32
+ exports.handleRequest = handleRequest;
33
+ var childProcess = require("child_process");
34
+ var httpProxy = require("http-proxy");
35
+ var path = require("path");
36
+ var logging = require("./logging");
37
+ /**
38
+ * Singleton tracking the jupyter server instance we manage.
39
+ */
40
+ var jupyterServer = null;
41
+ /**
42
+ * The maximum number of times we'll restart jupyter; we set a limit to avoid
43
+ * users being stuck with a slow-crash-looping server.
44
+ */
45
+ var remainingJupyterServerRestarts = 20;
46
+ /**
47
+ * The application settings instance.
48
+ */
49
+ var appSettings;
50
+ /*
51
+ * This list of levels should match the ones used by Python:
52
+ * https://docs.python.org/3/library/logging.html#logging-levels
53
+ */
54
+ var LogLevels;
55
+ (function (LogLevels) {
56
+ LogLevels["CRITICAL"] = "CRITICAL";
57
+ LogLevels["ERROR"] = "ERROR";
58
+ LogLevels["WARNING"] = "WARNING";
59
+ LogLevels["INFO"] = "INFO";
60
+ LogLevels["DEBUG"] = "DEBUG";
61
+ LogLevels["NOTSET"] = "NOTSET";
62
+ })(LogLevels || (LogLevels = {}));
63
+ function pipeOutput(stream) {
64
+ stream.setEncoding('utf8');
65
+ // The format we parse here corresponds to the log format we set in our
66
+ // jupyter configuration.
67
+ var logger = logging.getJupyterLogger();
68
+ stream.on('data', function (data) {
69
+ var e_1, _a;
70
+ try {
71
+ for (var _b = __values(data.split('\n')), _c = _b.next(); !_c.done; _c = _b.next()) {
72
+ var line = _c.value;
73
+ if (line.trim().length === 0) {
74
+ continue;
75
+ }
76
+ var parts = line.split('|', 3);
77
+ if (parts.length !== 3) {
78
+ // Non-logging messages (eg tracebacks) get logged as warnings.
79
+ logger.warn(line);
80
+ continue;
81
+ }
82
+ var level = parts[1];
83
+ var message = parts[2];
84
+ // We need to map Python's log levels to those used by bunyan.
85
+ if (level === LogLevels.CRITICAL || level === LogLevels.ERROR) {
86
+ logger.error(message);
87
+ }
88
+ else if (level === LogLevels.WARNING) {
89
+ logger.warn(message);
90
+ }
91
+ else if (level === LogLevels.INFO) {
92
+ logger.info(message);
93
+ }
94
+ else {
95
+ // We map DEBUG, NOTSET, and any unknown log levels to debug.
96
+ logger.debug(message);
97
+ }
98
+ }
99
+ }
100
+ catch (e_1_1) { e_1 = { error: e_1_1 }; }
101
+ finally {
102
+ try {
103
+ if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
104
+ }
105
+ finally { if (e_1) throw e_1.error; }
106
+ }
107
+ });
108
+ }
109
+ function createJupyterServer() {
110
+ var e_2, _a;
111
+ if (!remainingJupyterServerRestarts) {
112
+ logging.getLogger().error('No jupyter restart attempts remaining.');
113
+ return;
114
+ }
115
+ remainingJupyterServerRestarts -= 1;
116
+ var port = appSettings.nextJupyterPort;
117
+ logging.getLogger().info('Launching Jupyter server at %d', port);
118
+ var jupyterArgs = appSettings.jupyterArgs || [];
119
+ function exitHandler(code, signal) {
120
+ if (jupyterServer) {
121
+ logging.getLogger().error('Jupyter process %d exited due to signal: %s', jupyterServer.childProcess.pid, signal);
122
+ }
123
+ else {
124
+ logging.getLogger().error('Jupyter process exit before server creation finished due to signal: %s', signal);
125
+ }
126
+ // We want to restart jupyter whenever it terminates.
127
+ createJupyterServer();
128
+ }
129
+ var contentDir = path.join(appSettings.datalabRoot, appSettings.contentDir);
130
+ var processArgs = ['notebook'].concat(jupyterArgs || []).concat([
131
+ "--port=".concat(port),
132
+ "--FileContentsManager.root_dir=".concat(appSettings.datalabRoot, "/"),
133
+ // TODO: b/136659627 - Delete this line.
134
+ "--MappingKernelManager.root_dir=".concat(contentDir),
135
+ ]);
136
+ var jupyterServerAddr = 'localhost';
137
+ try {
138
+ for (var jupyterArgs_1 = __values(jupyterArgs), jupyterArgs_1_1 = jupyterArgs_1.next(); !jupyterArgs_1_1.done; jupyterArgs_1_1 = jupyterArgs_1.next()) {
139
+ var flag = jupyterArgs_1_1.value;
140
+ // Extracts a string like '1.2.3.4' from the string '--ip=1.2.3.4'
141
+ var match = flag.match(/--ip=([^ ]+)/);
142
+ if (match) {
143
+ jupyterServerAddr = match[1];
144
+ break;
145
+ }
146
+ }
147
+ }
148
+ catch (e_2_1) { e_2 = { error: e_2_1 }; }
149
+ finally {
150
+ try {
151
+ if (jupyterArgs_1_1 && !jupyterArgs_1_1.done && (_a = jupyterArgs_1.return)) _a.call(jupyterArgs_1);
152
+ }
153
+ finally { if (e_2) throw e_2.error; }
154
+ }
155
+ logging.getLogger().info('Using jupyter server address %s', jupyterServerAddr);
156
+ var processOptions = {
157
+ detached: false,
158
+ env: process.env,
159
+ };
160
+ var serverProcess = childProcess.spawn('jupyter', processArgs, processOptions);
161
+ serverProcess.on('exit', exitHandler);
162
+ logging.getLogger().info('Jupyter process started with pid %d and args %j', serverProcess.pid, processArgs);
163
+ // Capture the output, so it can be piped for logging.
164
+ pipeOutput(serverProcess.stdout);
165
+ pipeOutput(serverProcess.stderr);
166
+ // Create the proxy.
167
+ var proxyTargetHost = appSettings.kernelManagerProxyHost || jupyterServerAddr;
168
+ var proxyTargetPort = appSettings.kernelManagerProxyPort || port;
169
+ var proxy = httpProxy.createProxyServer({ target: "http://".concat(proxyTargetHost, ":").concat(proxyTargetPort) });
170
+ proxy.on('error', errorHandler);
171
+ jupyterServer = { port: port, proxy: proxy, childProcess: serverProcess };
172
+ }
173
+ /**
174
+ * Initializes the Jupyter server manager.
175
+ */
176
+ function init(settings) {
177
+ appSettings = settings;
178
+ createJupyterServer();
179
+ }
180
+ /**
181
+ * Closes the Jupyter server manager.
182
+ */
183
+ function close() {
184
+ if (!jupyterServer) {
185
+ return;
186
+ }
187
+ var pid = jupyterServer.childProcess.pid;
188
+ logging.getLogger().info("jupyter close: PID: ".concat(pid));
189
+ jupyterServer.childProcess.kill('SIGHUP');
190
+ }
191
+ /** Proxy this socket request to jupyter. */
192
+ function handleSocket(request, socket, head) {
193
+ if (!jupyterServer) {
194
+ logging.getLogger().error('Jupyter server is not running.');
195
+ return;
196
+ }
197
+ jupyterServer.proxy.ws(request, socket, head);
198
+ }
199
+ /** Proxy this HTTP request to jupyter. */
200
+ function handleRequest(request, response) {
201
+ if (!jupyterServer) {
202
+ response.statusCode = 500;
203
+ response.end();
204
+ return;
205
+ }
206
+ jupyterServer.proxy.web(request, response, null);
207
+ }
208
+ function errorHandler(error, request, response) {
209
+ logging.getLogger().error(error, 'Jupyter server returned error.');
210
+ response.writeHead(500, 'Internal Server Error');
211
+ response.end();
212
+ }
213
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"jupyter.js","sourceRoot":"","sources":["../../../../../../third_party/colab/sources/jupyter.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015 Google Inc. All rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\"); you may not\n * use this file except in compliance with the License. You may obtain a copy of\n * the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS, WITHOUT\n * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the\n * License for the specific language governing permissions and limitations under\n * the License.\n */\n\nimport * as childProcess from 'child_process';\nimport * as http from 'http';\nimport * as httpProxy from 'http-proxy';\nimport * as net from 'net';\nimport * as path from 'path';\n\nimport {AppSettings} from './appSettings';\nimport * as logging from './logging';\n\ninterface JupyterServer {\n  port: number;\n  childProcess: childProcess.ChildProcess;\n  proxy: httpProxy.ProxyServer;\n}\n\n/**\n * Singleton tracking the jupyter server instance we manage.\n */\nlet jupyterServer: JupyterServer|null = null;\n\n/**\n * The maximum number of times we'll restart jupyter; we set a limit to avoid\n * users being stuck with a slow-crash-looping server.\n */\nlet remainingJupyterServerRestarts: number = 20;\n\n/**\n * The application settings instance.\n */\nlet appSettings: AppSettings;\n\n/*\n * This list of levels should match the ones used by Python:\n *   https://docs.python.org/3/library/logging.html#logging-levels\n */\nenum LogLevels {\n  CRITICAL = 'CRITICAL',\n  ERROR = 'ERROR',\n  WARNING = 'WARNING',\n  INFO = 'INFO',\n  DEBUG = 'DEBUG',\n  NOTSET = 'NOTSET',\n}\n\nfunction pipeOutput(stream: NodeJS.ReadableStream) {\n  stream.setEncoding('utf8');\n\n  // The format we parse here corresponds to the log format we set in our\n  // jupyter configuration.\n  const logger = logging.getJupyterLogger();\n  stream.on('data', (data: string) => {\n    for (const line of data.split('\\n')) {\n      if (line.trim().length === 0) {\n        continue;\n      }\n      const parts = line.split('|', 3);\n      if (parts.length !== 3) {\n        // Non-logging messages (eg tracebacks) get logged as warnings.\n        logger.warn(line);\n        continue;\n      }\n      const level = parts[1];\n      const message = parts[2];\n      // We need to map Python's log levels to those used by bunyan.\n      if (level === LogLevels.CRITICAL || level === LogLevels.ERROR) {\n        logger.error(message);\n      } else if (level === LogLevels.WARNING) {\n        logger.warn(message);\n      } else if (level === LogLevels.INFO) {\n        logger.info(message);\n      } else {\n        // We map DEBUG, NOTSET, and any unknown log levels to debug.\n        logger.debug(message);\n      }\n    }\n  });\n}\n\nfunction createJupyterServer() {\n  if (!remainingJupyterServerRestarts) {\n    logging.getLogger().error('No jupyter restart attempts remaining.');\n    return;\n  }\n  remainingJupyterServerRestarts -= 1;\n  const port = appSettings.nextJupyterPort;\n  logging.getLogger().info('Launching Jupyter server at %d', port);\n  const jupyterArgs = appSettings.jupyterArgs || [];\n\n  function exitHandler(code: number, signal: string): void {\n    if (jupyterServer) {\n      logging.getLogger().error(\n          'Jupyter process %d exited due to signal: %s',\n          jupyterServer.childProcess.pid!, signal);\n    } else {\n      logging.getLogger().error(\n          'Jupyter process exit before server creation finished due to signal: %s',\n          signal);\n    }\n    // We want to restart jupyter whenever it terminates.\n    createJupyterServer();\n  }\n\n  const contentDir = path.join(appSettings.datalabRoot, appSettings.contentDir);\n  const processArgs = ['notebook'].concat(jupyterArgs || []).concat([\n    `--port=${port}`,\n    `--FileContentsManager.root_dir=${appSettings.datalabRoot}/`,\n    // TODO: b/136659627 - Delete this line.\n    `--MappingKernelManager.root_dir=${contentDir}`,\n  ]);\n\n  let jupyterServerAddr = 'localhost';\n  for (const flag of jupyterArgs) {\n    // Extracts a string like '1.2.3.4' from the string '--ip=1.2.3.4'\n    const match = flag.match(/--ip=([^ ]+)/);\n    if (match) {\n      jupyterServerAddr = match[1];\n      break;\n    }\n  }\n  logging.getLogger().info(\n      'Using jupyter server address %s', jupyterServerAddr);\n\n  const processOptions = {\n    detached: false,\n    env: process.env,\n  };\n\n  const serverProcess =\n      childProcess.spawn('jupyter', processArgs, processOptions);\n  serverProcess.on('exit', exitHandler);\n  logging.getLogger().info(\n      'Jupyter process started with pid %d and args %j', serverProcess.pid!,\n      processArgs);\n\n  // Capture the output, so it can be piped for logging.\n  pipeOutput(serverProcess.stdout);\n  pipeOutput(serverProcess.stderr);\n\n  // Create the proxy.\n  const proxyTargetHost =\n      appSettings.kernelManagerProxyHost || jupyterServerAddr;\n  const proxyTargetPort = appSettings.kernelManagerProxyPort || port;\n\n  const proxy = httpProxy.createProxyServer(\n      {target: `http://${proxyTargetHost}:${proxyTargetPort}`});\n  proxy.on('error', errorHandler);\n\n  jupyterServer = {port, proxy, childProcess: serverProcess};\n}\n\n/**\n * Initializes the Jupyter server manager.\n */\nexport function init(settings: AppSettings): void {\n  appSettings = settings;\n  createJupyterServer();\n}\n\n/**\n * Closes the Jupyter server manager.\n */\nexport function close(): void {\n  if (!jupyterServer) {\n    return;\n  }\n\n  const pid = jupyterServer.childProcess.pid;\n  logging.getLogger().info(`jupyter close: PID: ${pid}`);\n  jupyterServer.childProcess.kill('SIGHUP');\n}\n\n/** Proxy this socket request to jupyter. */\nexport function handleSocket(\n    request: http.IncomingMessage, socket: net.Socket, head: Buffer) {\n  if (!jupyterServer) {\n    logging.getLogger().error('Jupyter server is not running.');\n    return;\n  }\n  jupyterServer.proxy.ws(request, socket, head);\n}\n\n/** Proxy this HTTP request to jupyter. */\nexport function handleRequest(\n    request: http.IncomingMessage, response: http.ServerResponse) {\n  if (!jupyterServer) {\n    response.statusCode = 500;\n    response.end();\n    return;\n  }\n\n  jupyterServer.proxy.web(request, response, null);\n}\n\nfunction errorHandler(\n    error: Error, request: http.IncomingMessage,\n    response: http.ServerResponse) {\n  logging.getLogger().error(error, 'Jupyter server returned error.');\n\n  response.writeHead(500, 'Internal Server Error');\n  response.end();\n}\n"]}
datalab/web/logging.js ADDED
@@ -0,0 +1,129 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ "use strict";
2
+ /*
3
+ * Copyright 2015 Google Inc. All rights reserved.
4
+ *
5
+ * Licensed under the Apache License, Version 2.0 (the "License"); you may not
6
+ * use this file except in compliance with the License. You may obtain a copy of
7
+ * the License at
8
+ *
9
+ * http://www.apache.org/licenses/LICENSE-2.0
10
+ *
11
+ * Unless required by applicable law or agreed to in writing, software
12
+ * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
13
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
14
+ * License for the specific language governing permissions and limitations under
15
+ * the License.
16
+ */
17
+ var __values = (this && this.__values) || function(o) {
18
+ var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
19
+ if (m) return m.call(o);
20
+ if (o && typeof o.length === "number") return {
21
+ next: function () {
22
+ if (o && i >= o.length) o = void 0;
23
+ return { value: o && o[i++], done: !o };
24
+ }
25
+ };
26
+ throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
27
+ };
28
+ Object.defineProperty(exports, "__esModule", { value: true });
29
+ exports.getLogger = getLogger;
30
+ exports.getJupyterLogger = getJupyterLogger;
31
+ exports.logRequest = logRequest;
32
+ exports.initializeLoggers = initializeLoggers;
33
+ var bunyan = require("bunyan");
34
+ var path = require("path");
35
+ // We import the bunyan-rotating-file-stream package, which exports a
36
+ // constructor as a single object; we use lint disables here to make the usage
37
+ // below look reasonable.
38
+ //
39
+ // tslint:disable-next-line:no-require-imports variable-name enforce-name-casing
40
+ var RotatingFileStream = require('bunyan-rotating-file-stream');
41
+ var logger = null;
42
+ var requestLogger = null;
43
+ var jupyterLogger = null;
44
+ /**
45
+ * Gets the logger for generating debug logs.
46
+ * @returns the logger configured for debugging logging.
47
+ */
48
+ function getLogger() {
49
+ return logger;
50
+ }
51
+ /**
52
+ * Gets the logger for generating Jupyter logs.
53
+ * @returns the logger configured for Jupyter logging.
54
+ */
55
+ function getJupyterLogger() {
56
+ return jupyterLogger;
57
+ }
58
+ /**
59
+ * Logs a request and the corresponding response.
60
+ * @param request the request to be logged.
61
+ * @param response the response to be logged.
62
+ */
63
+ function logRequest(request, response) {
64
+ requestLogger.debug({ url: request.url, method: request.method }, 'Received a new request');
65
+ response.on('finish', function () {
66
+ requestLogger.debug({
67
+ url: request.url,
68
+ method: request.method,
69
+ status: response.statusCode
70
+ });
71
+ });
72
+ }
73
+ /**
74
+ * Initializes loggers used within the application.
75
+ */
76
+ function initializeLoggers(settings) {
77
+ var e_1, _a;
78
+ // We configure our loggers as follows:
79
+ // * our base logger tags all log records with `"name":"app"`, and sends logs
80
+ // to stderr (including logs of all children)
81
+ // * one child logger adds `"type":"request"`, and records method/URL for all
82
+ // HTTP requests to the app, and method/URL/response code for all responses
83
+ // * one child logger adds `"type":"jupyter"`, and records all messages from
84
+ // the jupyter notebook server. These logs are also sent to a file on disk
85
+ // (to assist user debugging).
86
+ //
87
+ // For more about bunyan, see:
88
+ // https://github.com/trentm/node-bunyan/tree/f21007d46c0e64072617380b70d3f542368318a8
89
+ var jupyterLogPath = path.join(settings.datalabRoot, '/var/colab/app.log');
90
+ logger = bunyan.createLogger({
91
+ name: 'app',
92
+ streams: [
93
+ { level: 'debug', type: 'stream', stream: process.stderr },
94
+ ]
95
+ });
96
+ requestLogger = logger.child({ type: 'request' });
97
+ jupyterLogger = logger.child({
98
+ type: 'jupyter',
99
+ streams: [{
100
+ level: 'info',
101
+ type: 'stream',
102
+ stream: new RotatingFileStream({
103
+ path: jupyterLogPath,
104
+ rotateExisting: false,
105
+ threshold: '2m',
106
+ totalSize: '20m'
107
+ }),
108
+ }]
109
+ });
110
+ // Omit superfluous fields, unless using the bunyan CLI to make logs human
111
+ // readable, because the CLI requires them.
112
+ if (process.env['COLAB_HUMAN_READABLE_NODE_LOGS'] !== '1') {
113
+ try {
114
+ for (var _b = __values([logger, jupyterLogger, requestLogger]), _c = _b.next(); !_c.done; _c = _b.next()) {
115
+ var logs = _c.value;
116
+ delete logs.fields['hostname'];
117
+ delete logs.fields['name'];
118
+ }
119
+ }
120
+ catch (e_1_1) { e_1 = { error: e_1_1 }; }
121
+ finally {
122
+ try {
123
+ if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
124
+ }
125
+ finally { if (e_1) throw e_1.error; }
126
+ }
127
+ }
128
+ }
129
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nZ2luZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3RoaXJkX3BhcnR5L2NvbGFiL3NvdXJjZXMvbG9nZ2luZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7Ozs7Ozs7Ozs7O0dBY0c7Ozs7Ozs7Ozs7Ozs7QUF1QkgsOEJBRUM7QUFNRCw0Q0FFQztBQU9ELGdDQVdDO0FBS0QsOENBeUNDO0FBL0ZELCtCQUFpQztBQUVqQywyQkFBNkI7QUFJN0IscUVBQXFFO0FBQ3JFLDhFQUE4RTtBQUM5RSx5QkFBeUI7QUFDekIsRUFBRTtBQUNGLGdGQUFnRjtBQUNoRixJQUFNLGtCQUFrQixHQUFHLE9BQU8sQ0FBQyw2QkFBNkIsQ0FBQyxDQUFDO0FBRWxFLElBQUksTUFBTSxHQUF3QixJQUFJLENBQUM7QUFDdkMsSUFBSSxhQUFhLEdBQXdCLElBQUksQ0FBQztBQUM5QyxJQUFJLGFBQWEsR0FBd0IsSUFBSSxDQUFDO0FBRTlDOzs7R0FHRztBQUNILFNBQWdCLFNBQVM7SUFDdkIsT0FBTyxNQUFPLENBQUM7QUFDakIsQ0FBQztBQUVEOzs7R0FHRztBQUNILFNBQWdCLGdCQUFnQjtJQUM5QixPQUFPLGFBQWMsQ0FBQztBQUN4QixDQUFDO0FBRUQ7Ozs7R0FJRztBQUNILFNBQWdCLFVBQVUsQ0FDdEIsT0FBNkIsRUFBRSxRQUE2QjtJQUM5RCxhQUFjLENBQUMsS0FBSyxDQUNoQixFQUFDLEdBQUcsRUFBRSxPQUFPLENBQUMsR0FBRyxFQUFFLE1BQU0sRUFBRSxPQUFPLENBQUMsTUFBTSxFQUFDLEVBQUUsd0JBQXdCLENBQUMsQ0FBQztJQUMxRSxRQUFRLENBQUMsRUFBRSxDQUFDLFFBQVEsRUFBRTtRQUNwQixhQUFjLENBQUMsS0FBSyxDQUFDO1lBQ25CLEdBQUcsRUFBRSxPQUFPLENBQUMsR0FBRztZQUNoQixNQUFNLEVBQUUsT0FBTyxDQUFDLE1BQU07WUFDdEIsTUFBTSxFQUFFLFFBQVEsQ0FBQyxVQUFVO1NBQzVCLENBQUMsQ0FBQztJQUNMLENBQUMsQ0FBQyxDQUFDO0FBQ0wsQ0FBQztBQUVEOztHQUVHO0FBQ0gsU0FBZ0IsaUJBQWlCLENBQUMsUUFBcUI7O0lBQ3JELHVDQUF1QztJQUN2Qyw4RUFBOEU7SUFDOUUsZ0RBQWdEO0lBQ2hELDhFQUE4RTtJQUM5RSw4RUFBOEU7SUFDOUUsNkVBQTZFO0lBQzdFLDZFQUE2RTtJQUM3RSxpQ0FBaUM7SUFDakMsRUFBRTtJQUNGLDhCQUE4QjtJQUM5Qix3RkFBd0Y7SUFDeEYsSUFBTSxjQUFjLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsV0FBVyxFQUFFLG9CQUFvQixDQUFDLENBQUM7SUFDN0UsTUFBTSxHQUFHLE1BQU0sQ0FBQyxZQUFZLENBQUM7UUFDM0IsSUFBSSxFQUFFLEtBQUs7UUFDWCxPQUFPLEVBQUU7WUFDUCxFQUFDLEtBQUssRUFBRSxPQUFPLEVBQUUsSUFBSSxFQUFFLFFBQVEsRUFBRSxNQUFNLEVBQUUsT0FBTyxDQUFDLE1BQU0sRUFBQztTQUN6RDtLQUNGLENBQUMsQ0FBQztJQUNILGFBQWEsR0FBRyxNQUFNLENBQUMsS0FBSyxDQUFDLEVBQUMsSUFBSSxFQUFFLFNBQVMsRUFBQyxDQUFDLENBQUM7SUFDaEQsYUFBYSxHQUFHLE1BQU0sQ0FBQyxLQUFLLENBQUM7UUFDM0IsSUFBSSxFQUFFLFNBQVM7UUFDZixPQUFPLEVBQUUsQ0FBQztnQkFDUixLQUFLLEVBQUUsTUFBTTtnQkFDYixJQUFJLEVBQUUsUUFBUTtnQkFDZCxNQUFNLEVBQUUsSUFBSSxrQkFBa0IsQ0FBQztvQkFDN0IsSUFBSSxFQUFFLGNBQWM7b0JBQ3BCLGNBQWMsRUFBRSxLQUFLO29CQUNyQixTQUFTLEVBQUUsSUFBSTtvQkFDZixTQUFTLEVBQUUsS0FBSztpQkFDakIsQ0FBQzthQUNILENBQUM7S0FDSCxDQUFDLENBQUM7SUFDSCwwRUFBMEU7SUFDMUUsMkNBQTJDO0lBQzNDLElBQUksT0FBTyxDQUFDLEdBQUcsQ0FBQyxnQ0FBZ0MsQ0FBQyxLQUFLLEdBQUcsRUFBRSxDQUFDOztZQUMxRCxLQUFtQixJQUFBLEtBQUEsU0FBQSxDQUFDLE1BQU0sRUFBRSxhQUFhLEVBQUUsYUFBYSxDQUFDLENBQUEsZ0JBQUEsNEJBQUUsQ0FBQztnQkFBdkQsSUFBTSxJQUFJLFdBQUE7Z0JBQ2IsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDO2dCQUMvQixPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUM7WUFDN0IsQ0FBQzs7Ozs7Ozs7O0lBQ0gsQ0FBQztBQUNILENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogQ29weXJpZ2h0IDIwMTUgR29vZ2xlIEluYy4gQWxsIHJpZ2h0cyByZXNlcnZlZC5cbiAqXG4gKiBMaWNlbnNlZCB1bmRlciB0aGUgQXBhY2hlIExpY2Vuc2UsIFZlcnNpb24gMi4wICh0aGUgXCJMaWNlbnNlXCIpOyB5b3UgbWF5IG5vdFxuICogdXNlIHRoaXMgZmlsZSBleGNlcHQgaW4gY29tcGxpYW5jZSB3aXRoIHRoZSBMaWNlbnNlLiBZb3UgbWF5IG9idGFpbiBhIGNvcHkgb2ZcbiAqIHRoZSBMaWNlbnNlIGF0XG4gKlxuICogaHR0cDovL3d3dy5hcGFjaGUub3JnL2xpY2Vuc2VzL0xJQ0VOU0UtMi4wXG4gKlxuICogVW5sZXNzIHJlcXVpcmVkIGJ5IGFwcGxpY2FibGUgbGF3IG9yIGFncmVlZCB0byBpbiB3cml0aW5nLCBzb2Z0d2FyZVxuICogZGlzdHJpYnV0ZWQgdW5kZXIgdGhlIExpY2Vuc2UgaXMgZGlzdHJpYnV0ZWQgb24gYW4gXCJBUyBJU1wiIEJBU0lTLCBXSVRIT1VUXG4gKiBXQVJSQU5USUVTIE9SIENPTkRJVElPTlMgT0YgQU5ZIEtJTkQsIGVpdGhlciBleHByZXNzIG9yIGltcGxpZWQuIFNlZSB0aGVcbiAqIExpY2Vuc2UgZm9yIHRoZSBzcGVjaWZpYyBsYW5ndWFnZSBnb3Zlcm5pbmcgcGVybWlzc2lvbnMgYW5kIGxpbWl0YXRpb25zIHVuZGVyXG4gKiB0aGUgTGljZW5zZS5cbiAqL1xuXG5pbXBvcnQgKiBhcyBidW55YW4gZnJvbSAnYnVueWFuJztcbmltcG9ydCAqIGFzIGh0dHAgZnJvbSAnaHR0cCc7XG5pbXBvcnQgKiBhcyBwYXRoIGZyb20gJ3BhdGgnO1xuXG5pbXBvcnQge0FwcFNldHRpbmdzfSBmcm9tICcuL2FwcFNldHRpbmdzJztcblxuLy8gV2UgaW1wb3J0IHRoZSBidW55YW4tcm90YXRpbmctZmlsZS1zdHJlYW0gcGFja2FnZSwgd2hpY2ggZXhwb3J0cyBhXG4vLyBjb25zdHJ1Y3RvciBhcyBhIHNpbmdsZSBvYmplY3Q7IHdlIHVzZSBsaW50IGRpc2FibGVzIGhlcmUgdG8gbWFrZSB0aGUgdXNhZ2Vcbi8vIGJlbG93IGxvb2sgcmVhc29uYWJsZS5cbi8vXG4vLyB0c2xpbnQ6ZGlzYWJsZS1uZXh0LWxpbmU6bm8tcmVxdWlyZS1pbXBvcnRzIHZhcmlhYmxlLW5hbWUgZW5mb3JjZS1uYW1lLWNhc2luZ1xuY29uc3QgUm90YXRpbmdGaWxlU3RyZWFtID0gcmVxdWlyZSgnYnVueWFuLXJvdGF0aW5nLWZpbGUtc3RyZWFtJyk7XG5cbmxldCBsb2dnZXI6IGJ1bnlhbi5JTG9nZ2VyfG51bGwgPSBudWxsO1xubGV0IHJlcXVlc3RMb2dnZXI6IGJ1bnlhbi5JTG9nZ2VyfG51bGwgPSBudWxsO1xubGV0IGp1cHl0ZXJMb2dnZXI6IGJ1bnlhbi5JTG9nZ2VyfG51bGwgPSBudWxsO1xuXG4vKipcbiAqIEdldHMgdGhlIGxvZ2dlciBmb3IgZ2VuZXJhdGluZyBkZWJ1ZyBsb2dzLlxuICogQHJldHVybnMgdGhlIGxvZ2dlciBjb25maWd1cmVkIGZvciBkZWJ1Z2dpbmcgbG9nZ2luZy5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGdldExvZ2dlcigpOiBidW55YW4uSUxvZ2dlciB7XG4gIHJldHVybiBsb2dnZXIhO1xufVxuXG4vKipcbiAqIEdldHMgdGhlIGxvZ2dlciBmb3IgZ2VuZXJhdGluZyBKdXB5dGVyIGxvZ3MuXG4gKiBAcmV0dXJucyB0aGUgbG9nZ2VyIGNvbmZpZ3VyZWQgZm9yIEp1cHl0ZXIgbG9nZ2luZy5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGdldEp1cHl0ZXJMb2dnZXIoKTogYnVueWFuLklMb2dnZXIge1xuICByZXR1cm4ganVweXRlckxvZ2dlciE7XG59XG5cbi8qKlxuICogTG9ncyBhIHJlcXVlc3QgYW5kIHRoZSBjb3JyZXNwb25kaW5nIHJlc3BvbnNlLlxuICogQHBhcmFtIHJlcXVlc3QgdGhlIHJlcXVlc3QgdG8gYmUgbG9nZ2VkLlxuICogQHBhcmFtIHJlc3BvbnNlIHRoZSByZXNwb25zZSB0byBiZSBsb2dnZWQuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBsb2dSZXF1ZXN0KFxuICAgIHJlcXVlc3Q6IGh0dHAuSW5jb21pbmdNZXNzYWdlLCByZXNwb25zZTogaHR0cC5TZXJ2ZXJSZXNwb25zZSk6IHZvaWQge1xuICByZXF1ZXN0TG9nZ2VyIS5kZWJ1ZyhcbiAgICAgIHt1cmw6IHJlcXVlc3QudXJsLCBtZXRob2Q6IHJlcXVlc3QubWV0aG9kfSwgJ1JlY2VpdmVkIGEgbmV3IHJlcXVlc3QnKTtcbiAgcmVzcG9uc2Uub24oJ2ZpbmlzaCcsICgpID0+IHtcbiAgICByZXF1ZXN0TG9nZ2VyIS5kZWJ1Zyh7XG4gICAgICB1cmw6IHJlcXVlc3QudXJsLFxuICAgICAgbWV0aG9kOiByZXF1ZXN0Lm1ldGhvZCxcbiAgICAgIHN0YXR1czogcmVzcG9uc2Uuc3RhdHVzQ29kZVxuICAgIH0pO1xuICB9KTtcbn1cblxuLyoqXG4gKiBJbml0aWFsaXplcyBsb2dnZXJzIHVzZWQgd2l0aGluIHRoZSBhcHBsaWNhdGlvbi5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGluaXRpYWxpemVMb2dnZXJzKHNldHRpbmdzOiBBcHBTZXR0aW5ncyk6IHZvaWQge1xuICAvLyBXZSBjb25maWd1cmUgb3VyIGxvZ2dlcnMgYXMgZm9sbG93czpcbiAgLy8gICogb3VyIGJhc2UgbG9nZ2VyIHRhZ3MgYWxsIGxvZyByZWNvcmRzIHdpdGggYFwibmFtZVwiOlwiYXBwXCJgLCBhbmQgc2VuZHMgbG9nc1xuICAvLyAgICB0byBzdGRlcnIgKGluY2x1ZGluZyBsb2dzIG9mIGFsbCBjaGlsZHJlbilcbiAgLy8gICogb25lIGNoaWxkIGxvZ2dlciBhZGRzIGBcInR5cGVcIjpcInJlcXVlc3RcImAsIGFuZCByZWNvcmRzIG1ldGhvZC9VUkwgZm9yIGFsbFxuICAvLyAgICBIVFRQIHJlcXVlc3RzIHRvIHRoZSBhcHAsIGFuZCBtZXRob2QvVVJML3Jlc3BvbnNlIGNvZGUgZm9yIGFsbCByZXNwb25zZXNcbiAgLy8gICogb25lIGNoaWxkIGxvZ2dlciBhZGRzIGBcInR5cGVcIjpcImp1cHl0ZXJcImAsIGFuZCByZWNvcmRzIGFsbCBtZXNzYWdlcyBmcm9tXG4gIC8vICAgIHRoZSBqdXB5dGVyIG5vdGVib29rIHNlcnZlci4gVGhlc2UgbG9ncyBhcmUgYWxzbyBzZW50IHRvIGEgZmlsZSBvbiBkaXNrXG4gIC8vICAgICh0byBhc3Npc3QgdXNlciBkZWJ1Z2dpbmcpLlxuICAvL1xuICAvLyBGb3IgbW9yZSBhYm91dCBidW55YW4sIHNlZTpcbiAgLy8gICBodHRwczovL2dpdGh1Yi5jb20vdHJlbnRtL25vZGUtYnVueWFuL3RyZWUvZjIxMDA3ZDQ2YzBlNjQwNzI2MTczODBiNzBkM2Y1NDIzNjgzMThhOFxuICBjb25zdCBqdXB5dGVyTG9nUGF0aCA9IHBhdGguam9pbihzZXR0aW5ncy5kYXRhbGFiUm9vdCwgJy92YXIvY29sYWIvYXBwLmxvZycpO1xuICBsb2dnZXIgPSBidW55YW4uY3JlYXRlTG9nZ2VyKHtcbiAgICBuYW1lOiAnYXBwJyxcbiAgICBzdHJlYW1zOiBbXG4gICAgICB7bGV2ZWw6ICdkZWJ1ZycsIHR5cGU6ICdzdHJlYW0nLCBzdHJlYW06IHByb2Nlc3Muc3RkZXJyfSxcbiAgICBdXG4gIH0pO1xuICByZXF1ZXN0TG9nZ2VyID0gbG9nZ2VyLmNoaWxkKHt0eXBlOiAncmVxdWVzdCd9KTtcbiAganVweXRlckxvZ2dlciA9IGxvZ2dlci5jaGlsZCh7XG4gICAgdHlwZTogJ2p1cHl0ZXInLFxuICAgIHN0cmVhbXM6IFt7XG4gICAgICBsZXZlbDogJ2luZm8nLFxuICAgICAgdHlwZTogJ3N0cmVhbScsXG4gICAgICBzdHJlYW06IG5ldyBSb3RhdGluZ0ZpbGVTdHJlYW0oe1xuICAgICAgICBwYXRoOiBqdXB5dGVyTG9nUGF0aCxcbiAgICAgICAgcm90YXRlRXhpc3Rpbmc6IGZhbHNlLFxuICAgICAgICB0aHJlc2hvbGQ6ICcybScsXG4gICAgICAgIHRvdGFsU2l6ZTogJzIwbSdcbiAgICAgIH0pLFxuICAgIH1dXG4gIH0pO1xuICAvLyBPbWl0IHN1cGVyZmx1b3VzIGZpZWxkcywgdW5sZXNzIHVzaW5nIHRoZSBidW55YW4gQ0xJIHRvIG1ha2UgbG9ncyBodW1hblxuICAvLyByZWFkYWJsZSwgYmVjYXVzZSB0aGUgQ0xJIHJlcXVpcmVzIHRoZW0uXG4gIGlmIChwcm9jZXNzLmVudlsnQ09MQUJfSFVNQU5fUkVBREFCTEVfTk9ERV9MT0dTJ10gIT09ICcxJykge1xuICAgIGZvciAoY29uc3QgbG9ncyBvZiBbbG9nZ2VyLCBqdXB5dGVyTG9nZ2VyLCByZXF1ZXN0TG9nZ2VyXSkge1xuICAgICAgZGVsZXRlIGxvZ3MuZmllbGRzWydob3N0bmFtZSddO1xuICAgICAgZGVsZXRlIGxvZ3MuZmllbGRzWyduYW1lJ107XG4gICAgfVxuICB9XG59XG4iXX0=
datalab/web/lsp/capabilities_node.js ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FwYWJpbGl0aWVzX25vZGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9nZW5maWxlcy90aGlyZF9wYXJ0eS9jb2xhYi9zb3VyY2VzL2xzcC9jYXBhYmlsaXRpZXNfbm9kZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgcHJvdG9jb2wgZnJvbSAnLi9wcm90b2NvbF9ub2RlJztcbmltcG9ydCAqIGFzIHRleHREb2N1bWVudCBmcm9tICcuL3RleHRfZG9jdW1lbnRfbm9kZSc7XG5pbXBvcnQgKiBhcyB3b3Jrc3BhY2UgZnJvbSAnLi93b3Jrc3BhY2Vfbm9kZSc7XG5cbmRlY2xhcmUgaW50ZXJmYWNlIENsaWVudENhcGFiaWxpdGllcyB7XG4gIC8qKlxuICAgKiBXb3Jrc3BhY2Ugc3BlY2lmaWMgY2xpZW50IGNhcGFiaWxpdGllcy5cbiAgICovXG4gIHdvcmtzcGFjZT86IHtcbiAgICAvKipcbiAgICAgKiBUaGUgY2xpZW50IHN1cHBvcnRzIGFwcGx5aW5nIGJhdGNoIGVkaXRzXG4gICAgICogdG8gdGhlIHdvcmtzcGFjZSBieSBzdXBwb3J0aW5nIHRoZSByZXF1ZXN0XG4gICAgICogJ3dvcmtzcGFjZS9hcHBseUVkaXQnXG4gICAgICovXG4gICAgYXBwbHlFZGl0PzogYm9vbGVhbjtcblxuICAgIC8qKlxuICAgICAqIENhcGFiaWxpdGllcyBzcGVjaWZpYyB0byBgV29ya3NwYWNlRWRpdGBzXG4gICAgICovXG4gICAgd29ya3NwYWNlRWRpdD86IHByb3RvY29sLldvcmtzcGFjZUVkaXRDbGllbnRDYXBhYmlsaXRpZXM7XG5cbiAgICAvKipcbiAgICAgKiBDYXBhYmlsaXRpZXMgc3BlY2lmaWMgdG8gdGhlIGB3b3Jrc3BhY2UvZGlkQ2hhbmdlQ29uZmlndXJhdGlvbmBcbiAgICAgKiBub3RpZmljYXRpb24uXG4gICAgICovXG4gICAgZGlkQ2hhbmdlQ29uZmlndXJhdGlvbj86IHdvcmtzcGFjZS5EaWRDaGFuZ2VDb25maWd1cmF0aW9uQ2xpZW50Q2FwYWJpbGl0aWVzO1xuXG4gICAgLyoqXG4gICAgICogQ2FwYWJpbGl0aWVzIHNwZWNpZmljIHRvIHRoZSBgd29ya3NwYWNlL2RpZENoYW5nZVdhdGNoZWRGaWxlc2BcbiAgICAgKiBub3RpZmljYXRpb24uXG4gICAgICovXG4gICAgZGlkQ2hhbmdlV2F0Y2hlZEZpbGVzPzogd29ya3NwYWNlLkRpZENoYW5nZVdhdGNoZWRGaWxlc0NsaWVudENhcGFiaWxpdGllcztcblxuICAgIC8qKlxuICAgICAqIENhcGFiaWxpdGllcyBzcGVjaWZpYyB0byB0aGUgYHdvcmtzcGFjZS9zeW1ib2xgIHJlcXVlc3QuXG4gICAgICovXG4gICAgc3ltYm9sPzogd29ya3NwYWNlLldvcmtzcGFjZVN5bWJvbENsaWVudENhcGFiaWxpdGllcztcblxuICAgIC8qKlxuICAgICAqIENhcGFiaWxpdGllcyBzcGVjaWZpYyB0byB0aGUgYHdvcmtzcGFjZS9leGVjdXRlQ29tbWFuZGAgcmVxdWVzdC5cbiAgICAgKi9cbiAgICBleGVjdXRlQ29tbWFuZD86IHByb3RvY29sLkV4ZWN1dGVDb21tYW5kQ2xpZW50Q2FwYWJpbGl0aWVzO1xuXG4gICAgLyoqXG4gICAgICogVGhlIGNsaWVudCBoYXMgc3VwcG9ydCBmb3Igd29ya3NwYWNlIGZvbGRlcnMuXG4gICAgICpcbiAgICAgKiBTaW5jZSAzLjYuMFxuICAgICAqL1xuICAgIHdvcmtzcGFjZUZvbGRlcnM/OiBib29sZWFuO1xuXG4gICAgLyoqXG4gICAgICogVGhlIGNsaWVudCBzdXBwb3J0cyBgd29ya3NwYWNlL2NvbmZpZ3VyYXRpb25gIHJlcXVlc3RzLlxuICAgICAqXG4gICAgICogU2luY2UgMy42LjBcbiAgICAgKi9cbiAgICBjb25maWd1cmF0aW9uPzogYm9vbGVhbjtcbiAgfTtcblxuICAvKipcbiAgICogVGV4dCBkb2N1bWVudCBzcGVjaWZpYyBjbGllbnQgY2FwYWJpbGl0aWVzLlxuICAgKi9cbiAgdGV4dERvY3VtZW50PzogdGV4dERvY3VtZW50LlRleHREb2N1bWVudENsaWVudENhcGFiaWxpdGllcztcblxuICAvKipcbiAgICogV2luZG93IHNwZWNpZmljIGNsaWVudCBjYXBhYmlsaXRpZXMuXG4gICAqL1xuICB3aW5kb3c/OiB7XG4gICAgLyoqXG4gICAgICogV2hldGhlciBjbGllbnQgc3VwcG9ydHMgaGFuZGxpbmcgcHJvZ3Jlc3Mgbm90aWZpY2F0aW9ucy5cbiAgICAgKiBJZiBzZXQsIHNlcnZlcnMgYXJlIGFsbG93ZWQgdG8gcmVwb3J0IGluIGB3b3JrRG9uZVByb2dyZXNzYCBwcm9wZXJ0eVxuICAgICAqIGluIHRoZSByZXF1ZXN0IHNwZWNpZmljIHNlcnZlciBjYXBhYmlsaXRpZXMuXG4gICAgICpcbiAgICAgKiBTaW5jZSAzLjE1LjBcbiAgICAgKi9cbiAgICB3b3JrRG9uZVByb2dyZXNzPzogYm9vbGVhbjtcbiAgfTtcblxuICAvKipcbiAgICogRXhwZXJpbWVudGFsIGNsaWVudCBjYXBhYmlsaXRpZXMuXG4gICAqL1xuICBleHBlcmltZW50YWw/OiB1bmtub3duO1xufVxuXG4vKipcbiAqIGh0dHBzOi8vbWljcm9zb2Z0LmdpdGh1Yi5pby9sYW5ndWFnZS1zZXJ2ZXItcHJvdG9jb2wvc3BlY2lmaWNhdGlvbnMvc3BlY2lmaWNhdGlvbi1jdXJyZW50LyNpbml0aWFsaXplXG4gKi9cbmV4cG9ydCBkZWNsYXJlIGludGVyZmFjZSBJbml0aWFsaXplIGV4dGVuZHNcbiAgICBwcm90b2NvbC5SZXF1ZXN0TWVzc2FnZTxJbml0aWFsaXplUGFyYW1zPiB7XG4gIG1ldGhvZDogcHJvdG9jb2wuTWV0aG9kLkluaXRpYWxpemU7XG59XG5cbi8qKlxuICogaHR0cHM6Ly9taWNyb3NvZnQuZ2l0aHViLmlvL2xhbmd1YWdlLXNlcnZlci1wcm90b2NvbC9zcGVjaWZpY2F0aW9ucy9zcGVjaWZpY2F0aW9uLWN1cnJlbnQvI2luaXRpYWxpemVcbiAqL1xuZXhwb3J0IGRlY2xhcmUgaW50ZXJmYWNlIEluaXRpYWxpemVQYXJhbXMgZXh0ZW5kc1xuICAgIHByb3RvY29sLldvcmtEb25lUHJvZ3Jlc3NQYXJhbXMge1xuICAvKipcbiAgICogVGhlIHByb2Nlc3MgSUQgb2YgdGhlIHBhcmVudCBwcm9jZXNzIHRoYXQgc3RhcnRlZCB0aGUgc2VydmVyLlxuICAgKiBJcyBudWxsIGlmIHRoZSBwcm9jZXNzIGhhcyBub3QgYmVlbiBzdGFydGVkIGJ5IGFub3RoZXIgcHJvY2Vzcy5cbiAgICogSWYgdGhlIHBhcmVudCBwcm9jZXNzIGlzIG5vdCBhbGl2ZSwgdGhlbiB0aGUgc2VydmVyIHNob3VsZCBleGl0XG4gICAqIChzZWUgZXhpdCBub3RpZmljYXRpb24pIGl0cyBwcm9jZXNzLlxuICAgKi9cbiAgcHJvY2Vzc0lkOiBudW1iZXJ8bnVsbDtcblxuICAvKipcbiAgICogSW5mb3JtYXRpb24gYWJvdXQgdGhlIGNsaWVudFxuICAgKlxuICAgKiBAc2luY2UgMy4xNS4wXG4gICAqL1xuICBjbGllbnRJbmZvPzoge1xuICAgIC8qKlxuICAgICAqIFRoZSBuYW1lIG9mIHRoZSBjbGllbnQgYXMgZGVmaW5lZCBieSB0aGUgY2xpZW50LlxuICAgICAqL1xuICAgIG5hbWU6IHN0cmluZztcblxuICAgIC8qKlxuICAgICAqIFRoZSBjbGllbnQncyB2ZXJzaW9uIGFzIGRlZmluZWQgYnkgdGhlIGNsaWVudC5cbiAgICAgKi9cbiAgICB2ZXJzaW9uPzogc3RyaW5nO1xuICB9O1xuXG4gIC8qKlxuICAgKiBUaGUgcm9vdFBhdGggb2YgdGhlIHdvcmtzcGFjZS4gSXMgbnVsbFxuICAgKiBpZiBubyBmb2xkZXIgaXMgb3Blbi5cbiAgICpcbiAgICogQGRlcHJlY2F0ZWQgaW4gZmF2b3VyIG9mIHJvb3RVcmkuXG4gICAqL1xuICByb290UGF0aD86IHN0cmluZ3xudWxsO1xuXG4gIC8qKlxuICAgKiBUaGUgcm9vdFVyaSBvZiB0aGUgd29ya3NwYWNlLiBJcyBudWxsIGlmIG5vXG4gICAqIGZvbGRlciBpcyBvcGVuLiBJZiBib3RoIGByb290UGF0aGAgYW5kIGByb290VXJpYCBhcmUgc2V0XG4gICAqIGByb290VXJpYCB3aW5zLlxuICAgKi9cbiAgcm9vdFVyaTogcHJvdG9jb2wuRG9jdW1lbnRVcml8bnVsbDtcblxuICAvKipcbiAgICogVXNlciBwcm92aWRlZCBpbml0aWFsaXphdGlvbiBvcHRpb25zLlxuICAgKi9cbiAgaW5pdGlhbGl6YXRpb25PcHRpb25zPzogdW5rbm93bjtcblxuICAvKipcbiAgICogVGhlIGNhcGFiaWxpdGllcyBwcm92aWRlZCBieSB0aGUgY2xpZW50IChlZGl0b3Igb3IgdG9vbClcbiAgICovXG4gIGNhcGFiaWxpdGllczogQ2xpZW50Q2FwYWJpbGl0aWVzO1xuXG4gIC8qKlxuICAgKiBUaGUgaW5pdGlhbCB0cmFjZSBzZXR0aW5nLiBJZiBvbWl0dGVkIHRyYWNlIGlzIGRpc2FibGVkICgnb2ZmJykuXG4gICAqL1xuICB0cmFjZT86ICdvZmYnfCdtZXNzYWdlcyd8J3ZlcmJvc2UnO1xuXG4gIC8qKlxuICAgKiBUaGUgd29ya3NwYWNlIGZvbGRlcnMgY29uZmlndXJlZCBpbiB0aGUgY2xpZW50IHdoZW4gdGhlIHNlcnZlciBzdGFydHMuXG4gICAqIFRoaXMgcHJvcGVydHkgaXMgb25seSBhdmFpbGFibGUgaWYgdGhlIGNsaWVudCBzdXBwb3J0cyB3b3Jrc3BhY2UgZm9sZGVycy5cbiAgICogSXQgY2FuIGJlIGBudWxsYCBpZiB0aGUgY2xpZW50IHN1cHBvcnRzIHdvcmtzcGFjZSBmb2xkZXJzIGJ1dCBub25lIGFyZVxuICAgKiBjb25maWd1cmVkLlxuICAgKlxuICAgKiBAc2luY2UgMy42LjBcbiAgICovXG4gIHdvcmtzcGFjZUZvbGRlcnM/OiB3b3Jrc3BhY2UuV29ya3NwYWNlRm9sZGVyW118bnVsbDtcbn1cbiJdfQ==
datalab/web/lsp/extensions_node.js ADDED
@@ -0,0 +1,14 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ExecutionStatus = void 0;
4
+ /** The status of a cell's execution. */
5
+ var ExecutionStatus;
6
+ (function (ExecutionStatus) {
7
+ /** The default value for an execution status. */
8
+ ExecutionStatus[ExecutionStatus["UNKNOWN"] = 0] = "UNKNOWN";
9
+ /** Execution is up to date. */
10
+ ExecutionStatus[ExecutionStatus["FRESH"] = 1] = "FRESH";
11
+ /** Execution is out of date. */
12
+ ExecutionStatus[ExecutionStatus["STALE"] = 2] = "STALE";
13
+ })(ExecutionStatus || (exports.ExecutionStatus = ExecutionStatus = {}));
14
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXh0ZW5zaW9uc19ub2RlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vZ2VuZmlsZXMvdGhpcmRfcGFydHkvY29sYWIvc291cmNlcy9sc3AvZXh0ZW5zaW9uc19ub2RlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQW1DQSx3Q0FBd0M7QUFDeEMsSUFBWSxlQU9YO0FBUEQsV0FBWSxlQUFlO0lBQ3pCLGlEQUFpRDtJQUNqRCwyREFBVyxDQUFBO0lBQ1gsK0JBQStCO0lBQy9CLHVEQUFLLENBQUE7SUFDTCxnQ0FBZ0M7SUFDaEMsdURBQUssQ0FBQTtBQUNQLENBQUMsRUFQVyxlQUFlLCtCQUFmLGVBQWUsUUFPMUIiLCJzb3VyY2VzQ29udGVudCI6WyJcbmltcG9ydCAqIGFzIGNhcGFiaWxpdGllcyBmcm9tICcuL2NhcGFiaWxpdGllc19ub2RlJztcbmltcG9ydCAqIGFzIHByb3RvY29sIGZyb20gJy4vcHJvdG9jb2xfbm9kZSc7XG5pbXBvcnQgKiBhcyB0ZXh0RG9jdW1lbnQgZnJvbSAnLi90ZXh0X2RvY3VtZW50X25vZGUnO1xuXG4vLyB0c2xpbnQ6ZGlzYWJsZTplbmZvcmNlLW5hbWUtY2FzaW5nXG5cbi8qKlxuICogUGFyYW1ldGVyIGZvciBgaW5pdGlhbGl6ZWAgbWVzc2FnZXMuXG4gKiBBZGRzIGEgZmxhZyBjb250cm9sbGluZyB3aGV0aGVyIHdlIHJ1biBBdXRvRml4LlxuICovXG5leHBvcnQgZGVjbGFyZSBpbnRlcmZhY2UgSW5pdGlhbGl6ZVBhcmFtcyBleHRlbmRzXG4gICAgY2FwYWJpbGl0aWVzLkluaXRpYWxpemVQYXJhbXMge1xuICBhdXRvRml4OiBib29sZWFuO1xufVxuXG4vKipcbiAqIFBhcmFtZXRlciBmb3IgYHRleHREb2N1bWVudC9kaWRPcGVuYCBtZXNzYWdlcy5cbiAqIEFkZHMgYSBwcmVhbWJsZSBzdHJpbmcuXG4gKi9cbmV4cG9ydCBkZWNsYXJlIGludGVyZmFjZSBEaWRPcGVuVGV4dERvY3VtZW50UGFyYW1zIGV4dGVuZHNcbiAgICB0ZXh0RG9jdW1lbnQuRGlkT3BlblRleHREb2N1bWVudFBhcmFtcyB7XG4gIHJlYWRvbmx5IHByZWFtYmxlOiBzdHJpbmc7XG59XG5cbi8qKiBQYXJhbWV0ZXJzIGZvciBgdGV4dERvY3VtZW50L3JlcGFpcmAgbWVzc2FnZXMuICovXG5leHBvcnQgZGVjbGFyZSBpbnRlcmZhY2UgUmVwYWlyUGFyYW1zIHtcbiAgY29kZTogc3RyaW5nO1xufVxuXG4vKiogUmVzdWx0IGZvciBgdGV4dERvY3VtZW50L3JlcGFpcmAgbWVzc2FnZXMuICovXG5leHBvcnQgZGVjbGFyZSBpbnRlcmZhY2UgUmVwYWlyUmVzdWx0IHtcbiAgcmVwYWlyZWRDb2RlOiBzdHJpbmc7XG59XG5cbi8qKiBUaGUgc3RhdHVzIG9mIGEgY2VsbCdzIGV4ZWN1dGlvbi4gKi9cbmV4cG9ydCBlbnVtIEV4ZWN1dGlvblN0YXR1cyB7XG4gIC8qKiBUaGUgZGVmYXVsdCB2YWx1ZSBmb3IgYW4gZXhlY3V0aW9uIHN0YXR1cy4gKi9cbiAgVU5LTk9XTiA9IDAsXG4gIC8qKiBFeGVjdXRpb24gaXMgdXAgdG8gZGF0ZS4gKi9cbiAgRlJFU0gsXG4gIC8qKiBFeGVjdXRpb24gaXMgb3V0IG9mIGRhdGUuICovXG4gIFNUQUxFLFxufVxuXG4vKipcbiAqIE1hcCBmcm9tIGNlbGwgaW5kZXggdG8gdGhlIGV4ZWN1dGlvbiBzdGF0dXMgb2YgdGhhdCBjZWxsLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIEV4ZWN1dGlvblN0YXR1c2VzIHtcbiAgW2luZGV4OiBudW1iZXJdOiBFeGVjdXRpb25TdGF0dXM7XG59XG5cbi8qKlxuICogRXhwYW5zaW9uRmVhdHVyZXMgZGVmaW5lcyB0aGUgb3B0aW9ucyB0aGF0IGNhbiBiZSBjb25maWd1cmVkIGhvd1xuICogcHJlcmVxdWlzaXRlcyBvciBkZXBlbmRlbnRzIGFyZSBleHBhbmRlZC5cbiAqXG4gKiBTZWUgZWFjaCBmaWVsZCBmb3IgaXRzIHJlc3BlY3RpdmUgZGVmYXVsdC4gTGVmdCB1bnNwZWNpZmllZCwgdGhleSBhcmUgdXNlZC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBFeHBhbnNpb25GZWF0dXJlcyB7XG4gIC8qKlxuICAgKiBFeGVjdXRpb25TdGF0dXNQcm9wYWdhdGlvbiB0b2dnbGVzIHdoZXRoZXIgdGhlIHByb3ZpZGVkIGV4ZWN1dGlvbiBzdGF0dXNlc1xuICAgKiBhcmUgcHJvcGFnYXRlZCBhbG9uZyB0aGUgZWRnZXMgb2YgY29ubmVjdGVkIGNlbGxzLlxuICAgKlxuICAgKiBVbnNwZWNpZmllZCBzZXJ2ZXItc2lkZSBkZWZhdWx0IGlzIHRydWUuXG4gICAqL1xuICBleGVjdXRpb25TdGF0dXNQcm9wYWdhdGlvbj86IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIExpbmtJbXBvcnRzVG9JbnN0YWxscyB0b2dnbGVzIHdoZXRoZXIgaW1wb3J0cyBhcmUgbGlua2VkIHRvIGluc3RhbGxzLlxuICAgKlxuICAgKiBVbnNwZWNpZmllZCBzZXJ2ZXItc2lkZSBkZWZhdWx0IGlzIHRydWUuXG4gICAqL1xuICBsaW5rSW1wb3J0c1RvSW5zdGFsbHM/OiBib29sZWFuO1xuXG4gIC8qKlxuICAgKiBMaW5rSURBc3NpZ25tZW50cyB0b2dnbGVzIHdoZXRoZXIgSURzIG9uIHRoZSBMSFMgb2YgYW4gYXNzaWdubWVudCBhcmVcbiAgICogbGlua2VkIHRvIHRob3NlIG9uIHRoZSBSSFMuXG4gICAqXG4gICAqIFVuc3BlY2lmaWVkIHNlcnZlci1zaWRlIGRlZmF1bHQgaXMgdHJ1ZS5cbiAgICovXG4gIGxpbmtJZEFzc2lnbm1lbnRzPzogYm9vbGVhbjtcblxuICAvKipcbiAgICogQmFja3RyYWNraW5nU3RyYXRlZ3kgZGVmaW5lcyB0aGUgc3RyYXRlZ3kgdG8gdXNlIHdoZW4gd29ya2luZy1iYWNrXG4gICAqIHJlZmVyZW5jZXMuXG4gICAqXG4gICAqIFVuc3BlY2lmaWVkIHNlcnZlci1zaWRlIGRlZmF1bHQgaXMgJ25vbi1saXRlcmFscycuXG4gICAqXG4gICAqIE9wdGlvbnMgYXJlOlxuICAgKlxuICAgKiAgIC0gJ25vbmUnXG4gICAqICAgLSAnYWxsJ1xuICAgKiAgIC0gJ25vbi1saXRlcmFscydcbiAgICovXG4gIGJhY2t0cmFja2luZ1N0cmF0ZWd5Pzogc3RyaW5nO1xufVxuXG4vKipcbiAqIFBhcmFtcyBmb3IgdGhlIGRlcGVuZGVudCBjZWxscyByZXF1ZXN0LlxuICovXG5leHBvcnQgaW50ZXJmYWNlIENlbGxEZXBlbmRlbnRzUGFyYW1zIHtcbiAgLyoqXG4gICAqIFRoZSBjb2xsZWN0aW9uIG9mIGNlbGwgaW5kaWNlcyB3aG9zZSBkZXBlbmRlbnRzIGFyZSByZXF1ZXN0ZWQuXG4gICAqL1xuICBjZWxsczogbnVtYmVyW107XG5cbiAgLyoqXG4gICAqIE9wdGlvbmFsbHkgZGVmaW5lcyB0aGUgZmVhdHVyZSBjb250cm9scyB0aGF0IGFyZSB1c2VkIHdoZW4gZXhwYW5kaW5nIHRoZVxuICAgKiBwcmVyZXF1aXNpdGVzLlxuICAgKi9cbiAgZXhwYW5zaW9uRmVhdHVyZXM/OiBFeHBhbnNpb25GZWF0dXJlcztcbn1cblxuLyoqXG4gKiBQYXJhbXMgZm9yIHRoZSBjZWxsIHByZXJlcXVpc2l0ZXMgcmVxdWVzdC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBDZWxsUHJlcmVxdWlzaXRlc1BhcmFtcyB7XG4gIC8qKiBUaGUgZG9jdW1lbnQgVVJJLiAqL1xuICB1cmk6IHByb3RvY29sLkRvY3VtZW50VXJpO1xuXG4gIC8qKlxuICAgKiBUaGUgY29sbGVjdGlvbiBvZiBjZWxsIGluZGljZXMgd2hvc2UgcHJlcmVxdWlzaXRlcyBhcmUgcmVxdWVzdGVkLlxuICAgKi9cbiAgY2VsbHM6IG51bWJlcltdO1xuXG4gIC8qKlxuICAgKiBNYXAgZnJvbSBjZWxsIGluZGV4IHRvIHRoZSBleGVjdXRpb24gc3RhdHVzIG9mIHRoYXQgY2VsbC5cbiAgICovXG4gIGV4ZWN1dGlvblN0YXR1c2VzPzogRXhlY3V0aW9uU3RhdHVzZXM7XG5cbiAgLyoqXG4gICAqIE9wdGlvbmFsbHkgZGVmaW5lcyB0aGUgZmVhdHVyZSBjb250cm9scyB0aGF0IGFyZSB1c2VkIHdoZW4gZXhwYW5kaW5nIHRoZVxuICAgKiBwcmVyZXF1aXNpdGVzLlxuICAgKi9cbiAgZXhwYW5zaW9uRmVhdHVyZXM/OiBFeHBhbnNpb25GZWF0dXJlcztcbn1cblxuLyoqIEEgcG9pbnRlciB0byBhIGNlbGwgaW4gdGhlIG5vdGVib29rIHdpdGggc3RhdGVmdWwgaW5mb3JtYXRpb24uICovXG5leHBvcnQgaW50ZXJmYWNlIENlbGwge1xuICAvKiogVGhlIGluZGV4IG9mIHRoZSBjZWxsIGluIHRoZSBub3RlYm9vay4gKi9cbiAgaW5kZXg6IG51bWJlcjtcbiAgLyoqIFRoZSBzdGF0dXMgb2YgdGhlIGNlbGwncyBleGVjdXRpb24uICovXG4gIGV4ZWN1dGlvblN0YXR1czogRXhlY3V0aW9uU3RhdHVzO1xufVxuXG4vKipcbiAqIEEgY29ubmVjdGlvbiBiZXR3ZWVuIHR3byBzeW1ib2xzIHdoZXJlIG9uZSByZWZlcmVuY2VzIGFub3RoZXIuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgU3ltYm9sUmVmIHtcbiAgLyoqXG4gICAqIFRoZSBzeW1ib2wgdGhhdCBlc3RhYmxpc2hlcyB0aGUgcmVmZXJlbmNlLlxuICAgKi9cbiAgc291cmNlOiBwcm90b2NvbC5SYW5nZTtcblxuICAvKipcbiAgICogVGhlIHN5bWJvbCB0aGF0IGlzIHJlZmVyZW5jZWQgYnkgdGhlIHNvdXJjZSBzeW1ib2wuXG4gICAqL1xuICB0YXJnZXQ6IHByb3RvY29sLlJhbmdlO1xufVxuXG4vKipcbiAqIEEgY29ubmVjdGlvbiBiZXR3ZWVuIHR3byBjZWxscyB3aGVyZSBvbmUgcmVmZXJlbmNlcyBhbm90aGVyLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIENlbGxSZWYge1xuICAvKipcbiAgICogVGhlIGNlbGwgdGhhdCBlc3RhYmxpc2hlcyB0aGUgcmVmZXJlbmNlLlxuICAgKi9cbiAgc291cmNlOiBudW1iZXI7XG5cbiAgLyoqXG4gICAqIFRoZSBjZWxsIHRoYXQgaXMgcmVmZXJlbmNlZCBieSB0aGUgc291cmNlIGNlbGwuXG4gICAqL1xuICB0YXJnZXQ6IG51bWJlcjtcblxuICAvKipcbiAgICogVGhlIGNvbGxlY3Rpb24gb2Ygc3ltYm9sIHJlZmVyZW5jZXMgdGhhdCBlc3RhYmxpc2ggdGhlIHJlZmVyZW5jZS5cbiAgICovXG4gIG9uOiBTeW1ib2xSZWZbXTtcbn1cblxuLyoqXG4gKiBBIGdyYXBoIG9mIGNlbGxzIGFuZCB0aGVpciByZWZlcmVuY2VzIHRoYXQgZXN0YWJsaXNoIGRlcGVuZGVuY2llcyBiZXR3ZWVuXG4gKiB0aGVtLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIENlbGxHcmFwaCB7XG4gIC8qKlxuICAgKiBUaGUgaW5kaWNlcyBvZiBjZWxscyBpbiBhIFB5dGhvbiBub3RlYm9vay5cbiAgICovXG4gIGNlbGxzPzogQ2VsbFtdO1xuXG4gIC8qKlxuICAgKiBUaGUgcmVmZXJlbmNlIGdyYXBoIHdoaWNoIGVzdGFibGlzaGVzIGRlcGVuZGVuY2llcyBiZXR3ZWVuIHRoZSBjZWxscy5cbiAgICovXG4gIHJlZnM/OiBDZWxsUmVmW107XG59XG5cbi8qKlxuICogRGVwZW5kZW50Q2VsbHNSZXNwb25zZSByZXByZXNlbnRzIGEgcmVzcG9uc2UgZnJvbSBlaXRoZXIgcHJlcmVxdWlzaXRlIG9yXG4gKiBkZXBlbmRlbnQgY2VsbHMuIEl0IGNvbnRhaW5zIGEgZ3JhcGggdGhhdCByZXByZXNlbnRzIGNlbGxzIGFuZCB0aGVpclxuICogcmVmZXJlbmNlcyB0aGF0IGVzdGFibGlzaGVzIHRoZSBkZXBlbmRlbmNpZXMgYmV0d2VlbiB0aGVtLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIERlcGVuZGVudENlbGxzUmVzcG9uc2UgZXh0ZW5kcyBDZWxsR3JhcGgge1xuICAvKipcbiAgICogTWFnaWNzIHRoYXQgYXJlIG5vdCBzdXBwb3J0ZWQgYnkgcHJlcmVxIGNlbGxzLCBhbmQgbWF5IGxlYWQgdG8gaW5jb3JyZWN0XG4gICAqIHJlc3VsdHMuXG4gICAqL1xuICB1bnN1cHBvcnRlZE1hZ2ljcz86IHN0cmluZ1tdO1xufVxuIl19
datalab/web/lsp/protocol_node.js ADDED
@@ -0,0 +1,191 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ "use strict";
2
+ // tslint:disable:enforce-name-casing
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.SymbolTag = exports.SymbolKind = exports.DiagnosticSeverity = exports.DiagnosticTag = exports.FailureHandlingKind = exports.ResourceOperationKind = exports.ErrorCode = exports.Method = void 0;
5
+ /**
6
+ * JSON-RPC Methods.
7
+ */
8
+ var Method;
9
+ (function (Method) {
10
+ Method["CancelRequest"] = "$/cancelRequest";
11
+ Method["ClientRegisterCapability"] = "client/registerCapability";
12
+ Method["ColabPipLogChanged"] = "colab/pipLogChanged";
13
+ Method["CompletionItemResolve"] = "completionItem/resolve";
14
+ Method["Initialize"] = "initialize";
15
+ Method["Initialized"] = "initialized";
16
+ Method["TextDocumentAutoExecuteCheck"] = "textDocument/autoExecuteCheck";
17
+ Method["TextDocumentCodeAction"] = "textDocument/codeAction";
18
+ Method["TextDocumentCompletion"] = "textDocument/completion";
19
+ Method["TextDocumentDefinition"] = "textDocument/definition";
20
+ Method["TextDocumentDidChange"] = "textDocument/didChange";
21
+ Method["TextDocumentDidClose"] = "textDocument/didClose";
22
+ Method["TextDocumentDidOpen"] = "textDocument/didOpen";
23
+ Method["TextDocumentEchoDocument"] = "textDocument/echoDocument";
24
+ Method["TextDocumentHover"] = "textDocument/hover";
25
+ Method["TextDocumentCellDependents"] = "textDocument/cellDependents";
26
+ Method["TextDocumentCellPrerequisites"] = "textDocument/cellPrerequisites";
27
+ Method["TextDocumentInlayHint"] = "textDocument/inlayHint";
28
+ Method["TextDocumentPublishDiagnostics"] = "textDocument/publishDiagnostics";
29
+ Method["TextDocumentPrepareRename"] = "textDocument/prepareRename";
30
+ Method["TextDocumentRename"] = "textDocument/rename";
31
+ Method["TextDocumentRepair"] = "textDocument/repair";
32
+ Method["TextDocumentSignatureHelp"] = "textDocument/signatureHelp";
33
+ Method["WindowLogMessage"] = "window/logMessage";
34
+ Method["WorkspaceConfiguration"] = "workspace/configuration";
35
+ Method["WorkspaceDidChangeConfiguration"] = "workspace/didChangeConfiguration";
36
+ Method["WorkspaceDidChangeWatchedFiles"] = "workspace/didChangeWatchedFiles";
37
+ })(Method || (exports.Method = Method = {}));
38
+ /**
39
+ * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#responseMessage
40
+ */
41
+ var ErrorCode;
42
+ (function (ErrorCode) {
43
+ // Defined by JSON RPC
44
+ ErrorCode[ErrorCode["ParseError"] = -32700] = "ParseError";
45
+ ErrorCode[ErrorCode["InvalidRequest"] = -32600] = "InvalidRequest";
46
+ ErrorCode[ErrorCode["MethodNotFound"] = -32601] = "MethodNotFound";
47
+ ErrorCode[ErrorCode["InvalidParams"] = -32602] = "InvalidParams";
48
+ ErrorCode[ErrorCode["InternalError"] = -32603] = "InternalError";
49
+ ErrorCode[ErrorCode["ServerErrorStart"] = -32099] = "ServerErrorStart";
50
+ ErrorCode[ErrorCode["ServerErrorEnd"] = -32000] = "ServerErrorEnd";
51
+ ErrorCode[ErrorCode["ServerNotInitialized"] = -32002] = "ServerNotInitialized";
52
+ ErrorCode[ErrorCode["UnknownErrorCode"] = -32001] = "UnknownErrorCode";
53
+ // Defined by the protocol.
54
+ ErrorCode[ErrorCode["RequestCancelled"] = -32800] = "RequestCancelled";
55
+ ErrorCode[ErrorCode["ContentModified"] = -32801] = "ContentModified";
56
+ })(ErrorCode || (exports.ErrorCode = ErrorCode = {}));
57
+ /**
58
+ * The kind of resource operations supported by the client.
59
+ */
60
+ var ResourceOperationKind;
61
+ (function (ResourceOperationKind) {
62
+ /**
63
+ * Supports creating new files and folders.
64
+ */
65
+ ResourceOperationKind["CREATE"] = "create";
66
+ /**
67
+ * Supports renaming existing files and folders.
68
+ */
69
+ ResourceOperationKind["RENAME"] = "rename";
70
+ /**
71
+ * Supports deleting existing files and folders.
72
+ */
73
+ ResourceOperationKind["DELETE"] = "delete";
74
+ })(ResourceOperationKind || (exports.ResourceOperationKind = ResourceOperationKind = {}));
75
+ /**
76
+ * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#workspaceEditClientCapabilities
77
+ */
78
+ var FailureHandlingKind;
79
+ (function (FailureHandlingKind) {
80
+ /**
81
+ * Applying the workspace change is simply aborted if one of the changes
82
+ * provided fails.
83
+ * All operations executed before the failing operation stay executed.
84
+ */
85
+ FailureHandlingKind["Abort"] = "abort";
86
+ /**
87
+ * All operations are executed transactional. That means they either all
88
+ * succeed or no changes at all are applied to the workspace.
89
+ */
90
+ FailureHandlingKind["Transactional"] = "transactional";
91
+ /**
92
+ * If the workspace edit contains only textual file changes, they are
93
+ * executed transactionally.
94
+ * If resource changes (create, rename or delete file) are part of the
95
+ * change, the failure handling strategy is abort.
96
+ */
97
+ FailureHandlingKind["TextOnlyTransactional"] = "textOnlyTransactional";
98
+ /**
99
+ * The client tries to undo the operations already executed. But there is no
100
+ * guarantee that this is succeeding.
101
+ */
102
+ FailureHandlingKind["Undo"] = "undo";
103
+ })(FailureHandlingKind || (exports.FailureHandlingKind = FailureHandlingKind = {}));
104
+ /**
105
+ * The diagnostic tags.
106
+ *
107
+ * @since 3.15.0
108
+ */
109
+ var DiagnosticTag;
110
+ (function (DiagnosticTag) {
111
+ /**
112
+ * Unused or unnecessary code.
113
+ *
114
+ * Clients are allowed to render diagnostics with this tag faded out
115
+ * instead of having an error squiggle.
116
+ */
117
+ DiagnosticTag[DiagnosticTag["Unnecessary"] = 1] = "Unnecessary";
118
+ /**
119
+ * Deprecated or obsolete code.
120
+ *
121
+ * Clients are allowed to rendered diagnostics with this tag strike through.
122
+ */
123
+ DiagnosticTag[DiagnosticTag["Deprecated"] = 2] = "Deprecated";
124
+ })(DiagnosticTag || (exports.DiagnosticTag = DiagnosticTag = {}));
125
+ /**
126
+ * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#diagnostic
127
+ */
128
+ var DiagnosticSeverity;
129
+ (function (DiagnosticSeverity) {
130
+ /**
131
+ * Reports an error.
132
+ */
133
+ DiagnosticSeverity[DiagnosticSeverity["Error"] = 1] = "Error";
134
+ /**
135
+ * Reports a warning.
136
+ */
137
+ DiagnosticSeverity[DiagnosticSeverity["Warning"] = 2] = "Warning";
138
+ /**
139
+ * Reports an information.
140
+ */
141
+ DiagnosticSeverity[DiagnosticSeverity["Information"] = 3] = "Information";
142
+ /**
143
+ * Reports a hint.
144
+ */
145
+ DiagnosticSeverity[DiagnosticSeverity["Hint"] = 4] = "Hint";
146
+ })(DiagnosticSeverity || (exports.DiagnosticSeverity = DiagnosticSeverity = {}));
147
+ /**
148
+ * A symbol kind.
149
+ */
150
+ var SymbolKind;
151
+ (function (SymbolKind) {
152
+ SymbolKind[SymbolKind["File"] = 1] = "File";
153
+ SymbolKind[SymbolKind["Module"] = 2] = "Module";
154
+ SymbolKind[SymbolKind["Namespace"] = 3] = "Namespace";
155
+ SymbolKind[SymbolKind["Package"] = 4] = "Package";
156
+ SymbolKind[SymbolKind["Class"] = 5] = "Class";
157
+ SymbolKind[SymbolKind["Method"] = 6] = "Method";
158
+ SymbolKind[SymbolKind["Property"] = 7] = "Property";
159
+ SymbolKind[SymbolKind["Field"] = 8] = "Field";
160
+ SymbolKind[SymbolKind["Constructor"] = 9] = "Constructor";
161
+ SymbolKind[SymbolKind["Enum"] = 10] = "Enum";
162
+ SymbolKind[SymbolKind["Interface"] = 11] = "Interface";
163
+ SymbolKind[SymbolKind["Function"] = 12] = "Function";
164
+ SymbolKind[SymbolKind["Variable"] = 13] = "Variable";
165
+ SymbolKind[SymbolKind["Constant"] = 14] = "Constant";
166
+ SymbolKind[SymbolKind["String"] = 15] = "String";
167
+ SymbolKind[SymbolKind["Number"] = 16] = "Number";
168
+ SymbolKind[SymbolKind["Boolean"] = 17] = "Boolean";
169
+ SymbolKind[SymbolKind["Array"] = 18] = "Array";
170
+ SymbolKind[SymbolKind["Object"] = 19] = "Object";
171
+ SymbolKind[SymbolKind["Key"] = 20] = "Key";
172
+ SymbolKind[SymbolKind["Null"] = 21] = "Null";
173
+ SymbolKind[SymbolKind["EnumMember"] = 22] = "EnumMember";
174
+ SymbolKind[SymbolKind["Struct"] = 23] = "Struct";
175
+ SymbolKind[SymbolKind["Event"] = 24] = "Event";
176
+ SymbolKind[SymbolKind["Operator"] = 25] = "Operator";
177
+ SymbolKind[SymbolKind["TypeParameter"] = 26] = "TypeParameter";
178
+ })(SymbolKind || (exports.SymbolKind = SymbolKind = {}));
179
+ /**
180
+ * Symbol tags are extra annotations that tweak the rendering of a symbol.
181
+ *
182
+ * @since 3.16
183
+ */
184
+ var SymbolTag;
185
+ (function (SymbolTag) {
186
+ /**
187
+ * Render a symbol as obsolete, usually using a strike-out.
188
+ */
189
+ SymbolTag[SymbolTag["Deprecated"] = 1] = "Deprecated";
190
+ })(SymbolTag || (exports.SymbolTag = SymbolTag = {}));
191
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"protocol_node.js","sourceRoot":"","sources":["../../../../../../../../genfiles/third_party/colab/sources/lsp/protocol_node.ts"],"names":[],"mappings":"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","sourcesContent":["// tslint:disable:enforce-name-casing\n\n/**\n * JSON-RPC Methods.\n */\nexport enum Method {\n  CancelRequest = '$/cancelRequest',\n  ClientRegisterCapability = 'client/registerCapability',\n  ColabPipLogChanged = 'colab/pipLogChanged',\n  CompletionItemResolve = 'completionItem/resolve',\n  Initialize = 'initialize',\n  Initialized = 'initialized',\n  TextDocumentAutoExecuteCheck = 'textDocument/autoExecuteCheck',\n  TextDocumentCodeAction = 'textDocument/codeAction',\n  TextDocumentCompletion = 'textDocument/completion',\n  TextDocumentDefinition = 'textDocument/definition',\n  TextDocumentDidChange = 'textDocument/didChange',\n  TextDocumentDidClose = 'textDocument/didClose',\n  TextDocumentDidOpen = 'textDocument/didOpen',\n  TextDocumentEchoDocument = 'textDocument/echoDocument',\n  TextDocumentHover = 'textDocument/hover',\n  TextDocumentCellDependents = 'textDocument/cellDependents',\n  TextDocumentCellPrerequisites = 'textDocument/cellPrerequisites',\n  TextDocumentInlayHint = 'textDocument/inlayHint',\n  TextDocumentPublishDiagnostics = 'textDocument/publishDiagnostics',\n  TextDocumentPrepareRename = 'textDocument/prepareRename',\n  TextDocumentRename = 'textDocument/rename',\n  TextDocumentRepair = 'textDocument/repair',\n  TextDocumentSignatureHelp = 'textDocument/signatureHelp',\n  WindowLogMessage = 'window/logMessage',\n  WorkspaceConfiguration = 'workspace/configuration',\n  WorkspaceDidChangeConfiguration = 'workspace/didChangeConfiguration',\n  WorkspaceDidChangeWatchedFiles = 'workspace/didChangeWatchedFiles',\n}\n\n/** Base JSON-RPC 2.0 type. */\nexport declare interface Message {\n  jsonrpc: '2.0';\n}\n\n/**\n * JSON-RPC 2.0 request.\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#requestMessage\n */\nexport declare interface RequestMessage<T> extends Message {\n  /**\n   * The request id.\n   */\n  id: number|string;\n  /**\n   * The method to be invoked.\n   */\n  method: Method;\n  /**\n   * The method's params.\n   */\n  params: T;\n}\n\n/**\n * JSON-RPC 2.0 response.\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#responseMessage\n */\nexport declare interface ResponseMessage extends Message {\n  /**\n   * The request id.\n   */\n  id: number|string|null;\n\n  /**\n   * The result of a request. This member is REQUIRED on success.\n   * This member MUST NOT exist if there was an error invoking the method.\n   */\n  result?: string|number|boolean|object|null;\n\n  /**\n   * The error object in case a request fails.\n   */\n  error?: ResponseError;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#responseMessage\n */\nexport declare interface ResponseError {\n  /**\n   * A number indicating the error type that occurred.\n   */\n  code: number;\n\n  /**\n   * A string providing a short description of the error.\n   */\n  message: string;\n\n  /**\n   * A primitive or structured value that contains additional\n   * information about the error. Can be omitted.\n   */\n  data?: string|number|boolean|unknown[]|object|null;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#responseMessage\n */\nexport enum ErrorCode {\n  // Defined by JSON RPC\n  ParseError = -32700,\n  InvalidRequest = -32600,\n  MethodNotFound = -32601,\n  InvalidParams = -32602,\n  InternalError = -32603,\n  ServerErrorStart = -32099,\n  ServerErrorEnd = -32000,\n  ServerNotInitialized = -32002,\n  UnknownErrorCode = -32001,\n\n  // Defined by the protocol.\n  RequestCancelled = -32800,\n  ContentModified = -32801,\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#notificationMessage\n */\nexport declare interface NotificationMessage<T> extends Message {\n  /**\n   * The method to be invoked.\n   */\n  method: string;\n\n  /**\n   * The notification's params.\n   */\n  params: T;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#cancelRequest\n */\nexport declare interface CancelParams {\n  /**\n   * The request id to cancel.\n   */\n  id: number|string;\n}\n\ntype ProgressToken = number|string;\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#progress\n */\nexport declare interface ProgressParams<T> {\n  /**\n   * The progress token provided by the client or server.\n   */\n  token: ProgressToken;\n\n  /**\n   * The progress data.\n   */\n  value: T;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#uri\n */\nexport type DocumentUri = string;\n\n/**\n * Position in a text document expressed as zero-based line and zero-based\n * character offset. A position is between two characters like an ‘insert’\n * cursor in a editor. Special values like for example -1 to denote the end of\n * a line are not supported.\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#position\n */\nexport declare interface Position {\n  /**\n   * Line position in a document (zero-based).\n   */\n  line: number;\n\n  /**\n   * Character offset on a line in a document (zero-based). Assuming that the\n   * line is represented as a string, the `character` value represents the gap\n   * between the `character` and `character + 1`.\n   *\n   * If the character value is greater than the line length it defaults back\n   * to the line length.\n   */\n  character: number;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#range\n */\nexport declare interface Range {\n  /**\n   * The range's start position.\n   */\n  start: Position;\n\n  /**\n   * The range's end position.\n   */\n  end: Position;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#location\n */\nexport declare interface Location {\n  uri: DocumentUri;\n  range: Range;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#locationLink\n */\nexport declare interface LocationLink {\n  /**\n   * Span of the origin of this link.\n   *\n   * Used as the underlined span for mouse interaction.\n   * Defaults to the word range at the mouse position.\n   */\n  originSelectionRange?: Range;\n\n  /**\n   * The target resource identifier of this link.\n   */\n  targetUri: DocumentUri;\n\n  /**\n   * The full target range of this link.\n   * For example, if the target is a symbol, then target range is the range\n   * enclosing this symbol not including leading/trailing whitespace but\n   * everything else like comments.\n   * This information is typically used to highlight the range in the editor.\n   */\n  targetRange: Range;\n\n  /**\n   * The range that should be selected and revealed when this link is being\n   * followed, for example, the name of a function.\n   * Must be contained by the `targetRange`.\n   * See also `DocumentSymbol#range`\n   */\n  targetSelectionRange: Range;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#command\n */\nexport interface Command {\n  /**\n   * Title of the command, like `save`.\n   */\n  title: string;\n  /**\n   * The identifier of the actual command handler.\n   */\n  command: string;\n  /**\n   * Arguments that the command handler should be\n   * invoked with.\n   */\n  arguments?: unknown[];\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#workspaceEditClientCapabilities\n */\nexport declare interface WorkspaceEditClientCapabilities {\n  /**\n   * The client supports versioned document changes in `WorkspaceEdit`s\n   */\n  documentChanges?: boolean;\n\n  /**\n   * The resource operations the client supports. Clients should at least\n   * support 'create', 'rename' and 'delete' files and folders.\n   *\n   * @since 3.13.0\n   */\n  resourceOperations?: ResourceOperationKind[];\n\n  /**\n   * The failure handling strategy of a client if applying the workspace edit\n   * fails.\n   *\n   * @since 3.13.0\n   */\n  failureHandling?: FailureHandlingKind;\n}\n\n/**\n * The kind of resource operations supported by the client.\n */\nexport enum ResourceOperationKind {\n  /**\n   * Supports creating new files and folders.\n   */\n  CREATE = 'create',\n  /**\n   * Supports renaming existing files and folders.\n   */\n  RENAME = 'rename',\n  /**\n   * Supports deleting existing files and folders.\n   */\n  DELETE = 'delete',\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#workspaceEditClientCapabilities\n */\nexport enum FailureHandlingKind {\n  /**\n   * Applying the workspace change is simply aborted if one of the changes\n   * provided fails.\n   * All operations executed before the failing operation stay executed.\n   */\n  Abort = 'abort',\n\n  /**\n   * All operations are executed transactional. That means they either all\n   * succeed or no changes at all are applied to the workspace.\n   */\n  Transactional = 'transactional',\n\n  /**\n   * If the workspace edit contains only textual file changes, they are\n   * executed transactionally.\n   * If resource changes (create, rename or delete file) are part of the\n   * change, the failure handling strategy is abort.\n   */\n  TextOnlyTransactional = 'textOnlyTransactional',\n\n  /**\n   * The client tries to undo the operations already executed. But there is no\n   * guarantee that this is succeeding.\n   */\n  Undo = 'undo',\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#documentFilter\n */\nexport declare interface DocumentFilter {\n  /**\n   * A language id, like `typescript`.\n   */\n  language?: string;\n\n  /**\n   * A Uri [scheme](#Uri.scheme), like `file` or `untitled`.\n   */\n  scheme?: string;\n\n  /**\n   * A glob pattern, like `*.{ts,js}`.\n   *\n   * Glob patterns can have the following syntax:\n   * - `*` to match one or more characters in a path segment\n   * - `?` to match on one character in a path segment\n   * - `**` to match any number of path segments, including none\n   * - `{}` to group conditions\n   *   (e.g. `**​/*.{ts,js}` matches all TypeScript and JavaScript files)\n   * - `[]` to declare a range of characters to match in a path segment\n   *   (e.g., `example.[0-9]` to match on `example.0`, `example.1`, …)\n   * - `[!...]` to negate a range of characters to match in a path segment\n   *   (e.g., `example.[!0-9]` to match on `example.a`, `example.b`,\n   *    but not `example.0`)\n   */\n  pattern?: string;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#documentFilter\n */\nexport type DocumentSelector = DocumentFilter[];\n\n/**\n * Static registration options to be returned in the initialize request.\n */\nexport declare interface StaticRegistrationOptions {\n  /**\n   * The id used to register the request. The id can be used to deregister\n   * the request again. See also Registration#id.\n   */\n  id?: string;\n}\n\n/**\n * General text document registration options.\n */\nexport declare interface TextDocumentRegistrationOptions {\n  /**\n   * A document selector to identify the scope of the registration.\n   * If set to null, the document selector provided on the client side\n   * will be used.\n   */\n  documentSelector: DocumentSelector|null;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#initiatingWorkDoneProgress\n */\nexport declare interface WorkDoneProgressParams {\n  /**\n   * An optional token that a server can use to report work done progress.\n   */\n  workDoneToken?: ProgressToken;\n}\n\n/**\n * The diagnostic tags.\n *\n * @since 3.15.0\n */\nexport enum DiagnosticTag {\n  /**\n   * Unused or unnecessary code.\n   *\n   * Clients are allowed to render diagnostics with this tag faded out\n   * instead of having an error squiggle.\n   */\n  Unnecessary = 1,\n  /**\n   * Deprecated or obsolete code.\n   *\n   * Clients are allowed to rendered diagnostics with this tag strike through.\n   */\n  Deprecated = 2,\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#diagnostic\n */\nexport declare interface Diagnostic {\n  /**\n   * The range at which the message applies.\n   */\n  range: Range;\n\n  /**\n   * The diagnostic's severity. Can be omitted. If omitted it is up to the\n   * client to interpret diagnostics as error, warning, info or hint.\n   */\n  severity?: DiagnosticSeverity;\n\n  /**\n   * The diagnostic's code, which might appear in the user interface.\n   */\n  code?: number|string;\n\n  /**\n   * A human-readable string describing the source of this\n   * diagnostic, e.g. 'typescript' or 'super lint'.\n   */\n  source?: string;\n\n  /**\n   * The diagnostic's message.\n   */\n  message: string;\n\n  /**\n   * Additional metadata about the diagnostic.\n   *\n   * @since 3.15.0\n   */\n  tags?: DiagnosticTag[];\n\n  /**\n   * An array of related diagnostic information, e.g. when symbol-names within\n   * a scope collide all definitions can be marked via this property.\n   */\n  relatedInformation?: DiagnosticRelatedInformation[];\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#diagnostic\n */\nexport enum DiagnosticSeverity {\n  /**\n   * Reports an error.\n   */\n  Error = 1,\n  /**\n   * Reports a warning.\n   */\n  Warning = 2,\n  /**\n   * Reports an information.\n   */\n  Information = 3,\n  /**\n   * Reports a hint.\n   */\n  Hint = 4,\n}\n\n/**\n * Represents a related message and source code location for a diagnostic.\n * This should be used to point to code locations that cause or are related\n * to a diagnostics, for example, when duplicating a symbol in a scope.\n */\nexport declare interface DiagnosticRelatedInformation {\n  /**\n   * The location of this related diagnostic information.\n   */\n  location: Location;\n\n  /**\n   * The message of this related diagnostic information.\n   */\n  message: string;\n}\n\n/**\n * A symbol kind.\n */\nexport enum SymbolKind {\n  File = 1,\n  Module = 2,\n  Namespace = 3,\n  Package = 4,\n  Class = 5,\n  Method = 6,\n  Property = 7,\n  Field = 8,\n  Constructor = 9,\n  Enum = 10,\n  Interface = 11,\n  Function = 12,\n  Variable = 13,\n  Constant = 14,\n  String = 15,\n  Number = 16,\n  Boolean = 17,\n  Array = 18,\n  Object = 19,\n  Key = 20,\n  Null = 21,\n  EnumMember = 22,\n  Struct = 23,\n  Event = 24,\n  Operator = 25,\n  TypeParameter = 26,\n}\n\n/**\n * Symbol tags are extra annotations that tweak the rendering of a symbol.\n *\n * @since 3.16\n */\nexport enum SymbolTag {\n\n  /**\n   * Render a symbol as obsolete, usually using a strike-out.\n   */\n  Deprecated = 1,\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#workspace_executeCommand\n */\nexport declare interface ExecuteCommandClientCapabilities {\n  /**\n   * Execute command supports dynamic registration.\n   */\n  dynamicRegistration?: boolean;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#partialResultParams\n */\nexport declare interface PartialResultParams {\n  /**\n   * An optional token that a server can use to report partial results (e.g.\n   * streaming) to the client.\n   */\n  partialResultToken?: ProgressToken;\n}\n\n/**\n * Defines an integer number in the range of -2^31 to 2^31 - 1.\n */\nexport type integer = number;\n/**\n * Defines an unsigned integer number in the range of 0 to 2^31 - 1.\n */\nexport type uinteger = number;\n/**\n * Defines a decimal number. Since decimal numbers are very\n * rare in the language server specification we denote the\n * exact range with every decimal using the mathematics\n * interval notation (e.g. [0, 1] denotes all decimals d with\n * 0 <= d <= 1.\n */\nexport type decimal = number;\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#initialized\n */\nexport interface Initialized extends NotificationMessage<InitializedParams> {\n  method: Method.Initialized;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#initialized\n */\nexport interface InitializedParams {}\n\n/**\n * General parameters to register for a capability.\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#client_registerCapability\n */\nexport interface Registration {\n  /**\n   * The id used to register the request. The id can be used to deregister\n   * the request again.\n   */\n  id: string;\n\n  /**\n   * The method / capability to register for.\n   */\n  method: string;\n\n  /**\n   * Options necessary for the registration.\n   */\n  registerOptions?: unknown;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#client_registerCapability\n */\nexport interface RegistrationParams {\n  registrations: Registration[];\n}\n"]}
datalab/web/lsp/settings_node.js ADDED
@@ -0,0 +1,44 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.all = void 0;
4
+ /**
5
+ * Settings which may be used by the Python language server.
6
+ * These are from the default preferences from a VSCode client, culled
7
+ * to the LSP-related values.
8
+ *
9
+ * The difficulty here is that LSP only defines a mechanism to provide
10
+ * generic settings and the server expects the client to send all necessary
11
+ * settings. VSCode sends all Python settings to every Python language server.
12
+ * Furthermore the language server may request specific settings later.
13
+ *
14
+ * See:
15
+ * https://github.com/microsoft/pyright/blob/9d4e58d06643dccbfe0f450070334675b6b64724/docs/settings.md
16
+ */
17
+ exports.all = {
18
+ 'python': {
19
+ 'analysis': {
20
+ 'diagnosticPublishDelay': 1000,
21
+ 'errors': [],
22
+ 'warnings': [],
23
+ 'information': [],
24
+ 'disabled': [],
25
+ 'typeshedPaths': [],
26
+ 'cacheFolderPath': '',
27
+ 'memory': { 'keepLibraryAst': false },
28
+ 'logLevel': 'Warning',
29
+ 'symbolsHierarchyDepthLimit': 10,
30
+ 'completeFunctionParens': false,
31
+ 'autoImportCompletions': true,
32
+ 'autoSearchPaths': true,
33
+ 'stubPath': 'typings',
34
+ 'diagnosticMode': 'openFilesOnly',
35
+ 'extraPaths': [],
36
+ 'useLibraryCodeForTypes': true,
37
+ 'typeCheckingMode': 'basic',
38
+ // See diagnostics explanation at:
39
+ // https://github.com/microsoft/pyright/blob/main/docs/configuration.md
40
+ 'diagnosticSeverityOverrides': {},
41
+ },
42
+ },
43
+ };
44
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2V0dGluZ3Nfbm9kZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2dlbmZpbGVzL3RoaXJkX3BhcnR5L2NvbGFiL3NvdXJjZXMvbHNwL3NldHRpbmdzX25vZGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUE7Ozs7Ozs7Ozs7OztHQVlHO0FBQ1UsUUFBQSxHQUFHLEdBQTZCO0lBQzNDLFFBQVEsRUFBRTtRQUNSLFVBQVUsRUFBRTtZQUNWLHdCQUF3QixFQUFFLElBQUk7WUFDOUIsUUFBUSxFQUFFLEVBQUU7WUFDWixVQUFVLEVBQUUsRUFBRTtZQUNkLGFBQWEsRUFBRSxFQUFFO1lBQ2pCLFVBQVUsRUFBRSxFQUFFO1lBQ2QsZUFBZSxFQUFFLEVBQUU7WUFDbkIsaUJBQWlCLEVBQUUsRUFBRTtZQUNyQixRQUFRLEVBQUUsRUFBQyxnQkFBZ0IsRUFBRSxLQUFLLEVBQUM7WUFDbkMsVUFBVSxFQUFFLFNBQVM7WUFDckIsNEJBQTRCLEVBQUUsRUFBRTtZQUNoQyx3QkFBd0IsRUFBRSxLQUFLO1lBQy9CLHVCQUF1QixFQUFFLElBQUk7WUFDN0IsaUJBQWlCLEVBQUUsSUFBSTtZQUN2QixVQUFVLEVBQUUsU0FBUztZQUNyQixnQkFBZ0IsRUFBRSxlQUFlO1lBQ2pDLFlBQVksRUFBRSxFQUFFO1lBQ2hCLHdCQUF3QixFQUFFLElBQUk7WUFDOUIsa0JBQWtCLEVBQUUsT0FBTztZQUMzQixrQ0FBa0M7WUFDbEMsdUVBQXVFO1lBQ3ZFLDZCQUE2QixFQUFFLEVBQUU7U0FDbEM7S0FDRjtDQUNGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFNldHRpbmdzIHdoaWNoIG1heSBiZSB1c2VkIGJ5IHRoZSBQeXRob24gbGFuZ3VhZ2Ugc2VydmVyLlxuICogVGhlc2UgYXJlIGZyb20gdGhlIGRlZmF1bHQgcHJlZmVyZW5jZXMgZnJvbSBhIFZTQ29kZSBjbGllbnQsIGN1bGxlZFxuICogdG8gdGhlIExTUC1yZWxhdGVkIHZhbHVlcy5cbiAqXG4gKiBUaGUgZGlmZmljdWx0eSBoZXJlIGlzIHRoYXQgTFNQIG9ubHkgZGVmaW5lcyBhIG1lY2hhbmlzbSB0byBwcm92aWRlXG4gKiBnZW5lcmljIHNldHRpbmdzIGFuZCB0aGUgc2VydmVyIGV4cGVjdHMgdGhlIGNsaWVudCB0byBzZW5kIGFsbCBuZWNlc3NhcnlcbiAqIHNldHRpbmdzLiBWU0NvZGUgc2VuZHMgYWxsIFB5dGhvbiBzZXR0aW5ncyB0byBldmVyeSBQeXRob24gbGFuZ3VhZ2Ugc2VydmVyLlxuICogRnVydGhlcm1vcmUgdGhlIGxhbmd1YWdlIHNlcnZlciBtYXkgcmVxdWVzdCBzcGVjaWZpYyBzZXR0aW5ncyBsYXRlci5cbiAqXG4gKiBTZWU6XG4gKiBodHRwczovL2dpdGh1Yi5jb20vbWljcm9zb2Z0L3B5cmlnaHQvYmxvYi85ZDRlNThkMDY2NDNkY2NiZmUwZjQ1MDA3MDMzNDY3NWI2YjY0NzI0L2RvY3Mvc2V0dGluZ3MubWRcbiAqL1xuZXhwb3J0IGNvbnN0IGFsbDoge1trZXk6IHN0cmluZ106IHVua25vd259ID0ge1xuICAncHl0aG9uJzoge1xuICAgICdhbmFseXNpcyc6IHtcbiAgICAgICdkaWFnbm9zdGljUHVibGlzaERlbGF5JzogMTAwMCxcbiAgICAgICdlcnJvcnMnOiBbXSxcbiAgICAgICd3YXJuaW5ncyc6IFtdLFxuICAgICAgJ2luZm9ybWF0aW9uJzogW10sXG4gICAgICAnZGlzYWJsZWQnOiBbXSxcbiAgICAgICd0eXBlc2hlZFBhdGhzJzogW10sXG4gICAgICAnY2FjaGVGb2xkZXJQYXRoJzogJycsXG4gICAgICAnbWVtb3J5JzogeydrZWVwTGlicmFyeUFzdCc6IGZhbHNlfSxcbiAgICAgICdsb2dMZXZlbCc6ICdXYXJuaW5nJyxcbiAgICAgICdzeW1ib2xzSGllcmFyY2h5RGVwdGhMaW1pdCc6IDEwLFxuICAgICAgJ2NvbXBsZXRlRnVuY3Rpb25QYXJlbnMnOiBmYWxzZSxcbiAgICAgICdhdXRvSW1wb3J0Q29tcGxldGlvbnMnOiB0cnVlLFxuICAgICAgJ2F1dG9TZWFyY2hQYXRocyc6IHRydWUsXG4gICAgICAnc3R1YlBhdGgnOiAndHlwaW5ncycsXG4gICAgICAnZGlhZ25vc3RpY01vZGUnOiAnb3BlbkZpbGVzT25seScsXG4gICAgICAnZXh0cmFQYXRocyc6IFtdLFxuICAgICAgJ3VzZUxpYnJhcnlDb2RlRm9yVHlwZXMnOiB0cnVlLFxuICAgICAgJ3R5cGVDaGVja2luZ01vZGUnOiAnYmFzaWMnLFxuICAgICAgLy8gU2VlIGRpYWdub3N0aWNzIGV4cGxhbmF0aW9uIGF0OlxuICAgICAgLy8gaHR0cHM6Ly9naXRodWIuY29tL21pY3Jvc29mdC9weXJpZ2h0L2Jsb2IvbWFpbi9kb2NzL2NvbmZpZ3VyYXRpb24ubWRcbiAgICAgICdkaWFnbm9zdGljU2V2ZXJpdHlPdmVycmlkZXMnOiB7fSxcbiAgICB9LFxuICB9LFxufTtcbiJdfQ==
datalab/web/lsp/text_document_node.js ADDED
The diff for this file is too large to render. See raw diff
 
datalab/web/lsp/window_node.js ADDED
@@ -0,0 +1,24 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.MessageType = void 0;
4
+ /** Log message type. */
5
+ var MessageType;
6
+ (function (MessageType) {
7
+ /**
8
+ * An error message.
9
+ */
10
+ MessageType[MessageType["Error"] = 1] = "Error";
11
+ /**
12
+ * A warning message.
13
+ */
14
+ MessageType[MessageType["Warning"] = 2] = "Warning";
15
+ /**
16
+ * An information message.
17
+ */
18
+ MessageType[MessageType["Info"] = 3] = "Info";
19
+ /**
20
+ * A log message.
21
+ */
22
+ MessageType[MessageType["Log"] = 4] = "Log";
23
+ })(MessageType || (exports.MessageType = MessageType = {}));
24
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2luZG93X25vZGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9nZW5maWxlcy90aGlyZF9wYXJ0eS9jb2xhYi9zb3VyY2VzL2xzcC93aW5kb3dfbm9kZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUErQkEsd0JBQXdCO0FBQ3hCLElBQVksV0FpQlg7QUFqQkQsV0FBWSxXQUFXO0lBQ3JCOztPQUVHO0lBQ0gsK0NBQVMsQ0FBQTtJQUNUOztPQUVHO0lBQ0gsbURBQVcsQ0FBQTtJQUNYOztPQUVHO0lBQ0gsNkNBQVEsQ0FBQTtJQUNSOztPQUVHO0lBQ0gsMkNBQU8sQ0FBQTtBQUNULENBQUMsRUFqQlcsV0FBVywyQkFBWCxXQUFXLFFBaUJ0QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIHByb3RvY29sIGZyb20gJy4vcHJvdG9jb2xfbm9kZSc7XG5cbi8vIHRzbGludDpkaXNhYmxlOmVuZm9yY2UtbmFtZS1jYXNpbmdcblxuLyoqXG4gKiBUaGUgbG9nIG1lc3NhZ2Ugbm90aWZpY2F0aW9uIGlzIHNlbnQgZnJvbSB0aGUgc2VydmVyIHRvIHRoZSBjbGllbnQgdG8gYXNrIHRoZVxuICogY2xpZW50IHRvIGxvZyBhIHBhcnRpY3VsYXIgbWVzc2FnZS5cbiAqIGh0dHBzOi8vbWljcm9zb2Z0LmdpdGh1Yi5pby9sYW5ndWFnZS1zZXJ2ZXItcHJvdG9jb2wvc3BlY2lmaWNhdGlvbnMvc3BlY2lmaWNhdGlvbi1jdXJyZW50LyN3aW5kb3dfbG9nTWVzc2FnZVxuICovXG5leHBvcnQgZGVjbGFyZSBpbnRlcmZhY2UgTG9nTWVzc2FnZSBleHRlbmRzXG4gICAgcHJvdG9jb2wuTm90aWZpY2F0aW9uTWVzc2FnZTxMb2dNZXNzYWdlUGFyYW1zPiB7XG4gIG1ldGhvZDogcHJvdG9jb2wuTWV0aG9kLldpbmRvd0xvZ01lc3NhZ2U7XG59XG5cbi8qKlxuICogVGhlIGxvZyBtZXNzYWdlIG5vdGlmaWNhdGlvbiBpcyBzZW50IGZyb20gdGhlIHNlcnZlciB0byB0aGUgY2xpZW50IHRvIGFzayB0aGVcbiAqIGNsaWVudCB0byBsb2cgYSBwYXJ0aWN1bGFyIG1lc3NhZ2UuXG4gKiBodHRwczovL21pY3Jvc29mdC5naXRodWIuaW8vbGFuZ3VhZ2Utc2VydmVyLXByb3RvY29sL3NwZWNpZmljYXRpb25zL3NwZWNpZmljYXRpb24tY3VycmVudC8jd2luZG93X2xvZ01lc3NhZ2VcbiAqL1xuZXhwb3J0IGRlY2xhcmUgaW50ZXJmYWNlIExvZ01lc3NhZ2VQYXJhbXMge1xuICAvKipcbiAgICogVGhlIG1lc3NhZ2UgdHlwZS4gU2VlIHtAbGluayBNZXNzYWdlVHlwZX1cbiAgICovXG4gIHR5cGU6IE1lc3NhZ2VUeXBlO1xuXG4gIC8qKlxuICAgKiBUaGUgYWN0dWFsIG1lc3NhZ2VcbiAgICovXG4gIG1lc3NhZ2U6IHN0cmluZztcbn1cblxuLyoqIExvZyBtZXNzYWdlIHR5cGUuICovXG5leHBvcnQgZW51bSBNZXNzYWdlVHlwZSB7XG4gIC8qKlxuICAgKiBBbiBlcnJvciBtZXNzYWdlLlxuICAgKi9cbiAgRXJyb3IgPSAxLFxuICAvKipcbiAgICogQSB3YXJuaW5nIG1lc3NhZ2UuXG4gICAqL1xuICBXYXJuaW5nID0gMixcbiAgLyoqXG4gICAqIEFuIGluZm9ybWF0aW9uIG1lc3NhZ2UuXG4gICAqL1xuICBJbmZvID0gMyxcbiAgLyoqXG4gICAqIEEgbG9nIG1lc3NhZ2UuXG4gICAqL1xuICBMb2cgPSA0LFxufVxuIl19
datalab/web/lsp/workspace_node.js ADDED
@@ -0,0 +1,41 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.FileChangeType = exports.WatchKind = void 0;
4
+ /**
5
+ * See:
6
+ * https://microsoft.github.io/language-server-protocol/specification#workspace_didChangeWatchedFiles
7
+ */
8
+ var WatchKind;
9
+ (function (WatchKind) {
10
+ /**
11
+ * Interested in create events.
12
+ */
13
+ WatchKind[WatchKind["Create"] = 1] = "Create";
14
+ /**
15
+ * Interested in change events
16
+ */
17
+ WatchKind[WatchKind["Change"] = 2] = "Change";
18
+ /**
19
+ * Interested in delete events
20
+ */
21
+ WatchKind[WatchKind["Delete"] = 4] = "Delete";
22
+ })(WatchKind || (exports.WatchKind = WatchKind = {}));
23
+ /**
24
+ * The file event type.
25
+ */
26
+ var FileChangeType;
27
+ (function (FileChangeType) {
28
+ /**
29
+ * The file got created.
30
+ */
31
+ FileChangeType[FileChangeType["Created"] = 1] = "Created";
32
+ /**
33
+ * The file got changed.
34
+ */
35
+ FileChangeType[FileChangeType["Changed"] = 2] = "Changed";
36
+ /**
37
+ * The file got deleted.
38
+ */
39
+ FileChangeType[FileChangeType["Deleted"] = 3] = "Deleted";
40
+ })(FileChangeType || (exports.FileChangeType = FileChangeType = {}));
41
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workspace_node.js","sourceRoot":"","sources":["../../../../../../../../genfiles/third_party/colab/sources/lsp/workspace_node.ts"],"names":[],"mappings":";;;AAiTA;;;GAGG;AACH,IAAY,SAeX;AAfD,WAAY,SAAS;IACnB;;OAEG;IACH,6CAAU,CAAA;IAEV;;OAEG;IACH,6CAAU,CAAA;IAEV;;OAEG;IACH,6CAAU,CAAA;AACZ,CAAC,EAfW,SAAS,yBAAT,SAAS,QAepB;AA2BD;;GAEG;AACH,IAAY,cAaX;AAbD,WAAY,cAAc;IACxB;;OAEG;IACH,yDAAW,CAAA;IACX;;OAEG;IACH,yDAAW,CAAA;IACX;;OAEG;IACH,yDAAW,CAAA;AACb,CAAC,EAbW,cAAc,8BAAd,cAAc,QAazB","sourcesContent":["import * as protocol from './protocol_node';\nimport * as textDocument from './text_document_node';\n\n// tslint:disable:enforce-name-casing\n\n/**\n * The workspace/configuration request is sent from the server to the client to\n * fetch configuration settings from the client. The request can fetch several\n * configuration settings in one roundtrip. The order of the returned\n * configuration settings correspond to the order of the passed\n * ConfigurationItems (e.g. the first item in the response is the result for\n * the first configuration item in the params).\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#workspace_configuration\n */\nexport declare interface ConfigurationParams {\n  items: ConfigurationItem[];\n}\n\n/**\n * Specific part of the Configuration which is being requested.\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#workspace_configuration\n */\nexport declare interface ConfigurationItem {\n  /**\n   * The scope to get the configuration section for.\n   */\n  scopeUri?: protocol.DocumentUri;\n\n  /**\n   * The configuration section asked for.\n   */\n  section?: string;\n}\n\n/**\n * A notification sent from the client to the server to signal the change of\n * configuration settings.\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#workspace_didChangeConfiguration\n */\nexport declare interface DidChangeConfiguration extends\n    protocol.NotificationMessage<DidChangeConfigurationParams> {\n  method: protocol.Method.WorkspaceDidChangeConfiguration;\n}\n\n/**\n * Parameters for DidChangeConfiguration.\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#workspace_didChangeConfiguration\n */\nexport declare interface DidChangeConfigurationParams {\n  /**\n   * The actual changed settings\n   */\n  settings: unknown;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#workspaceEdit\n */\nexport declare interface WorkspaceEdit {\n  /**\n   * Holds changes to existing resources.\n   */\n  changes?: {[uri: string]: textDocument.TextEdit[];};\n\n  /**\n   * The client capability `workspace.workspaceEdit.resourceOperations`\n   * determines whether document changes are either an array of\n   * `TextDocumentEdit`s to express changes to different text documents,\n   * where each text document edit addresses a specific version\n   * of a text document, or it can contains the above `TextDocumentEdit`s\n   * mixed with create, rename, and delete file / folder operations.\n   *\n   * Whether a client supports versioned document edits is expressed via\n   * `workspace.workspaceEdit.documentChanges` client capability.\n   *\n   * If a client doesn't support `documentChanges` or\n   * `workspace.workspaceEdit.resourceOperations`, then only plain\n   * `TextEdit`s using the `changes` property are supported.\n   */\n  documentChanges?:\n      (textDocument.TextDocumentEdit[]|\n       Array<textDocument.TextDocumentEdit|CreateFile|RenameFile|DeleteFile>);\n}\n\n/**\n * Options to create a file.\n */\nexport declare interface CreateFileOptions {\n  /**\n   * Overwrite existing file. Overwrite wins over `ignoreIfExists`\n   */\n  overwrite?: boolean;\n  /**\n   * Ignore if exists.\n   */\n  ignoreIfExists?: boolean;\n}\n\n/**\n * Create file operation\n */\nexport declare interface CreateFile {\n  /**\n   * A create\n   */\n  kind: 'create';\n  /**\n   * The resource to create.\n   */\n  uri: protocol.DocumentUri;\n  /**\n   * Additional options\n   */\n  options?: CreateFileOptions;\n}\n\n\n/**\n * Rename file options\n */\nexport declare interface RenameFileOptions {\n  /**\n   * Overwrite target if existing. Overwrite wins over `ignoreIfExists`\n   */\n  overwrite?: boolean;\n  /**\n   * Ignores if target exists.\n   */\n  ignoreIfExists?: boolean;\n}\n\n/**\n * Rename file operation\n */\nexport declare interface RenameFile {\n  /**\n   * A rename\n   */\n  kind: 'rename';\n  /**\n   * The old (existing) location.\n   */\n  oldUri: protocol.DocumentUri;\n  /**\n   * The new location.\n   */\n  newUri: protocol.DocumentUri;\n  /**\n   * Rename options.\n   */\n  options?: RenameFileOptions;\n}\n\n/**\n * Delete file options\n */\nexport declare interface DeleteFileOptions {\n  /**\n   * Delete the content recursively if a folder is denoted.\n   */\n  recursive?: boolean;\n  /**\n   * Ignore the operation if the file doesn't exist.\n   */\n  ignoreIfNotExists?: boolean;\n}\n\n/**\n * Delete file operation\n */\nexport declare interface DeleteFile {\n  /**\n   * A delete\n   */\n  kind: 'delete';\n  /**\n   * The file to delete.\n   */\n  uri: protocol.DocumentUri;\n  /**\n   * Delete options.\n   */\n  options?: DeleteFileOptions;\n}\n\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#workspace_symbol\n */\nexport interface WorkspaceSymbolClientCapabilities {\n  /**\n   * Symbol request supports dynamic registration.\n   */\n  dynamicRegistration?: boolean;\n\n  /**\n   * Specific capabilities for the `SymbolKind` in the\n   * `workspace/symbol` request.\n   */\n  symbolKind?: {\n    /**\n     * The symbol kind values the client supports. When this\n     * property exists the client also guarantees that it will\n     * handle values outside its set gracefully and falls back\n     * to a default value when unknown.\n     *\n     * If this property is not present the client only supports\n     * the symbol kinds from `File` to `Array` as defined in\n     * the initial version of the protocol.\n     */\n    valueSet?: protocol.SymbolKind[];\n  };\n\n  /**\n   * The client supports tags on `SymbolInformation`.\n   * Clients supporting tags have to handle unknown tags gracefully.\n   *\n   * @since 3.16.0\n   */\n  tagSupport?: {\n    /**\n     * The tags supported by the client.\n     */\n    valueSet: protocol.SymbolTag[],\n  };\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#workspace_didChangeWatchedFiles\n */\nexport declare interface DidChangeWatchedFilesClientCapabilities {\n  /**\n   * Did change watched files notification supports dynamic registration.\n   * Please note that the current protocol doesn't support static\n   * configuration for file changes from the server side.\n   */\n  dynamicRegistration?: boolean;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#workspace_didChangeConfiguration\n */\nexport declare interface DidChangeConfigurationClientCapabilities {\n  /**\n   * Did change configuration notification supports dynamic registration.\n   */\n  dynamicRegistration?: boolean;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#workspace_workspaceFolders\n */\nexport declare interface WorkspaceFolder {\n  /**\n   * The associated URI for this workspace folder.\n   */\n  uri: protocol.DocumentUri;\n\n  /**\n   * The name of the workspace folder. Used to refer to this\n   * workspace folder in the user interface.\n   */\n  name: string;\n}\n\n/**\n * Describe options to be used when registering for file system change events.\n */\nexport declare interface DidChangeWatchedFilesRegistrationOptions {\n  /**\n   * The watchers to register.\n   */\n  watchers: FileSystemWatcher[];\n}\n\n/**\n * See:\n * https://microsoft.github.io/language-server-protocol/specification#workspace_didChangeWatchedFiles\n */\nexport declare interface FileSystemWatcher {\n  /**\n   * The glob pattern to watch.\n   *\n   * Glob patterns can have the following syntax:\n   * - `*` to match one or more characters in a path segment\n   * - `?` to match on one character in a path segment\n   * - `**` to match any number of path segments, including none\n   * - `{}` to group sub patterns into an OR expression. (e.g. `**​/*.{ts,js}`\n   *   matches all TypeScript and JavaScript files)\n   * - `[]` to declare a range of characters to match in a path segment\n   *   (e.g., `example.[0-9]` to match on `example.0`, `example.1`, …)\n   * - `[!...]` to negate a range of characters to match in a path segment\n   *   (e.g., `example.[!0-9]` to match on `example.a`, `example.b`, but not\n   *   `example.0`)\n   */\n  globPattern: string;\n\n  /**\n   * The kind of events of interest. If omitted it defaults\n   * to WatchKind.Create | WatchKind.Change | WatchKind.Delete\n   * which is 7.\n   */\n  kind?: WatchKind;\n}\n\n/**\n * See:\n * https://microsoft.github.io/language-server-protocol/specification#workspace_didChangeWatchedFiles\n */\nexport enum WatchKind {\n  /**\n   * Interested in create events.\n   */\n  Create = 1,\n\n  /**\n   * Interested in change events\n   */\n  Change = 2,\n\n  /**\n   * Interested in delete events\n   */\n  Delete = 4,\n}\n\n/**\n * See:\n * https://microsoft.github.io/language-server-protocol/specification#workspace_didChangeWatchedFiles\n */\nexport declare interface DidChangeWatchedFilesParams {\n  /**\n   * The actual file events.\n   */\n  changes: FileEvent[];\n}\n\n/**\n * An event describing a file change.\n */\ndeclare interface FileEvent {\n  /**\n   * The file's URI.\n   */\n  uri: protocol.DocumentUri;\n  /**\n   * The change type.\n   */\n  type: FileChangeType;\n}\n\n/**\n * The file event type.\n */\nexport enum FileChangeType {\n  /**\n   * The file got created.\n   */\n  Created = 1,\n  /**\n   * The file got changed.\n   */\n  Changed = 2,\n  /**\n   * The file got deleted.\n   */\n  Deleted = 3,\n}\n"]}
datalab/web/node_modules/.bin/bunyan ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:cb97ac3eee1e35dfbaa2025aa5bb391bbe5adcbe7305a32d6f6e6cdbe1879ac9
3
+ size 56829
datalab/web/node_modules/.bin/mkdirp ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:24b028bccb1773f02cf0d0fb3dca5468f1b5d22a06cbc5cbf351e1eb3accefb1
3
+ size 731
datalab/web/node_modules/.bin/ncp ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:c7ca0417a675931d7d4f549009af66f25b47ea5a07e6ddcd85efb712afba3178
3
+ size 1084
datalab/web/node_modules/.bin/rimraf ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:3a1557fb195dd6ba967235a93927f74e0452b913425c713bcabdeaee9f62d189
3
+ size 838
datalab/web/node_modules/.bin/semver ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:e5c53c713df57d8bdfd03f00e758b5b6a3f51e91a44eb888065394c0deb0da51
3
+ size 4784
datalab/web/node_modules/.package-lock.json ADDED
@@ -0,0 +1,634 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ {
2
+ "name": "ipy-rev-proxy",
3
+ "lockfileVersion": 2,
4
+ "requires": true,
5
+ "packages": {
6
+ "node_modules/accepts": {
7
+ "version": "1.3.5",
8
+ "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.5.tgz",
9
+ "integrity": "sha1-63d99gEXI6OxTopywIBcjoZ0a9I=",
10
+ "dependencies": {
11
+ "mime-types": "~2.1.18",
12
+ "negotiator": "0.6.1"
13
+ },
14
+ "engines": {
15
+ "node": ">= 0.6"
16
+ }
17
+ },
18
+ "node_modules/after": {
19
+ "version": "0.8.2",
20
+ "resolved": "https://registry.npmjs.org/after/-/after-0.8.2.tgz",
21
+ "integrity": "sha1-/ts5T58OAqqXaOcCvaI7UF+ufh8="
22
+ },
23
+ "node_modules/arraybuffer.slice": {
24
+ "version": "0.0.7",
25
+ "resolved": "https://registry.npmjs.org/arraybuffer.slice/-/arraybuffer.slice-0.0.7.tgz",
26
+ "integrity": "sha512-wGUIVQXuehL5TCqQun8OW81jGzAWycqzFF8lFp+GOM5BXLYj3bKNsYC4daB7n6XjCqxQA/qgTJ+8ANR3acjrog=="
27
+ },
28
+ "node_modules/async": {
29
+ "version": "1.5.2",
30
+ "resolved": "https://registry.npmjs.org/async/-/async-1.5.2.tgz",
31
+ "integrity": "sha1-7GphrlZIDAw8skHJVhjiCJL5Zyo="
32
+ },
33
+ "node_modules/async-limiter": {
34
+ "version": "1.0.0",
35
+ "resolved": "https://registry.npmjs.org/async-limiter/-/async-limiter-1.0.0.tgz",
36
+ "integrity": "sha512-jp/uFnooOiO+L211eZOoSyzpOITMXx1rBITauYykG3BRYPu8h0UcxsPNB04RR5vo4Tyz3+ay17tR6JVf9qzYWg=="
37
+ },
38
+ "node_modules/backo2": {
39
+ "version": "1.0.2",
40
+ "resolved": "https://registry.npmjs.org/backo2/-/backo2-1.0.2.tgz",
41
+ "integrity": "sha1-MasayLEpNjRj41s+u2n038+6eUc="
42
+ },
43
+ "node_modules/balanced-match": {
44
+ "version": "1.0.0",
45
+ "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz",
46
+ "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=",
47
+ "optional": true
48
+ },
49
+ "node_modules/base64-arraybuffer": {
50
+ "version": "0.1.5",
51
+ "resolved": "https://registry.npmjs.org/base64-arraybuffer/-/base64-arraybuffer-0.1.5.tgz",
52
+ "integrity": "sha1-c5JncZI7Whl0etZmqlzUv5xunOg=",
53
+ "engines": {
54
+ "node": ">= 0.6.0"
55
+ }
56
+ },
57
+ "node_modules/base64id": {
58
+ "version": "1.0.0",
59
+ "resolved": "https://registry.npmjs.org/base64id/-/base64id-1.0.0.tgz",
60
+ "integrity": "sha1-R2iMuZu2gE8OBtPnY7HDLlfY5rY=",
61
+ "engines": {
62
+ "node": ">= 0.4.0"
63
+ }
64
+ },
65
+ "node_modules/better-assert": {
66
+ "version": "1.0.2",
67
+ "resolved": "https://registry.npmjs.org/better-assert/-/better-assert-1.0.2.tgz",
68
+ "integrity": "sha1-QIZrnhueC1W0gYlDEeaPr/rrxSI=",
69
+ "dependencies": {
70
+ "callsite": "1.0.0"
71
+ },
72
+ "engines": {
73
+ "node": "*"
74
+ }
75
+ },
76
+ "node_modules/blob": {
77
+ "version": "0.0.4",
78
+ "resolved": "https://registry.npmjs.org/blob/-/blob-0.0.4.tgz",
79
+ "integrity": "sha1-vPEwUspURj8w+fx+lbmkdjCpSSE="
80
+ },
81
+ "node_modules/brace-expansion": {
82
+ "version": "1.1.11",
83
+ "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
84
+ "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
85
+ "optional": true,
86
+ "dependencies": {
87
+ "balanced-match": "^1.0.0",
88
+ "concat-map": "0.0.1"
89
+ }
90
+ },
91
+ "node_modules/bunyan": {
92
+ "version": "1.8.12",
93
+ "resolved": "https://registry.npmjs.org/bunyan/-/bunyan-1.8.12.tgz",
94
+ "integrity": "sha1-8VDw9nSKvdcq6uhPBEA74u8RN5c=",
95
+ "engines": [
96
+ "node >=0.10.0"
97
+ ],
98
+ "bin": {
99
+ "bunyan": "bin/bunyan"
100
+ },
101
+ "optionalDependencies": {
102
+ "dtrace-provider": "~0.8",
103
+ "moment": "^2.10.6",
104
+ "mv": "~2",
105
+ "safe-json-stringify": "~1"
106
+ }
107
+ },
108
+ "node_modules/bunyan-rotating-file-stream": {
109
+ "version": "1.6.3",
110
+ "resolved": "https://registry.npmjs.org/bunyan-rotating-file-stream/-/bunyan-rotating-file-stream-1.6.3.tgz",
111
+ "integrity": "sha512-pJFBvosqXjYXsOtDr72SDhZr3d+1ADDBO8TiU0ju0DbNBS4+vjI3GatczzB7LCcBWqWevQ91j1HYsl8cgnI+HQ==",
112
+ "engines": [
113
+ "node >=0.10.0"
114
+ ],
115
+ "dependencies": {
116
+ "async": "^1.5.2",
117
+ "lodash": "^4.2.1",
118
+ "semver": "^5.1.0",
119
+ "strftime": "^0.9.2"
120
+ }
121
+ },
122
+ "node_modules/callsite": {
123
+ "version": "1.0.0",
124
+ "resolved": "https://registry.npmjs.org/callsite/-/callsite-1.0.0.tgz",
125
+ "integrity": "sha1-KAOY5dZkvXQDi28JBRU+borxvCA=",
126
+ "engines": {
127
+ "node": "*"
128
+ }
129
+ },
130
+ "node_modules/component-bind": {
131
+ "version": "1.0.0",
132
+ "resolved": "https://registry.npmjs.org/component-bind/-/component-bind-1.0.0.tgz",
133
+ "integrity": "sha1-AMYIq33Nk4l8AAllGx06jh5zu9E="
134
+ },
135
+ "node_modules/component-emitter": {
136
+ "version": "1.2.1",
137
+ "resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.2.1.tgz",
138
+ "integrity": "sha1-E3kY1teCg/ffemt8WmPhQOaUJeY="
139
+ },
140
+ "node_modules/component-inherit": {
141
+ "version": "0.0.3",
142
+ "resolved": "https://registry.npmjs.org/component-inherit/-/component-inherit-0.0.3.tgz",
143
+ "integrity": "sha1-ZF/ErfWLcrZJ1crmUTVhnbJv8UM="
144
+ },
145
+ "node_modules/concat-map": {
146
+ "version": "0.0.1",
147
+ "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz",
148
+ "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=",
149
+ "optional": true
150
+ },
151
+ "node_modules/cookie": {
152
+ "version": "0.3.1",
153
+ "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.3.1.tgz",
154
+ "integrity": "sha1-5+Ch+e9DtMi6klxcWpboBtFoc7s=",
155
+ "engines": {
156
+ "node": ">= 0.6"
157
+ }
158
+ },
159
+ "node_modules/debug": {
160
+ "version": "3.1.0",
161
+ "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz",
162
+ "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==",
163
+ "dependencies": {
164
+ "ms": "2.0.0"
165
+ }
166
+ },
167
+ "node_modules/dtrace-provider": {
168
+ "version": "0.8.7",
169
+ "resolved": "https://registry.npmjs.org/dtrace-provider/-/dtrace-provider-0.8.7.tgz",
170
+ "integrity": "sha1-3JObTT4GIM/gwc2APQ0tftBP/QQ=",
171
+ "hasInstallScript": true,
172
+ "optional": true,
173
+ "dependencies": {
174
+ "nan": "^2.10.0"
175
+ },
176
+ "engines": {
177
+ "node": ">=0.10"
178
+ }
179
+ },
180
+ "node_modules/engine.io": {
181
+ "version": "3.2.0",
182
+ "resolved": "https://registry.npmjs.org/engine.io/-/engine.io-3.2.0.tgz",
183
+ "integrity": "sha512-mRbgmAtQ4GAlKwuPnnAvXXwdPhEx+jkc0OBCLrXuD/CRvwNK3AxRSnqK4FSqmAMRRHryVJP8TopOvmEaA64fKw==",
184
+ "dependencies": {
185
+ "accepts": "~1.3.4",
186
+ "base64id": "1.0.0",
187
+ "cookie": "0.3.1",
188
+ "debug": "~3.1.0",
189
+ "engine.io-parser": "~2.1.0",
190
+ "ws": "~3.3.1"
191
+ }
192
+ },
193
+ "node_modules/engine.io-client": {
194
+ "version": "3.2.1",
195
+ "resolved": "https://registry.npmjs.org/engine.io-client/-/engine.io-client-3.2.1.tgz",
196
+ "integrity": "sha512-y5AbkytWeM4jQr7m/koQLc5AxpRKC1hEVUb/s1FUAWEJq5AzJJ4NLvzuKPuxtDi5Mq755WuDvZ6Iv2rXj4PTzw==",
197
+ "dependencies": {
198
+ "component-emitter": "1.2.1",
199
+ "component-inherit": "0.0.3",
200
+ "debug": "~3.1.0",
201
+ "engine.io-parser": "~2.1.1",
202
+ "has-cors": "1.1.0",
203
+ "indexof": "0.0.1",
204
+ "parseqs": "0.0.5",
205
+ "parseuri": "0.0.5",
206
+ "ws": "~3.3.1",
207
+ "xmlhttprequest-ssl": "~1.5.4",
208
+ "yeast": "0.1.2"
209
+ }
210
+ },
211
+ "node_modules/engine.io-client/node_modules/ws": {
212
+ "version": "3.3.3",
213
+ "resolved": "https://registry.npmjs.org/ws/-/ws-3.3.3.tgz",
214
+ "integrity": "sha512-nnWLa/NwZSt4KQJu51MYlCcSQ5g7INpOrOMt4XV8j4dqTXdmlUmSHQ8/oLC069ckre0fRsgfvsKwbTdtKLCDkA==",
215
+ "dependencies": {
216
+ "async-limiter": "~1.0.0",
217
+ "safe-buffer": "~5.1.0",
218
+ "ultron": "~1.1.0"
219
+ }
220
+ },
221
+ "node_modules/engine.io-parser": {
222
+ "version": "2.1.2",
223
+ "resolved": "https://registry.npmjs.org/engine.io-parser/-/engine.io-parser-2.1.2.tgz",
224
+ "integrity": "sha512-dInLFzr80RijZ1rGpx1+56/uFoH7/7InhH3kZt+Ms6hT8tNx3NGW/WNSA/f8As1WkOfkuyb3tnRyuXGxusclMw==",
225
+ "dependencies": {
226
+ "after": "0.8.2",
227
+ "arraybuffer.slice": "~0.0.7",
228
+ "base64-arraybuffer": "0.1.5",
229
+ "blob": "0.0.4",
230
+ "has-binary2": "~1.0.2"
231
+ }
232
+ },
233
+ "node_modules/engine.io/node_modules/ws": {
234
+ "version": "3.3.3",
235
+ "resolved": "https://registry.npmjs.org/ws/-/ws-3.3.3.tgz",
236
+ "integrity": "sha512-nnWLa/NwZSt4KQJu51MYlCcSQ5g7INpOrOMt4XV8j4dqTXdmlUmSHQ8/oLC069ckre0fRsgfvsKwbTdtKLCDkA==",
237
+ "dependencies": {
238
+ "async-limiter": "~1.0.0",
239
+ "safe-buffer": "~5.1.0",
240
+ "ultron": "~1.1.0"
241
+ }
242
+ },
243
+ "node_modules/eventemitter3": {
244
+ "version": "3.1.0",
245
+ "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-3.1.0.tgz",
246
+ "integrity": "sha512-ivIvhpq/Y0uSjcHDcOIccjmYjGLcP09MFGE7ysAwkAvkXfpZlC985pH2/ui64DKazbTW/4kN3yqozUxlXzI6cA=="
247
+ },
248
+ "node_modules/follow-redirects": {
249
+ "version": "1.5.1",
250
+ "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.5.1.tgz",
251
+ "integrity": "sha512-v9GI1hpaqq1ZZR6pBD1+kI7O24PhDvNGNodjS3MdcEqyrahCp8zbtpv+2B/krUnSmUH80lbAS7MrdeK5IylgKg==",
252
+ "dependencies": {
253
+ "debug": "^3.1.0"
254
+ },
255
+ "engines": {
256
+ "node": ">=4.0"
257
+ }
258
+ },
259
+ "node_modules/glob": {
260
+ "version": "6.0.4",
261
+ "resolved": "https://registry.npmjs.org/glob/-/glob-6.0.4.tgz",
262
+ "integrity": "sha1-DwiGD2oVUSey+t1PnOJLGqtuTSI=",
263
+ "deprecated": "Glob versions prior to v9 are no longer supported",
264
+ "optional": true,
265
+ "dependencies": {
266
+ "inflight": "^1.0.4",
267
+ "inherits": "2",
268
+ "minimatch": "2 || 3",
269
+ "once": "^1.3.0",
270
+ "path-is-absolute": "^1.0.0"
271
+ },
272
+ "engines": {
273
+ "node": "*"
274
+ }
275
+ },
276
+ "node_modules/has-binary2": {
277
+ "version": "1.0.3",
278
+ "resolved": "https://registry.npmjs.org/has-binary2/-/has-binary2-1.0.3.tgz",
279
+ "integrity": "sha512-G1LWKhDSvhGeAQ8mPVQlqNcOB2sJdwATtZKl2pDKKHfpf/rYj24lkinxf69blJbnsvtqqNU+L3SL50vzZhXOnw==",
280
+ "dependencies": {
281
+ "isarray": "2.0.1"
282
+ }
283
+ },
284
+ "node_modules/has-cors": {
285
+ "version": "1.1.0",
286
+ "resolved": "https://registry.npmjs.org/has-cors/-/has-cors-1.1.0.tgz",
287
+ "integrity": "sha1-XkdHk/fqmEPRu5nCPu9J/xJv/zk="
288
+ },
289
+ "node_modules/http-proxy": {
290
+ "version": "1.17.0",
291
+ "resolved": "https://registry.npmjs.org/http-proxy/-/http-proxy-1.17.0.tgz",
292
+ "integrity": "sha512-Taqn+3nNvYRfJ3bGvKfBSRwy1v6eePlm3oc/aWVxZp57DQr5Eq3xhKJi7Z4hZpS8PC3H4qI+Yly5EmFacGuA/g==",
293
+ "dependencies": {
294
+ "eventemitter3": "^3.0.0",
295
+ "follow-redirects": "^1.0.0",
296
+ "requires-port": "^1.0.0"
297
+ },
298
+ "engines": {
299
+ "node": ">=4.0.0"
300
+ }
301
+ },
302
+ "node_modules/indexof": {
303
+ "version": "0.0.1",
304
+ "resolved": "https://registry.npmjs.org/indexof/-/indexof-0.0.1.tgz",
305
+ "integrity": "sha1-gtwzbSMrkGIXnQWrMpOmYFn9Q10="
306
+ },
307
+ "node_modules/inflight": {
308
+ "version": "1.0.6",
309
+ "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz",
310
+ "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=",
311
+ "deprecated": "This module is not supported, and leaks memory. Do not use it. Check out lru-cache if you want a good and tested way to coalesce async requests by a key value, which is much more comprehensive and powerful.",
312
+ "optional": true,
313
+ "dependencies": {
314
+ "once": "^1.3.0",
315
+ "wrappy": "1"
316
+ }
317
+ },
318
+ "node_modules/inherits": {
319
+ "version": "2.0.3",
320
+ "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz",
321
+ "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=",
322
+ "optional": true
323
+ },
324
+ "node_modules/isarray": {
325
+ "version": "2.0.1",
326
+ "resolved": "https://registry.npmjs.org/isarray/-/isarray-2.0.1.tgz",
327
+ "integrity": "sha1-o32U7ZzaLVmGXJ92/llu4fM4dB4="
328
+ },
329
+ "node_modules/lodash": {
330
+ "version": "4.17.11",
331
+ "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.11.tgz",
332
+ "integrity": "sha512-cQKh8igo5QUhZ7lg38DYWAxMvjSAKG0A8wGSVimP07SIUEK2UO+arSRKbRZWtelMtN5V0Hkwh5ryOto/SshYIg=="
333
+ },
334
+ "node_modules/mime-db": {
335
+ "version": "1.35.0",
336
+ "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.35.0.tgz",
337
+ "integrity": "sha512-JWT/IcCTsB0Io3AhWUMjRqucrHSPsSf2xKLaRldJVULioggvkJvggZ3VXNNSRkCddE6D+BUI4HEIZIA2OjwIvg==",
338
+ "engines": {
339
+ "node": ">= 0.6"
340
+ }
341
+ },
342
+ "node_modules/mime-types": {
343
+ "version": "2.1.19",
344
+ "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.19.tgz",
345
+ "integrity": "sha512-P1tKYHVSZ6uFo26mtnve4HQFE3koh1UWVkp8YUC+ESBHe945xWSoXuHHiGarDqcEZ+whpCDnlNw5LON0kLo+sw==",
346
+ "dependencies": {
347
+ "mime-db": "~1.35.0"
348
+ },
349
+ "engines": {
350
+ "node": ">= 0.6"
351
+ }
352
+ },
353
+ "node_modules/minimatch": {
354
+ "version": "3.0.4",
355
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz",
356
+ "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==",
357
+ "optional": true,
358
+ "dependencies": {
359
+ "brace-expansion": "^1.1.7"
360
+ },
361
+ "engines": {
362
+ "node": "*"
363
+ }
364
+ },
365
+ "node_modules/minimist": {
366
+ "version": "0.0.8",
367
+ "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz",
368
+ "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=",
369
+ "optional": true
370
+ },
371
+ "node_modules/mkdirp": {
372
+ "version": "0.5.1",
373
+ "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz",
374
+ "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=",
375
+ "deprecated": "Legacy versions of mkdirp are no longer supported. Please update to mkdirp 1.x. (Note that the API surface has changed to use Promises in 1.x.)",
376
+ "optional": true,
377
+ "dependencies": {
378
+ "minimist": "0.0.8"
379
+ },
380
+ "bin": {
381
+ "mkdirp": "bin/cmd.js"
382
+ }
383
+ },
384
+ "node_modules/moment": {
385
+ "version": "2.22.2",
386
+ "resolved": "https://registry.npmjs.org/moment/-/moment-2.22.2.tgz",
387
+ "integrity": "sha1-PCV/mDn8DpP/UxSWMiOeuQeD/2Y=",
388
+ "optional": true,
389
+ "engines": {
390
+ "node": "*"
391
+ }
392
+ },
393
+ "node_modules/ms": {
394
+ "version": "2.0.0",
395
+ "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
396
+ "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g="
397
+ },
398
+ "node_modules/mv": {
399
+ "version": "2.1.1",
400
+ "resolved": "https://registry.npmjs.org/mv/-/mv-2.1.1.tgz",
401
+ "integrity": "sha1-rmzg1vbV4KT32JN5jQPB6pVZtqI=",
402
+ "optional": true,
403
+ "dependencies": {
404
+ "mkdirp": "~0.5.1",
405
+ "ncp": "~2.0.0",
406
+ "rimraf": "~2.4.0"
407
+ },
408
+ "engines": {
409
+ "node": ">=0.8.0"
410
+ }
411
+ },
412
+ "node_modules/nan": {
413
+ "version": "2.10.0",
414
+ "resolved": "https://registry.npmjs.org/nan/-/nan-2.10.0.tgz",
415
+ "integrity": "sha512-bAdJv7fBLhWC+/Bls0Oza+mvTaNQtP+1RyhhhvD95pgUJz6XM5IzgmxOkItJ9tkoCiplvAnXI1tNmmUD/eScyA==",
416
+ "optional": true
417
+ },
418
+ "node_modules/ncp": {
419
+ "version": "2.0.0",
420
+ "resolved": "https://registry.npmjs.org/ncp/-/ncp-2.0.0.tgz",
421
+ "integrity": "sha1-GVoh1sRuNh0vsSgbo4uR6d9727M=",
422
+ "optional": true,
423
+ "bin": {
424
+ "ncp": "bin/ncp"
425
+ }
426
+ },
427
+ "node_modules/negotiator": {
428
+ "version": "0.6.1",
429
+ "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.1.tgz",
430
+ "integrity": "sha1-KzJxhOiZIQEXeyhWP7XnECrNDKk=",
431
+ "engines": {
432
+ "node": ">= 0.6"
433
+ }
434
+ },
435
+ "node_modules/node-pty": {
436
+ "version": "0.9.0",
437
+ "resolved": "https://registry.npmjs.org/node-pty/-/node-pty-0.9.0.tgz",
438
+ "integrity": "sha512-MBnCQl83FTYOu7B4xWw10AW77AAh7ThCE1VXEv+JeWj8mSpGo+0bwgsV+b23ljBFwEM9OmsOv3kM27iUPPm84g==",
439
+ "hasInstallScript": true,
440
+ "dependencies": {
441
+ "nan": "^2.14.0"
442
+ }
443
+ },
444
+ "node_modules/node-pty/node_modules/nan": {
445
+ "version": "2.14.2",
446
+ "resolved": "https://registry.npmjs.org/nan/-/nan-2.14.2.tgz",
447
+ "integrity": "sha512-M2ufzIiINKCuDfBSAUr1vWQ+vuVcA9kqx8JJUsbQi6yf1uGRyb7HfpdfUr5qLXf3B/t8dPvcjhKMmlfnP47EzQ=="
448
+ },
449
+ "node_modules/object-component": {
450
+ "version": "0.0.3",
451
+ "resolved": "https://registry.npmjs.org/object-component/-/object-component-0.0.3.tgz",
452
+ "integrity": "sha1-8MaapQ78lbhmwYb0AKM3acsvEpE="
453
+ },
454
+ "node_modules/once": {
455
+ "version": "1.4.0",
456
+ "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz",
457
+ "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=",
458
+ "optional": true,
459
+ "dependencies": {
460
+ "wrappy": "1"
461
+ }
462
+ },
463
+ "node_modules/options": {
464
+ "version": "0.0.6",
465
+ "resolved": "https://registry.npmjs.org/options/-/options-0.0.6.tgz",
466
+ "integrity": "sha1-7CLTEoBrtT5zF3Pnza788cZDEo8=",
467
+ "engines": {
468
+ "node": ">=0.4.0"
469
+ }
470
+ },
471
+ "node_modules/parseqs": {
472
+ "version": "0.0.5",
473
+ "resolved": "https://registry.npmjs.org/parseqs/-/parseqs-0.0.5.tgz",
474
+ "integrity": "sha1-1SCKNzjkZ2bikbouoXNoSSGouJ0=",
475
+ "dependencies": {
476
+ "better-assert": "~1.0.0"
477
+ }
478
+ },
479
+ "node_modules/parseuri": {
480
+ "version": "0.0.5",
481
+ "resolved": "https://registry.npmjs.org/parseuri/-/parseuri-0.0.5.tgz",
482
+ "integrity": "sha1-gCBKUNTbt3m/3G6+J3jZDkvOMgo=",
483
+ "dependencies": {
484
+ "better-assert": "~1.0.0"
485
+ }
486
+ },
487
+ "node_modules/path-is-absolute": {
488
+ "version": "1.0.1",
489
+ "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz",
490
+ "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=",
491
+ "optional": true,
492
+ "engines": {
493
+ "node": ">=0.10.0"
494
+ }
495
+ },
496
+ "node_modules/requires-port": {
497
+ "version": "1.0.0",
498
+ "resolved": "https://registry.npmjs.org/requires-port/-/requires-port-1.0.0.tgz",
499
+ "integrity": "sha1-kl0mAdOaxIXgkc8NpcbmlNw9yv8="
500
+ },
501
+ "node_modules/rimraf": {
502
+ "version": "2.4.5",
503
+ "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.4.5.tgz",
504
+ "integrity": "sha1-7nEM5dk6j9uFb7Xqj/Di11k0sto=",
505
+ "deprecated": "Rimraf versions prior to v4 are no longer supported",
506
+ "optional": true,
507
+ "dependencies": {
508
+ "glob": "^6.0.1"
509
+ },
510
+ "bin": {
511
+ "rimraf": "bin.js"
512
+ }
513
+ },
514
+ "node_modules/safe-buffer": {
515
+ "version": "5.1.2",
516
+ "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz",
517
+ "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g=="
518
+ },
519
+ "node_modules/safe-json-stringify": {
520
+ "version": "1.2.0",
521
+ "resolved": "https://registry.npmjs.org/safe-json-stringify/-/safe-json-stringify-1.2.0.tgz",
522
+ "integrity": "sha512-gH8eh2nZudPQO6TytOvbxnuhYBOvDBBLW52tz5q6X58lJcd/tkmqFR+5Z9adS8aJtURSXWThWy/xJtJwixErvg==",
523
+ "optional": true
524
+ },
525
+ "node_modules/semver": {
526
+ "version": "5.6.0",
527
+ "resolved": "https://registry.npmjs.org/semver/-/semver-5.6.0.tgz",
528
+ "integrity": "sha512-RS9R6R35NYgQn++fkDWaOmqGoj4Ek9gGs+DPxNUZKuwE183xjJroKvyo1IzVFeXvUrvmALy6FWD5xrdJT25gMg==",
529
+ "bin": {
530
+ "semver": "bin/semver"
531
+ }
532
+ },
533
+ "node_modules/socket.io": {
534
+ "version": "2.1.1",
535
+ "resolved": "https://registry.npmjs.org/socket.io/-/socket.io-2.1.1.tgz",
536
+ "integrity": "sha512-rORqq9c+7W0DAK3cleWNSyfv/qKXV99hV4tZe+gGLfBECw3XEhBy7x85F3wypA9688LKjtwO9pX9L33/xQI8yA==",
537
+ "dependencies": {
538
+ "debug": "~3.1.0",
539
+ "engine.io": "~3.2.0",
540
+ "has-binary2": "~1.0.2",
541
+ "socket.io-adapter": "~1.1.0",
542
+ "socket.io-client": "2.1.1",
543
+ "socket.io-parser": "~3.2.0"
544
+ }
545
+ },
546
+ "node_modules/socket.io-adapter": {
547
+ "version": "1.1.1",
548
+ "resolved": "https://registry.npmjs.org/socket.io-adapter/-/socket.io-adapter-1.1.1.tgz",
549
+ "integrity": "sha1-KoBeihTWNyEk3ZFZrUUC+MsH8Gs="
550
+ },
551
+ "node_modules/socket.io-client": {
552
+ "version": "2.1.1",
553
+ "resolved": "https://registry.npmjs.org/socket.io-client/-/socket.io-client-2.1.1.tgz",
554
+ "integrity": "sha512-jxnFyhAuFxYfjqIgduQlhzqTcOEQSn+OHKVfAxWaNWa7ecP7xSNk2Dx/3UEsDcY7NcFafxvNvKPmmO7HTwTxGQ==",
555
+ "dependencies": {
556
+ "backo2": "1.0.2",
557
+ "base64-arraybuffer": "0.1.5",
558
+ "component-bind": "1.0.0",
559
+ "component-emitter": "1.2.1",
560
+ "debug": "~3.1.0",
561
+ "engine.io-client": "~3.2.0",
562
+ "has-binary2": "~1.0.2",
563
+ "has-cors": "1.1.0",
564
+ "indexof": "0.0.1",
565
+ "object-component": "0.0.3",
566
+ "parseqs": "0.0.5",
567
+ "parseuri": "0.0.5",
568
+ "socket.io-parser": "~3.2.0",
569
+ "to-array": "0.1.4"
570
+ }
571
+ },
572
+ "node_modules/socket.io-parser": {
573
+ "version": "3.2.0",
574
+ "resolved": "https://registry.npmjs.org/socket.io-parser/-/socket.io-parser-3.2.0.tgz",
575
+ "integrity": "sha512-FYiBx7rc/KORMJlgsXysflWx/RIvtqZbyGLlHZvjfmPTPeuD/I8MaW7cfFrj5tRltICJdgwflhfZ3NVVbVLFQA==",
576
+ "dependencies": {
577
+ "component-emitter": "1.2.1",
578
+ "debug": "~3.1.0",
579
+ "isarray": "2.0.1"
580
+ }
581
+ },
582
+ "node_modules/strftime": {
583
+ "version": "0.9.2",
584
+ "resolved": "https://registry.npmjs.org/strftime/-/strftime-0.9.2.tgz",
585
+ "integrity": "sha1-vMooYfKUVtNyqvaheBHIvG859YM=",
586
+ "engines": {
587
+ "node": ">=0.2.0"
588
+ }
589
+ },
590
+ "node_modules/to-array": {
591
+ "version": "0.1.4",
592
+ "resolved": "https://registry.npmjs.org/to-array/-/to-array-0.1.4.tgz",
593
+ "integrity": "sha1-F+bBH3PdTz10zaek/zI46a2b+JA="
594
+ },
595
+ "node_modules/ultron": {
596
+ "version": "1.1.1",
597
+ "resolved": "https://registry.npmjs.org/ultron/-/ultron-1.1.1.tgz",
598
+ "integrity": "sha512-UIEXBNeYmKptWH6z8ZnqTeS8fV74zG0/eRU9VGkpzz+LIJNs8W/zM/L+7ctCkRrgbNnnR0xxw4bKOr0cW0N0Og=="
599
+ },
600
+ "node_modules/wrappy": {
601
+ "version": "1.0.2",
602
+ "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz",
603
+ "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=",
604
+ "optional": true
605
+ },
606
+ "node_modules/ws": {
607
+ "version": "1.1.4",
608
+ "resolved": "https://registry.npmjs.org/ws/-/ws-1.1.4.tgz",
609
+ "integrity": "sha1-V/QNA2gy5fUFVmKjl8Tedu1mv2E=",
610
+ "dependencies": {
611
+ "options": ">=0.0.5",
612
+ "ultron": "1.0.x"
613
+ }
614
+ },
615
+ "node_modules/ws/node_modules/ultron": {
616
+ "version": "1.0.2",
617
+ "resolved": "https://registry.npmjs.org/ultron/-/ultron-1.0.2.tgz",
618
+ "integrity": "sha1-rOEWq1V80Zc4ak6I9GhTeMiy5Po="
619
+ },
620
+ "node_modules/xmlhttprequest-ssl": {
621
+ "version": "1.5.5",
622
+ "resolved": "https://registry.npmjs.org/xmlhttprequest-ssl/-/xmlhttprequest-ssl-1.5.5.tgz",
623
+ "integrity": "sha1-wodrBhaKrcQOV9l+gRkayPQ5iz4=",
624
+ "engines": {
625
+ "node": ">=0.4.0"
626
+ }
627
+ },
628
+ "node_modules/yeast": {
629
+ "version": "0.1.2",
630
+ "resolved": "https://registry.npmjs.org/yeast/-/yeast-0.1.2.tgz",
631
+ "integrity": "sha1-AI4G2AlDIMNy28L47XagymyKxBk="
632
+ }
633
+ }
634
+ }
datalab/web/node_modules/accepts/HISTORY.md ADDED
@@ -0,0 +1,224 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ 1.3.5 / 2018-02-28
2
+ ==================
3
+
4
+ * deps: mime-types@~2.1.18
5
+ - deps: mime-db@~1.33.0
6
+
7
+ 1.3.4 / 2017-08-22
8
+ ==================
9
+
10
+ * deps: mime-types@~2.1.16
11
+ - deps: mime-db@~1.29.0
12
+
13
+ 1.3.3 / 2016-05-02
14
+ ==================
15
+
16
+ * deps: mime-types@~2.1.11
17
+ - deps: mime-db@~1.23.0
18
+ * deps: [email protected]
19
+ - perf: improve `Accept` parsing speed
20
+ - perf: improve `Accept-Charset` parsing speed
21
+ - perf: improve `Accept-Encoding` parsing speed
22
+ - perf: improve `Accept-Language` parsing speed
23
+
24
+ 1.3.2 / 2016-03-08
25
+ ==================
26
+
27
+ * deps: mime-types@~2.1.10
28
+ - Fix extension of `application/dash+xml`
29
+ - Update primary extension for `audio/mp4`
30
+ - deps: mime-db@~1.22.0
31
+
32
+ 1.3.1 / 2016-01-19
33
+ ==================
34
+
35
+ * deps: mime-types@~2.1.9
36
+ - deps: mime-db@~1.21.0
37
+
38
+ 1.3.0 / 2015-09-29
39
+ ==================
40
+
41
+ * deps: mime-types@~2.1.7
42
+ - deps: mime-db@~1.19.0
43
+ * deps: [email protected]
44
+ - Fix including type extensions in parameters in `Accept` parsing
45
+ - Fix parsing `Accept` parameters with quoted equals
46
+ - Fix parsing `Accept` parameters with quoted semicolons
47
+ - Lazy-load modules from main entry point
48
+ - perf: delay type concatenation until needed
49
+ - perf: enable strict mode
50
+ - perf: hoist regular expressions
51
+ - perf: remove closures getting spec properties
52
+ - perf: remove a closure from media type parsing
53
+ - perf: remove property delete from media type parsing
54
+
55
+ 1.2.13 / 2015-09-06
56
+ ===================
57
+
58
+ * deps: mime-types@~2.1.6
59
+ - deps: mime-db@~1.18.0
60
+
61
+ 1.2.12 / 2015-07-30
62
+ ===================
63
+
64
+ * deps: mime-types@~2.1.4
65
+ - deps: mime-db@~1.16.0
66
+
67
+ 1.2.11 / 2015-07-16
68
+ ===================
69
+
70
+ * deps: mime-types@~2.1.3
71
+ - deps: mime-db@~1.15.0
72
+
73
+ 1.2.10 / 2015-07-01
74
+ ===================
75
+
76
+ * deps: mime-types@~2.1.2
77
+ - deps: mime-db@~1.14.0
78
+
79
+ 1.2.9 / 2015-06-08
80
+ ==================
81
+
82
+ * deps: mime-types@~2.1.1
83
+ - perf: fix deopt during mapping
84
+
85
+ 1.2.8 / 2015-06-07
86
+ ==================
87
+
88
+ * deps: mime-types@~2.1.0
89
+ - deps: mime-db@~1.13.0
90
+ * perf: avoid argument reassignment & argument slice
91
+ * perf: avoid negotiator recursive construction
92
+ * perf: enable strict mode
93
+ * perf: remove unnecessary bitwise operator
94
+
95
+ 1.2.7 / 2015-05-10
96
+ ==================
97
+
98
+ * deps: [email protected]
99
+ - Fix media type parameter matching to be case-insensitive
100
+
101
+ 1.2.6 / 2015-05-07
102
+ ==================
103
+
104
+ * deps: mime-types@~2.0.11
105
+ - deps: mime-db@~1.9.1
106
+ * deps: [email protected]
107
+ - Fix comparing media types with quoted values
108
+ - Fix splitting media types with quoted commas
109
+
110
+ 1.2.5 / 2015-03-13
111
+ ==================
112
+
113
+ * deps: mime-types@~2.0.10
114
+ - deps: mime-db@~1.8.0
115
+
116
+ 1.2.4 / 2015-02-14
117
+ ==================
118
+
119
+ * Support Node.js 0.6
120
+ * deps: mime-types@~2.0.9
121
+ - deps: mime-db@~1.7.0
122
+ * deps: [email protected]
123
+ - Fix preference sorting to be stable for long acceptable lists
124
+
125
+ 1.2.3 / 2015-01-31
126
+ ==================
127
+
128
+ * deps: mime-types@~2.0.8
129
+ - deps: mime-db@~1.6.0
130
+
131
+ 1.2.2 / 2014-12-30
132
+ ==================
133
+
134
+ * deps: mime-types@~2.0.7
135
+ - deps: mime-db@~1.5.0
136
+
137
+ 1.2.1 / 2014-12-30
138
+ ==================
139
+
140
+ * deps: mime-types@~2.0.5
141
+ - deps: mime-db@~1.3.1
142
+
143
+ 1.2.0 / 2014-12-19
144
+ ==================
145
+
146
+ * deps: [email protected]
147
+ - Fix list return order when large accepted list
148
+ - Fix missing identity encoding when q=0 exists
149
+ - Remove dynamic building of Negotiator class
150
+
151
+ 1.1.4 / 2014-12-10
152
+ ==================
153
+
154
+ * deps: mime-types@~2.0.4
155
+ - deps: mime-db@~1.3.0
156
+
157
+ 1.1.3 / 2014-11-09
158
+ ==================
159
+
160
+ * deps: mime-types@~2.0.3
161
+ - deps: mime-db@~1.2.0
162
+
163
+ 1.1.2 / 2014-10-14
164
+ ==================
165
+
166
+ * deps: [email protected]
167
+ - Fix error when media type has invalid parameter
168
+
169
+ 1.1.1 / 2014-09-28
170
+ ==================
171
+
172
+ * deps: mime-types@~2.0.2
173
+ - deps: mime-db@~1.1.0
174
+ * deps: [email protected]
175
+ - Fix all negotiations to be case-insensitive
176
+ - Stable sort preferences of same quality according to client order
177
+
178
+ 1.1.0 / 2014-09-02
179
+ ==================
180
+
181
+ * update `mime-types`
182
+
183
+ 1.0.7 / 2014-07-04
184
+ ==================
185
+
186
+ * Fix wrong type returned from `type` when match after unknown extension
187
+
188
+ 1.0.6 / 2014-06-24
189
+ ==================
190
+
191
+ * deps: [email protected]
192
+
193
+ 1.0.5 / 2014-06-20
194
+ ==================
195
+
196
+ * fix crash when unknown extension given
197
+
198
+ 1.0.4 / 2014-06-19
199
+ ==================
200
+
201
+ * use `mime-types`
202
+
203
+ 1.0.3 / 2014-06-11
204
+ ==================
205
+
206
+ * deps: [email protected]
207
+ - Order by specificity when quality is the same
208
+
209
+ 1.0.2 / 2014-05-29
210
+ ==================
211
+
212
+ * Fix interpretation when header not in request
213
+ * deps: pin [email protected]
214
+
215
+ 1.0.1 / 2014-01-18
216
+ ==================
217
+
218
+ * Identity encoding isn't always acceptable
219
+ * deps: negotiator@~0.4.0
220
+
221
+ 1.0.0 / 2013-12-27
222
+ ==================
223
+
224
+ * Genesis
datalab/web/node_modules/accepts/LICENSE ADDED
@@ -0,0 +1,23 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ (The MIT License)
2
+
3
+ Copyright (c) 2014 Jonathan Ong <[email protected]>
4
+ Copyright (c) 2015 Douglas Christopher Wilson <[email protected]>
5
+
6
+ Permission is hereby granted, free of charge, to any person obtaining
7
+ a copy of this software and associated documentation files (the
8
+ 'Software'), to deal in the Software without restriction, including
9
+ without limitation the rights to use, copy, modify, merge, publish,
10
+ distribute, sublicense, and/or sell copies of the Software, and to
11
+ permit persons to whom the Software is furnished to do so, subject to
12
+ the following conditions:
13
+
14
+ The above copyright notice and this permission notice shall be
15
+ included in all copies or substantial portions of the Software.
16
+
17
+ THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND,
18
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
19
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
20
+ IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
21
+ CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
22
+ TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
23
+ SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
datalab/web/node_modules/accepts/README.md ADDED
@@ -0,0 +1,143 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ # accepts
2
+
3
+ [![NPM Version][npm-image]][npm-url]
4
+ [![NPM Downloads][downloads-image]][downloads-url]
5
+ [![Node.js Version][node-version-image]][node-version-url]
6
+ [![Build Status][travis-image]][travis-url]
7
+ [![Test Coverage][coveralls-image]][coveralls-url]
8
+
9
+ Higher level content negotiation based on [negotiator](https://www.npmjs.com/package/negotiator).
10
+ Extracted from [koa](https://www.npmjs.com/package/koa) for general use.
11
+
12
+ In addition to negotiator, it allows:
13
+
14
+ - Allows types as an array or arguments list, ie `(['text/html', 'application/json'])`
15
+ as well as `('text/html', 'application/json')`.
16
+ - Allows type shorthands such as `json`.
17
+ - Returns `false` when no types match
18
+ - Treats non-existent headers as `*`
19
+
20
+ ## Installation
21
+
22
+ This is a [Node.js](https://nodejs.org/en/) module available through the
23
+ [npm registry](https://www.npmjs.com/). Installation is done using the
24
+ [`npm install` command](https://docs.npmjs.com/getting-started/installing-npm-packages-locally):
25
+
26
+ ```sh
27
+ $ npm install accepts
28
+ ```
29
+
30
+ ## API
31
+
32
+ <!-- eslint-disable no-unused-vars -->
33
+
34
+ ```js
35
+ var accepts = require('accepts')
36
+ ```
37
+
38
+ ### accepts(req)
39
+
40
+ Create a new `Accepts` object for the given `req`.
41
+
42
+ #### .charset(charsets)
43
+
44
+ Return the first accepted charset. If nothing in `charsets` is accepted,
45
+ then `false` is returned.
46
+
47
+ #### .charsets()
48
+
49
+ Return the charsets that the request accepts, in the order of the client's
50
+ preference (most preferred first).
51
+
52
+ #### .encoding(encodings)
53
+
54
+ Return the first accepted encoding. If nothing in `encodings` is accepted,
55
+ then `false` is returned.
56
+
57
+ #### .encodings()
58
+
59
+ Return the encodings that the request accepts, in the order of the client's
60
+ preference (most preferred first).
61
+
62
+ #### .language(languages)
63
+
64
+ Return the first accepted language. If nothing in `languages` is accepted,
65
+ then `false` is returned.
66
+
67
+ #### .languages()
68
+
69
+ Return the languages that the request accepts, in the order of the client's
70
+ preference (most preferred first).
71
+
72
+ #### .type(types)
73
+
74
+ Return the first accepted type (and it is returned as the same text as what
75
+ appears in the `types` array). If nothing in `types` is accepted, then `false`
76
+ is returned.
77
+
78
+ The `types` array can contain full MIME types or file extensions. Any value
79
+ that is not a full MIME types is passed to `require('mime-types').lookup`.
80
+
81
+ #### .types()
82
+
83
+ Return the types that the request accepts, in the order of the client's
84
+ preference (most preferred first).
85
+
86
+ ## Examples
87
+
88
+ ### Simple type negotiation
89
+
90
+ This simple example shows how to use `accepts` to return a different typed
91
+ respond body based on what the client wants to accept. The server lists it's
92
+ preferences in order and will get back the best match between the client and
93
+ server.
94
+
95
+ ```js
96
+ var accepts = require('accepts')
97
+ var http = require('http')
98
+
99
+ function app (req, res) {
100
+ var accept = accepts(req)
101
+
102
+ // the order of this list is significant; should be server preferred order
103
+ switch (accept.type(['json', 'html'])) {
104
+ case 'json':
105
+ res.setHeader('Content-Type', 'application/json')
106
+ res.write('{"hello":"world!"}')
107
+ break
108
+ case 'html':
109
+ res.setHeader('Content-Type', 'text/html')
110
+ res.write('<b>hello, world!</b>')
111
+ break
112
+ default:
113
+ // the fallback is text/plain, so no need to specify it above
114
+ res.setHeader('Content-Type', 'text/plain')
115
+ res.write('hello, world!')
116
+ break
117
+ }
118
+
119
+ res.end()
120
+ }
121
+
122
+ http.createServer(app).listen(3000)
123
+ ```
124
+
125
+ You can test this out with the cURL program:
126
+ ```sh
127
+ curl -I -H'Accept: text/html' http://localhost:3000/
128
+ ```
129
+
130
+ ## License
131
+
132
+ [MIT](LICENSE)
133
+
134
+ [npm-image]: https://img.shields.io/npm/v/accepts.svg
135
+ [npm-url]: https://npmjs.org/package/accepts
136
+ [node-version-image]: https://img.shields.io/node/v/accepts.svg
137
+ [node-version-url]: https://nodejs.org/en/download/
138
+ [travis-image]: https://img.shields.io/travis/jshttp/accepts/master.svg
139
+ [travis-url]: https://travis-ci.org/jshttp/accepts
140
+ [coveralls-image]: https://img.shields.io/coveralls/jshttp/accepts/master.svg
141
+ [coveralls-url]: https://coveralls.io/r/jshttp/accepts
142
+ [downloads-image]: https://img.shields.io/npm/dm/accepts.svg
143
+ [downloads-url]: https://npmjs.org/package/accepts
datalab/web/node_modules/accepts/index.js ADDED
@@ -0,0 +1,238 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ /*!
2
+ * accepts
3
+ * Copyright(c) 2014 Jonathan Ong
4
+ * Copyright(c) 2015 Douglas Christopher Wilson
5
+ * MIT Licensed
6
+ */
7
+
8
+ 'use strict'
9
+
10
+ /**
11
+ * Module dependencies.
12
+ * @private
13
+ */
14
+
15
+ var Negotiator = require('negotiator')
16
+ var mime = require('mime-types')
17
+
18
+ /**
19
+ * Module exports.
20
+ * @public
21
+ */
22
+
23
+ module.exports = Accepts
24
+
25
+ /**
26
+ * Create a new Accepts object for the given req.
27
+ *
28
+ * @param {object} req
29
+ * @public
30
+ */
31
+
32
+ function Accepts (req) {
33
+ if (!(this instanceof Accepts)) {
34
+ return new Accepts(req)
35
+ }
36
+
37
+ this.headers = req.headers
38
+ this.negotiator = new Negotiator(req)
39
+ }
40
+
41
+ /**
42
+ * Check if the given `type(s)` is acceptable, returning
43
+ * the best match when true, otherwise `undefined`, in which
44
+ * case you should respond with 406 "Not Acceptable".
45
+ *
46
+ * The `type` value may be a single mime type string
47
+ * such as "application/json", the extension name
48
+ * such as "json" or an array `["json", "html", "text/plain"]`. When a list
49
+ * or array is given the _best_ match, if any is returned.
50
+ *
51
+ * Examples:
52
+ *
53
+ * // Accept: text/html
54
+ * this.types('html');
55
+ * // => "html"
56
+ *
57
+ * // Accept: text/*, application/json
58
+ * this.types('html');
59
+ * // => "html"
60
+ * this.types('text/html');
61
+ * // => "text/html"
62
+ * this.types('json', 'text');
63
+ * // => "json"
64
+ * this.types('application/json');
65
+ * // => "application/json"
66
+ *
67
+ * // Accept: text/*, application/json
68
+ * this.types('image/png');
69
+ * this.types('png');
70
+ * // => undefined
71
+ *
72
+ * // Accept: text/*;q=.5, application/json
73
+ * this.types(['html', 'json']);
74
+ * this.types('html', 'json');
75
+ * // => "json"
76
+ *
77
+ * @param {String|Array} types...
78
+ * @return {String|Array|Boolean}
79
+ * @public
80
+ */
81
+
82
+ Accepts.prototype.type =
83
+ Accepts.prototype.types = function (types_) {
84
+ var types = types_
85
+
86
+ // support flattened arguments
87
+ if (types && !Array.isArray(types)) {
88
+ types = new Array(arguments.length)
89
+ for (var i = 0; i < types.length; i++) {
90
+ types[i] = arguments[i]
91
+ }
92
+ }
93
+
94
+ // no types, return all requested types
95
+ if (!types || types.length === 0) {
96
+ return this.negotiator.mediaTypes()
97
+ }
98
+
99
+ // no accept header, return first given type
100
+ if (!this.headers.accept) {
101
+ return types[0]
102
+ }
103
+
104
+ var mimes = types.map(extToMime)
105
+ var accepts = this.negotiator.mediaTypes(mimes.filter(validMime))
106
+ var first = accepts[0]
107
+
108
+ return first
109
+ ? types[mimes.indexOf(first)]
110
+ : false
111
+ }
112
+
113
+ /**
114
+ * Return accepted encodings or best fit based on `encodings`.
115
+ *
116
+ * Given `Accept-Encoding: gzip, deflate`
117
+ * an array sorted by quality is returned:
118
+ *
119
+ * ['gzip', 'deflate']
120
+ *
121
+ * @param {String|Array} encodings...
122
+ * @return {String|Array}
123
+ * @public
124
+ */
125
+
126
+ Accepts.prototype.encoding =
127
+ Accepts.prototype.encodings = function (encodings_) {
128
+ var encodings = encodings_
129
+
130
+ // support flattened arguments
131
+ if (encodings && !Array.isArray(encodings)) {
132
+ encodings = new Array(arguments.length)
133
+ for (var i = 0; i < encodings.length; i++) {
134
+ encodings[i] = arguments[i]
135
+ }
136
+ }
137
+
138
+ // no encodings, return all requested encodings
139
+ if (!encodings || encodings.length === 0) {
140
+ return this.negotiator.encodings()
141
+ }
142
+
143
+ return this.negotiator.encodings(encodings)[0] || false
144
+ }
145
+
146
+ /**
147
+ * Return accepted charsets or best fit based on `charsets`.
148
+ *
149
+ * Given `Accept-Charset: utf-8, iso-8859-1;q=0.2, utf-7;q=0.5`
150
+ * an array sorted by quality is returned:
151
+ *
152
+ * ['utf-8', 'utf-7', 'iso-8859-1']
153
+ *
154
+ * @param {String|Array} charsets...
155
+ * @return {String|Array}
156
+ * @public
157
+ */
158
+
159
+ Accepts.prototype.charset =
160
+ Accepts.prototype.charsets = function (charsets_) {
161
+ var charsets = charsets_
162
+
163
+ // support flattened arguments
164
+ if (charsets && !Array.isArray(charsets)) {
165
+ charsets = new Array(arguments.length)
166
+ for (var i = 0; i < charsets.length; i++) {
167
+ charsets[i] = arguments[i]
168
+ }
169
+ }
170
+
171
+ // no charsets, return all requested charsets
172
+ if (!charsets || charsets.length === 0) {
173
+ return this.negotiator.charsets()
174
+ }
175
+
176
+ return this.negotiator.charsets(charsets)[0] || false
177
+ }
178
+
179
+ /**
180
+ * Return accepted languages or best fit based on `langs`.
181
+ *
182
+ * Given `Accept-Language: en;q=0.8, es, pt`
183
+ * an array sorted by quality is returned:
184
+ *
185
+ * ['es', 'pt', 'en']
186
+ *
187
+ * @param {String|Array} langs...
188
+ * @return {Array|String}
189
+ * @public
190
+ */
191
+
192
+ Accepts.prototype.lang =
193
+ Accepts.prototype.langs =
194
+ Accepts.prototype.language =
195
+ Accepts.prototype.languages = function (languages_) {
196
+ var languages = languages_
197
+
198
+ // support flattened arguments
199
+ if (languages && !Array.isArray(languages)) {
200
+ languages = new Array(arguments.length)
201
+ for (var i = 0; i < languages.length; i++) {
202
+ languages[i] = arguments[i]
203
+ }
204
+ }
205
+
206
+ // no languages, return all requested languages
207
+ if (!languages || languages.length === 0) {
208
+ return this.negotiator.languages()
209
+ }
210
+
211
+ return this.negotiator.languages(languages)[0] || false
212
+ }
213
+
214
+ /**
215
+ * Convert extnames to mime.
216
+ *
217
+ * @param {String} type
218
+ * @return {String}
219
+ * @private
220
+ */
221
+
222
+ function extToMime (type) {
223
+ return type.indexOf('/') === -1
224
+ ? mime.lookup(type)
225
+ : type
226
+ }
227
+
228
+ /**
229
+ * Check if mime is valid.
230
+ *
231
+ * @param {String} type
232
+ * @return {String}
233
+ * @private
234
+ */
235
+
236
+ function validMime (type) {
237
+ return typeof type === 'string'
238
+ }
datalab/web/node_modules/accepts/package.json ADDED
@@ -0,0 +1,46 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ {
2
+ "name": "accepts",
3
+ "description": "Higher-level content negotiation",
4
+ "version": "1.3.5",
5
+ "contributors": [
6
+ "Douglas Christopher Wilson <[email protected]>",
7
+ "Jonathan Ong <[email protected]> (http://jongleberry.com)"
8
+ ],
9
+ "license": "MIT",
10
+ "repository": "jshttp/accepts",
11
+ "dependencies": {
12
+ "mime-types": "~2.1.18",
13
+ "negotiator": "0.6.1"
14
+ },
15
+ "devDependencies": {
16
+ "eslint": "4.18.1",
17
+ "eslint-config-standard": "11.0.0",
18
+ "eslint-plugin-import": "2.9.0",
19
+ "eslint-plugin-markdown": "1.0.0-beta.6",
20
+ "eslint-plugin-node": "6.0.1",
21
+ "eslint-plugin-promise": "3.6.0",
22
+ "eslint-plugin-standard": "3.0.1",
23
+ "istanbul": "0.4.5",
24
+ "mocha": "~1.21.5"
25
+ },
26
+ "files": [
27
+ "LICENSE",
28
+ "HISTORY.md",
29
+ "index.js"
30
+ ],
31
+ "engines": {
32
+ "node": ">= 0.6"
33
+ },
34
+ "scripts": {
35
+ "lint": "eslint --plugin markdown --ext js,md .",
36
+ "test": "mocha --reporter spec --check-leaks --bail test/",
37
+ "test-cov": "istanbul cover node_modules/mocha/bin/_mocha -- --reporter dot --check-leaks test/",
38
+ "test-travis": "istanbul cover node_modules/mocha/bin/_mocha --report lcovonly -- --reporter spec --check-leaks test/"
39
+ },
40
+ "keywords": [
41
+ "content",
42
+ "negotiation",
43
+ "accept",
44
+ "accepts"
45
+ ]
46
+ }
datalab/web/node_modules/after/.npmignore ADDED
@@ -0,0 +1,2 @@
 
 
 
1
+ node_modules
2
+ .monitor
datalab/web/node_modules/after/.travis.yml ADDED
@@ -0,0 +1,12 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ language: node_js
2
+ node_js:
3
+ - 0.6
4
+ - 0.8
5
+ - 0.9
6
+ - 0.10
7
+ - 0.12
8
+ - 4.2.4
9
+ - 5.4.1
10
+ - iojs-1
11
+ - iojs-2
12
+ - iojs-3
datalab/web/node_modules/after/LICENCE ADDED
@@ -0,0 +1,19 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ Copyright (c) 2011 Raynos.
2
+
3
+ Permission is hereby granted, free of charge, to any person obtaining a copy
4
+ of this software and associated documentation files (the "Software"), to deal
5
+ in the Software without restriction, including without limitation the rights
6
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
7
+ copies of the Software, and to permit persons to whom the Software is
8
+ furnished to do so, subject to the following conditions:
9
+
10
+ The above copyright notice and this permission notice shall be included in
11
+ all copies or substantial portions of the Software.
12
+
13
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
14
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
15
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
16
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
17
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
18
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
19
+ THE SOFTWARE.
datalab/web/node_modules/after/README.md ADDED
@@ -0,0 +1,115 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ # After [![Build Status][1]][2]
2
+
3
+ Invoke callback after n calls
4
+
5
+ ## Status: production ready
6
+
7
+ ## Example
8
+
9
+ ```js
10
+ var after = require("after")
11
+ var db = require("./db") // some db.
12
+
13
+ var updateUser = function (req, res) {
14
+ // use after to run two tasks in parallel,
15
+ // namely get request body and get session
16
+ // then run updateUser with the results
17
+ var next = after(2, updateUser)
18
+ var results = {}
19
+
20
+ getJSONBody(req, res, function (err, body) {
21
+ if (err) return next(err)
22
+
23
+ results.body = body
24
+ next(null, results)
25
+ })
26
+
27
+ getSessionUser(req, res, function (err, user) {
28
+ if (err) return next(err)
29
+
30
+ results.user = user
31
+ next(null, results)
32
+ })
33
+
34
+ // now do the thing!
35
+ function updateUser(err, result) {
36
+ if (err) {
37
+ res.statusCode = 500
38
+ return res.end("Unexpected Error")
39
+ }
40
+
41
+ if (!result.user || result.user.role !== "admin") {
42
+ res.statusCode = 403
43
+ return res.end("Permission Denied")
44
+ }
45
+
46
+ db.put("users:" + req.params.userId, result.body, function (err) {
47
+ if (err) {
48
+ res.statusCode = 500
49
+ return res.end("Unexpected Error")
50
+ }
51
+
52
+ res.statusCode = 200
53
+ res.end("Ok")
54
+ })
55
+ }
56
+ }
57
+ ```
58
+
59
+ ## Naive Example
60
+
61
+ ```js
62
+ var after = require("after")
63
+ , next = after(3, logItWorks)
64
+
65
+ next()
66
+ next()
67
+ next() // it works
68
+
69
+ function logItWorks() {
70
+ console.log("it works!")
71
+ }
72
+ ```
73
+
74
+ ## Example with error handling
75
+
76
+ ```js
77
+ var after = require("after")
78
+ , next = after(3, logError)
79
+
80
+ next()
81
+ next(new Error("oops")) // logs oops
82
+ next() // does nothing
83
+
84
+ // This callback is only called once.
85
+ // If there is an error the callback gets called immediately
86
+ // this avoids the situation where errors get lost.
87
+ function logError(err) {
88
+ console.log(err)
89
+ }
90
+ ```
91
+
92
+ ## Installation
93
+
94
+ `npm install after`
95
+
96
+ ## Tests
97
+
98
+ `npm test`
99
+
100
+ ## Contributors
101
+
102
+ - Raynos
103
+ - defunctzombie
104
+
105
+ ## MIT Licenced
106
+
107
+ [1]: https://secure.travis-ci.org/Raynos/after.png
108
+ [2]: http://travis-ci.org/Raynos/after
109
+ [3]: http://raynos.org/blog/2/Flow-control-in-node.js
110
+ [4]: http://stackoverflow.com/questions/6852059/determining-the-end-of-asynchronous-operations-javascript/6852307#6852307
111
+ [5]: http://stackoverflow.com/questions/6869872/in-javascript-what-are-best-practices-for-executing-multiple-asynchronous-functi/6870031#6870031
112
+ [6]: http://stackoverflow.com/questions/6864397/javascript-performance-long-running-tasks/6889419#6889419
113
+ [7]: http://stackoverflow.com/questions/6597493/synchronous-database-queries-with-node-js/6620091#6620091
114
+ [8]: http://github.com/Raynos/iterators
115
+ [9]: http://github.com/Raynos/composite
datalab/web/node_modules/after/index.js ADDED
@@ -0,0 +1,28 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ module.exports = after
2
+
3
+ function after(count, callback, err_cb) {
4
+ var bail = false
5
+ err_cb = err_cb || noop
6
+ proxy.count = count
7
+
8
+ return (count === 0) ? callback() : proxy
9
+
10
+ function proxy(err, result) {
11
+ if (proxy.count <= 0) {
12
+ throw new Error('after called too many times')
13
+ }
14
+ --proxy.count
15
+
16
+ // after first error, rest are passed to err_cb
17
+ if (err) {
18
+ bail = true
19
+ callback(err)
20
+ // future error callbacks will go to error handler
21
+ callback = err_cb
22
+ } else if (proxy.count === 0 && !bail) {
23
+ callback(null, result)
24
+ }
25
+ }
26
+ }
27
+
28
+ function noop() {}
datalab/web/node_modules/after/package.json ADDED
@@ -0,0 +1,28 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ {
2
+ "name": "after",
3
+ "description": "after - tiny flow control",
4
+ "version": "0.8.2",
5
+ "author": "Raynos <[email protected]>",
6
+ "contributors": [
7
+ {
8
+ "name": "Raynos",
9
+ "email": "[email protected]",
10
+ "url": "http://raynos.org"
11
+ }
12
+ ],
13
+ "scripts": {
14
+ "test": "mocha --ui tdd --reporter spec test/*.js"
15
+ },
16
+ "devDependencies": {
17
+ "mocha": "~1.8.1"
18
+ },
19
+ "keywords": [
20
+ "flowcontrol",
21
+ "after",
22
+ "flow",
23
+ "control",
24
+ "arch"
25
+ ],
26
+ "license": "MIT",
27
+ "repository": "git://github.com/Raynos/after.git"
28
+ }
datalab/web/node_modules/after/test/after-test.js ADDED
@@ -0,0 +1,120 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ /*global suite, test*/
2
+
3
+ var assert = require("assert")
4
+ , after = require("../")
5
+
6
+ test("exists", function () {
7
+ assert(typeof after === "function", "after is not a function")
8
+ })
9
+
10
+ test("after when called with 0 invokes", function (done) {
11
+ after(0, done)
12
+ });
13
+
14
+ test("after 1", function (done) {
15
+ var next = after(1, done)
16
+ next()
17
+ })
18
+
19
+ test("after 5", function (done) {
20
+ var next = after(5, done)
21
+ , i = 5
22
+
23
+ while (i--) {
24
+ next()
25
+ }
26
+ })
27
+
28
+ test("manipulate count", function (done) {
29
+ var next = after(1, done)
30
+ , i = 5
31
+
32
+ next.count = i
33
+ while (i--) {
34
+ next()
35
+ }
36
+ })
37
+
38
+ test("after terminates on error", function (done) {
39
+ var next = after(2, function(err) {
40
+ assert.equal(err.message, 'test');
41
+ done();
42
+ })
43
+ next(new Error('test'))
44
+ next(new Error('test2'))
45
+ })
46
+
47
+ test('gee', function(done) {
48
+ done = after(2, done)
49
+
50
+ function cb(err) {
51
+ assert.equal(err.message, 1);
52
+ done()
53
+ }
54
+
55
+ var next = after(3, cb, function(err) {
56
+ assert.equal(err.message, 2)
57
+ done()
58
+ });
59
+
60
+ next()
61
+ next(new Error(1))
62
+ next(new Error(2))
63
+ })
64
+
65
+ test('eee', function(done) {
66
+ done = after(3, done)
67
+
68
+ function cb(err) {
69
+ assert.equal(err.message, 1);
70
+ done()
71
+ }
72
+
73
+ var next = after(3, cb, function(err) {
74
+ assert.equal(err.message, 2)
75
+ done()
76
+ });
77
+
78
+ next(new Error(1))
79
+ next(new Error(2))
80
+ next(new Error(2))
81
+ })
82
+
83
+ test('gge', function(done) {
84
+ function cb(err) {
85
+ assert.equal(err.message, 1);
86
+ done()
87
+ }
88
+
89
+ var next = after(3, cb, function(err) {
90
+ // should not happen
91
+ assert.ok(false);
92
+ });
93
+
94
+ next()
95
+ next()
96
+ next(new Error(1))
97
+ })
98
+
99
+ test('egg', function(done) {
100
+ function cb(err) {
101
+ assert.equal(err.message, 1);
102
+ done()
103
+ }
104
+
105
+ var next = after(3, cb, function(err) {
106
+ // should not happen
107
+ assert.ok(false);
108
+ });
109
+
110
+ next(new Error(1))
111
+ next()
112
+ next()
113
+ })
114
+
115
+ test('throws on too many calls', function(done) {
116
+ var next = after(1, done);
117
+ next()
118
+ assert.throws(next, /after called too many times/);
119
+ });
120
+
datalab/web/node_modules/arraybuffer.slice/.npmignore ADDED
@@ -0,0 +1,17 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ lib-cov
2
+ lcov.info
3
+ *.seed
4
+ *.log
5
+ *.csv
6
+ *.dat
7
+ *.out
8
+ *.pid
9
+ *.gz
10
+
11
+ pids
12
+ logs
13
+ results
14
+ build
15
+ .grunt
16
+
17
+ node_modules
datalab/web/node_modules/arraybuffer.slice/LICENCE ADDED
@@ -0,0 +1,18 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ Copyright (C) 2013 Rase-
2
+
3
+ Permission is hereby granted, free of charge, to any person obtaining a copy of
4
+ this software and associated documentation files (the "Software"), to deal in
5
+ the Software without restriction, including without limitation the rights to
6
+ use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
7
+ of the Software, and to permit persons to whom the Software is furnished to do
8
+ so, subject to the following conditions:
9
+
10
+ The above copyright notice and this permission notice shall be included in all
11
+ copies or substantial portions of the Software.
12
+
13
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
14
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
15
+ FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
16
+ COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
17
+ IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
18
+ CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
datalab/web/node_modules/arraybuffer.slice/Makefile ADDED
@@ -0,0 +1,8 @@
 
 
 
 
 
 
 
 
 
1
+
2
+ REPORTER = dot
3
+
4
+ test:
5
+ @./node_modules/.bin/mocha \
6
+ --reporter $(REPORTER)
7
+
8
+ .PHONY: test
datalab/web/node_modules/arraybuffer.slice/README.md ADDED
@@ -0,0 +1,17 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ # How to
2
+ ```javascript
3
+ var sliceBuffer = require('arraybuffer.slice');
4
+ var ab = (new Int8Array(5)).buffer;
5
+ var sliced = sliceBuffer(ab, 1, 3);
6
+ sliced = sliceBuffer(ab, 1);
7
+ ```
8
+
9
+ # Licence (MIT)
10
+ Copyright (C) 2013 Rase-
11
+
12
+
13
+ Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
14
+
15
+ The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
16
+
17
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
datalab/web/node_modules/arraybuffer.slice/index.js ADDED
@@ -0,0 +1,29 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ /**
2
+ * An abstraction for slicing an arraybuffer even when
3
+ * ArrayBuffer.prototype.slice is not supported
4
+ *
5
+ * @api public
6
+ */
7
+
8
+ module.exports = function(arraybuffer, start, end) {
9
+ var bytes = arraybuffer.byteLength;
10
+ start = start || 0;
11
+ end = end || bytes;
12
+
13
+ if (arraybuffer.slice) { return arraybuffer.slice(start, end); }
14
+
15
+ if (start < 0) { start += bytes; }
16
+ if (end < 0) { end += bytes; }
17
+ if (end > bytes) { end = bytes; }
18
+
19
+ if (start >= bytes || start >= end || bytes === 0) {
20
+ return new ArrayBuffer(0);
21
+ }
22
+
23
+ var abv = new Uint8Array(arraybuffer);
24
+ var result = new Uint8Array(end - start);
25
+ for (var i = start, ii = 0; i < end; i++, ii++) {
26
+ result[ii] = abv[i];
27
+ }
28
+ return result.buffer;
29
+ };
datalab/web/node_modules/arraybuffer.slice/package.json ADDED
@@ -0,0 +1,16 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ {
2
+ "name": "arraybuffer.slice",
3
+ "description": "Exports a function for slicing ArrayBuffers (no polyfilling)",
4
+ "version": "0.0.7",
5
+ "license": "MIT",
6
+ "homepage": "https://github.com/rase-/arraybuffer.slice",
7
+ "dependencies": {},
8
+ "devDependencies": {
9
+ "mocha": "1.17.1",
10
+ "expect.js": "0.2.0"
11
+ },
12
+ "repository": {
13
+ "type": "git",
14
+ "url": "[email protected]:rase-/arraybuffer.slice.git"
15
+ }
16
+ }
datalab/web/node_modules/arraybuffer.slice/test/slice-buffer.js ADDED
@@ -0,0 +1,227 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ /*
2
+ * Test dependencies
3
+ */
4
+
5
+ var sliceBuffer = require('../index.js');
6
+ var expect = require('expect.js');
7
+
8
+ /**
9
+ * Tests
10
+ */
11
+
12
+ describe('sliceBuffer', function() {
13
+ describe('using standard slice', function() {
14
+ it('should slice correctly with only start provided', function() {
15
+ var abv = new Uint8Array(10);
16
+ for (var i = 0; i < abv.length; i++) {
17
+ abv[i] = i;
18
+ }
19
+
20
+ var sliced = sliceBuffer(abv.buffer, 3);
21
+ var sabv = new Uint8Array(sliced);
22
+ for (var i = 3, ii = 0; i < abv.length; i++, ii++) {
23
+ expect(abv[i]).to.equal(sabv[ii]);
24
+ }
25
+ });
26
+
27
+ it('should slice correctly with start and end provided', function() {
28
+ var abv = new Uint8Array(10);
29
+ for (var i = 0; i < abv.length; i++) {
30
+ abv[i] = i;
31
+ }
32
+
33
+ var sliced = sliceBuffer(abv.buffer, 3, 8);
34
+ var sabv = new Uint8Array(sliced);
35
+ for (var i = 3, ii = 0; i < 8; i++, ii++) {
36
+ expect(abv[i]).to.equal(sabv[ii]);
37
+ }
38
+ });
39
+
40
+ it('should slice correctly with negative start', function() {
41
+ var abv = new Uint8Array(10);
42
+ for (var i = 0; i < abv.length; i++) {
43
+ abv[i] = i;
44
+ }
45
+
46
+ var sliced = sliceBuffer(abv.buffer, -3);
47
+ var sabv = new Uint8Array(sliced);
48
+ for (var i = abv.length - 3, ii = 0; i < abv.length; i++, ii++) {
49
+ expect(abv[i]).to.equal(sabv[ii]);
50
+ }
51
+ });
52
+
53
+ it('should slice correctly with negative end', function() {
54
+ var abv = new Uint8Array(10);
55
+ for (var i = 0; i < abv.length; i++) {
56
+ abv[i] = i;
57
+ }
58
+
59
+ var sliced = sliceBuffer(abv.buffer, 0, -3);
60
+ var sabv = new Uint8Array(sliced);
61
+ for (var i = 0, ii = 0; i < abv.length - 3; i++, ii++) {
62
+ expect(abv[i]).to.equal(sabv[ii]);
63
+ }
64
+ });
65
+
66
+ it('should slice correctly with negative start and end', function() {
67
+ var abv = new Uint8Array(10);
68
+ for (var i = 0; i < abv.length; i++) {
69
+ abv[i] = i;
70
+ }
71
+
72
+ var sliced = sliceBuffer(abv.buffer, -6, -3);
73
+ var sabv = new Uint8Array(sliced);
74
+ for (var i = abv.length - 6, ii = 0; i < abv.length - 3; i++, ii++) {
75
+ expect(abv[i]).to.equal(sabv[ii]);
76
+ }
77
+ });
78
+
79
+ it('should slice correctly with equal start and end', function() {
80
+ var abv = new Uint8Array(10);
81
+ for (var i = 0; i < abv.length; i++) {
82
+ abv[i] = i;
83
+ }
84
+
85
+ var sliced = sliceBuffer(abv.buffer, 1, 1);
86
+ expect(sliced.byteLength).to.equal(0);
87
+ });
88
+
89
+ it('should slice correctly when end larger than buffer', function() {
90
+ var abv = new Uint8Array(10);
91
+ for (var i = 0; i < abv.length; i++) {
92
+ abv[i] = i;
93
+ }
94
+
95
+ var sliced = sliceBuffer(abv.buffer, 0, 100);
96
+ expect(new Uint8Array(sliced)).to.eql(abv);
97
+ });
98
+
99
+ it('shoud slice correctly when start larger than end', function() {
100
+ var abv = new Uint8Array(10);
101
+ for (var i = 0; i < abv.length; i++) {
102
+ abv[i] = i;
103
+ }
104
+
105
+ var sliced = sliceBuffer(abv.buffer, 6, 5);
106
+ expect(sliced.byteLength).to.equal(0);
107
+ });
108
+ });
109
+
110
+ describe('using fallback', function() {
111
+ it('should slice correctly with only start provided', function() {
112
+ var abv = new Uint8Array(10);
113
+ for (var i = 0; i < abv.length; i++) {
114
+ abv[i] = i;
115
+ }
116
+ var ab = abv.buffer;
117
+ ab.slice = undefined;
118
+
119
+ var sliced = sliceBuffer(ab, 3);
120
+ var sabv = new Uint8Array(sliced);
121
+ for (var i = 3, ii = 0; i < abv.length; i++, ii++) {
122
+ expect(abv[i]).to.equal(sabv[ii]);
123
+ }
124
+ });
125
+
126
+ it('should slice correctly with start and end provided', function() {
127
+ var abv = new Uint8Array(10);
128
+ for (var i = 0; i < abv.length; i++) {
129
+ abv[i] = i;
130
+ }
131
+ var ab = abv.buffer;
132
+ ab.slice = undefined;
133
+
134
+
135
+ var sliced = sliceBuffer(ab, 3, 8);
136
+ var sabv = new Uint8Array(sliced);
137
+ for (var i = 3, ii = 0; i < 8; i++, ii++) {
138
+ expect(abv[i]).to.equal(sabv[ii]);
139
+ }
140
+ });
141
+
142
+ it('should slice correctly with negative start', function() {
143
+ var abv = new Uint8Array(10);
144
+ for (var i = 0; i < abv.length; i++) {
145
+ abv[i] = i;
146
+ }
147
+ var ab = abv.buffer;
148
+ ab.slice = undefined;
149
+
150
+
151
+ var sliced = sliceBuffer(ab, -3);
152
+ var sabv = new Uint8Array(sliced);
153
+ for (var i = abv.length - 3, ii = 0; i < abv.length; i++, ii++) {
154
+ expect(abv[i]).to.equal(sabv[ii]);
155
+ }
156
+ });
157
+
158
+ it('should slice correctly with negative end', function() {
159
+ var abv = new Uint8Array(10);
160
+ for (var i = 0; i < abv.length; i++) {
161
+ abv[i] = i;
162
+ }
163
+ var ab = abv.buffer;
164
+ ab.slice = undefined;
165
+
166
+ var sliced = sliceBuffer(ab, 0, -3);
167
+ var sabv = new Uint8Array(sliced);
168
+ for (var i = 0, ii = 0; i < abv.length - 3; i++, ii++) {
169
+ expect(abv[i]).to.equal(sabv[ii]);
170
+ }
171
+ });
172
+
173
+ it('should slice correctly with negative start and end', function() {
174
+ var abv = new Uint8Array(10);
175
+ for (var i = 0; i < abv.length; i++) {
176
+ abv[i] = i;
177
+ }
178
+ var ab = abv.buffer;
179
+ ab.slice = undefined;
180
+
181
+ var sliced = sliceBuffer(ab, -6, -3);
182
+ var sabv = new Uint8Array(sliced);
183
+ for (var i = abv.length - 6, ii = 0; i < abv.length - 3; i++, ii++) {
184
+ expect(abv[i]).to.equal(sabv[ii]);
185
+ }
186
+ });
187
+
188
+ it('should slice correctly with equal start and end', function() {
189
+ var abv = new Uint8Array(10);
190
+ for (var i = 0; i < abv.length; i++) {
191
+ abv[i] = i;
192
+ }
193
+ var ab = abv.buffer;
194
+ ab.slice = undefined;
195
+
196
+ var sliced = sliceBuffer(ab, 1, 1);
197
+ expect(sliced.byteLength).to.equal(0);
198
+ });
199
+
200
+ it('should slice correctly when end larger than buffer', function() {
201
+ var abv = new Uint8Array(10);
202
+ for (var i = 0; i < abv.length; i++) {
203
+ abv[i] = i;
204
+ }
205
+ var ab = abv.buffer;
206
+ ab.slice = undefined;
207
+
208
+ var sliced = sliceBuffer(ab, 0, 100);
209
+ var sabv = new Uint8Array(sliced);
210
+ for (var i = 0; i < abv.length; i++) {
211
+ expect(abv[i]).to.equal(sabv[i]);
212
+ }
213
+ });
214
+
215
+ it('shoud slice correctly when start larger than end', function() {
216
+ var abv = new Uint8Array(10);
217
+ for (var i = 0; i < abv.length; i++) {
218
+ abv[i] = i;
219
+ }
220
+ var ab = abv.buffer;
221
+ ab.slice = undefined;
222
+
223
+ var sliced = sliceBuffer(ab, 6, 5);
224
+ expect(sliced.byteLength).to.equal(0);
225
+ });
226
+ });
227
+ });
datalab/web/node_modules/async-limiter/.travis.yml ADDED
@@ -0,0 +1,7 @@
 
 
 
 
 
 
 
 
1
+ language: node_js
2
+ node_js:
3
+ - "6"
4
+ - "node"
5
+ script: npm run travis
6
+ cache:
7
+ yarn: true
datalab/web/node_modules/async-limiter/LICENSE ADDED
@@ -0,0 +1,8 @@
 
 
 
 
 
 
 
 
 
1
+ The MIT License (MIT)
2
+ Copyright (c) 2017 Samuel Reed <[email protected]>
3
+
4
+ Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
5
+
6
+ The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
7
+
8
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
datalab/web/node_modules/async-limiter/coverage/coverage.json ADDED
@@ -0,0 +1 @@
 
 
1
+ {"/Users/samuelreed/git/forks/async-throttle/index.js":{"path":"/Users/samuelreed/git/forks/async-throttle/index.js","s":{"1":1,"2":7,"3":1,"4":6,"5":6,"6":6,"7":6,"8":6,"9":6,"10":1,"11":1,"12":3,"13":13,"14":13,"15":13,"16":1,"17":19,"18":1,"19":45,"20":6,"21":39,"22":13,"23":13,"24":13,"25":13,"26":39,"27":18,"28":6,"29":6,"30":1,"31":6,"32":6,"33":6,"34":1,"35":13,"36":13,"37":1},"b":{"1":[1,6],"2":[6,5],"3":[6,5],"4":[6,39],"5":[13,26],"6":[18,21],"7":[6,0]},"f":{"1":7,"2":3,"3":13,"4":19,"5":45,"6":6,"7":13},"fnMap":{"1":{"name":"Queue","line":3,"loc":{"start":{"line":3,"column":0},"end":{"line":3,"column":24}}},"2":{"name":"(anonymous_2)","line":22,"loc":{"start":{"line":22,"column":24},"end":{"line":22,"column":41}}},"3":{"name":"(anonymous_3)","line":23,"loc":{"start":{"line":23,"column":28},"end":{"line":23,"column":39}}},"4":{"name":"(anonymous_4)","line":31,"loc":{"start":{"line":31,"column":7},"end":{"line":31,"column":18}}},"5":{"name":"(anonymous_5)","line":36,"loc":{"start":{"line":36,"column":23},"end":{"line":36,"column":34}}},"6":{"name":"(anonymous_6)","line":55,"loc":{"start":{"line":55,"column":25},"end":{"line":55,"column":38}}},"7":{"name":"done","line":62,"loc":{"start":{"line":62,"column":0},"end":{"line":62,"column":16}}}},"statementMap":{"1":{"start":{"line":3,"column":0},"end":{"line":14,"column":1}},"2":{"start":{"line":4,"column":2},"end":{"line":6,"column":3}},"3":{"start":{"line":5,"column":4},"end":{"line":5,"column":30}},"4":{"start":{"line":8,"column":2},"end":{"line":8,"column":26}},"5":{"start":{"line":9,"column":2},"end":{"line":9,"column":53}},"6":{"start":{"line":10,"column":2},"end":{"line":10,"column":19}},"7":{"start":{"line":11,"column":2},"end":{"line":11,"column":17}},"8":{"start":{"line":12,"column":2},"end":{"line":12,"column":16}},"9":{"start":{"line":13,"column":2},"end":{"line":13,"column":31}},"10":{"start":{"line":16,"column":0},"end":{"line":20,"column":2}},"11":{"start":{"line":22,"column":0},"end":{"line":28,"column":3}},"12":{"start":{"line":23,"column":2},"end":{"line":27,"column":4}},"13":{"start":{"line":24,"column":4},"end":{"line":24,"column":75}},"14":{"start":{"line":25,"column":4},"end":{"line":25,"column":16}},"15":{"start":{"line":26,"column":4},"end":{"line":26,"column":24}},"16":{"start":{"line":30,"column":0},"end":{"line":34,"column":3}},"17":{"start":{"line":32,"column":4},"end":{"line":32,"column":43}},"18":{"start":{"line":36,"column":0},"end":{"line":53,"column":2}},"19":{"start":{"line":37,"column":2},"end":{"line":39,"column":3}},"20":{"start":{"line":38,"column":4},"end":{"line":38,"column":11}},"21":{"start":{"line":40,"column":2},"end":{"line":45,"column":3}},"22":{"start":{"line":41,"column":4},"end":{"line":41,"column":32}},"23":{"start":{"line":42,"column":4},"end":{"line":42,"column":19}},"24":{"start":{"line":43,"column":4},"end":{"line":43,"column":20}},"25":{"start":{"line":44,"column":4},"end":{"line":44,"column":16}},"26":{"start":{"line":47,"column":2},"end":{"line":52,"column":3}},"27":{"start":{"line":48,"column":4},"end":{"line":51,"column":5}},"28":{"start":{"line":49,"column":6},"end":{"line":49,"column":30}},"29":{"start":{"line":50,"column":6},"end":{"line":50,"column":27}},"30":{"start":{"line":55,"column":0},"end":{"line":60,"column":2}},"31":{"start":{"line":56,"column":2},"end":{"line":59,"column":3}},"32":{"start":{"line":57,"column":4},"end":{"line":57,"column":22}},"33":{"start":{"line":58,"column":4},"end":{"line":58,"column":16}},"34":{"start":{"line":62,"column":0},"end":{"line":65,"column":1}},"35":{"start":{"line":63,"column":2},"end":{"line":63,"column":17}},"36":{"start":{"line":64,"column":2},"end":{"line":64,"column":14}},"37":{"start":{"line":67,"column":0},"end":{"line":67,"column":23}}},"branchMap":{"1":{"line":4,"type":"if","locations":[{"start":{"line":4,"column":2},"end":{"line":4,"column":2}},{"start":{"line":4,"column":2},"end":{"line":4,"column":2}}]},"2":{"line":8,"type":"binary-expr","locations":[{"start":{"line":8,"column":12},"end":{"line":8,"column":19}},{"start":{"line":8,"column":23},"end":{"line":8,"column":25}}]},"3":{"line":9,"type":"binary-expr","locations":[{"start":{"line":9,"column":21},"end":{"line":9,"column":40}},{"start":{"line":9,"column":44},"end":{"line":9,"column":52}}]},"4":{"line":37,"type":"if","locations":[{"start":{"line":37,"column":2},"end":{"line":37,"column":2}},{"start":{"line":37,"column":2},"end":{"line":37,"column":2}}]},"5":{"line":40,"type":"if","locations":[{"start":{"line":40,"column":2},"end":{"line":40,"column":2}},{"start":{"line":40,"column":2},"end":{"line":40,"column":2}}]},"6":{"line":47,"type":"if","locations":[{"start":{"line":47,"column":2},"end":{"line":47,"column":2}},{"start":{"line":47,"column":2},"end":{"line":47,"column":2}}]},"7":{"line":56,"type":"if","locations":[{"start":{"line":56,"column":2},"end":{"line":56,"column":2}},{"start":{"line":56,"column":2},"end":{"line":56,"column":2}}]}}}}
datalab/web/node_modules/async-limiter/coverage/lcov-report/async-throttle/index.html ADDED
@@ -0,0 +1,73 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ <!doctype html>
2
+ <html lang="en">
3
+ <head>
4
+ <title>Code coverage report for async-throttle/</title>
5
+ <meta charset="utf-8">
6
+ <link rel="stylesheet" href="../prettify.css">
7
+ <link rel="stylesheet" href="../base.css">
8
+ <style type='text/css'>
9
+ div.coverage-summary .sorter {
10
+ background-image: url(../sort-arrow-sprite.png);
11
+ }
12
+ </style>
13
+ </head>
14
+ <body>
15
+ <div class="header high">
16
+ <h1>Code coverage report for <span class="entity">async-throttle/</span></h1>
17
+ <h2>
18
+ Statements: <span class="metric">100% <small>(37 / 37)</small></span> &nbsp;&nbsp;&nbsp;&nbsp;
19
+ Branches: <span class="metric">92.86% <small>(13 / 14)</small></span> &nbsp;&nbsp;&nbsp;&nbsp;
20
+ Functions: <span class="metric">100% <small>(7 / 7)</small></span> &nbsp;&nbsp;&nbsp;&nbsp;
21
+ Lines: <span class="metric">100% <small>(37 / 37)</small></span> &nbsp;&nbsp;&nbsp;&nbsp;
22
+ Ignored: <span class="metric"><span class="ignore-none">none</span></span> &nbsp;&nbsp;&nbsp;&nbsp;
23
+ </h2>
24
+ <div class="path"><a href="../index.html">All files</a> &#187; async-throttle/</div>
25
+ </div>
26
+ <div class="body">
27
+ <div class="coverage-summary">
28
+ <table>
29
+ <thead>
30
+ <tr>
31
+ <th data-col="file" data-fmt="html" data-html="true" class="file">File</th>
32
+ <th data-col="pic" data-type="number" data-fmt="html" data-html="true" class="pic"></th>
33
+ <th data-col="statements" data-type="number" data-fmt="pct" class="pct">Statements</th>
34
+ <th data-col="statements_raw" data-type="number" data-fmt="html" class="abs"></th>
35
+ <th data-col="branches" data-type="number" data-fmt="pct" class="pct">Branches</th>
36
+ <th data-col="branches_raw" data-type="number" data-fmt="html" class="abs"></th>
37
+ <th data-col="functions" data-type="number" data-fmt="pct" class="pct">Functions</th>
38
+ <th data-col="functions_raw" data-type="number" data-fmt="html" class="abs"></th>
39
+ <th data-col="lines" data-type="number" data-fmt="pct" class="pct">Lines</th>
40
+ <th data-col="lines_raw" data-type="number" data-fmt="html" class="abs"></th>
41
+ </tr>
42
+ </thead>
43
+ <tbody><tr>
44
+ <td class="file high" data-value="index.js"><a href="index.js.html">index.js</a></td>
45
+ <td data-value="100" class="pic high"><span class="cover-fill cover-full" style="width: 100px;"></span><span class="cover-empty" style="width:0px;"></span></td>
46
+ <td data-value="100" class="pct high">100%</td>
47
+ <td data-value="37" class="abs high">(37&nbsp;/&nbsp;37)</td>
48
+ <td data-value="92.86" class="pct high">92.86%</td>
49
+ <td data-value="14" class="abs high">(13&nbsp;/&nbsp;14)</td>
50
+ <td data-value="100" class="pct high">100%</td>
51
+ <td data-value="7" class="abs high">(7&nbsp;/&nbsp;7)</td>
52
+ <td data-value="100" class="pct high">100%</td>
53
+ <td data-value="37" class="abs high">(37&nbsp;/&nbsp;37)</td>
54
+ </tr>
55
+
56
+ </tbody>
57
+ </table>
58
+ </div>
59
+ </div>
60
+ <div class="footer">
61
+ <div class="meta">Generated by <a href="http://istanbul-js.org/" target="_blank">istanbul</a> at Mon Sep 11 2017 11:14:14 GMT-0500 (CDT)</div>
62
+ </div>
63
+ <script src="../prettify.js"></script>
64
+ <script>
65
+ window.onload = function () {
66
+ if (typeof prettyPrint === 'function') {
67
+ prettyPrint();
68
+ }
69
+ };
70
+ </script>
71
+ <script src="../sorter.js"></script>
72
+ </body>
73
+ </html>
datalab/web/node_modules/async-limiter/coverage/lcov-report/async-throttle/index.js.html ADDED
@@ -0,0 +1,246 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ <!doctype html>
2
+ <html lang="en">
3
+ <head>
4
+ <title>Code coverage report for async-throttle/index.js</title>
5
+ <meta charset="utf-8">
6
+ <link rel="stylesheet" href="../prettify.css">
7
+ <link rel="stylesheet" href="../base.css">
8
+ <style type='text/css'>
9
+ div.coverage-summary .sorter {
10
+ background-image: url(../sort-arrow-sprite.png);
11
+ }
12
+ </style>
13
+ </head>
14
+ <body>
15
+ <div class="header high">
16
+ <h1>Code coverage report for <span class="entity">async-throttle/index.js</span></h1>
17
+ <h2>
18
+ Statements: <span class="metric">100% <small>(37 / 37)</small></span> &nbsp;&nbsp;&nbsp;&nbsp;
19
+ Branches: <span class="metric">92.86% <small>(13 / 14)</small></span> &nbsp;&nbsp;&nbsp;&nbsp;
20
+ Functions: <span class="metric">100% <small>(7 / 7)</small></span> &nbsp;&nbsp;&nbsp;&nbsp;
21
+ Lines: <span class="metric">100% <small>(37 / 37)</small></span> &nbsp;&nbsp;&nbsp;&nbsp;
22
+ Ignored: <span class="metric"><span class="ignore-none">none</span></span> &nbsp;&nbsp;&nbsp;&nbsp;
23
+ </h2>
24
+ <div class="path"><a href="../index.html">All files</a> &#187; <a href="index.html">async-throttle/</a> &#187; index.js</div>
25
+ </div>
26
+ <div class="body">
27
+ <pre><table class="coverage">
28
+ <tr><td class="line-count">1
29
+ 2
30
+ 3
31
+ 4
32
+ 5
33
+ 6
34
+ 7
35
+ 8
36
+ 9
37
+ 10
38
+ 11
39
+ 12
40
+ 13
41
+ 14
42
+ 15
43
+ 16
44
+ 17
45
+ 18
46
+ 19
47
+ 20
48
+ 21
49
+ 22
50
+ 23
51
+ 24
52
+ 25
53
+ 26
54
+ 27
55
+ 28
56
+ 29
57
+ 30
58
+ 31
59
+ 32
60
+ 33
61
+ 34
62
+ 35
63
+ 36
64
+ 37
65
+ 38
66
+ 39
67
+ 40
68
+ 41
69
+ 42
70
+ 43
71
+ 44
72
+ 45
73
+ 46
74
+ 47
75
+ 48
76
+ 49
77
+ 50
78
+ 51
79
+ 52
80
+ 53
81
+ 54
82
+ 55
83
+ 56
84
+ 57
85
+ 58
86
+ 59
87
+ 60
88
+ 61
89
+ 62
90
+ 63
91
+ 64
92
+ 65
93
+ 66
94
+ 67
95
+ 68</td><td class="line-coverage"><span class="cline-any cline-neutral">&nbsp;</span>
96
+ <span class="cline-any cline-neutral">&nbsp;</span>
97
+ <span class="cline-any cline-yes">1</span>
98
+ <span class="cline-any cline-yes">7</span>
99
+ <span class="cline-any cline-yes">1</span>
100
+ <span class="cline-any cline-neutral">&nbsp;</span>
101
+ <span class="cline-any cline-neutral">&nbsp;</span>
102
+ <span class="cline-any cline-yes">6</span>
103
+ <span class="cline-any cline-yes">6</span>
104
+ <span class="cline-any cline-yes">6</span>
105
+ <span class="cline-any cline-yes">6</span>
106
+ <span class="cline-any cline-yes">6</span>
107
+ <span class="cline-any cline-yes">6</span>
108
+ <span class="cline-any cline-neutral">&nbsp;</span>
109
+ <span class="cline-any cline-neutral">&nbsp;</span>
110
+ <span class="cline-any cline-yes">1</span>
111
+ <span class="cline-any cline-neutral">&nbsp;</span>
112
+ <span class="cline-any cline-neutral">&nbsp;</span>
113
+ <span class="cline-any cline-neutral">&nbsp;</span>
114
+ <span class="cline-any cline-neutral">&nbsp;</span>
115
+ <span class="cline-any cline-neutral">&nbsp;</span>
116
+ <span class="cline-any cline-yes">1</span>
117
+ <span class="cline-any cline-yes">3</span>
118
+ <span class="cline-any cline-yes">13</span>
119
+ <span class="cline-any cline-yes">13</span>
120
+ <span class="cline-any cline-yes">13</span>
121
+ <span class="cline-any cline-neutral">&nbsp;</span>
122
+ <span class="cline-any cline-neutral">&nbsp;</span>
123
+ <span class="cline-any cline-neutral">&nbsp;</span>
124
+ <span class="cline-any cline-yes">1</span>
125
+ <span class="cline-any cline-neutral">&nbsp;</span>
126
+ <span class="cline-any cline-yes">19</span>
127
+ <span class="cline-any cline-neutral">&nbsp;</span>
128
+ <span class="cline-any cline-neutral">&nbsp;</span>
129
+ <span class="cline-any cline-neutral">&nbsp;</span>
130
+ <span class="cline-any cline-yes">1</span>
131
+ <span class="cline-any cline-yes">45</span>
132
+ <span class="cline-any cline-yes">6</span>
133
+ <span class="cline-any cline-neutral">&nbsp;</span>
134
+ <span class="cline-any cline-yes">39</span>
135
+ <span class="cline-any cline-yes">13</span>
136
+ <span class="cline-any cline-yes">13</span>
137
+ <span class="cline-any cline-yes">13</span>
138
+ <span class="cline-any cline-yes">13</span>
139
+ <span class="cline-any cline-neutral">&nbsp;</span>
140
+ <span class="cline-any cline-neutral">&nbsp;</span>
141
+ <span class="cline-any cline-yes">39</span>
142
+ <span class="cline-any cline-yes">18</span>
143
+ <span class="cline-any cline-yes">6</span>
144
+ <span class="cline-any cline-yes">6</span>
145
+ <span class="cline-any cline-neutral">&nbsp;</span>
146
+ <span class="cline-any cline-neutral">&nbsp;</span>
147
+ <span class="cline-any cline-neutral">&nbsp;</span>
148
+ <span class="cline-any cline-neutral">&nbsp;</span>
149
+ <span class="cline-any cline-yes">1</span>
150
+ <span class="cline-any cline-yes">6</span>
151
+ <span class="cline-any cline-yes">6</span>
152
+ <span class="cline-any cline-yes">6</span>
153
+ <span class="cline-any cline-neutral">&nbsp;</span>
154
+ <span class="cline-any cline-neutral">&nbsp;</span>
155
+ <span class="cline-any cline-neutral">&nbsp;</span>
156
+ <span class="cline-any cline-yes">1</span>
157
+ <span class="cline-any cline-yes">13</span>
158
+ <span class="cline-any cline-yes">13</span>
159
+ <span class="cline-any cline-neutral">&nbsp;</span>
160
+ <span class="cline-any cline-neutral">&nbsp;</span>
161
+ <span class="cline-any cline-yes">1</span>
162
+ <span class="cline-any cline-neutral">&nbsp;</span></td><td class="text"><pre class="prettyprint lang-js">'use strict';
163
+ &nbsp;
164
+ function Queue(options) {
165
+ if (!(this instanceof Queue)) {
166
+ return new Queue(options);
167
+ }
168
+ &nbsp;
169
+ options = options || {};
170
+ this.concurrency = options.concurrency || Infinity;
171
+ this.pending = 0;
172
+ this.jobs = [];
173
+ this.cbs = [];
174
+ this._done = done.bind(this);
175
+ }
176
+ &nbsp;
177
+ var arrayAddMethods = [
178
+ 'push',
179
+ 'unshift',
180
+ 'splice'
181
+ ];
182
+ &nbsp;
183
+ arrayAddMethods.forEach(function(method) {
184
+ Queue.prototype[method] = function() {
185
+ var methodResult = Array.prototype[method].apply(this.jobs, arguments);
186
+ this._run();
187
+ return methodResult;
188
+ };
189
+ });
190
+ &nbsp;
191
+ Object.defineProperty(Queue.prototype, 'length', {
192
+ get: function() {
193
+ return this.pending + this.jobs.length;
194
+ }
195
+ });
196
+ &nbsp;
197
+ Queue.prototype._run = function() {
198
+ if (this.pending === this.concurrency) {
199
+ return;
200
+ }
201
+ if (this.jobs.length) {
202
+ var job = this.jobs.shift();
203
+ this.pending++;
204
+ job(this._done);
205
+ this._run();
206
+ }
207
+ &nbsp;
208
+ if (this.pending === 0) {
209
+ while (this.cbs.length !== 0) {
210
+ var cb = this.cbs.pop();
211
+ process.nextTick(cb);
212
+ }
213
+ }
214
+ };
215
+ &nbsp;
216
+ Queue.prototype.onDone = function(cb) {
217
+ <span class="missing-if-branch" title="else path not taken" >E</span>if (typeof cb === 'function') {
218
+ this.cbs.push(cb);
219
+ this._run();
220
+ }
221
+ };
222
+ &nbsp;
223
+ function done() {
224
+ this.pending--;
225
+ this._run();
226
+ }
227
+ &nbsp;
228
+ module.exports = Queue;
229
+ &nbsp;</pre></td></tr>
230
+ </table></pre>
231
+
232
+ </div>
233
+ <div class="footer">
234
+ <div class="meta">Generated by <a href="http://istanbul-js.org/" target="_blank">istanbul</a> at Mon Sep 11 2017 11:14:14 GMT-0500 (CDT)</div>
235
+ </div>
236
+ <script src="../prettify.js"></script>
237
+ <script>
238
+ window.onload = function () {
239
+ if (typeof prettyPrint === 'function') {
240
+ prettyPrint();
241
+ }
242
+ };
243
+ </script>
244
+ <script src="../sorter.js"></script>
245
+ </body>
246
+ </html>
datalab/web/node_modules/async-limiter/coverage/lcov-report/base.css ADDED
@@ -0,0 +1,182 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ body, html {
2
+ margin:0; padding: 0;
3
+ }
4
+ body {
5
+ font-family: Helvetica Neue, Helvetica,Arial;
6
+ font-size: 10pt;
7
+ }
8
+ div.header, div.footer {
9
+ background: #eee;
10
+ padding: 1em;
11
+ }
12
+ div.header {
13
+ z-index: 100;
14
+ position: fixed;
15
+ top: 0;
16
+ border-bottom: 1px solid #666;
17
+ width: 100%;
18
+ }
19
+ div.footer {
20
+ border-top: 1px solid #666;
21
+ }
22
+ div.body {
23
+ margin-top: 10em;
24
+ }
25
+ div.meta {
26
+ font-size: 90%;
27
+ text-align: center;
28
+ }
29
+ h1, h2, h3 {
30
+ font-weight: normal;
31
+ }
32
+ h1 {
33
+ font-size: 12pt;
34
+ }
35
+ h2 {
36
+ font-size: 10pt;
37
+ }
38
+ pre {
39
+ font-family: Consolas, Menlo, Monaco, monospace;
40
+ margin: 0;
41
+ padding: 0;
42
+ line-height: 1.3;
43
+ font-size: 14px;
44
+ -moz-tab-size: 2;
45
+ -o-tab-size: 2;
46
+ tab-size: 2;
47
+ }
48
+
49
+ div.path { font-size: 110%; }
50
+ div.path a:link, div.path a:visited { color: #000; }
51
+ table.coverage { border-collapse: collapse; margin:0; padding: 0 }
52
+
53
+ table.coverage td {
54
+ margin: 0;
55
+ padding: 0;
56
+ color: #111;
57
+ vertical-align: top;
58
+ }
59
+ table.coverage td.line-count {
60
+ width: 50px;
61
+ text-align: right;
62
+ padding-right: 5px;
63
+ }
64
+ table.coverage td.line-coverage {
65
+ color: #777 !important;
66
+ text-align: right;
67
+ border-left: 1px solid #666;
68
+ border-right: 1px solid #666;
69
+ }
70
+
71
+ table.coverage td.text {
72
+ }
73
+
74
+ table.coverage td span.cline-any {
75
+ display: inline-block;
76
+ padding: 0 5px;
77
+ width: 40px;
78
+ }
79
+ table.coverage td span.cline-neutral {
80
+ background: #eee;
81
+ }
82
+ table.coverage td span.cline-yes {
83
+ background: #b5d592;
84
+ color: #999;
85
+ }
86
+ table.coverage td span.cline-no {
87
+ background: #fc8c84;
88
+ }
89
+
90
+ .cstat-yes { color: #111; }
91
+ .cstat-no { background: #fc8c84; color: #111; }
92
+ .fstat-no { background: #ffc520; color: #111 !important; }
93
+ .cbranch-no { background: yellow !important; color: #111; }
94
+
95
+ .cstat-skip { background: #ddd; color: #111; }
96
+ .fstat-skip { background: #ddd; color: #111 !important; }
97
+ .cbranch-skip { background: #ddd !important; color: #111; }
98
+
99
+ .missing-if-branch {
100
+ display: inline-block;
101
+ margin-right: 10px;
102
+ position: relative;
103
+ padding: 0 4px;
104
+ background: black;
105
+ color: yellow;
106
+ }
107
+
108
+ .skip-if-branch {
109
+ display: none;
110
+ margin-right: 10px;
111
+ position: relative;
112
+ padding: 0 4px;
113
+ background: #ccc;
114
+ color: white;
115
+ }
116
+
117
+ .missing-if-branch .typ, .skip-if-branch .typ {
118
+ color: inherit !important;
119
+ }
120
+
121
+ .entity, .metric { font-weight: bold; }
122
+ .metric { display: inline-block; border: 1px solid #333; padding: 0.3em; background: white; }
123
+ .metric small { font-size: 80%; font-weight: normal; color: #666; }
124
+
125
+ div.coverage-summary table { border-collapse: collapse; margin: 3em; font-size: 110%; }
126
+ div.coverage-summary td, div.coverage-summary table th { margin: 0; padding: 0.25em 1em; border-top: 1px solid #666; border-bottom: 1px solid #666; }
127
+ div.coverage-summary th { text-align: left; border: 1px solid #666; background: #eee; font-weight: normal; }
128
+ div.coverage-summary th.file { border-right: none !important; }
129
+ div.coverage-summary th.pic { border-left: none !important; text-align: right; }
130
+ div.coverage-summary th.pct { border-right: none !important; }
131
+ div.coverage-summary th.abs { border-left: none !important; text-align: right; }
132
+ div.coverage-summary td.pct { text-align: right; border-left: 1px solid #666; }
133
+ div.coverage-summary td.abs { text-align: right; font-size: 90%; color: #444; border-right: 1px solid #666; }
134
+ div.coverage-summary td.file { border-left: 1px solid #666; white-space: nowrap; }
135
+ div.coverage-summary td.pic { min-width: 120px !important; }
136
+ div.coverage-summary a:link { text-decoration: none; color: #000; }
137
+ div.coverage-summary a:visited { text-decoration: none; color: #777; }
138
+ div.coverage-summary a:hover { text-decoration: underline; }
139
+ div.coverage-summary tfoot td { border-top: 1px solid #666; }
140
+
141
+ div.coverage-summary .sorter {
142
+ height: 10px;
143
+ width: 7px;
144
+ display: inline-block;
145
+ margin-left: 0.5em;
146
+ background: url(sort-arrow-sprite.png) no-repeat scroll 0 0 transparent;
147
+ }
148
+ div.coverage-summary .sorted .sorter {
149
+ background-position: 0 -20px;
150
+ }
151
+ div.coverage-summary .sorted-desc .sorter {
152
+ background-position: 0 -10px;
153
+ }
154
+
155
+ .high { background: #b5d592 !important; }
156
+ .medium { background: #ffe87c !important; }
157
+ .low { background: #fc8c84 !important; }
158
+
159
+ span.cover-fill, span.cover-empty {
160
+ display:inline-block;
161
+ border:1px solid #444;
162
+ background: white;
163
+ height: 12px;
164
+ }
165
+ span.cover-fill {
166
+ background: #ccc;
167
+ border-right: 1px solid #444;
168
+ }
169
+ span.cover-empty {
170
+ background: white;
171
+ border-left: none;
172
+ }
173
+ span.cover-full {
174
+ border-right: none !important;
175
+ }
176
+ pre.prettyprint {
177
+ border: none !important;
178
+ padding: 0 !important;
179
+ margin: 0 !important;
180
+ }
181
+ .com { color: #999 !important; }
182
+ .ignore-none { color: #999; font-weight: normal; }
datalab/web/node_modules/async-limiter/coverage/lcov-report/index.html ADDED
@@ -0,0 +1,73 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ <!doctype html>
2
+ <html lang="en">
3
+ <head>
4
+ <title>Code coverage report for All files</title>
5
+ <meta charset="utf-8">
6
+ <link rel="stylesheet" href="prettify.css">
7
+ <link rel="stylesheet" href="base.css">
8
+ <style type='text/css'>
9
+ div.coverage-summary .sorter {
10
+ background-image: url(sort-arrow-sprite.png);
11
+ }
12
+ </style>
13
+ </head>
14
+ <body>
15
+ <div class="header high">
16
+ <h1>Code coverage report for <span class="entity">All files</span></h1>
17
+ <h2>
18
+ Statements: <span class="metric">100% <small>(37 / 37)</small></span> &nbsp;&nbsp;&nbsp;&nbsp;
19
+ Branches: <span class="metric">92.86% <small>(13 / 14)</small></span> &nbsp;&nbsp;&nbsp;&nbsp;
20
+ Functions: <span class="metric">100% <small>(7 / 7)</small></span> &nbsp;&nbsp;&nbsp;&nbsp;
21
+ Lines: <span class="metric">100% <small>(37 / 37)</small></span> &nbsp;&nbsp;&nbsp;&nbsp;
22
+ Ignored: <span class="metric"><span class="ignore-none">none</span></span> &nbsp;&nbsp;&nbsp;&nbsp;
23
+ </h2>
24
+ <div class="path"></div>
25
+ </div>
26
+ <div class="body">
27
+ <div class="coverage-summary">
28
+ <table>
29
+ <thead>
30
+ <tr>
31
+ <th data-col="file" data-fmt="html" data-html="true" class="file">File</th>
32
+ <th data-col="pic" data-type="number" data-fmt="html" data-html="true" class="pic"></th>
33
+ <th data-col="statements" data-type="number" data-fmt="pct" class="pct">Statements</th>
34
+ <th data-col="statements_raw" data-type="number" data-fmt="html" class="abs"></th>
35
+ <th data-col="branches" data-type="number" data-fmt="pct" class="pct">Branches</th>
36
+ <th data-col="branches_raw" data-type="number" data-fmt="html" class="abs"></th>
37
+ <th data-col="functions" data-type="number" data-fmt="pct" class="pct">Functions</th>
38
+ <th data-col="functions_raw" data-type="number" data-fmt="html" class="abs"></th>
39
+ <th data-col="lines" data-type="number" data-fmt="pct" class="pct">Lines</th>
40
+ <th data-col="lines_raw" data-type="number" data-fmt="html" class="abs"></th>
41
+ </tr>
42
+ </thead>
43
+ <tbody><tr>
44
+ <td class="file high" data-value="async-throttle/"><a href="async-throttle/index.html">async-throttle/</a></td>
45
+ <td data-value="100" class="pic high"><span class="cover-fill cover-full" style="width: 100px;"></span><span class="cover-empty" style="width:0px;"></span></td>
46
+ <td data-value="100" class="pct high">100%</td>
47
+ <td data-value="37" class="abs high">(37&nbsp;/&nbsp;37)</td>
48
+ <td data-value="92.86" class="pct high">92.86%</td>
49
+ <td data-value="14" class="abs high">(13&nbsp;/&nbsp;14)</td>
50
+ <td data-value="100" class="pct high">100%</td>
51
+ <td data-value="7" class="abs high">(7&nbsp;/&nbsp;7)</td>
52
+ <td data-value="100" class="pct high">100%</td>
53
+ <td data-value="37" class="abs high">(37&nbsp;/&nbsp;37)</td>
54
+ </tr>
55
+
56
+ </tbody>
57
+ </table>
58
+ </div>
59
+ </div>
60
+ <div class="footer">
61
+ <div class="meta">Generated by <a href="http://istanbul-js.org/" target="_blank">istanbul</a> at Mon Sep 11 2017 11:14:14 GMT-0500 (CDT)</div>
62
+ </div>
63
+ <script src="prettify.js"></script>
64
+ <script>
65
+ window.onload = function () {
66
+ if (typeof prettyPrint === 'function') {
67
+ prettyPrint();
68
+ }
69
+ };
70
+ </script>
71
+ <script src="sorter.js"></script>
72
+ </body>
73
+ </html>
datalab/web/node_modules/async-limiter/coverage/lcov-report/prettify.css ADDED
@@ -0,0 +1 @@
 
 
1
+ .pln{color:#000}@media screen{.str{color:#080}.kwd{color:#008}.com{color:#800}.typ{color:#606}.lit{color:#066}.pun,.opn,.clo{color:#660}.tag{color:#008}.atn{color:#606}.atv{color:#080}.dec,.var{color:#606}.fun{color:red}}@media print,projection{.str{color:#060}.kwd{color:#006;font-weight:bold}.com{color:#600;font-style:italic}.typ{color:#404;font-weight:bold}.lit{color:#044}.pun,.opn,.clo{color:#440}.tag{color:#006;font-weight:bold}.atn{color:#404}.atv{color:#060}}pre.prettyprint{padding:2px;border:1px solid #888}ol.linenums{margin-top:0;margin-bottom:0}li.L0,li.L1,li.L2,li.L3,li.L5,li.L6,li.L7,li.L8{list-style-type:none}li.L1,li.L3,li.L5,li.L7,li.L9{background:#eee}
datalab/web/node_modules/async-limiter/coverage/lcov-report/prettify.js ADDED
@@ -0,0 +1 @@
 
 
1
+ window.PR_SHOULD_USE_CONTINUATION=true;(function(){var h=["break,continue,do,else,for,if,return,while"];var u=[h,"auto,case,char,const,default,double,enum,extern,float,goto,int,long,register,short,signed,sizeof,static,struct,switch,typedef,union,unsigned,void,volatile"];var p=[u,"catch,class,delete,false,import,new,operator,private,protected,public,this,throw,true,try,typeof"];var l=[p,"alignof,align_union,asm,axiom,bool,concept,concept_map,const_cast,constexpr,decltype,dynamic_cast,explicit,export,friend,inline,late_check,mutable,namespace,nullptr,reinterpret_cast,static_assert,static_cast,template,typeid,typename,using,virtual,where"];var x=[p,"abstract,boolean,byte,extends,final,finally,implements,import,instanceof,null,native,package,strictfp,super,synchronized,throws,transient"];var R=[x,"as,base,by,checked,decimal,delegate,descending,dynamic,event,fixed,foreach,from,group,implicit,in,interface,internal,into,is,lock,object,out,override,orderby,params,partial,readonly,ref,sbyte,sealed,stackalloc,string,select,uint,ulong,unchecked,unsafe,ushort,var"];var r="all,and,by,catch,class,else,extends,false,finally,for,if,in,is,isnt,loop,new,no,not,null,of,off,on,or,return,super,then,true,try,unless,until,when,while,yes";var w=[p,"debugger,eval,export,function,get,null,set,undefined,var,with,Infinity,NaN"];var s="caller,delete,die,do,dump,elsif,eval,exit,foreach,for,goto,if,import,last,local,my,next,no,our,print,package,redo,require,sub,undef,unless,until,use,wantarray,while,BEGIN,END";var I=[h,"and,as,assert,class,def,del,elif,except,exec,finally,from,global,import,in,is,lambda,nonlocal,not,or,pass,print,raise,try,with,yield,False,True,None"];var f=[h,"alias,and,begin,case,class,def,defined,elsif,end,ensure,false,in,module,next,nil,not,or,redo,rescue,retry,self,super,then,true,undef,unless,until,when,yield,BEGIN,END"];var H=[h,"case,done,elif,esac,eval,fi,function,in,local,set,then,until"];var A=[l,R,w,s+I,f,H];var e=/^(DIR|FILE|vector|(de|priority_)?queue|list|stack|(const_)?iterator|(multi)?(set|map)|bitset|u?(int|float)\d*)/;var C="str";var z="kwd";var j="com";var O="typ";var G="lit";var L="pun";var F="pln";var m="tag";var E="dec";var J="src";var P="atn";var n="atv";var N="nocode";var M="(?:^^\\.?|[+-]|\\!|\\!=|\\!==|\\#|\\%|\\%=|&|&&|&&=|&=|\\(|\\*|\\*=|\\+=|\\,|\\-=|\\->|\\/|\\/=|:|::|\\;|<|<<|<<=|<=|=|==|===|>|>=|>>|>>=|>>>|>>>=|\\?|\\@|\\[|\\^|\\^=|\\^\\^|\\^\\^=|\\{|\\||\\|=|\\|\\||\\|\\|=|\\~|break|case|continue|delete|do|else|finally|instanceof|return|throw|try|typeof)\\s*";function k(Z){var ad=0;var S=false;var ac=false;for(var V=0,U=Z.length;V<U;++V){var ae=Z[V];if(ae.ignoreCase){ac=true}else{if(/[a-z]/i.test(ae.source.replace(/\\u[0-9a-f]{4}|\\x[0-9a-f]{2}|\\[^ux]/gi,""))){S=true;ac=false;break}}}var Y={b:8,t:9,n:10,v:11,f:12,r:13};function ab(ah){var ag=ah.charCodeAt(0);if(ag!==92){return ag}var af=ah.charAt(1);ag=Y[af];if(ag){return ag}else{if("0"<=af&&af<="7"){return parseInt(ah.substring(1),8)}else{if(af==="u"||af==="x"){return parseInt(ah.substring(2),16)}else{return ah.charCodeAt(1)}}}}function T(af){if(af<32){return(af<16?"\\x0":"\\x")+af.toString(16)}var ag=String.fromCharCode(af);if(ag==="\\"||ag==="-"||ag==="["||ag==="]"){ag="\\"+ag}return ag}function X(am){var aq=am.substring(1,am.length-1).match(new RegExp("\\\\u[0-9A-Fa-f]{4}|\\\\x[0-9A-Fa-f]{2}|\\\\[0-3][0-7]{0,2}|\\\\[0-7]{1,2}|\\\\[\\s\\S]|-|[^-\\\\]","g"));var ak=[];var af=[];var ao=aq[0]==="^";for(var ar=ao?1:0,aj=aq.length;ar<aj;++ar){var ah=aq[ar];if(/\\[bdsw]/i.test(ah)){ak.push(ah)}else{var ag=ab(ah);var al;if(ar+2<aj&&"-"===aq[ar+1]){al=ab(aq[ar+2]);ar+=2}else{al=ag}af.push([ag,al]);if(!(al<65||ag>122)){if(!(al<65||ag>90)){af.push([Math.max(65,ag)|32,Math.min(al,90)|32])}if(!(al<97||ag>122)){af.push([Math.max(97,ag)&~32,Math.min(al,122)&~32])}}}}af.sort(function(av,au){return(av[0]-au[0])||(au[1]-av[1])});var ai=[];var ap=[NaN,NaN];for(var ar=0;ar<af.length;++ar){var at=af[ar];if(at[0]<=ap[1]+1){ap[1]=Math.max(ap[1],at[1])}else{ai.push(ap=at)}}var an=["["];if(ao){an.push("^")}an.push.apply(an,ak);for(var ar=0;ar<ai.length;++ar){var at=ai[ar];an.push(T(at[0]));if(at[1]>at[0]){if(at[1]+1>at[0]){an.push("-")}an.push(T(at[1]))}}an.push("]");return an.join("")}function W(al){var aj=al.source.match(new RegExp("(?:\\[(?:[^\\x5C\\x5D]|\\\\[\\s\\S])*\\]|\\\\u[A-Fa-f0-9]{4}|\\\\x[A-Fa-f0-9]{2}|\\\\[0-9]+|\\\\[^ux0-9]|\\(\\?[:!=]|[\\(\\)\\^]|[^\\x5B\\x5C\\(\\)\\^]+)","g"));var ah=aj.length;var an=[];for(var ak=0,am=0;ak<ah;++ak){var ag=aj[ak];if(ag==="("){++am}else{if("\\"===ag.charAt(0)){var af=+ag.substring(1);if(af&&af<=am){an[af]=-1}}}}for(var ak=1;ak<an.length;++ak){if(-1===an[ak]){an[ak]=++ad}}for(var ak=0,am=0;ak<ah;++ak){var ag=aj[ak];if(ag==="("){++am;if(an[am]===undefined){aj[ak]="(?:"}}else{if("\\"===ag.charAt(0)){var af=+ag.substring(1);if(af&&af<=am){aj[ak]="\\"+an[am]}}}}for(var ak=0,am=0;ak<ah;++ak){if("^"===aj[ak]&&"^"!==aj[ak+1]){aj[ak]=""}}if(al.ignoreCase&&S){for(var ak=0;ak<ah;++ak){var ag=aj[ak];var ai=ag.charAt(0);if(ag.length>=2&&ai==="["){aj[ak]=X(ag)}else{if(ai!=="\\"){aj[ak]=ag.replace(/[a-zA-Z]/g,function(ao){var ap=ao.charCodeAt(0);return"["+String.fromCharCode(ap&~32,ap|32)+"]"})}}}}return aj.join("")}var aa=[];for(var V=0,U=Z.length;V<U;++V){var ae=Z[V];if(ae.global||ae.multiline){throw new Error(""+ae)}aa.push("(?:"+W(ae)+")")}return new RegExp(aa.join("|"),ac?"gi":"g")}function a(V){var U=/(?:^|\s)nocode(?:\s|$)/;var X=[];var T=0;var Z=[];var W=0;var S;if(V.currentStyle){S=V.currentStyle.whiteSpace}else{if(window.getComputedStyle){S=document.defaultView.getComputedStyle(V,null).getPropertyValue("white-space")}}var Y=S&&"pre"===S.substring(0,3);function aa(ab){switch(ab.nodeType){case 1:if(U.test(ab.className)){return}for(var ae=ab.firstChild;ae;ae=ae.nextSibling){aa(ae)}var ad=ab.nodeName;if("BR"===ad||"LI"===ad){X[W]="\n";Z[W<<1]=T++;Z[(W++<<1)|1]=ab}break;case 3:case 4:var ac=ab.nodeValue;if(ac.length){if(!Y){ac=ac.replace(/[ \t\r\n]+/g," ")}else{ac=ac.replace(/\r\n?/g,"\n")}X[W]=ac;Z[W<<1]=T;T+=ac.length;Z[(W++<<1)|1]=ab}break}}aa(V);return{sourceCode:X.join("").replace(/\n$/,""),spans:Z}}function B(S,U,W,T){if(!U){return}var V={sourceCode:U,basePos:S};W(V);T.push.apply(T,V.decorations)}var v=/\S/;function o(S){var V=undefined;for(var U=S.firstChild;U;U=U.nextSibling){var T=U.nodeType;V=(T===1)?(V?S:U):(T===3)?(v.test(U.nodeValue)?S:V):V}return V===S?undefined:V}function g(U,T){var S={};var V;(function(){var ad=U.concat(T);var ah=[];var ag={};for(var ab=0,Z=ad.length;ab<Z;++ab){var Y=ad[ab];var ac=Y[3];if(ac){for(var ae=ac.length;--ae>=0;){S[ac.charAt(ae)]=Y}}var af=Y[1];var aa=""+af;if(!ag.hasOwnProperty(aa)){ah.push(af);ag[aa]=null}}ah.push(/[\0-\uffff]/);V=k(ah)})();var X=T.length;var W=function(ah){var Z=ah.sourceCode,Y=ah.basePos;var ad=[Y,F];var af=0;var an=Z.match(V)||[];var aj={};for(var ae=0,aq=an.length;ae<aq;++ae){var ag=an[ae];var ap=aj[ag];var ai=void 0;var am;if(typeof ap==="string"){am=false}else{var aa=S[ag.charAt(0)];if(aa){ai=ag.match(aa[1]);ap=aa[0]}else{for(var ao=0;ao<X;++ao){aa=T[ao];ai=ag.match(aa[1]);if(ai){ap=aa[0];break}}if(!ai){ap=F}}am=ap.length>=5&&"lang-"===ap.substring(0,5);if(am&&!(ai&&typeof ai[1]==="string")){am=false;ap=J}if(!am){aj[ag]=ap}}var ab=af;af+=ag.length;if(!am){ad.push(Y+ab,ap)}else{var al=ai[1];var ak=ag.indexOf(al);var ac=ak+al.length;if(ai[2]){ac=ag.length-ai[2].length;ak=ac-al.length}var ar=ap.substring(5);B(Y+ab,ag.substring(0,ak),W,ad);B(Y+ab+ak,al,q(ar,al),ad);B(Y+ab+ac,ag.substring(ac),W,ad)}}ah.decorations=ad};return W}function i(T){var W=[],S=[];if(T.tripleQuotedStrings){W.push([C,/^(?:\'\'\'(?:[^\'\\]|\\[\s\S]|\'{1,2}(?=[^\']))*(?:\'\'\'|$)|\"\"\"(?:[^\"\\]|\\[\s\S]|\"{1,2}(?=[^\"]))*(?:\"\"\"|$)|\'(?:[^\\\']|\\[\s\S])*(?:\'|$)|\"(?:[^\\\"]|\\[\s\S])*(?:\"|$))/,null,"'\""])}else{if(T.multiLineStrings){W.push([C,/^(?:\'(?:[^\\\']|\\[\s\S])*(?:\'|$)|\"(?:[^\\\"]|\\[\s\S])*(?:\"|$)|\`(?:[^\\\`]|\\[\s\S])*(?:\`|$))/,null,"'\"`"])}else{W.push([C,/^(?:\'(?:[^\\\'\r\n]|\\.)*(?:\'|$)|\"(?:[^\\\"\r\n]|\\.)*(?:\"|$))/,null,"\"'"])}}if(T.verbatimStrings){S.push([C,/^@\"(?:[^\"]|\"\")*(?:\"|$)/,null])}var Y=T.hashComments;if(Y){if(T.cStyleComments){if(Y>1){W.push([j,/^#(?:##(?:[^#]|#(?!##))*(?:###|$)|.*)/,null,"#"])}else{W.push([j,/^#(?:(?:define|elif|else|endif|error|ifdef|include|ifndef|line|pragma|undef|warning)\b|[^\r\n]*)/,null,"#"])}S.push([C,/^<(?:(?:(?:\.\.\/)*|\/?)(?:[\w-]+(?:\/[\w-]+)+)?[\w-]+\.h|[a-z]\w*)>/,null])}else{W.push([j,/^#[^\r\n]*/,null,"#"])}}if(T.cStyleComments){S.push([j,/^\/\/[^\r\n]*/,null]);S.push([j,/^\/\*[\s\S]*?(?:\*\/|$)/,null])}if(T.regexLiterals){var X=("/(?=[^/*])(?:[^/\\x5B\\x5C]|\\x5C[\\s\\S]|\\x5B(?:[^\\x5C\\x5D]|\\x5C[\\s\\S])*(?:\\x5D|$))+/");S.push(["lang-regex",new RegExp("^"+M+"("+X+")")])}var V=T.types;if(V){S.push([O,V])}var U=(""+T.keywords).replace(/^ | $/g,"");if(U.length){S.push([z,new RegExp("^(?:"+U.replace(/[\s,]+/g,"|")+")\\b"),null])}W.push([F,/^\s+/,null," \r\n\t\xA0"]);S.push([G,/^@[a-z_$][a-z_$@0-9]*/i,null],[O,/^(?:[@_]?[A-Z]+[a-z][A-Za-z_$@0-9]*|\w+_t\b)/,null],[F,/^[a-z_$][a-z_$@0-9]*/i,null],[G,new RegExp("^(?:0x[a-f0-9]+|(?:\\d(?:_\\d+)*\\d*(?:\\.\\d*)?|\\.\\d\\+)(?:e[+\\-]?\\d+)?)[a-z]*","i"),null,"0123456789"],[F,/^\\[\s\S]?/,null],[L,/^.[^\s\w\.$@\'\"\`\/\#\\]*/,null]);return g(W,S)}var K=i({keywords:A,hashComments:true,cStyleComments:true,multiLineStrings:true,regexLiterals:true});function Q(V,ag){var U=/(?:^|\s)nocode(?:\s|$)/;var ab=/\r\n?|\n/;var ac=V.ownerDocument;var S;if(V.currentStyle){S=V.currentStyle.whiteSpace}else{if(window.getComputedStyle){S=ac.defaultView.getComputedStyle(V,null).getPropertyValue("white-space")}}var Z=S&&"pre"===S.substring(0,3);var af=ac.createElement("LI");while(V.firstChild){af.appendChild(V.firstChild)}var W=[af];function ae(al){switch(al.nodeType){case 1:if(U.test(al.className)){break}if("BR"===al.nodeName){ad(al);if(al.parentNode){al.parentNode.removeChild(al)}}else{for(var an=al.firstChild;an;an=an.nextSibling){ae(an)}}break;case 3:case 4:if(Z){var am=al.nodeValue;var aj=am.match(ab);if(aj){var ai=am.substring(0,aj.index);al.nodeValue=ai;var ah=am.substring(aj.index+aj[0].length);if(ah){var ak=al.parentNode;ak.insertBefore(ac.createTextNode(ah),al.nextSibling)}ad(al);if(!ai){al.parentNode.removeChild(al)}}}break}}function ad(ak){while(!ak.nextSibling){ak=ak.parentNode;if(!ak){return}}function ai(al,ar){var aq=ar?al.cloneNode(false):al;var ao=al.parentNode;if(ao){var ap=ai(ao,1);var an=al.nextSibling;ap.appendChild(aq);for(var am=an;am;am=an){an=am.nextSibling;ap.appendChild(am)}}return aq}var ah=ai(ak.nextSibling,0);for(var aj;(aj=ah.parentNode)&&aj.nodeType===1;){ah=aj}W.push(ah)}for(var Y=0;Y<W.length;++Y){ae(W[Y])}if(ag===(ag|0)){W[0].setAttribute("value",ag)}var aa=ac.createElement("OL");aa.className="linenums";var X=Math.max(0,((ag-1))|0)||0;for(var Y=0,T=W.length;Y<T;++Y){af=W[Y];af.className="L"+((Y+X)%10);if(!af.firstChild){af.appendChild(ac.createTextNode("\xA0"))}aa.appendChild(af)}V.appendChild(aa)}function D(ac){var aj=/\bMSIE\b/.test(navigator.userAgent);var am=/\n/g;var al=ac.sourceCode;var an=al.length;var V=0;var aa=ac.spans;var T=aa.length;var ah=0;var X=ac.decorations;var Y=X.length;var Z=0;X[Y]=an;var ar,aq;for(aq=ar=0;aq<Y;){if(X[aq]!==X[aq+2]){X[ar++]=X[aq++];X[ar++]=X[aq++]}else{aq+=2}}Y=ar;for(aq=ar=0;aq<Y;){var at=X[aq];var ab=X[aq+1];var W=aq+2;while(W+2<=Y&&X[W+1]===ab){W+=2}X[ar++]=at;X[ar++]=ab;aq=W}Y=X.length=ar;var ae=null;while(ah<T){var af=aa[ah];var S=aa[ah+2]||an;var ag=X[Z];var ap=X[Z+2]||an;var W=Math.min(S,ap);var ak=aa[ah+1];var U;if(ak.nodeType!==1&&(U=al.substring(V,W))){if(aj){U=U.replace(am,"\r")}ak.nodeValue=U;var ai=ak.ownerDocument;var ao=ai.createElement("SPAN");ao.className=X[Z+1];var ad=ak.parentNode;ad.replaceChild(ao,ak);ao.appendChild(ak);if(V<S){aa[ah+1]=ak=ai.createTextNode(al.substring(W,S));ad.insertBefore(ak,ao.nextSibling)}}V=W;if(V>=S){ah+=2}if(V>=ap){Z+=2}}}var t={};function c(U,V){for(var S=V.length;--S>=0;){var T=V[S];if(!t.hasOwnProperty(T)){t[T]=U}else{if(window.console){console.warn("cannot override language handler %s",T)}}}}function q(T,S){if(!(T&&t.hasOwnProperty(T))){T=/^\s*</.test(S)?"default-markup":"default-code"}return t[T]}c(K,["default-code"]);c(g([],[[F,/^[^<?]+/],[E,/^<!\w[^>]*(?:>|$)/],[j,/^<\!--[\s\S]*?(?:-\->|$)/],["lang-",/^<\?([\s\S]+?)(?:\?>|$)/],["lang-",/^<%([\s\S]+?)(?:%>|$)/],[L,/^(?:<[%?]|[%?]>)/],["lang-",/^<xmp\b[^>]*>([\s\S]+?)<\/xmp\b[^>]*>/i],["lang-js",/^<script\b[^>]*>([\s\S]*?)(<\/script\b[^>]*>)/i],["lang-css",/^<style\b[^>]*>([\s\S]*?)(<\/style\b[^>]*>)/i],["lang-in.tag",/^(<\/?[a-z][^<>]*>)/i]]),["default-markup","htm","html","mxml","xhtml","xml","xsl"]);c(g([[F,/^[\s]+/,null," \t\r\n"],[n,/^(?:\"[^\"]*\"?|\'[^\']*\'?)/,null,"\"'"]],[[m,/^^<\/?[a-z](?:[\w.:-]*\w)?|\/?>$/i],[P,/^(?!style[\s=]|on)[a-z](?:[\w:-]*\w)?/i],["lang-uq.val",/^=\s*([^>\'\"\s]*(?:[^>\'\"\s\/]|\/(?=\s)))/],[L,/^[=<>\/]+/],["lang-js",/^on\w+\s*=\s*\"([^\"]+)\"/i],["lang-js",/^on\w+\s*=\s*\'([^\']+)\'/i],["lang-js",/^on\w+\s*=\s*([^\"\'>\s]+)/i],["lang-css",/^style\s*=\s*\"([^\"]+)\"/i],["lang-css",/^style\s*=\s*\'([^\']+)\'/i],["lang-css",/^style\s*=\s*([^\"\'>\s]+)/i]]),["in.tag"]);c(g([],[[n,/^[\s\S]+/]]),["uq.val"]);c(i({keywords:l,hashComments:true,cStyleComments:true,types:e}),["c","cc","cpp","cxx","cyc","m"]);c(i({keywords:"null,true,false"}),["json"]);c(i({keywords:R,hashComments:true,cStyleComments:true,verbatimStrings:true,types:e}),["cs"]);c(i({keywords:x,cStyleComments:true}),["java"]);c(i({keywords:H,hashComments:true,multiLineStrings:true}),["bsh","csh","sh"]);c(i({keywords:I,hashComments:true,multiLineStrings:true,tripleQuotedStrings:true}),["cv","py"]);c(i({keywords:s,hashComments:true,multiLineStrings:true,regexLiterals:true}),["perl","pl","pm"]);c(i({keywords:f,hashComments:true,multiLineStrings:true,regexLiterals:true}),["rb"]);c(i({keywords:w,cStyleComments:true,regexLiterals:true}),["js"]);c(i({keywords:r,hashComments:3,cStyleComments:true,multilineStrings:true,tripleQuotedStrings:true,regexLiterals:true}),["coffee"]);c(g([],[[C,/^[\s\S]+/]]),["regex"]);function d(V){var U=V.langExtension;try{var S=a(V.sourceNode);var T=S.sourceCode;V.sourceCode=T;V.spans=S.spans;V.basePos=0;q(U,T)(V);D(V)}catch(W){if("console" in window){console.log(W&&W.stack?W.stack:W)}}}function y(W,V,U){var S=document.createElement("PRE");S.innerHTML=W;if(U){Q(S,U)}var T={langExtension:V,numberLines:U,sourceNode:S};d(T);return S.innerHTML}function b(ad){function Y(af){return document.getElementsByTagName(af)}var ac=[Y("pre"),Y("code"),Y("xmp")];var T=[];for(var aa=0;aa<ac.length;++aa){for(var Z=0,V=ac[aa].length;Z<V;++Z){T.push(ac[aa][Z])}}ac=null;var W=Date;if(!W.now){W={now:function(){return +(new Date)}}}var X=0;var S;var ab=/\blang(?:uage)?-([\w.]+)(?!\S)/;var ae=/\bprettyprint\b/;function U(){var ag=(window.PR_SHOULD_USE_CONTINUATION?W.now()+250:Infinity);for(;X<T.length&&W.now()<ag;X++){var aj=T[X];var ai=aj.className;if(ai.indexOf("prettyprint")>=0){var ah=ai.match(ab);var am;if(!ah&&(am=o(aj))&&"CODE"===am.tagName){ah=am.className.match(ab)}if(ah){ah=ah[1]}var al=false;for(var ak=aj.parentNode;ak;ak=ak.parentNode){if((ak.tagName==="pre"||ak.tagName==="code"||ak.tagName==="xmp")&&ak.className&&ak.className.indexOf("prettyprint")>=0){al=true;break}}if(!al){var af=aj.className.match(/\blinenums\b(?::(\d+))?/);af=af?af[1]&&af[1].length?+af[1]:true:false;if(af){Q(aj,af)}S={langExtension:ah,sourceNode:aj,numberLines:af};d(S)}}}if(X<T.length){setTimeout(U,250)}else{if(ad){ad()}}}U()}window.prettyPrintOne=y;window.prettyPrint=b;window.PR={createSimpleLexer:g,registerLangHandler:c,sourceDecorator:i,PR_ATTRIB_NAME:P,PR_ATTRIB_VALUE:n,PR_COMMENT:j,PR_DECLARATION:E,PR_KEYWORD:z,PR_LITERAL:G,PR_NOCODE:N,PR_PLAIN:F,PR_PUNCTUATION:L,PR_SOURCE:J,PR_STRING:C,PR_TAG:m,PR_TYPE:O}})();PR.registerLangHandler(PR.createSimpleLexer([],[[PR.PR_DECLARATION,/^<!\w[^>]*(?:>|$)/],[PR.PR_COMMENT,/^<\!--[\s\S]*?(?:-\->|$)/],[PR.PR_PUNCTUATION,/^(?:<[%?]|[%?]>)/],["lang-",/^<\?([\s\S]+?)(?:\?>|$)/],["lang-",/^<%([\s\S]+?)(?:%>|$)/],["lang-",/^<xmp\b[^>]*>([\s\S]+?)<\/xmp\b[^>]*>/i],["lang-handlebars",/^<script\b[^>]*type\s*=\s*['"]?text\/x-handlebars-template['"]?\b[^>]*>([\s\S]*?)(<\/script\b[^>]*>)/i],["lang-js",/^<script\b[^>]*>([\s\S]*?)(<\/script\b[^>]*>)/i],["lang-css",/^<style\b[^>]*>([\s\S]*?)(<\/style\b[^>]*>)/i],["lang-in.tag",/^(<\/?[a-z][^<>]*>)/i],[PR.PR_DECLARATION,/^{{[#^>/]?\s*[\w.][^}]*}}/],[PR.PR_DECLARATION,/^{{&?\s*[\w.][^}]*}}/],[PR.PR_DECLARATION,/^{{{>?\s*[\w.][^}]*}}}/],[PR.PR_COMMENT,/^{{![^}]*}}/]]),["handlebars","hbs"]);PR.registerLangHandler(PR.createSimpleLexer([[PR.PR_PLAIN,/^[ \t\r\n\f]+/,null," \t\r\n\f"]],[[PR.PR_STRING,/^\"(?:[^\n\r\f\\\"]|\\(?:\r\n?|\n|\f)|\\[\s\S])*\"/,null],[PR.PR_STRING,/^\'(?:[^\n\r\f\\\']|\\(?:\r\n?|\n|\f)|\\[\s\S])*\'/,null],["lang-css-str",/^url\(([^\)\"\']*)\)/i],[PR.PR_KEYWORD,/^(?:url|rgb|\!important|@import|@page|@media|@charset|inherit)(?=[^\-\w]|$)/i,null],["lang-css-kw",/^(-?(?:[_a-z]|(?:\\[0-9a-f]+ ?))(?:[_a-z0-9\-]|\\(?:\\[0-9a-f]+ ?))*)\s*:/i],[PR.PR_COMMENT,/^\/\*[^*]*\*+(?:[^\/*][^*]*\*+)*\//],[PR.PR_COMMENT,/^(?:<!--|-->)/],[PR.PR_LITERAL,/^(?:\d+|\d*\.\d+)(?:%|[a-z]+)?/i],[PR.PR_LITERAL,/^#(?:[0-9a-f]{3}){1,2}/i],[PR.PR_PLAIN,/^-?(?:[_a-z]|(?:\\[\da-f]+ ?))(?:[_a-z\d\-]|\\(?:\\[\da-f]+ ?))*/i],[PR.PR_PUNCTUATION,/^[^\s\w\'\"]+/]]),["css"]);PR.registerLangHandler(PR.createSimpleLexer([],[[PR.PR_KEYWORD,/^-?(?:[_a-z]|(?:\\[\da-f]+ ?))(?:[_a-z\d\-]|\\(?:\\[\da-f]+ ?))*/i]]),["css-kw"]);PR.registerLangHandler(PR.createSimpleLexer([],[[PR.PR_STRING,/^[^\)\"\']+/]]),["css-str"]);