Upload folder using huggingface_hub
Browse filesThis view is limited to 50 files because it contains too many changes.
See raw diff
- run.sh +72 -0
- web/app.js +78 -0
- web/appSettings.js +145 -0
- web/config/basePath.json +1 -0
- web/config/settings.json +8 -0
- web/json_rpc.js +137 -0
- web/jupyter.js +214 -0
- web/logging.js +130 -0
- web/lsp/capabilities_node.js +3 -0
- web/lsp/extensions_node.js +3 -0
- web/lsp/protocol_node.js +186 -0
- web/lsp/settings_node.js +44 -0
- web/lsp/text_document_node.js +313 -0
- web/lsp/window_node.js +24 -0
- web/lsp/workspace_node.js +41 -0
- web/node_modules/.bin/bunyan +3 -0
- web/node_modules/.bin/mkdirp +3 -0
- web/node_modules/.bin/ncp +3 -0
- web/node_modules/.bin/rimraf +3 -0
- web/node_modules/.bin/semver +3 -0
- web/node_modules/accepts/HISTORY.md +224 -0
- web/node_modules/accepts/LICENSE +23 -0
- web/node_modules/accepts/README.md +143 -0
- web/node_modules/accepts/index.js +238 -0
- web/node_modules/accepts/package.json +50 -0
- web/node_modules/after/.npmignore +2 -0
- web/node_modules/after/.travis.yml +12 -0
- web/node_modules/after/LICENCE +19 -0
- web/node_modules/after/README.md +115 -0
- web/node_modules/after/index.js +28 -0
- web/node_modules/after/package.json +32 -0
- web/node_modules/after/test/after-test.js +120 -0
- web/node_modules/arraybuffer.slice/.npmignore +17 -0
- web/node_modules/arraybuffer.slice/LICENCE +18 -0
- web/node_modules/arraybuffer.slice/Makefile +8 -0
- web/node_modules/arraybuffer.slice/README.md +17 -0
- web/node_modules/arraybuffer.slice/index.js +29 -0
- web/node_modules/arraybuffer.slice/package.json +20 -0
- web/node_modules/arraybuffer.slice/test/slice-buffer.js +227 -0
- web/node_modules/async-limiter/.travis.yml +7 -0
- web/node_modules/async-limiter/LICENSE +8 -0
- web/node_modules/async-limiter/coverage/coverage.json +1 -0
- web/node_modules/async-limiter/coverage/lcov-report/async-throttle/index.html +73 -0
- web/node_modules/async-limiter/coverage/lcov-report/async-throttle/index.js.html +246 -0
- web/node_modules/async-limiter/coverage/lcov-report/base.css +182 -0
- web/node_modules/async-limiter/coverage/lcov-report/index.html +73 -0
- web/node_modules/async-limiter/coverage/lcov-report/prettify.css +1 -0
- web/node_modules/async-limiter/coverage/lcov-report/prettify.js +1 -0
- web/node_modules/async-limiter/coverage/lcov-report/sort-arrow-sprite.png +0 -0
- web/node_modules/async-limiter/coverage/lcov-report/sorter.js +156 -0
run.sh
ADDED
@@ -0,0 +1,72 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
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 |
+
if [[ -e /customize_for_vm_type.sh ]]; then
|
21 |
+
/customize_for_vm_type.sh
|
22 |
+
fi
|
23 |
+
|
24 |
+
/usr/local/colab/bin/oom_monitor.sh &
|
25 |
+
|
26 |
+
# Start the Colab proxy to the Jupyter kernel manager.
|
27 |
+
# TODO(b/267667580): Evaluate use of tcmalloc here and possibly other places.
|
28 |
+
( while true; do
|
29 |
+
GCE_METADATA_HOST="${VM_GCE_METADATA_HOST}" \
|
30 |
+
LD_PRELOAD='/usr/lib/x86_64-linux-gnu/libtcmalloc.so.4' \
|
31 |
+
/usr/colab/bin/kernel_manager_proxy \
|
32 |
+
--listen_port="${KMP_LISTEN_PORT}" \
|
33 |
+
--target_port="${KMP_TARGET_PORT}" \
|
34 |
+
${KMP_EXTRA_ARGS} || true
|
35 |
+
sleep 1
|
36 |
+
done & )
|
37 |
+
|
38 |
+
# Start fresh to isolate user-initiated actions from VM build & startup events.
|
39 |
+
for f in /var/log/apt/history.log /var/log/pip.log; do
|
40 |
+
mv "$f" "${f}.bak-run.sh" 2>/dev/null || true # Ignore missing files.
|
41 |
+
done
|
42 |
+
|
43 |
+
# Warm disk buffers for modules we need for kernel startup. (cf: b/116536906)
|
44 |
+
if [[ "${COLAB_WARMUP_DEFAULTS}" == "1" ]]; then
|
45 |
+
python3 -c "import google.colab._kernel"
|
46 |
+
python3 -c "import matplotlib"
|
47 |
+
python3 -c "import tensorflow" &
|
48 |
+
fi
|
49 |
+
|
50 |
+
# Start the server to handle /files and /api/contents requests.
|
51 |
+
/usr/local/bin/colab-fileshim.py ${COLAB_FILESHIM_EXTRA_ARGS} &
|
52 |
+
|
53 |
+
# Link NVidia tools from a read-only volume mount.
|
54 |
+
for f in $(ls /opt/bin/.nvidia 2>/dev/null); do
|
55 |
+
ln -st /opt/bin "/opt/bin/.nvidia/${f}"
|
56 |
+
ln -st /usr/bin "/opt/bin/.nvidia/${f}"
|
57 |
+
done
|
58 |
+
|
59 |
+
cd /
|
60 |
+
|
61 |
+
# Start the node server.
|
62 |
+
if [[ "${COLAB_HUMAN_READABLE_NODE_LOGS}" == "1" ]]; then
|
63 |
+
PIPE=/tmp/.node.out
|
64 |
+
if ! [[ -p "${PIPE}" ]]; then
|
65 |
+
mkfifo "${PIPE}"
|
66 |
+
fi
|
67 |
+
/datalab/web/node_modules/bunyan/bin/bunyan \
|
68 |
+
-l "${COLAB_NODE_LOG_LEVEL:-info}" < "${PIPE}" &
|
69 |
+
exec >& "${PIPE}"
|
70 |
+
fi
|
71 |
+
exec /tools/node/bin/node /datalab/web/app.js
|
72 |
+
|
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
|
web/appSettings.js
ADDED
@@ -0,0 +1,145 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
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 = void 0;
|
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 |
+
exports.applyEnvironmentVariables = applyEnvironmentVariables;
|
145 |
+
//# 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"]}
|
web/config/basePath.json
ADDED
@@ -0,0 +1 @@
|
|
|
|
|
1 |
+
""
|
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 |
+
}
|
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.encodeJsonRpc = exports.JsonRpcReader = void 0;
|
15 |
+
var CR = 13;
|
16 |
+
var LF = 10;
|
17 |
+
/**
|
18 |
+
* JSON RPC reader following the Debug Adapter Protocol message
|
19 |
+
* format which itself follows Chrome's V8 debugger protocol, originally
|
20 |
+
* documented at
|
21 |
+
* https://github.com/buggerjs/bugger-v8-client/blob/master/PROTOCOL.md#v8-debugger-protocol
|
22 |
+
*/
|
23 |
+
var JsonRpcReader = /** @class */ (function () {
|
24 |
+
function JsonRpcReader(callback) {
|
25 |
+
this.callback = callback;
|
26 |
+
this.position = 0;
|
27 |
+
this.allocationSize = 4096;
|
28 |
+
this.decoder = new TextDecoder();
|
29 |
+
this.buffer = new Uint8Array(this.allocationSize);
|
30 |
+
}
|
31 |
+
JsonRpcReader.prototype.append = function (data) {
|
32 |
+
// Grow the buffer if necessary to hold the data.
|
33 |
+
if (data.byteLength > (this.buffer.byteLength - this.position)) {
|
34 |
+
var requiredSize = this.position + data.byteLength;
|
35 |
+
var newSize = Math.ceil(requiredSize / this.allocationSize) * this.allocationSize;
|
36 |
+
var newBuffer = new Uint8Array(newSize);
|
37 |
+
newBuffer.set(this.buffer, 0);
|
38 |
+
this.buffer = newBuffer;
|
39 |
+
}
|
40 |
+
// Push new data onto end of the buffer.
|
41 |
+
this.buffer.set(data, this.position);
|
42 |
+
this.position += data.byteLength;
|
43 |
+
var parsedMessages = [];
|
44 |
+
while (true) {
|
45 |
+
// Parse all messages out of the buffer.
|
46 |
+
var message = this.tryReadMessage();
|
47 |
+
if (!message) {
|
48 |
+
break;
|
49 |
+
}
|
50 |
+
parsedMessages.push(message);
|
51 |
+
this.callback(message);
|
52 |
+
}
|
53 |
+
return parsedMessages;
|
54 |
+
};
|
55 |
+
JsonRpcReader.prototype.tryReadMessage = function () {
|
56 |
+
var e_1, _a;
|
57 |
+
// Loop through looking for \r\n\r\n in the buffer.
|
58 |
+
for (var i = 0; i < this.position - 4; ++i) {
|
59 |
+
// First \r\n indicates the end of the headers.
|
60 |
+
if (this.buffer[i] === CR && this.buffer[i + 1] === LF &&
|
61 |
+
this.buffer[i + 2] === CR && this.buffer[i + 3] === LF) {
|
62 |
+
// Parse each of the header lines out of the header block.
|
63 |
+
var headerLength = i + 4;
|
64 |
+
var headerBytes = this.buffer.subarray(0, headerLength);
|
65 |
+
var headerString = this.decoder.decode(headerBytes);
|
66 |
+
var headerLines = headerString.split('\r\n');
|
67 |
+
var headers = {};
|
68 |
+
try {
|
69 |
+
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()) {
|
70 |
+
var line = headerLines_1_1.value;
|
71 |
+
if (!line.trim()) {
|
72 |
+
continue;
|
73 |
+
}
|
74 |
+
var pair = line.split(':');
|
75 |
+
if (pair.length !== 2) {
|
76 |
+
throw new Error("Illegal header value: ".concat(line));
|
77 |
+
}
|
78 |
+
headers[pair[0]] = pair[1].trim();
|
79 |
+
}
|
80 |
+
}
|
81 |
+
catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
82 |
+
finally {
|
83 |
+
try {
|
84 |
+
if (headerLines_1_1 && !headerLines_1_1.done && (_a = headerLines_1.return)) _a.call(headerLines_1);
|
85 |
+
}
|
86 |
+
finally { if (e_1) throw e_1.error; }
|
87 |
+
}
|
88 |
+
var contentLengthString = headers['Content-Length'];
|
89 |
+
if (!contentLengthString) {
|
90 |
+
throw new Error('Missing Content-Length header.');
|
91 |
+
}
|
92 |
+
var contentLength = Number(contentLengthString);
|
93 |
+
if (isNaN(contentLength)) {
|
94 |
+
throw new Error("Header Content-Length not a number: ".concat(contentLengthString, "."));
|
95 |
+
}
|
96 |
+
var requiredLength = headerLength + contentLength;
|
97 |
+
if (requiredLength <= this.position) {
|
98 |
+
// This is just a view onto the current buffer.
|
99 |
+
var contentBytes = this.buffer.subarray(headerLength, headerLength + contentLength);
|
100 |
+
var content = this.decoder.decode(contentBytes);
|
101 |
+
this.buffer.copyWithin(0, headerLength + contentLength, this.position);
|
102 |
+
this.position = this.position - (headerLength + contentLength);
|
103 |
+
return { headers: headers, content: content };
|
104 |
+
}
|
105 |
+
}
|
106 |
+
}
|
107 |
+
return null;
|
108 |
+
};
|
109 |
+
return JsonRpcReader;
|
110 |
+
}());
|
111 |
+
exports.JsonRpcReader = JsonRpcReader;
|
112 |
+
/** Encodes the string content to a JSON RPC message. */
|
113 |
+
function encodeJsonRpc(content) {
|
114 |
+
var e_2, _a;
|
115 |
+
var headers = {
|
116 |
+
'Content-Length': String(new TextEncoder().encode(content).byteLength),
|
117 |
+
};
|
118 |
+
var requestString = '';
|
119 |
+
try {
|
120 |
+
for (var _b = __values(Object.keys(headers)), _c = _b.next(); !_c.done; _c = _b.next()) {
|
121 |
+
var key = _c.value;
|
122 |
+
requestString += "".concat(key, ": ").concat(headers[key], "\r\n");
|
123 |
+
}
|
124 |
+
}
|
125 |
+
catch (e_2_1) { e_2 = { error: e_2_1 }; }
|
126 |
+
finally {
|
127 |
+
try {
|
128 |
+
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
|
129 |
+
}
|
130 |
+
finally { if (e_2) throw e_2.error; }
|
131 |
+
}
|
132 |
+
requestString += '\r\n';
|
133 |
+
requestString += content;
|
134 |
+
return requestString;
|
135 |
+
}
|
136 |
+
exports.encodeJsonRpc = encodeJsonRpc;
|
137 |
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"json_rpc.js","sourceRoot":"","sources":["../../../../../../third_party/colab/sources/json_rpc.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAAA,IAAM,EAAE,GAAG,EAAE,CAAC;AACd,IAAM,EAAE,GAAG,EAAE,CAAC;AAQd;;;;;GAKG;AACH;IAME,uBAAqB,QAA2C;QAA3C,aAAQ,GAAR,QAAQ,CAAmC;QAJxD,aAAQ,GAAW,CAAC,CAAC;QACZ,mBAAc,GAAG,IAAI,CAAC;QACtB,YAAO,GAAG,IAAI,WAAW,EAAE,CAAC;QAG3C,IAAI,CAAC,MAAM,GAAG,IAAI,UAAU,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;IACpD,CAAC;IAED,8BAAM,GAAN,UAAO,IAAgB;QACrB,iDAAiD;QACjD,IAAI,IAAI,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC;YAC/D,IAAM,YAAY,GAAG,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,UAAU,CAAC;YACrD,IAAM,OAAO,GACT,IAAI,CAAC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,cAAc,CAAC,GAAG,IAAI,CAAC,cAAc,CAAC;YACxE,IAAM,SAAS,GAAG,IAAI,UAAU,CAAC,OAAO,CAAC,CAAC;YAC1C,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;YAC9B,IAAI,CAAC,MAAM,GAAG,SAAS,CAAC;QAC1B,CAAC;QACD,wCAAwC;QACxC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;QACrC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,UAAU,CAAC;QAEjC,IAAM,cAAc,GAAG,EAAE,CAAC;QAC1B,OAAO,IAAI,EAAE,CAAC;YACZ,wCAAwC;YACxC,IAAM,OAAO,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;YACtC,IAAI,CAAC,OAAO,EAAE,CAAC;gBACb,MAAM;YACR,CAAC;YACD,cAAc,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAC7B,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;QACzB,CAAC;QACD,OAAO,cAAc,CAAC;IACxB,CAAC;IAED,sCAAc,GAAd;;QACE,mDAAmD;QACnD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,QAAQ,GAAG,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC;YAC3C,+CAA+C;YAC/C,IAAI,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,EAAE,IAAI,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE;gBAClD,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,IAAI,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC;gBAC3D,0DAA0D;gBAC1D,IAAM,YAAY,GAAG,CAAC,GAAG,CAAC,CAAC;gBAC3B,IAAM,WAAW,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,EAAE,YAAY,CAAC,CAAC;gBAC1D,IAAM,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC;gBACtD,IAAM,WAAW,GAAG,YAAY,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;gBAC/C,IAAM,OAAO,GAA4B,EAAE,CAAC;;oBAC5C,KAAmB,IAAA,+BAAA,SAAA,WAAW,CAAA,CAAA,wCAAA,iEAAE,CAAC;wBAA5B,IAAM,IAAI,wBAAA;wBACb,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,EAAE,CAAC;4BACjB,SAAS;wBACX,CAAC;wBACD,IAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;wBAC7B,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;4BACtB,MAAM,IAAI,KAAK,CAAC,gCAAyB,IAAI,CAAE,CAAC,CAAC;wBACnD,CAAC;wBACD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;oBACpC,CAAC;;;;;;;;;gBACD,IAAM,mBAAmB,GAAG,OAAO,CAAC,gBAAgB,CAAC,CAAC;gBACtD,IAAI,CAAC,mBAAmB,EAAE,CAAC;oBACzB,MAAM,IAAI,KAAK,CAAC,gCAAgC,CAAC,CAAC;gBACpD,CAAC;gBACD,IAAM,aAAa,GAAG,MAAM,CAAC,mBAAmB,CAAC,CAAC;gBAClD,IAAI,KAAK,CAAC,aAAa,CAAC,EAAE,CAAC;oBACzB,MAAM,IAAI,KAAK,CACX,8CAAuC,mBAAmB,MAAG,CAAC,CAAC;gBACrE,CAAC;gBACD,IAAM,cAAc,GAAG,YAAY,GAAG,aAAa,CAAC;gBACpD,IAAI,cAAc,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;oBACpC,+CAA+C;oBAC/C,IAAM,YAAY,GACd,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,YAAY,EAAE,YAAY,GAAG,aAAa,CAAC,CAAC;oBACrE,IAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;oBAClD,IAAI,CAAC,MAAM,CAAC,UAAU,CAClB,CAAC,EAAE,YAAY,GAAG,aAAa,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;oBACpD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,GAAG,CAAC,YAAY,GAAG,aAAa,CAAC,CAAC;oBAC/D,OAAO,EAAC,OAAO,SAAA,EAAE,OAAO,SAAA,EAAC,CAAC;gBAC5B,CAAC;YACH,CAAC;QACH,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IACH,oBAAC;AAAD,CAAC,AAnFD,IAmFC;AAnFY,sCAAa;AAqF1B,wDAAwD;AACxD,SAAgB,aAAa,CAAC,OAAe;;IAC3C,IAAM,OAAO,GAA4B;QACvC,gBAAgB,EAAE,MAAM,CAAC,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,UAAU,CAAC;KACvE,CAAC;IACF,IAAI,aAAa,GAAG,EAAE,CAAC;;QACvB,KAAkB,IAAA,KAAA,SAAA,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA,gBAAA,4BAAE,CAAC;YAApC,IAAM,GAAG,WAAA;YACZ,aAAa,IAAI,UAAG,GAAG,eAAK,OAAO,CAAC,GAAG,CAAC,SAAM,CAAC;QACjD,CAAC;;;;;;;;;IACD,aAAa,IAAI,MAAM,CAAC;IACxB,aAAa,IAAI,OAAO,CAAC;IACzB,OAAO,aAAa,CAAC;AACvB,CAAC;AAXD,sCAWC","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"]}
|
web/jupyter.js
ADDED
@@ -0,0 +1,214 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
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.handleRequest = exports.handleSocket = exports.close = exports.init = void 0;
|
30 |
+
var childProcess = require("child_process");
|
31 |
+
var httpProxy = require("http-proxy");
|
32 |
+
var path = require("path");
|
33 |
+
var logging = require("./logging");
|
34 |
+
/**
|
35 |
+
* Singleton tracking the jupyter server instance we manage.
|
36 |
+
*/
|
37 |
+
var jupyterServer = null;
|
38 |
+
/**
|
39 |
+
* The maximum number of times we'll restart jupyter; we set a limit to avoid
|
40 |
+
* users being stuck with a slow-crash-looping server.
|
41 |
+
*/
|
42 |
+
var remainingJupyterServerRestarts = 20;
|
43 |
+
/**
|
44 |
+
* The application settings instance.
|
45 |
+
*/
|
46 |
+
var appSettings;
|
47 |
+
/*
|
48 |
+
* This list of levels should match the ones used by Python:
|
49 |
+
* https://docs.python.org/3/library/logging.html#logging-levels
|
50 |
+
*/
|
51 |
+
var LogLevels;
|
52 |
+
(function (LogLevels) {
|
53 |
+
LogLevels["CRITICAL"] = "CRITICAL";
|
54 |
+
LogLevels["ERROR"] = "ERROR";
|
55 |
+
LogLevels["WARNING"] = "WARNING";
|
56 |
+
LogLevels["INFO"] = "INFO";
|
57 |
+
LogLevels["DEBUG"] = "DEBUG";
|
58 |
+
LogLevels["NOTSET"] = "NOTSET";
|
59 |
+
})(LogLevels || (LogLevels = {}));
|
60 |
+
function pipeOutput(stream) {
|
61 |
+
stream.setEncoding('utf8');
|
62 |
+
// The format we parse here corresponds to the log format we set in our
|
63 |
+
// jupyter configuration.
|
64 |
+
var logger = logging.getJupyterLogger();
|
65 |
+
stream.on('data', function (data) {
|
66 |
+
var e_1, _a;
|
67 |
+
try {
|
68 |
+
for (var _b = __values(data.split('\n')), _c = _b.next(); !_c.done; _c = _b.next()) {
|
69 |
+
var line = _c.value;
|
70 |
+
if (line.trim().length === 0) {
|
71 |
+
continue;
|
72 |
+
}
|
73 |
+
var parts = line.split('|', 3);
|
74 |
+
if (parts.length !== 3) {
|
75 |
+
// Non-logging messages (eg tracebacks) get logged as warnings.
|
76 |
+
logger.warn(line);
|
77 |
+
continue;
|
78 |
+
}
|
79 |
+
var level = parts[1];
|
80 |
+
var message = parts[2];
|
81 |
+
// We need to map Python's log levels to those used by bunyan.
|
82 |
+
if (level === LogLevels.CRITICAL || level === LogLevels.ERROR) {
|
83 |
+
logger.error(message);
|
84 |
+
}
|
85 |
+
else if (level === LogLevels.WARNING) {
|
86 |
+
logger.warn(message);
|
87 |
+
}
|
88 |
+
else if (level === LogLevels.INFO) {
|
89 |
+
logger.info(message);
|
90 |
+
}
|
91 |
+
else {
|
92 |
+
// We map DEBUG, NOTSET, and any unknown log levels to debug.
|
93 |
+
logger.debug(message);
|
94 |
+
}
|
95 |
+
}
|
96 |
+
}
|
97 |
+
catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
98 |
+
finally {
|
99 |
+
try {
|
100 |
+
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
|
101 |
+
}
|
102 |
+
finally { if (e_1) throw e_1.error; }
|
103 |
+
}
|
104 |
+
});
|
105 |
+
}
|
106 |
+
function createJupyterServer() {
|
107 |
+
var e_2, _a;
|
108 |
+
if (!remainingJupyterServerRestarts) {
|
109 |
+
logging.getLogger().error('No jupyter restart attempts remaining.');
|
110 |
+
return;
|
111 |
+
}
|
112 |
+
remainingJupyterServerRestarts -= 1;
|
113 |
+
var port = appSettings.nextJupyterPort;
|
114 |
+
logging.getLogger().info('Launching Jupyter server at %d', port);
|
115 |
+
var jupyterArgs = appSettings.jupyterArgs || [];
|
116 |
+
function exitHandler(code, signal) {
|
117 |
+
if (jupyterServer) {
|
118 |
+
logging.getLogger().error('Jupyter process %d exited due to signal: %s', jupyterServer.childProcess.pid, signal);
|
119 |
+
}
|
120 |
+
else {
|
121 |
+
logging.getLogger().error('Jupyter process exit before server creation finished due to signal: %s', signal);
|
122 |
+
}
|
123 |
+
// We want to restart jupyter whenever it terminates.
|
124 |
+
createJupyterServer();
|
125 |
+
}
|
126 |
+
var contentDir = path.join(appSettings.datalabRoot, appSettings.contentDir);
|
127 |
+
var processArgs = ['notebook'].concat(jupyterArgs || []).concat([
|
128 |
+
"--port=".concat(port),
|
129 |
+
"--FileContentsManager.root_dir=".concat(appSettings.datalabRoot, "/"),
|
130 |
+
// TODO(b/136659627): Delete this line.
|
131 |
+
"--MappingKernelManager.root_dir=".concat(contentDir),
|
132 |
+
]);
|
133 |
+
var jupyterServerAddr = 'localhost';
|
134 |
+
try {
|
135 |
+
for (var jupyterArgs_1 = __values(jupyterArgs), jupyterArgs_1_1 = jupyterArgs_1.next(); !jupyterArgs_1_1.done; jupyterArgs_1_1 = jupyterArgs_1.next()) {
|
136 |
+
var flag = jupyterArgs_1_1.value;
|
137 |
+
// Extracts a string like '1.2.3.4' from the string '--ip=1.2.3.4'
|
138 |
+
var match = flag.match(/--ip=([^ ]+)/);
|
139 |
+
if (match) {
|
140 |
+
jupyterServerAddr = match[1];
|
141 |
+
break;
|
142 |
+
}
|
143 |
+
}
|
144 |
+
}
|
145 |
+
catch (e_2_1) { e_2 = { error: e_2_1 }; }
|
146 |
+
finally {
|
147 |
+
try {
|
148 |
+
if (jupyterArgs_1_1 && !jupyterArgs_1_1.done && (_a = jupyterArgs_1.return)) _a.call(jupyterArgs_1);
|
149 |
+
}
|
150 |
+
finally { if (e_2) throw e_2.error; }
|
151 |
+
}
|
152 |
+
logging.getLogger().info('Using jupyter server address %s', jupyterServerAddr);
|
153 |
+
var processOptions = {
|
154 |
+
detached: false,
|
155 |
+
env: process.env,
|
156 |
+
};
|
157 |
+
var serverProcess = childProcess.spawn('jupyter', processArgs, processOptions);
|
158 |
+
serverProcess.on('exit', exitHandler);
|
159 |
+
logging.getLogger().info('Jupyter process started with pid %d and args %j', serverProcess.pid, processArgs);
|
160 |
+
// Capture the output, so it can be piped for logging.
|
161 |
+
pipeOutput(serverProcess.stdout);
|
162 |
+
pipeOutput(serverProcess.stderr);
|
163 |
+
// Create the proxy.
|
164 |
+
var proxyTargetHost = appSettings.kernelManagerProxyHost || jupyterServerAddr;
|
165 |
+
var proxyTargetPort = appSettings.kernelManagerProxyPort || port;
|
166 |
+
var proxy = httpProxy.createProxyServer({ target: "http://".concat(proxyTargetHost, ":").concat(proxyTargetPort) });
|
167 |
+
proxy.on('error', errorHandler);
|
168 |
+
jupyterServer = { port: port, proxy: proxy, childProcess: serverProcess };
|
169 |
+
}
|
170 |
+
/**
|
171 |
+
* Initializes the Jupyter server manager.
|
172 |
+
*/
|
173 |
+
function init(settings) {
|
174 |
+
appSettings = settings;
|
175 |
+
createJupyterServer();
|
176 |
+
}
|
177 |
+
exports.init = init;
|
178 |
+
/**
|
179 |
+
* Closes the Jupyter server manager.
|
180 |
+
*/
|
181 |
+
function close() {
|
182 |
+
if (!jupyterServer) {
|
183 |
+
return;
|
184 |
+
}
|
185 |
+
var pid = jupyterServer.childProcess.pid;
|
186 |
+
logging.getLogger().info("jupyter close: PID: ".concat(pid));
|
187 |
+
jupyterServer.childProcess.kill('SIGHUP');
|
188 |
+
}
|
189 |
+
exports.close = close;
|
190 |
+
/** Proxy this socket request to jupyter. */
|
191 |
+
function handleSocket(request, socket, head) {
|
192 |
+
if (!jupyterServer) {
|
193 |
+
logging.getLogger().error('Jupyter server is not running.');
|
194 |
+
return;
|
195 |
+
}
|
196 |
+
jupyterServer.proxy.ws(request, socket, head);
|
197 |
+
}
|
198 |
+
exports.handleSocket = handleSocket;
|
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 |
+
exports.handleRequest = handleRequest;
|
209 |
+
function errorHandler(error, request, response) {
|
210 |
+
logging.getLogger().error(error, 'Jupyter server returned error.');
|
211 |
+
response.writeHead(500, 'Internal Server Error');
|
212 |
+
response.end();
|
213 |
+
}
|
214 |
+
//# 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"]}
|
web/logging.js
ADDED
@@ -0,0 +1,130 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
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.initializeLoggers = exports.logRequest = exports.getJupyterLogger = exports.getLogger = void 0;
|
30 |
+
var bunyan = require("bunyan");
|
31 |
+
var path = require("path");
|
32 |
+
// We import the bunyan-rotating-file-stream package, which exports a
|
33 |
+
// constructor as a single object; we use lint disables here to make the usage
|
34 |
+
// below look reasonable.
|
35 |
+
//
|
36 |
+
// tslint:disable-next-line:no-require-imports variable-name enforce-name-casing
|
37 |
+
var RotatingFileStream = require('bunyan-rotating-file-stream');
|
38 |
+
var logger = null;
|
39 |
+
var requestLogger = null;
|
40 |
+
var jupyterLogger = null;
|
41 |
+
/**
|
42 |
+
* Gets the logger for generating debug logs.
|
43 |
+
* @returns the logger configured for debugging logging.
|
44 |
+
*/
|
45 |
+
function getLogger() {
|
46 |
+
return logger;
|
47 |
+
}
|
48 |
+
exports.getLogger = getLogger;
|
49 |
+
/**
|
50 |
+
* Gets the logger for generating Jupyter logs.
|
51 |
+
* @returns the logger configured for Jupyter logging.
|
52 |
+
*/
|
53 |
+
function getJupyterLogger() {
|
54 |
+
return jupyterLogger;
|
55 |
+
}
|
56 |
+
exports.getJupyterLogger = getJupyterLogger;
|
57 |
+
/**
|
58 |
+
* Logs a request and the corresponding response.
|
59 |
+
* @param request the request to be logged.
|
60 |
+
* @param response the response to be logged.
|
61 |
+
*/
|
62 |
+
function logRequest(request, response) {
|
63 |
+
requestLogger.debug({ url: request.url, method: request.method }, 'Received a new request');
|
64 |
+
response.on('finish', function () {
|
65 |
+
requestLogger.debug({
|
66 |
+
url: request.url,
|
67 |
+
method: request.method,
|
68 |
+
status: response.statusCode
|
69 |
+
});
|
70 |
+
});
|
71 |
+
}
|
72 |
+
exports.logRequest = logRequest;
|
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 |
+
exports.initializeLoggers = initializeLoggers;
|
130 |
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nZ2luZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3RoaXJkX3BhcnR5L2NvbGFiL3NvdXJjZXMvbG9nZ2luZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7Ozs7Ozs7Ozs7O0dBY0c7Ozs7Ozs7Ozs7Ozs7O0FBRUgsK0JBQWlDO0FBRWpDLDJCQUE2QjtBQUk3QixxRUFBcUU7QUFDckUsOEVBQThFO0FBQzlFLHlCQUF5QjtBQUN6QixFQUFFO0FBQ0YsZ0ZBQWdGO0FBQ2hGLElBQU0sa0JBQWtCLEdBQUcsT0FBTyxDQUFDLDZCQUE2QixDQUFDLENBQUM7QUFFbEUsSUFBSSxNQUFNLEdBQXdCLElBQUksQ0FBQztBQUN2QyxJQUFJLGFBQWEsR0FBd0IsSUFBSSxDQUFDO0FBQzlDLElBQUksYUFBYSxHQUF3QixJQUFJLENBQUM7QUFFOUM7OztHQUdHO0FBQ0gsU0FBZ0IsU0FBUztJQUN2QixPQUFPLE1BQU8sQ0FBQztBQUNqQixDQUFDO0FBRkQsOEJBRUM7QUFFRDs7O0dBR0c7QUFDSCxTQUFnQixnQkFBZ0I7SUFDOUIsT0FBTyxhQUFjLENBQUM7QUFDeEIsQ0FBQztBQUZELDRDQUVDO0FBRUQ7Ozs7R0FJRztBQUNILFNBQWdCLFVBQVUsQ0FDdEIsT0FBNkIsRUFBRSxRQUE2QjtJQUM5RCxhQUFjLENBQUMsS0FBSyxDQUNoQixFQUFDLEdBQUcsRUFBRSxPQUFPLENBQUMsR0FBRyxFQUFFLE1BQU0sRUFBRSxPQUFPLENBQUMsTUFBTSxFQUFDLEVBQUUsd0JBQXdCLENBQUMsQ0FBQztJQUMxRSxRQUFRLENBQUMsRUFBRSxDQUFDLFFBQVEsRUFBRTtRQUNwQixhQUFjLENBQUMsS0FBSyxDQUFDO1lBQ25CLEdBQUcsRUFBRSxPQUFPLENBQUMsR0FBRztZQUNoQixNQUFNLEVBQUUsT0FBTyxDQUFDLE1BQU07WUFDdEIsTUFBTSxFQUFFLFFBQVEsQ0FBQyxVQUFVO1NBQzVCLENBQUMsQ0FBQztJQUNMLENBQUMsQ0FBQyxDQUFDO0FBQ0wsQ0FBQztBQVhELGdDQVdDO0FBRUQ7O0dBRUc7QUFDSCxTQUFnQixpQkFBaUIsQ0FBQyxRQUFxQjs7SUFDckQsdUNBQXVDO0lBQ3ZDLDhFQUE4RTtJQUM5RSxnREFBZ0Q7SUFDaEQsOEVBQThFO0lBQzlFLDhFQUE4RTtJQUM5RSw2RUFBNkU7SUFDN0UsNkVBQTZFO0lBQzdFLGlDQUFpQztJQUNqQyxFQUFFO0lBQ0YsOEJBQThCO0lBQzlCLHdGQUF3RjtJQUN4RixJQUFNLGNBQWMsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxXQUFXLEVBQUUsb0JBQW9CLENBQUMsQ0FBQztJQUM3RSxNQUFNLEdBQUcsTUFBTSxDQUFDLFlBQVksQ0FBQztRQUMzQixJQUFJLEVBQUUsS0FBSztRQUNYLE9BQU8sRUFBRTtZQUNQLEVBQUMsS0FBSyxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxPQUFPLENBQUMsTUFBTSxFQUFDO1NBQ3pEO0tBQ0YsQ0FBQyxDQUFDO0lBQ0gsYUFBYSxHQUFHLE1BQU0sQ0FBQyxLQUFLLENBQUMsRUFBQyxJQUFJLEVBQUUsU0FBUyxFQUFDLENBQUMsQ0FBQztJQUNoRCxhQUFhLEdBQUcsTUFBTSxDQUFDLEtBQUssQ0FBQztRQUMzQixJQUFJLEVBQUUsU0FBUztRQUNmLE9BQU8sRUFBRSxDQUFDO2dCQUNSLEtBQUssRUFBRSxNQUFNO2dCQUNiLElBQUksRUFBRSxRQUFRO2dCQUNkLE1BQU0sRUFBRSxJQUFJLGtCQUFrQixDQUFDO29CQUM3QixJQUFJLEVBQUUsY0FBYztvQkFDcEIsY0FBYyxFQUFFLEtBQUs7b0JBQ3JCLFNBQVMsRUFBRSxJQUFJO29CQUNmLFNBQVMsRUFBRSxLQUFLO2lCQUNqQixDQUFDO2FBQ0gsQ0FBQztLQUNILENBQUMsQ0FBQztJQUNILDBFQUEwRTtJQUMxRSwyQ0FBMkM7SUFDM0MsSUFBSSxPQUFPLENBQUMsR0FBRyxDQUFDLGdDQUFnQyxDQUFDLEtBQUssR0FBRyxFQUFFLENBQUM7O1lBQzFELEtBQW1CLElBQUEsS0FBQSxTQUFBLENBQUMsTUFBTSxFQUFFLGFBQWEsRUFBRSxhQUFhLENBQUMsQ0FBQSxnQkFBQSw0QkFBRSxDQUFDO2dCQUF2RCxJQUFNLElBQUksV0FBQTtnQkFDYixPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUM7Z0JBQy9CLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUM3QixDQUFDOzs7Ozs7Ozs7SUFDSCxDQUFDO0FBQ0gsQ0FBQztBQXpDRCw4Q0F5Q0MiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogQ29weXJpZ2h0IDIwMTUgR29vZ2xlIEluYy4gQWxsIHJpZ2h0cyByZXNlcnZlZC5cbiAqXG4gKiBMaWNlbnNlZCB1bmRlciB0aGUgQXBhY2hlIExpY2Vuc2UsIFZlcnNpb24gMi4wICh0aGUgXCJMaWNlbnNlXCIpOyB5b3UgbWF5IG5vdFxuICogdXNlIHRoaXMgZmlsZSBleGNlcHQgaW4gY29tcGxpYW5jZSB3aXRoIHRoZSBMaWNlbnNlLiBZb3UgbWF5IG9idGFpbiBhIGNvcHkgb2ZcbiAqIHRoZSBMaWNlbnNlIGF0XG4gKlxuICogaHR0cDovL3d3dy5hcGFjaGUub3JnL2xpY2Vuc2VzL0xJQ0VOU0UtMi4wXG4gKlxuICogVW5sZXNzIHJlcXVpcmVkIGJ5IGFwcGxpY2FibGUgbGF3IG9yIGFncmVlZCB0byBpbiB3cml0aW5nLCBzb2Z0d2FyZVxuICogZGlzdHJpYnV0ZWQgdW5kZXIgdGhlIExpY2Vuc2UgaXMgZGlzdHJpYnV0ZWQgb24gYW4gXCJBUyBJU1wiIEJBU0lTLCBXSVRIT1VUXG4gKiBXQVJSQU5USUVTIE9SIENPTkRJVElPTlMgT0YgQU5ZIEtJTkQsIGVpdGhlciBleHByZXNzIG9yIGltcGxpZWQuIFNlZSB0aGVcbiAqIExpY2Vuc2UgZm9yIHRoZSBzcGVjaWZpYyBsYW5ndWFnZSBnb3Zlcm5pbmcgcGVybWlzc2lvbnMgYW5kIGxpbWl0YXRpb25zIHVuZGVyXG4gKiB0aGUgTGljZW5zZS5cbiAqL1xuXG5pbXBvcnQgKiBhcyBidW55YW4gZnJvbSAnYnVueWFuJztcbmltcG9ydCAqIGFzIGh0dHAgZnJvbSAnaHR0cCc7XG5pbXBvcnQgKiBhcyBwYXRoIGZyb20gJ3BhdGgnO1xuXG5pbXBvcnQge0FwcFNldHRpbmdzfSBmcm9tICcuL2FwcFNldHRpbmdzJztcblxuLy8gV2UgaW1wb3J0IHRoZSBidW55YW4tcm90YXRpbmctZmlsZS1zdHJlYW0gcGFja2FnZSwgd2hpY2ggZXhwb3J0cyBhXG4vLyBjb25zdHJ1Y3RvciBhcyBhIHNpbmdsZSBvYmplY3Q7IHdlIHVzZSBsaW50IGRpc2FibGVzIGhlcmUgdG8gbWFrZSB0aGUgdXNhZ2Vcbi8vIGJlbG93IGxvb2sgcmVhc29uYWJsZS5cbi8vXG4vLyB0c2xpbnQ6ZGlzYWJsZS1uZXh0LWxpbmU6bm8tcmVxdWlyZS1pbXBvcnRzIHZhcmlhYmxlLW5hbWUgZW5mb3JjZS1uYW1lLWNhc2luZ1xuY29uc3QgUm90YXRpbmdGaWxlU3RyZWFtID0gcmVxdWlyZSgnYnVueWFuLXJvdGF0aW5nLWZpbGUtc3RyZWFtJyk7XG5cbmxldCBsb2dnZXI6IGJ1bnlhbi5JTG9nZ2VyfG51bGwgPSBudWxsO1xubGV0IHJlcXVlc3RMb2dnZXI6IGJ1bnlhbi5JTG9nZ2VyfG51bGwgPSBudWxsO1xubGV0IGp1cHl0ZXJMb2dnZXI6IGJ1bnlhbi5JTG9nZ2VyfG51bGwgPSBudWxsO1xuXG4vKipcbiAqIEdldHMgdGhlIGxvZ2dlciBmb3IgZ2VuZXJhdGluZyBkZWJ1ZyBsb2dzLlxuICogQHJldHVybnMgdGhlIGxvZ2dlciBjb25maWd1cmVkIGZvciBkZWJ1Z2dpbmcgbG9nZ2luZy5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGdldExvZ2dlcigpOiBidW55YW4uSUxvZ2dlciB7XG4gIHJldHVybiBsb2dnZXIhO1xufVxuXG4vKipcbiAqIEdldHMgdGhlIGxvZ2dlciBmb3IgZ2VuZXJhdGluZyBKdXB5dGVyIGxvZ3MuXG4gKiBAcmV0dXJucyB0aGUgbG9nZ2VyIGNvbmZpZ3VyZWQgZm9yIEp1cHl0ZXIgbG9nZ2luZy5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGdldEp1cHl0ZXJMb2dnZXIoKTogYnVueWFuLklMb2dnZXIge1xuICByZXR1cm4ganVweXRlckxvZ2dlciE7XG59XG5cbi8qKlxuICogTG9ncyBhIHJlcXVlc3QgYW5kIHRoZSBjb3JyZXNwb25kaW5nIHJlc3BvbnNlLlxuICogQHBhcmFtIHJlcXVlc3QgdGhlIHJlcXVlc3QgdG8gYmUgbG9nZ2VkLlxuICogQHBhcmFtIHJlc3BvbnNlIHRoZSByZXNwb25zZSB0byBiZSBsb2dnZWQuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBsb2dSZXF1ZXN0KFxuICAgIHJlcXVlc3Q6IGh0dHAuSW5jb21pbmdNZXNzYWdlLCByZXNwb25zZTogaHR0cC5TZXJ2ZXJSZXNwb25zZSk6IHZvaWQge1xuICByZXF1ZXN0TG9nZ2VyIS5kZWJ1ZyhcbiAgICAgIHt1cmw6IHJlcXVlc3QudXJsLCBtZXRob2Q6IHJlcXVlc3QubWV0aG9kfSwgJ1JlY2VpdmVkIGEgbmV3IHJlcXVlc3QnKTtcbiAgcmVzcG9uc2Uub24oJ2ZpbmlzaCcsICgpID0+IHtcbiAgICByZXF1ZXN0TG9nZ2VyIS5kZWJ1Zyh7XG4gICAgICB1cmw6IHJlcXVlc3QudXJsLFxuICAgICAgbWV0aG9kOiByZXF1ZXN0Lm1ldGhvZCxcbiAgICAgIHN0YXR1czogcmVzcG9uc2Uuc3RhdHVzQ29kZVxuICAgIH0pO1xuICB9KTtcbn1cblxuLyoqXG4gKiBJbml0aWFsaXplcyBsb2dnZXJzIHVzZWQgd2l0aGluIHRoZSBhcHBsaWNhdGlvbi5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGluaXRpYWxpemVMb2dnZXJzKHNldHRpbmdzOiBBcHBTZXR0aW5ncyk6IHZvaWQge1xuICAvLyBXZSBjb25maWd1cmUgb3VyIGxvZ2dlcnMgYXMgZm9sbG93czpcbiAgLy8gICogb3VyIGJhc2UgbG9nZ2VyIHRhZ3MgYWxsIGxvZyByZWNvcmRzIHdpdGggYFwibmFtZVwiOlwiYXBwXCJgLCBhbmQgc2VuZHMgbG9nc1xuICAvLyAgICB0byBzdGRlcnIgKGluY2x1ZGluZyBsb2dzIG9mIGFsbCBjaGlsZHJlbilcbiAgLy8gICogb25lIGNoaWxkIGxvZ2dlciBhZGRzIGBcInR5cGVcIjpcInJlcXVlc3RcImAsIGFuZCByZWNvcmRzIG1ldGhvZC9VUkwgZm9yIGFsbFxuICAvLyAgICBIVFRQIHJlcXVlc3RzIHRvIHRoZSBhcHAsIGFuZCBtZXRob2QvVVJML3Jlc3BvbnNlIGNvZGUgZm9yIGFsbCByZXNwb25zZXNcbiAgLy8gICogb25lIGNoaWxkIGxvZ2dlciBhZGRzIGBcInR5cGVcIjpcImp1cHl0ZXJcImAsIGFuZCByZWNvcmRzIGFsbCBtZXNzYWdlcyBmcm9tXG4gIC8vICAgIHRoZSBqdXB5dGVyIG5vdGVib29rIHNlcnZlci4gVGhlc2UgbG9ncyBhcmUgYWxzbyBzZW50IHRvIGEgZmlsZSBvbiBkaXNrXG4gIC8vICAgICh0byBhc3Npc3QgdXNlciBkZWJ1Z2dpbmcpLlxuICAvL1xuICAvLyBGb3IgbW9yZSBhYm91dCBidW55YW4sIHNlZTpcbiAgLy8gICBodHRwczovL2dpdGh1Yi5jb20vdHJlbnRtL25vZGUtYnVueWFuL3RyZWUvZjIxMDA3ZDQ2YzBlNjQwNzI2MTczODBiNzBkM2Y1NDIzNjgzMThhOFxuICBjb25zdCBqdXB5dGVyTG9nUGF0aCA9IHBhdGguam9pbihzZXR0aW5ncy5kYXRhbGFiUm9vdCwgJy92YXIvY29sYWIvYXBwLmxvZycpO1xuICBsb2dnZXIgPSBidW55YW4uY3JlYXRlTG9nZ2VyKHtcbiAgICBuYW1lOiAnYXBwJyxcbiAgICBzdHJlYW1zOiBbXG4gICAgICB7bGV2ZWw6ICdkZWJ1ZycsIHR5cGU6ICdzdHJlYW0nLCBzdHJlYW06IHByb2Nlc3Muc3RkZXJyfSxcbiAgICBdXG4gIH0pO1xuICByZXF1ZXN0TG9nZ2VyID0gbG9nZ2VyLmNoaWxkKHt0eXBlOiAncmVxdWVzdCd9KTtcbiAganVweXRlckxvZ2dlciA9IGxvZ2dlci5jaGlsZCh7XG4gICAgdHlwZTogJ2p1cHl0ZXInLFxuICAgIHN0cmVhbXM6IFt7XG4gICAgICBsZXZlbDogJ2luZm8nLFxuICAgICAgdHlwZTogJ3N0cmVhbScsXG4gICAgICBzdHJlYW06IG5ldyBSb3RhdGluZ0ZpbGVTdHJlYW0oe1xuICAgICAgICBwYXRoOiBqdXB5dGVyTG9nUGF0aCxcbiAgICAgICAgcm90YXRlRXhpc3Rpbmc6IGZhbHNlLFxuICAgICAgICB0aHJlc2hvbGQ6ICcybScsXG4gICAgICAgIHRvdGFsU2l6ZTogJzIwbSdcbiAgICAgIH0pLFxuICAgIH1dXG4gIH0pO1xuICAvLyBPbWl0IHN1cGVyZmx1b3VzIGZpZWxkcywgdW5sZXNzIHVzaW5nIHRoZSBidW55YW4gQ0xJIHRvIG1ha2UgbG9ncyBodW1hblxuICAvLyByZWFkYWJsZSwgYmVjYXVzZSB0aGUgQ0xJIHJlcXVpcmVzIHRoZW0uXG4gIGlmIChwcm9jZXNzLmVudlsnQ09MQUJfSFVNQU5fUkVBREFCTEVfTk9ERV9MT0dTJ10gIT09ICcxJykge1xuICAgIGZvciAoY29uc3QgbG9ncyBvZiBbbG9nZ2VyLCBqdXB5dGVyTG9nZ2VyLCByZXF1ZXN0TG9nZ2VyXSkge1xuICAgICAgZGVsZXRlIGxvZ3MuZmllbGRzWydob3N0bmFtZSddO1xuICAgICAgZGVsZXRlIGxvZ3MuZmllbGRzWyduYW1lJ107XG4gICAgfVxuICB9XG59XG4iXX0=
|
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FwYWJpbGl0aWVzX25vZGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9nZW5maWxlcy90aGlyZF9wYXJ0eS9jb2xhYi9zb3VyY2VzL2xzcC9jYXBhYmlsaXRpZXNfbm9kZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgcHJvdG9jb2wgZnJvbSAnLi9wcm90b2NvbF9ub2RlJztcbmltcG9ydCAqIGFzIHRleHREb2N1bWVudCBmcm9tICcuL3RleHRfZG9jdW1lbnRfbm9kZSc7XG5pbXBvcnQgKiBhcyB3b3Jrc3BhY2UgZnJvbSAnLi93b3Jrc3BhY2Vfbm9kZSc7XG5cbmludGVyZmFjZSBDbGllbnRDYXBhYmlsaXRpZXMge1xuICAvKipcbiAgICogV29ya3NwYWNlIHNwZWNpZmljIGNsaWVudCBjYXBhYmlsaXRpZXMuXG4gICAqL1xuICB3b3Jrc3BhY2U/OiB7XG4gICAgLyoqXG4gICAgICogVGhlIGNsaWVudCBzdXBwb3J0cyBhcHBseWluZyBiYXRjaCBlZGl0c1xuICAgICAqIHRvIHRoZSB3b3Jrc3BhY2UgYnkgc3VwcG9ydGluZyB0aGUgcmVxdWVzdFxuICAgICAqICd3b3Jrc3BhY2UvYXBwbHlFZGl0J1xuICAgICAqL1xuICAgIGFwcGx5RWRpdD86IGJvb2xlYW47XG5cbiAgICAvKipcbiAgICAgKiBDYXBhYmlsaXRpZXMgc3BlY2lmaWMgdG8gYFdvcmtzcGFjZUVkaXRgc1xuICAgICAqL1xuICAgIHdvcmtzcGFjZUVkaXQ/OiBwcm90b2NvbC5Xb3Jrc3BhY2VFZGl0Q2xpZW50Q2FwYWJpbGl0aWVzO1xuXG4gICAgLyoqXG4gICAgICogQ2FwYWJpbGl0aWVzIHNwZWNpZmljIHRvIHRoZSBgd29ya3NwYWNlL2RpZENoYW5nZUNvbmZpZ3VyYXRpb25gXG4gICAgICogbm90aWZpY2F0aW9uLlxuICAgICAqL1xuICAgIGRpZENoYW5nZUNvbmZpZ3VyYXRpb24/OiB3b3Jrc3BhY2UuRGlkQ2hhbmdlQ29uZmlndXJhdGlvbkNsaWVudENhcGFiaWxpdGllcztcblxuICAgIC8qKlxuICAgICAqIENhcGFiaWxpdGllcyBzcGVjaWZpYyB0byB0aGUgYHdvcmtzcGFjZS9kaWRDaGFuZ2VXYXRjaGVkRmlsZXNgXG4gICAgICogbm90aWZpY2F0aW9uLlxuICAgICAqL1xuICAgIGRpZENoYW5nZVdhdGNoZWRGaWxlcz86IHdvcmtzcGFjZS5EaWRDaGFuZ2VXYXRjaGVkRmlsZXNDbGllbnRDYXBhYmlsaXRpZXM7XG5cbiAgICAvKipcbiAgICAgKiBDYXBhYmlsaXRpZXMgc3BlY2lmaWMgdG8gdGhlIGB3b3Jrc3BhY2Uvc3ltYm9sYCByZXF1ZXN0LlxuICAgICAqL1xuICAgIHN5bWJvbD86IHdvcmtzcGFjZS5Xb3Jrc3BhY2VTeW1ib2xDbGllbnRDYXBhYmlsaXRpZXM7XG5cbiAgICAvKipcbiAgICAgKiBDYXBhYmlsaXRpZXMgc3BlY2lmaWMgdG8gdGhlIGB3b3Jrc3BhY2UvZXhlY3V0ZUNvbW1hbmRgIHJlcXVlc3QuXG4gICAgICovXG4gICAgZXhlY3V0ZUNvbW1hbmQ/OiBwcm90b2NvbC5FeGVjdXRlQ29tbWFuZENsaWVudENhcGFiaWxpdGllcztcblxuICAgIC8qKlxuICAgICAqIFRoZSBjbGllbnQgaGFzIHN1cHBvcnQgZm9yIHdvcmtzcGFjZSBmb2xkZXJzLlxuICAgICAqXG4gICAgICogU2luY2UgMy42LjBcbiAgICAgKi9cbiAgICB3b3Jrc3BhY2VGb2xkZXJzPzogYm9vbGVhbjtcblxuICAgIC8qKlxuICAgICAqIFRoZSBjbGllbnQgc3VwcG9ydHMgYHdvcmtzcGFjZS9jb25maWd1cmF0aW9uYCByZXF1ZXN0cy5cbiAgICAgKlxuICAgICAqIFNpbmNlIDMuNi4wXG4gICAgICovXG4gICAgY29uZmlndXJhdGlvbj86IGJvb2xlYW47XG4gIH07XG5cbiAgLyoqXG4gICAqIFRleHQgZG9jdW1lbnQgc3BlY2lmaWMgY2xpZW50IGNhcGFiaWxpdGllcy5cbiAgICovXG4gIHRleHREb2N1bWVudD86IHRleHREb2N1bWVudC5UZXh0RG9jdW1lbnRDbGllbnRDYXBhYmlsaXRpZXM7XG5cbiAgLyoqXG4gICAqIFdpbmRvdyBzcGVjaWZpYyBjbGllbnQgY2FwYWJpbGl0aWVzLlxuICAgKi9cbiAgd2luZG93Pzoge1xuICAgIC8qKlxuICAgICAqIFdoZXRoZXIgY2xpZW50IHN1cHBvcnRzIGhhbmRsaW5nIHByb2dyZXNzIG5vdGlmaWNhdGlvbnMuXG4gICAgICogSWYgc2V0LCBzZXJ2ZXJzIGFyZSBhbGxvd2VkIHRvIHJlcG9ydCBpbiBgd29ya0RvbmVQcm9ncmVzc2AgcHJvcGVydHlcbiAgICAgKiBpbiB0aGUgcmVxdWVzdCBzcGVjaWZpYyBzZXJ2ZXIgY2FwYWJpbGl0aWVzLlxuICAgICAqXG4gICAgICogU2luY2UgMy4xNS4wXG4gICAgICovXG4gICAgd29ya0RvbmVQcm9ncmVzcz86IGJvb2xlYW47XG4gIH07XG5cbiAgLyoqXG4gICAqIEV4cGVyaW1lbnRhbCBjbGllbnQgY2FwYWJpbGl0aWVzLlxuICAgKi9cbiAgZXhwZXJpbWVudGFsPzogdW5rbm93bjtcbn1cblxuLyoqXG4gKiBodHRwczovL21pY3Jvc29mdC5naXRodWIuaW8vbGFuZ3VhZ2Utc2VydmVyLXByb3RvY29sL3NwZWNpZmljYXRpb25zL3NwZWNpZmljYXRpb24tY3VycmVudC8jaW5pdGlhbGl6ZVxuICovXG5leHBvcnQgZGVjbGFyZSBpbnRlcmZhY2UgSW5pdGlhbGl6ZSBleHRlbmRzXG4gICAgcHJvdG9jb2wuUmVxdWVzdE1lc3NhZ2U8SW5pdGlhbGl6ZVBhcmFtcz4ge1xuICBtZXRob2Q6IHByb3RvY29sLk1ldGhvZC5Jbml0aWFsaXplO1xufVxuXG4vKipcbiAqIGh0dHBzOi8vbWljcm9zb2Z0LmdpdGh1Yi5pby9sYW5ndWFnZS1zZXJ2ZXItcHJvdG9jb2wvc3BlY2lmaWNhdGlvbnMvc3BlY2lmaWNhdGlvbi1jdXJyZW50LyNpbml0aWFsaXplXG4gKi9cbmV4cG9ydCBkZWNsYXJlIGludGVyZmFjZSBJbml0aWFsaXplUGFyYW1zIGV4dGVuZHNcbiAgICBwcm90b2NvbC5Xb3JrRG9uZVByb2dyZXNzUGFyYW1zIHtcbiAgLyoqXG4gICAqIFRoZSBwcm9jZXNzIElEIG9mIHRoZSBwYXJlbnQgcHJvY2VzcyB0aGF0IHN0YXJ0ZWQgdGhlIHNlcnZlci5cbiAgICogSXMgbnVsbCBpZiB0aGUgcHJvY2VzcyBoYXMgbm90IGJlZW4gc3RhcnRlZCBieSBhbm90aGVyIHByb2Nlc3MuXG4gICAqIElmIHRoZSBwYXJlbnQgcHJvY2VzcyBpcyBub3QgYWxpdmUsIHRoZW4gdGhlIHNlcnZlciBzaG91bGQgZXhpdFxuICAgKiAoc2VlIGV4aXQgbm90aWZpY2F0aW9uKSBpdHMgcHJvY2Vzcy5cbiAgICovXG4gIHByb2Nlc3NJZDogbnVtYmVyfG51bGw7XG5cbiAgLyoqXG4gICAqIEluZm9ybWF0aW9uIGFib3V0IHRoZSBjbGllbnRcbiAgICpcbiAgICogQHNpbmNlIDMuMTUuMFxuICAgKi9cbiAgY2xpZW50SW5mbz86IHtcbiAgICAvKipcbiAgICAgKiBUaGUgbmFtZSBvZiB0aGUgY2xpZW50IGFzIGRlZmluZWQgYnkgdGhlIGNsaWVudC5cbiAgICAgKi9cbiAgICBuYW1lOiBzdHJpbmc7XG5cbiAgICAvKipcbiAgICAgKiBUaGUgY2xpZW50J3MgdmVyc2lvbiBhcyBkZWZpbmVkIGJ5IHRoZSBjbGllbnQuXG4gICAgICovXG4gICAgdmVyc2lvbj86IHN0cmluZztcbiAgfTtcblxuICAvKipcbiAgICogVGhlIHJvb3RQYXRoIG9mIHRoZSB3b3Jrc3BhY2UuIElzIG51bGxcbiAgICogaWYgbm8gZm9sZGVyIGlzIG9wZW4uXG4gICAqXG4gICAqIEBkZXByZWNhdGVkIGluIGZhdm91ciBvZiByb290VXJpLlxuICAgKi9cbiAgcm9vdFBhdGg/OiBzdHJpbmd8bnVsbDtcblxuICAvKipcbiAgICogVGhlIHJvb3RVcmkgb2YgdGhlIHdvcmtzcGFjZS4gSXMgbnVsbCBpZiBub1xuICAgKiBmb2xkZXIgaXMgb3Blbi4gSWYgYm90aCBgcm9vdFBhdGhgIGFuZCBgcm9vdFVyaWAgYXJlIHNldFxuICAgKiBgcm9vdFVyaWAgd2lucy5cbiAgICovXG4gIHJvb3RVcmk6IHByb3RvY29sLkRvY3VtZW50VXJpfG51bGw7XG5cbiAgLyoqXG4gICAqIFVzZXIgcHJvdmlkZWQgaW5pdGlhbGl6YXRpb24gb3B0aW9ucy5cbiAgICovXG4gIGluaXRpYWxpemF0aW9uT3B0aW9ucz86IHVua25vd247XG5cbiAgLyoqXG4gICAqIFRoZSBjYXBhYmlsaXRpZXMgcHJvdmlkZWQgYnkgdGhlIGNsaWVudCAoZWRpdG9yIG9yIHRvb2wpXG4gICAqL1xuICBjYXBhYmlsaXRpZXM6IENsaWVudENhcGFiaWxpdGllcztcblxuICAvKipcbiAgICogVGhlIGluaXRpYWwgdHJhY2Ugc2V0dGluZy4gSWYgb21pdHRlZCB0cmFjZSBpcyBkaXNhYmxlZCAoJ29mZicpLlxuICAgKi9cbiAgdHJhY2U/OiAnb2ZmJ3wnbWVzc2FnZXMnfCd2ZXJib3NlJztcblxuICAvKipcbiAgICogVGhlIHdvcmtzcGFjZSBmb2xkZXJzIGNvbmZpZ3VyZWQgaW4gdGhlIGNsaWVudCB3aGVuIHRoZSBzZXJ2ZXIgc3RhcnRzLlxuICAgKiBUaGlzIHByb3BlcnR5IGlzIG9ubHkgYXZhaWxhYmxlIGlmIHRoZSBjbGllbnQgc3VwcG9ydHMgd29ya3NwYWNlIGZvbGRlcnMuXG4gICAqIEl0IGNhbiBiZSBgbnVsbGAgaWYgdGhlIGNsaWVudCBzdXBwb3J0cyB3b3Jrc3BhY2UgZm9sZGVycyBidXQgbm9uZSBhcmVcbiAgICogY29uZmlndXJlZC5cbiAgICpcbiAgICogQHNpbmNlIDMuNi4wXG4gICAqL1xuICB3b3Jrc3BhY2VGb2xkZXJzPzogd29ya3NwYWNlLldvcmtzcGFjZUZvbGRlcltdfG51bGw7XG59XG4iXX0=
|
web/lsp/extensions_node.js
ADDED
@@ -0,0 +1,3 @@
|
|
|
|
|
|
|
|
|
1 |
+
"use strict";
|
2 |
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3 |
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXh0ZW5zaW9uc19ub2RlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vZ2VuZmlsZXMvdGhpcmRfcGFydHkvY29sYWIvc291cmNlcy9sc3AvZXh0ZW5zaW9uc19ub2RlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJcbmltcG9ydCAqIGFzIGNhcGFiaWxpdGllcyBmcm9tICcuL2NhcGFiaWxpdGllc19ub2RlJztcbmltcG9ydCAqIGFzIHRleHREb2N1bWVudCBmcm9tICcuL3RleHRfZG9jdW1lbnRfbm9kZSc7XG5cbi8vIHRzbGludDpkaXNhYmxlOmVuZm9yY2UtbmFtZS1jYXNpbmdcblxuLyoqXG4gKiBQYXJhbWV0ZXIgZm9yIGBpbml0aWFsaXplYCBtZXNzYWdlcy5cbiAqIEFkZHMgYSBmbGFnIGNvbnRyb2xsaW5nIHdoZXRoZXIgd2UgcnVuIEF1dG9GaXguXG4gKi9cbmV4cG9ydCBkZWNsYXJlIGludGVyZmFjZSBJbml0aWFsaXplUGFyYW1zIGV4dGVuZHNcbiAgICBjYXBhYmlsaXRpZXMuSW5pdGlhbGl6ZVBhcmFtcyB7XG4gIGF1dG9GaXg6IGJvb2xlYW47XG59XG5cbi8qKlxuICogUGFyYW1ldGVyIGZvciBgdGV4dERvY3VtZW50L2RpZE9wZW5gIG1lc3NhZ2VzLlxuICogQWRkcyBhIHByZWFtYmxlIHN0cmluZy5cbiAqL1xuZXhwb3J0IGRlY2xhcmUgaW50ZXJmYWNlIERpZE9wZW5UZXh0RG9jdW1lbnRQYXJhbXMgZXh0ZW5kc1xuICAgIHRleHREb2N1bWVudC5EaWRPcGVuVGV4dERvY3VtZW50UGFyYW1zIHtcbiAgcmVhZG9ubHkgcHJlYW1ibGU6IHN0cmluZztcbn1cbiJdfQ==
|
web/lsp/protocol_node.js
ADDED
@@ -0,0 +1,186 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
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["TextDocumentPublishDiagnostics"] = "textDocument/publishDiagnostics";
|
26 |
+
Method["TextDocumentRename"] = "textDocument/rename";
|
27 |
+
Method["TextDocumentSignatureHelp"] = "textDocument/signatureHelp";
|
28 |
+
Method["WindowLogMessage"] = "window/logMessage";
|
29 |
+
Method["WorkspaceConfiguration"] = "workspace/configuration";
|
30 |
+
Method["WorkspaceDidChangeConfiguration"] = "workspace/didChangeConfiguration";
|
31 |
+
Method["WorkspaceDidChangeWatchedFiles"] = "workspace/didChangeWatchedFiles";
|
32 |
+
})(Method || (exports.Method = Method = {}));
|
33 |
+
/**
|
34 |
+
* https://microsoft.github.io/language-server-protocol/specifications/specification-current/#responseMessage
|
35 |
+
*/
|
36 |
+
var ErrorCode;
|
37 |
+
(function (ErrorCode) {
|
38 |
+
// Defined by JSON RPC
|
39 |
+
ErrorCode[ErrorCode["ParseError"] = -32700] = "ParseError";
|
40 |
+
ErrorCode[ErrorCode["InvalidRequest"] = -32600] = "InvalidRequest";
|
41 |
+
ErrorCode[ErrorCode["MethodNotFound"] = -32601] = "MethodNotFound";
|
42 |
+
ErrorCode[ErrorCode["InvalidParams"] = -32602] = "InvalidParams";
|
43 |
+
ErrorCode[ErrorCode["InternalError"] = -32603] = "InternalError";
|
44 |
+
ErrorCode[ErrorCode["ServerErrorStart"] = -32099] = "ServerErrorStart";
|
45 |
+
ErrorCode[ErrorCode["ServerErrorEnd"] = -32000] = "ServerErrorEnd";
|
46 |
+
ErrorCode[ErrorCode["ServerNotInitialized"] = -32002] = "ServerNotInitialized";
|
47 |
+
ErrorCode[ErrorCode["UnknownErrorCode"] = -32001] = "UnknownErrorCode";
|
48 |
+
// Defined by the protocol.
|
49 |
+
ErrorCode[ErrorCode["RequestCancelled"] = -32800] = "RequestCancelled";
|
50 |
+
ErrorCode[ErrorCode["ContentModified"] = -32801] = "ContentModified";
|
51 |
+
})(ErrorCode || (exports.ErrorCode = ErrorCode = {}));
|
52 |
+
/**
|
53 |
+
* The kind of resource operations supported by the client.
|
54 |
+
*/
|
55 |
+
var ResourceOperationKind;
|
56 |
+
(function (ResourceOperationKind) {
|
57 |
+
/**
|
58 |
+
* Supports creating new files and folders.
|
59 |
+
*/
|
60 |
+
ResourceOperationKind["CREATE"] = "create";
|
61 |
+
/**
|
62 |
+
* Supports renaming existing files and folders.
|
63 |
+
*/
|
64 |
+
ResourceOperationKind["RENAME"] = "rename";
|
65 |
+
/**
|
66 |
+
* Supports deleting existing files and folders.
|
67 |
+
*/
|
68 |
+
ResourceOperationKind["DELETE"] = "delete";
|
69 |
+
})(ResourceOperationKind || (exports.ResourceOperationKind = ResourceOperationKind = {}));
|
70 |
+
/**
|
71 |
+
* https://microsoft.github.io/language-server-protocol/specifications/specification-current/#workspaceEditClientCapabilities
|
72 |
+
*/
|
73 |
+
var FailureHandlingKind;
|
74 |
+
(function (FailureHandlingKind) {
|
75 |
+
/**
|
76 |
+
* Applying the workspace change is simply aborted if one of the changes
|
77 |
+
* provided fails.
|
78 |
+
* All operations executed before the failing operation stay executed.
|
79 |
+
*/
|
80 |
+
FailureHandlingKind["Abort"] = "abort";
|
81 |
+
/**
|
82 |
+
* All operations are executed transactional. That means they either all
|
83 |
+
* succeed or no changes at all are applied to the workspace.
|
84 |
+
*/
|
85 |
+
FailureHandlingKind["Transactional"] = "transactional";
|
86 |
+
/**
|
87 |
+
* If the workspace edit contains only textual file changes, they are
|
88 |
+
* executed transactionally.
|
89 |
+
* If resource changes (create, rename or delete file) are part of the
|
90 |
+
* change, the failure handling strategy is abort.
|
91 |
+
*/
|
92 |
+
FailureHandlingKind["TextOnlyTransactional"] = "textOnlyTransactional";
|
93 |
+
/**
|
94 |
+
* The client tries to undo the operations already executed. But there is no
|
95 |
+
* guarantee that this is succeeding.
|
96 |
+
*/
|
97 |
+
FailureHandlingKind["Undo"] = "undo";
|
98 |
+
})(FailureHandlingKind || (exports.FailureHandlingKind = FailureHandlingKind = {}));
|
99 |
+
/**
|
100 |
+
* The diagnostic tags.
|
101 |
+
*
|
102 |
+
* @since 3.15.0
|
103 |
+
*/
|
104 |
+
var DiagnosticTag;
|
105 |
+
(function (DiagnosticTag) {
|
106 |
+
/**
|
107 |
+
* Unused or unnecessary code.
|
108 |
+
*
|
109 |
+
* Clients are allowed to render diagnostics with this tag faded out
|
110 |
+
* instead of having an error squiggle.
|
111 |
+
*/
|
112 |
+
DiagnosticTag[DiagnosticTag["Unnecessary"] = 1] = "Unnecessary";
|
113 |
+
/**
|
114 |
+
* Deprecated or obsolete code.
|
115 |
+
*
|
116 |
+
* Clients are allowed to rendered diagnostics with this tag strike through.
|
117 |
+
*/
|
118 |
+
DiagnosticTag[DiagnosticTag["Deprecated"] = 2] = "Deprecated";
|
119 |
+
})(DiagnosticTag || (exports.DiagnosticTag = DiagnosticTag = {}));
|
120 |
+
/**
|
121 |
+
* https://microsoft.github.io/language-server-protocol/specifications/specification-current/#diagnostic
|
122 |
+
*/
|
123 |
+
var DiagnosticSeverity;
|
124 |
+
(function (DiagnosticSeverity) {
|
125 |
+
/**
|
126 |
+
* Reports an error.
|
127 |
+
*/
|
128 |
+
DiagnosticSeverity[DiagnosticSeverity["Error"] = 1] = "Error";
|
129 |
+
/**
|
130 |
+
* Reports a warning.
|
131 |
+
*/
|
132 |
+
DiagnosticSeverity[DiagnosticSeverity["Warning"] = 2] = "Warning";
|
133 |
+
/**
|
134 |
+
* Reports an information.
|
135 |
+
*/
|
136 |
+
DiagnosticSeverity[DiagnosticSeverity["Information"] = 3] = "Information";
|
137 |
+
/**
|
138 |
+
* Reports a hint.
|
139 |
+
*/
|
140 |
+
DiagnosticSeverity[DiagnosticSeverity["Hint"] = 4] = "Hint";
|
141 |
+
})(DiagnosticSeverity || (exports.DiagnosticSeverity = DiagnosticSeverity = {}));
|
142 |
+
/**
|
143 |
+
* A symbol kind.
|
144 |
+
*/
|
145 |
+
var SymbolKind;
|
146 |
+
(function (SymbolKind) {
|
147 |
+
SymbolKind[SymbolKind["File"] = 1] = "File";
|
148 |
+
SymbolKind[SymbolKind["Module"] = 2] = "Module";
|
149 |
+
SymbolKind[SymbolKind["Namespace"] = 3] = "Namespace";
|
150 |
+
SymbolKind[SymbolKind["Package"] = 4] = "Package";
|
151 |
+
SymbolKind[SymbolKind["Class"] = 5] = "Class";
|
152 |
+
SymbolKind[SymbolKind["Method"] = 6] = "Method";
|
153 |
+
SymbolKind[SymbolKind["Property"] = 7] = "Property";
|
154 |
+
SymbolKind[SymbolKind["Field"] = 8] = "Field";
|
155 |
+
SymbolKind[SymbolKind["Constructor"] = 9] = "Constructor";
|
156 |
+
SymbolKind[SymbolKind["Enum"] = 10] = "Enum";
|
157 |
+
SymbolKind[SymbolKind["Interface"] = 11] = "Interface";
|
158 |
+
SymbolKind[SymbolKind["Function"] = 12] = "Function";
|
159 |
+
SymbolKind[SymbolKind["Variable"] = 13] = "Variable";
|
160 |
+
SymbolKind[SymbolKind["Constant"] = 14] = "Constant";
|
161 |
+
SymbolKind[SymbolKind["String"] = 15] = "String";
|
162 |
+
SymbolKind[SymbolKind["Number"] = 16] = "Number";
|
163 |
+
SymbolKind[SymbolKind["Boolean"] = 17] = "Boolean";
|
164 |
+
SymbolKind[SymbolKind["Array"] = 18] = "Array";
|
165 |
+
SymbolKind[SymbolKind["Object"] = 19] = "Object";
|
166 |
+
SymbolKind[SymbolKind["Key"] = 20] = "Key";
|
167 |
+
SymbolKind[SymbolKind["Null"] = 21] = "Null";
|
168 |
+
SymbolKind[SymbolKind["EnumMember"] = 22] = "EnumMember";
|
169 |
+
SymbolKind[SymbolKind["Struct"] = 23] = "Struct";
|
170 |
+
SymbolKind[SymbolKind["Event"] = 24] = "Event";
|
171 |
+
SymbolKind[SymbolKind["Operator"] = 25] = "Operator";
|
172 |
+
SymbolKind[SymbolKind["TypeParameter"] = 26] = "TypeParameter";
|
173 |
+
})(SymbolKind || (exports.SymbolKind = SymbolKind = {}));
|
174 |
+
/**
|
175 |
+
* Symbol tags are extra annotations that tweak the rendering of a symbol.
|
176 |
+
*
|
177 |
+
* @since 3.16
|
178 |
+
*/
|
179 |
+
var SymbolTag;
|
180 |
+
(function (SymbolTag) {
|
181 |
+
/**
|
182 |
+
* Render a symbol as obsolete, usually using a strike-out.
|
183 |
+
*/
|
184 |
+
SymbolTag[SymbolTag["Deprecated"] = 1] = "Deprecated";
|
185 |
+
})(SymbolTag || (exports.SymbolTag = SymbolTag = {}));
|
186 |
+
//# 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  TextDocumentPublishDiagnostics = 'textDocument/publishDiagnostics',\n  TextDocumentRename = 'textDocument/rename',\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"]}
|
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==
|
web/lsp/text_document_node.js
ADDED
@@ -0,0 +1,313 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
"use strict";
|
2 |
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3 |
+
exports.SignatureHelpTriggerKind = exports.InsertTextMode = exports.InsertTextFormat = exports.CodeActionKind = exports.TextDocumentSyncKind = exports.CompletionTriggerKind = exports.LanguageIdentifier = exports.CompletionItemKind = exports.CompletionItemTag = exports.MarkupKind = void 0;
|
4 |
+
/**
|
5 |
+
* Describes the content type that a client supports in various
|
6 |
+
* result literals like `Hover`, `ParameterInfo` or `CompletionItem`.
|
7 |
+
*
|
8 |
+
* Please note that `MarkupKinds` must not start with a `$`. This kinds
|
9 |
+
* are reserved for internal usage.
|
10 |
+
*/
|
11 |
+
var MarkupKind;
|
12 |
+
(function (MarkupKind) {
|
13 |
+
/**
|
14 |
+
* Plain text is supported as a content format
|
15 |
+
*/
|
16 |
+
MarkupKind["PlainText"] = "plaintext";
|
17 |
+
/**
|
18 |
+
* Markdown is supported as a content format
|
19 |
+
*/
|
20 |
+
MarkupKind["Markdown"] = "markdown";
|
21 |
+
})(MarkupKind || (exports.MarkupKind = MarkupKind = {}));
|
22 |
+
/**
|
23 |
+
* Completion item tags are extra annotations that tweak the rendering of
|
24 |
+
* a completion item.
|
25 |
+
*
|
26 |
+
* @since 3.15.0
|
27 |
+
*/
|
28 |
+
var CompletionItemTag;
|
29 |
+
(function (CompletionItemTag) {
|
30 |
+
/**
|
31 |
+
* Render a completion as obsolete, usually using a strike-out.
|
32 |
+
*/
|
33 |
+
CompletionItemTag[CompletionItemTag["Deprecated"] = 1] = "Deprecated";
|
34 |
+
})(CompletionItemTag || (exports.CompletionItemTag = CompletionItemTag = {}));
|
35 |
+
/**
|
36 |
+
* The kind of a completion entry.
|
37 |
+
*/
|
38 |
+
var CompletionItemKind;
|
39 |
+
(function (CompletionItemKind) {
|
40 |
+
CompletionItemKind[CompletionItemKind["Text"] = 1] = "Text";
|
41 |
+
CompletionItemKind[CompletionItemKind["Method"] = 2] = "Method";
|
42 |
+
CompletionItemKind[CompletionItemKind["Function"] = 3] = "Function";
|
43 |
+
CompletionItemKind[CompletionItemKind["Constructor"] = 4] = "Constructor";
|
44 |
+
CompletionItemKind[CompletionItemKind["Field"] = 5] = "Field";
|
45 |
+
CompletionItemKind[CompletionItemKind["Variable"] = 6] = "Variable";
|
46 |
+
CompletionItemKind[CompletionItemKind["Class"] = 7] = "Class";
|
47 |
+
CompletionItemKind[CompletionItemKind["Interface"] = 8] = "Interface";
|
48 |
+
CompletionItemKind[CompletionItemKind["Module"] = 9] = "Module";
|
49 |
+
CompletionItemKind[CompletionItemKind["Property"] = 10] = "Property";
|
50 |
+
CompletionItemKind[CompletionItemKind["Unit"] = 11] = "Unit";
|
51 |
+
CompletionItemKind[CompletionItemKind["Value"] = 12] = "Value";
|
52 |
+
CompletionItemKind[CompletionItemKind["Enum"] = 13] = "Enum";
|
53 |
+
CompletionItemKind[CompletionItemKind["Keyword"] = 14] = "Keyword";
|
54 |
+
CompletionItemKind[CompletionItemKind["Snippet"] = 15] = "Snippet";
|
55 |
+
CompletionItemKind[CompletionItemKind["Color"] = 16] = "Color";
|
56 |
+
CompletionItemKind[CompletionItemKind["File"] = 17] = "File";
|
57 |
+
CompletionItemKind[CompletionItemKind["Reference"] = 18] = "Reference";
|
58 |
+
CompletionItemKind[CompletionItemKind["Folder"] = 19] = "Folder";
|
59 |
+
CompletionItemKind[CompletionItemKind["EnumMember"] = 20] = "EnumMember";
|
60 |
+
CompletionItemKind[CompletionItemKind["Constant"] = 21] = "Constant";
|
61 |
+
CompletionItemKind[CompletionItemKind["Struct"] = 22] = "Struct";
|
62 |
+
CompletionItemKind[CompletionItemKind["Event"] = 23] = "Event";
|
63 |
+
CompletionItemKind[CompletionItemKind["Operator"] = 24] = "Operator";
|
64 |
+
CompletionItemKind[CompletionItemKind["TypeParameter"] = 25] = "TypeParameter";
|
65 |
+
})(CompletionItemKind || (exports.CompletionItemKind = CompletionItemKind = {}));
|
66 |
+
/**
|
67 |
+
* Known language identifiers.
|
68 |
+
* https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocumentItem
|
69 |
+
*/
|
70 |
+
var LanguageIdentifier;
|
71 |
+
(function (LanguageIdentifier) {
|
72 |
+
LanguageIdentifier["ABAP"] = "abap";
|
73 |
+
LanguageIdentifier["WindowsBat"] = "bat";
|
74 |
+
LanguageIdentifier["BibTeX"] = "bibtex";
|
75 |
+
LanguageIdentifier["Clojure"] = "clojure";
|
76 |
+
LanguageIdentifier["Coffeescript"] = "coffeescript";
|
77 |
+
LanguageIdentifier["C"] = "c";
|
78 |
+
LanguageIdentifier["CPlusPlus"] = "cpp";
|
79 |
+
LanguageIdentifier["CSharp"] = "csharp";
|
80 |
+
LanguageIdentifier["CSS"] = "css";
|
81 |
+
LanguageIdentifier["Diff"] = "diff";
|
82 |
+
LanguageIdentifier["Dart"] = "dart";
|
83 |
+
LanguageIdentifier["Dockerfile"] = "dockerfile";
|
84 |
+
LanguageIdentifier["Elixir"] = "elixir";
|
85 |
+
LanguageIdentifier["Erlang"] = "erlang";
|
86 |
+
LanguageIdentifier["FSharp"] = "fsharp";
|
87 |
+
LanguageIdentifier["GitCommit"] = "git-commit";
|
88 |
+
LanguageIdentifier["GitRebase"] = "git-rebase";
|
89 |
+
LanguageIdentifier["Go"] = "go";
|
90 |
+
LanguageIdentifier["Groovy"] = "groovy";
|
91 |
+
LanguageIdentifier["Handlebars"] = "handlebars";
|
92 |
+
LanguageIdentifier["HTML"] = "html";
|
93 |
+
LanguageIdentifier["Ini"] = "ini";
|
94 |
+
LanguageIdentifier["Java"] = "java";
|
95 |
+
LanguageIdentifier["JavaScript"] = "javascript";
|
96 |
+
LanguageIdentifier["JavaScriptReact"] = "javascriptreact";
|
97 |
+
LanguageIdentifier["JSON"] = "json";
|
98 |
+
LanguageIdentifier["LaTeX"] = "latex";
|
99 |
+
LanguageIdentifier["Less"] = "less";
|
100 |
+
LanguageIdentifier["Lua"] = "lua";
|
101 |
+
LanguageIdentifier["Makefile"] = "makefile";
|
102 |
+
LanguageIdentifier["Markdown"] = "markdown";
|
103 |
+
LanguageIdentifier["ObjectiveC"] = "c";
|
104 |
+
LanguageIdentifier["ObjectiveCPlusPlus"] = "cpp";
|
105 |
+
LanguageIdentifier["Perl"] = "perl";
|
106 |
+
LanguageIdentifier["Perl6"] = "perl6";
|
107 |
+
LanguageIdentifier["PHP"] = "php";
|
108 |
+
LanguageIdentifier["Powershell"] = "powershell";
|
109 |
+
LanguageIdentifier["Pug"] = "jade";
|
110 |
+
LanguageIdentifier["Python"] = "python";
|
111 |
+
LanguageIdentifier["R"] = "r";
|
112 |
+
LanguageIdentifier["Razor"] = "razor";
|
113 |
+
LanguageIdentifier["Ruby"] = "ruby";
|
114 |
+
LanguageIdentifier["Rust"] = "rust";
|
115 |
+
LanguageIdentifier["SCSS"] = "scss";
|
116 |
+
LanguageIdentifier["Sass"] = "syntax";
|
117 |
+
LanguageIdentifier["Scala"] = "scala";
|
118 |
+
LanguageIdentifier["ShaderLab"] = "shaderlab";
|
119 |
+
LanguageIdentifier["Shell"] = "shellscript";
|
120 |
+
LanguageIdentifier["SQL"] = "sql";
|
121 |
+
LanguageIdentifier["Swift"] = "swift";
|
122 |
+
LanguageIdentifier["TypeScript"] = "typescript";
|
123 |
+
LanguageIdentifier["TypeScriptReact"] = "typescriptreact";
|
124 |
+
LanguageIdentifier["TeX"] = "tex";
|
125 |
+
LanguageIdentifier["VisualBasic"] = "vb";
|
126 |
+
LanguageIdentifier["XML"] = "xml";
|
127 |
+
LanguageIdentifier["XSL"] = "xsl";
|
128 |
+
LanguageIdentifier["YAML"] = "yaml";
|
129 |
+
})(LanguageIdentifier || (exports.LanguageIdentifier = LanguageIdentifier = {}));
|
130 |
+
/**
|
131 |
+
* How a completion was triggered
|
132 |
+
* https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_completion
|
133 |
+
*/
|
134 |
+
var CompletionTriggerKind;
|
135 |
+
(function (CompletionTriggerKind) {
|
136 |
+
/**
|
137 |
+
* Completion was triggered by typing an identifier (24x7 code
|
138 |
+
* complete), manual invocation (e.g Ctrl+Space) or via API.
|
139 |
+
*/
|
140 |
+
CompletionTriggerKind[CompletionTriggerKind["Invoked"] = 1] = "Invoked";
|
141 |
+
/**
|
142 |
+
* Completion was triggered by a trigger character specified by
|
143 |
+
* the `triggerCharacters` properties of the
|
144 |
+
* `CompletionRegistrationOptions`.
|
145 |
+
*/
|
146 |
+
CompletionTriggerKind[CompletionTriggerKind["TriggerCharacter"] = 2] = "TriggerCharacter";
|
147 |
+
/**
|
148 |
+
* Completion was re-triggered as the current completion list is incomplete.
|
149 |
+
*/
|
150 |
+
CompletionTriggerKind[CompletionTriggerKind["TriggerForIncompleteCompletions"] = 3] = "TriggerForIncompleteCompletions";
|
151 |
+
})(CompletionTriggerKind || (exports.CompletionTriggerKind = CompletionTriggerKind = {}));
|
152 |
+
/**
|
153 |
+
* Defines how the host (editor) should sync document changes
|
154 |
+
* to the language server.
|
155 |
+
*/
|
156 |
+
var TextDocumentSyncKind;
|
157 |
+
(function (TextDocumentSyncKind) {
|
158 |
+
/**
|
159 |
+
* Documents should not be synced at all.
|
160 |
+
*/
|
161 |
+
TextDocumentSyncKind[TextDocumentSyncKind["None"] = 0] = "None";
|
162 |
+
/**
|
163 |
+
* Documents are synced by always sending the full content
|
164 |
+
* of the document.
|
165 |
+
*/
|
166 |
+
TextDocumentSyncKind[TextDocumentSyncKind["Full"] = 1] = "Full";
|
167 |
+
/**
|
168 |
+
* Documents are synced by sending the full content on open.
|
169 |
+
* After that only incremental updates to the document are
|
170 |
+
* send.
|
171 |
+
*/
|
172 |
+
TextDocumentSyncKind[TextDocumentSyncKind["Incremental"] = 2] = "Incremental";
|
173 |
+
})(TextDocumentSyncKind || (exports.TextDocumentSyncKind = TextDocumentSyncKind = {}));
|
174 |
+
/**
|
175 |
+
* The kind of a code action.
|
176 |
+
*
|
177 |
+
* Kinds are a hierarchical list of identifiers separated by `.`,
|
178 |
+
* e.g. `"refactor.extract.function"`.
|
179 |
+
*
|
180 |
+
* The set of kinds is open and the client needs to announce the kinds it
|
181 |
+
* supports to the server during initialization.
|
182 |
+
*/
|
183 |
+
var CodeActionKind;
|
184 |
+
(function (CodeActionKind) {
|
185 |
+
/**
|
186 |
+
* Empty kind.
|
187 |
+
*/
|
188 |
+
CodeActionKind["Empty"] = "";
|
189 |
+
/**
|
190 |
+
* Base kind for quickfix actions: 'quickfix'.
|
191 |
+
*/
|
192 |
+
CodeActionKind["QuickFix"] = "quickfix";
|
193 |
+
/**
|
194 |
+
* Base kind for refactoring actions: 'refactor'.
|
195 |
+
*/
|
196 |
+
CodeActionKind["Refactor"] = "refactor";
|
197 |
+
/**
|
198 |
+
* Base kind for refactoring extraction actions: 'refactor.extract'.
|
199 |
+
*
|
200 |
+
* Example extract actions:
|
201 |
+
*
|
202 |
+
* - Extract method
|
203 |
+
* - Extract function
|
204 |
+
* - Extract variable
|
205 |
+
* - Extract interface from class
|
206 |
+
* - ...
|
207 |
+
*/
|
208 |
+
CodeActionKind["RefactorExtract"] = "refactor.extract";
|
209 |
+
/**
|
210 |
+
* Base kind for refactoring inline actions: 'refactor.inline'.
|
211 |
+
*
|
212 |
+
* Example inline actions:
|
213 |
+
*
|
214 |
+
* - Inline function
|
215 |
+
* - Inline variable
|
216 |
+
* - Inline constant
|
217 |
+
* - ...
|
218 |
+
*/
|
219 |
+
CodeActionKind["RefactorInline"] = "refactor.inline";
|
220 |
+
/**
|
221 |
+
* Base kind for refactoring rewrite actions: 'refactor.rewrite'.
|
222 |
+
*
|
223 |
+
* Example rewrite actions:
|
224 |
+
*
|
225 |
+
* - Convert JavaScript function to class
|
226 |
+
* - Add or remove parameter
|
227 |
+
* - Encapsulate field
|
228 |
+
* - Make method static
|
229 |
+
* - Move method to base class
|
230 |
+
* - ...
|
231 |
+
*/
|
232 |
+
CodeActionKind["RefactorRewrite"] = "refactor.rewrite";
|
233 |
+
/**
|
234 |
+
* Base kind for source actions: `source`.
|
235 |
+
*
|
236 |
+
* Source code actions apply to the entire file.
|
237 |
+
*/
|
238 |
+
CodeActionKind["Source"] = "source";
|
239 |
+
/**
|
240 |
+
* Base kind for an organize imports source action `source.organizeImports`.
|
241 |
+
*/
|
242 |
+
CodeActionKind["SourceOrganizeImports"] = "source.organizeImports";
|
243 |
+
})(CodeActionKind || (exports.CodeActionKind = CodeActionKind = {}));
|
244 |
+
/**
|
245 |
+
* Defines whether the insert text in a completion item should be interpreted as
|
246 |
+
* plain text or a snippet.
|
247 |
+
*/
|
248 |
+
var InsertTextFormat;
|
249 |
+
(function (InsertTextFormat) {
|
250 |
+
/**
|
251 |
+
* The primary text to be inserted is treated as a plain string.
|
252 |
+
*/
|
253 |
+
InsertTextFormat[InsertTextFormat["PlainText"] = 1] = "PlainText";
|
254 |
+
/**
|
255 |
+
* The primary text to be inserted is treated as a snippet.
|
256 |
+
*
|
257 |
+
* A snippet can define tab stops and placeholders with `$1`, `$2`
|
258 |
+
* and `${3:foo}`. `$0` defines the final tab stop, it defaults to
|
259 |
+
* the end of the snippet. Placeholders with equal identifiers are linked,
|
260 |
+
* that is typing in one will update others too.
|
261 |
+
*/
|
262 |
+
InsertTextFormat[InsertTextFormat["Snippet"] = 2] = "Snippet";
|
263 |
+
})(InsertTextFormat || (exports.InsertTextFormat = InsertTextFormat = {}));
|
264 |
+
/**
|
265 |
+
* How whitespace and indentation is handled during completion
|
266 |
+
* item insertion.
|
267 |
+
*
|
268 |
+
* @since 3.16.0
|
269 |
+
*/
|
270 |
+
var InsertTextMode;
|
271 |
+
(function (InsertTextMode) {
|
272 |
+
/**
|
273 |
+
* The insertion or replace strings is taken as it is. If the
|
274 |
+
* value is multi line the lines below the cursor will be
|
275 |
+
* inserted using the indentation defined in the string value.
|
276 |
+
* The client will not apply any kind of adjustments to the
|
277 |
+
* string.
|
278 |
+
*/
|
279 |
+
InsertTextMode[InsertTextMode["asIs"] = 1] = "asIs";
|
280 |
+
/**
|
281 |
+
* The editor adjusts leading whitespace of new lines so that
|
282 |
+
* they match the indentation up to the cursor of the line for
|
283 |
+
* which the item is accepted.
|
284 |
+
*
|
285 |
+
* Consider a line like this: <2tabs><cursor><3tabs>foo. Accepting a
|
286 |
+
* multi line completion item is indented using 2 tabs and all
|
287 |
+
* following lines inserted will be indented using 2 tabs as well.
|
288 |
+
*/
|
289 |
+
InsertTextMode[InsertTextMode["adjustIndentation"] = 2] = "adjustIndentation";
|
290 |
+
})(InsertTextMode || (exports.InsertTextMode = InsertTextMode = {}));
|
291 |
+
/**
|
292 |
+
* How a signature help was triggered.
|
293 |
+
*
|
294 |
+
* @since 3.15.0
|
295 |
+
*/
|
296 |
+
var SignatureHelpTriggerKind;
|
297 |
+
(function (SignatureHelpTriggerKind) {
|
298 |
+
/**
|
299 |
+
* Signature help was invoked manually by the user or by a command.
|
300 |
+
*/
|
301 |
+
SignatureHelpTriggerKind[SignatureHelpTriggerKind["Invoked"] = 1] = "Invoked";
|
302 |
+
/**
|
303 |
+
* Signature help was triggered by a trigger character.
|
304 |
+
*/
|
305 |
+
SignatureHelpTriggerKind[SignatureHelpTriggerKind["TriggerCharacter"] = 2] = "TriggerCharacter";
|
306 |
+
/**
|
307 |
+
* Signature help was triggered by the cursor moving or by the document
|
308 |
+
* content changing.
|
309 |
+
*/
|
310 |
+
SignatureHelpTriggerKind[SignatureHelpTriggerKind["ContentChange"] = 3] = "ContentChange";
|
311 |
+
})(SignatureHelpTriggerKind || (exports.SignatureHelpTriggerKind = SignatureHelpTriggerKind = {}));
|
312 |
+
// tslint:enable:enforce-name-casing
|
313 |
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text_document_node.js","sourceRoot":"","sources":["../../../../../../../../genfiles/third_party/colab/sources/lsp/text_document_node.ts"],"names":[],"mappings":"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","sourcesContent":["import * as protocol from './protocol_node';\nimport * as workspace from './workspace_node';\n\n// tslint:disable:enforce-name-casing\n\n/**\n * Text document specific client capabilities.\n */\nexport declare interface TextDocumentClientCapabilities {\n  synchronization?: TextDocumentSyncClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/completion` request.\n   */\n  completion?: CompletionClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/hover` request.\n   */\n  hover?: HoverClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/signatureHelp` request.\n   */\n  signatureHelp?: SignatureHelpClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/declaration` request.\n   *\n   * @since 3.14.0\n   */\n  declaration?: DeclarationClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/definition` request.\n   */\n  definition?: DefinitionClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/typeDefinition` request.\n   *\n   * @since 3.6.0\n   */\n  typeDefinition?: TypeDefinitionClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/implementation` request.\n   *\n   * @since 3.6.0\n   */\n  implementation?: ImplementationClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/references` request.\n   */\n  references?: ReferenceClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/documentHighlight` request.\n   */\n  documentHighlight?: DocumentHighlightClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/documentSymbol` request.\n   */\n  documentSymbol?: DocumentSymbolClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/codeAction` request.\n   */\n  codeAction?: CodeActionClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/codeLens` request.\n   */\n  codeLens?: CodeLensClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/documentLink` request.\n   */\n  documentLink?: DocumentLinkClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/documentColor` and the\n   * `textDocument/colorPresentation` request.\n   *\n   * @since 3.6.0\n   */\n  colorProvider?: DocumentColorClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/formatting` request.\n   */\n  formatting?: DocumentFormattingClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/rangeFormatting` request.\n   */\n  rangeFormatting?: DocumentRangeFormattingClientCapabilities;\n\n  /**\n   * request.\n   * Capabilities specific to the `textDocument/onTypeFormatting` request.\n   */\n  onTypeFormatting?: DocumentOnTypeFormattingClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/rename` request.\n   */\n  rename?: RenameClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/publishDiagnostics`\n   * notification.\n   */\n  publishDiagnostics?: PublishDiagnosticsClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/foldingRange` request.\n   *\n   * @since 3.10.0\n   */\n  foldingRange?: FoldingRangeClientCapabilities;\n\n  /**\n   * Capabilities specific to the `textDocument/selectionRange` request.\n   *\n   * @since 3.15.0\n   */\n  selectionRange?: SelectionRangeClientCapabilities;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_completion\n */\nexport declare interface CompletionClientCapabilities {\n  /**\n   * Whether completion supports dynamic registration.\n   */\n  dynamicRegistration?: boolean;\n\n  /**\n   * The client supports the following `CompletionItem` specific\n   * capabilities.\n   */\n  completionItem?: {\n    /**\n     * Client supports snippets as insert text.\n     *\n     * A snippet can define tab stops and placeholders with `$1`, `$2`\n     * and `${3:foo}`. `$0` defines the final tab stop, it defaults to\n     * the end of the snippet.\n     * Placeholders with equal identifiers are linked, so that typing in\n     * one will update others as well.\n     */\n    snippetSupport?: boolean;\n\n    /**\n     * Client supports commit characters on a completion item.\n     */\n    commitCharactersSupport?: boolean\n\n  /**\n   * Client supports the follow content formats for the documentation\n   * property. The order describes the preferred format of the client.\n   */\n    documentationFormat?: MarkupKind[];\n\n    /**\n     * Client supports the deprecated property on a completion item.\n     */\n    deprecatedSupport?: boolean;\n\n    /**\n     * Client supports the preselect property on a completion item.\n     */\n    preselectSupport?: boolean;\n\n    /**\n     * Client supports the tag property on a completion item.\n     * Clients supporting tags have to handle unknown tags gracefully.\n     * Clients especially need to preserve unknown tags when sending\n     * a completion item back to the server in a resolve call.\n     *\n     * @since 3.15.0\n     */\n    tagSupport?: {\n      /**\n       * The tags supported by the client.\n       */\n      valueSet: CompletionItemTag[]\n    }\n  };\n\n    completionItemKind?: {\n      /**\n       * The completion item 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 completion items kinds from `Text` to `Reference` as defined in\n       * the initial version of the protocol.\n       */\n      valueSet?: CompletionItemKind[];\n    };\n\n    /**\n     * The client supports to send additional context information for a\n     * `textDocument/completion` request.\n     */\n    contextSupport?: boolean;\n}\n\n/**\n * Describes the content type that a client supports in various\n * result literals like `Hover`, `ParameterInfo` or `CompletionItem`.\n *\n * Please note that `MarkupKinds` must not start with a `$`. This kinds\n * are reserved for internal usage.\n */\nexport enum MarkupKind {\n  /**\n   * Plain text is supported as a content format\n   */\n  PlainText = 'plaintext',\n\n  /**\n   * Markdown is supported as a content format\n   */\n  Markdown = 'markdown',\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_hover\n */\nexport declare interface HoverClientCapabilities {\n    /**\n     * Whether hover supports dynamic registration.\n     */\n    dynamicRegistration?: boolean;\n\n    /**\n     * Client supports the follow content formats for the content\n     * property. The order describes the preferred format of the client.\n     */\n    contentFormat?: MarkupKind[];\n}\n\n/**\n * Completion item tags are extra annotations that tweak the rendering of\n * a completion item.\n *\n * @since 3.15.0\n */\nexport enum CompletionItemTag {\n  /**\n   * Render a completion as obsolete, usually using a strike-out.\n   */\n  Deprecated = 1,\n}\n\n/**\n * The kind of a completion entry.\n */\nexport enum CompletionItemKind {\n  Text = 1,\n  Method = 2,\n  Function = 3,\n  Constructor = 4,\n  Field = 5,\n  Variable = 6,\n  Class = 7,\n  Interface = 8,\n  Module = 9,\n  Property = 10,\n  Unit = 11,\n  Value = 12,\n  Enum = 13,\n  Keyword = 14,\n  Snippet = 15,\n  Color = 16,\n  File = 17,\n  Reference = 18,\n  Folder = 19,\n  EnumMember = 20,\n  Constant = 21,\n  Struct = 22,\n  Event = 23,\n  Operator = 24,\n  TypeParameter = 25,\n}\n\n\n/**\n * An item to transfer a text document from the client to the server.\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocumentItem\n */\nexport declare interface TextDocumentItem {\n    /**\n     * The text document's URI.\n     */\n    uri: protocol.DocumentUri;\n\n    /**\n     * The text document's language identifier.\n     */\n    languageId: LanguageIdentifier;\n\n    /**\n     * The version number of this document (it will increase after each\n     * change, including undo/redo).\n     */\n    version: number;\n\n    /**\n     * The content of the opened text document.\n     */\n    text: string;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_didOpen\n */\nexport declare interface DidOpenTextDocumentParams {\n    /**\n     * The document that was opened.\n     */\n    textDocument: TextDocumentItem;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_didOpen\n */\nexport declare interface DidOpenTextDocument extends\n    protocol.NotificationMessage<DidOpenTextDocumentParams> {\n    method: protocol.Method.TextDocumentDidOpen;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_didClose\n */\nexport declare interface DidCloseTextDocumentParams {\n    /**\n     * The document that was closed.\n     */\n    textDocument: TextDocumentIdentifier;\n}\n\n/**\n * Known language identifiers.\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocumentItem\n */\nexport enum LanguageIdentifier {\n  ABAP = 'abap',\n  WindowsBat = 'bat',\n  BibTeX = 'bibtex',\n  Clojure = 'clojure',\n  Coffeescript = 'coffeescript',\n  C = 'c',\n  CPlusPlus = 'cpp',\n  CSharp = 'csharp',\n  CSS = 'css',\n  Diff = 'diff',\n  Dart = 'dart',\n  Dockerfile = 'dockerfile',\n  Elixir = 'elixir',\n  Erlang = 'erlang',\n  FSharp = 'fsharp',\n  GitCommit = 'git-commit',\n  GitRebase = 'git-rebase',\n  Go = 'go',\n  Groovy = 'groovy',\n  Handlebars = 'handlebars',\n  HTML = 'html',\n  Ini = 'ini',\n  Java = 'java',\n  JavaScript = 'javascript',\n  JavaScriptReact = 'javascriptreact',\n  JSON = 'json',\n  LaTeX = 'latex',\n  Less = 'less',\n  Lua = 'lua',\n  Makefile = 'makefile',\n  Markdown = 'markdown',\n  ObjectiveC = 'c',\n  ObjectiveCPlusPlus = 'cpp',\n  Perl = 'perl',\n  Perl6 = 'perl6',\n  PHP = 'php',\n  Powershell = 'powershell',\n  Pug = 'jade',\n  Python = 'python',\n  R = 'r',\n  Razor = 'razor',\n  Ruby = 'ruby',\n  Rust = 'rust',\n  SCSS = 'scss',\n  Sass = 'syntax',\n  Scala = 'scala',\n  ShaderLab = 'shaderlab',\n  Shell = 'shellscript',\n  SQL = 'sql',\n  Swift = 'swift',\n  TypeScript = 'typescript',\n  TypeScriptReact = 'typescriptreact',\n  TeX = 'tex',\n  VisualBasic = 'vb',\n  XML = 'xml',\n  XSL = 'xsl',\n  YAML = 'yaml',\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_publishDiagnostics\n */\nexport declare interface PublishDiagnosticsClientCapabilities {\n    /**\n     * Whether the clients accepts diagnostics with related information.\n     */\n    relatedInformation?: boolean;\n\n    /**\n     * Client supports the tag property to provide meta data about a diagnostic.\n     * Clients supporting tags have to handle unknown tags gracefully.\n     *\n     * @since 3.15.0\n     */\n    tagSupport?: {\n      /**\n       * The tags supported by the client.\n       */\n      valueSet: protocol.DiagnosticTag[];\n    };\n\n    /**\n     * Whether the client interprets the version property of the\n     * `textDocument/publishDiagnostics` notification's parameter.\n     *\n     * @since 3.15.0\n     */\n    versionSupport?: boolean;\n}\n\n/**\n * Diagnostics notification are sent from the server to the client to signal\n * results of validation runs.\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_publishDiagnostics\n */\nexport declare interface PublishDiagnostics extends\n    protocol.NotificationMessage<PublishDiagnosticsParams> {\n    method: protocol.Method.TextDocumentPublishDiagnostics;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_publishDiagnostics\n */\nexport declare interface PublishDiagnosticsParams {\n    /**\n     * The URI for which diagnostic information is reported.\n     */\n    uri: protocol.DocumentUri;\n\n    /**\n     * The version number of the document the diagnostics are published for.\n     * Optional.\n     * @since 3.15.0\n     */\n    version?: number;\n\n    /**\n     * An array of diagnostic information items.\n     */\n    diagnostics: protocol.Diagnostic[];\n}\n\n/**\n * Text documents are identified using a URI. On the protocol level, URIs are\n * passed as strings. The corresponding JSON structure looks like this:\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocumentIdentifier\n */\nexport declare interface TextDocumentIdentifier {\n    /**\n     * The text document's URI.\n     */\n    uri: protocol.DocumentUri;\n}\n\n/**\n * An identifier to denote a specific version of a text document. This\n * information usually flows from the client to the server.\n */\ninterface VersionedTextDocumentIdentifier extends TextDocumentIdentifier {\n    /**\n     * The version number of this document.\n     *\n     * The version number of a document will increase after each change,\n     * including undo/redo. The number doesn't need to be consecutive.\n     */\n    version: protocol.integer;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocumentPositionParams\n */\nexport interface TextDocumentPositionParams {\n    /**\n     * The text document.\n     */\n    textDocument: TextDocumentIdentifier;\n\n    /**\n     * The position inside the text document.\n     */\n    position: protocol.Position;\n}\n\n/**\n * The Completion request is sent from the client to the server to compute\n * completion items at a given cursor position. Completion items are presented\n * in the IntelliSense user interface. If computing full completion items is\n * expensive, servers can additionally provide a handler for the completion\n * item resolve request (`completionItem/resolve`). This request is sent when a\n * completion item is selected in the user interface. A typical use case is for\n * example: the `textDocument/completion` request doesn’t fill in the\n * documentation property for returned completion items since it is expensive\n * to compute. When the item is selected in the user interface then a\n * `completionItem/resolve` request is sent with the selected completion item\n * as a parameter. The returned completion item should have the documentation\n * property filled in. By default the request can only delay the computation of\n * the detail and documentation properties. Since 3.16.0 the client can signal\n * that it can resolve more properties lazily. This is done using the\n * completionItem#resolveSupport client capability which lists all properties\n * that can be filled in during a `completionItem/resolve` request. All other\n * properties (usually sortText, filterText, insertText and textEdit) must be\n * provided in the textDocument/completion response and must not be changed\n * during resolve.\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_completion\n */\nexport declare interface Completion extends\n    protocol.RequestMessage<CompletionParams> {\n    method: protocol.Method.TextDocumentCompletion;\n}\n\n/**\n * Params for the autoExecuteCheck call. This is a custom LSP command that\n * verifies that the provided code passes a number of LSP-related checks.\n */\nexport declare interface AutoExecuteCheckParams extends TextDocumentIdentifier {\n    /**\n     * The code to check whether it can be auto executed in the current\n     * document.\n     */\n    codeToCheck: string;\n\n    /**\n     * The position to insert the code at. If not set, append to the end of the\n     * notebook.\n     */\n    position?: protocol.Position;\n}\n\n/**\n * Response for the autoExecuteCheck call.\n */\nexport declare interface AutoExecuteCheckResponse {\n    /**\n     * Errors found when checking the code in the request. An empty list means\n     * that all checks passed and the code can be executed automatically.\n     */\n    errors: string[];\n\n    /**\n     * The actual code that should be executed. This will usually be the code\n     * that was passed in the request, but may include additional edits to make\n     * the code safer to run.\n     */\n    codeToExecute: string;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_completion\n */\nexport declare interface CompletionParams extends\n    TextDocumentPositionParams, protocol.WorkDoneProgressParams,\n    protocol.PartialResultParams {\n    /**\n     * The completion context. This is only available if the client specifies\n     * to send this using the client capability\n     * `completion.contextSupport === true`\n     */\n    context?: CompletionContext;\n}\n\n/**\n * How a completion was triggered\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_completion\n */\nexport enum CompletionTriggerKind {\n  /**\n   * Completion was triggered by typing an identifier (24x7 code\n   * complete), manual invocation (e.g Ctrl+Space) or via API.\n   */\n  Invoked = 1,\n\n  /**\n   * Completion was triggered by a trigger character specified by\n   * the `triggerCharacters` properties of the\n   * `CompletionRegistrationOptions`.\n   */\n  TriggerCharacter = 2,\n\n  /**\n   * Completion was re-triggered as the current completion list is incomplete.\n   */\n  TriggerForIncompleteCompletions = 3,\n}\n\n\n/**\n * Contains additional information about the context in which a completion\n * request is triggered.\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_completion\n */\nexport declare interface CompletionContext {\n    /**\n     * How the completion was triggered.\n     */\n    triggerKind: CompletionTriggerKind;\n\n    /**\n     * The trigger character (a single character) that has trigger code\n     * complete. Is undefined if\n     * `triggerKind !== CompletionTriggerKind.TriggerCharacter`\n     */\n    triggerCharacter?: string;\n}\n\n/**\n * The document change notification is sent from the client to the server to\n * signal changes to a text document. Before a client can change a text\n * document it must claim ownership of its content using the\n * textDocument/didOpen notification. In 2.0 the shape of the params has\n * changed to include proper version numbers and language ids.\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_didChange\n */\nexport interface DidChangeTextDocumentParams {\n    /**\n     * The document that did change. The version number points\n     * to the version after all provided content changes have\n     * been applied.\n     */\n    textDocument: VersionedTextDocumentIdentifier;\n\n    /**\n     * The actual content changes. The content changes describe single state\n     * changes to the document. So if there are two content changes c1 (at\n     * array index 0) and c2 (at array index 1) for a document in state S then\n     * c1 moves the document from S to S' and c2 from S' to S''. So c1 is\n     * computed on the state S and c2 is computed on the state S'.\n     *\n     * To mirror the content of a document using change events use the following\n     * approach:\n     * - start with the same initial content\n     * - apply the 'textDocument/didChange' notifications in the order you\n     *   receive them.\n     * - apply the `TextDocumentContentChangeEvent`s in a single notification\n     *   in the order you receive them.\n     */\n    contentChanges: TextDocumentContentChangeEvent[];\n}\n\n/**\n * An event describing a change to a text document. If range and rangeLength are\n * omitted the new text is considered to be the full content of the document.\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_didChange\n */\nexport type TextDocumentContentChangeEvent = {\n  /**\n   * The range of the document that changed.\n   */\n  range: protocol.Range;\n\n  /**\n   * The optional length of the range that got replaced.\n   *\n   * @deprecated use range instead.\n   */\n  rangeLength?: protocol.uinteger;\n\n  /**\n   * The new text for the provided range.\n   */\n  text: string;\n}|{\n    /**\n     * The new text of the whole document.\n     */\n    text: string;\n};\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocumentEdit\n */\nexport declare interface TextDocumentEdit {\n    /**\n     * The text document to change.\n     */\n    textDocument: VersionedTextDocumentIdentifier;\n\n    /**\n     * The edits to be applied.\n     */\n    edits: TextEdit[];\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textEdit\n */\nexport interface TextEdit {\n    /**\n     * The range of the text document to be manipulated. To insert\n     * text into a document create a range where start === end.\n     */\n    range: protocol.Range;\n\n    /**\n     * The string to be inserted. For delete operations use an\n     * empty string.\n     */\n    newText: string;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_foldingRange\n */\nexport declare interface FoldingRangeClientCapabilities {\n    /**\n     * Whether the implementation supports dynamic registration for\n     * folding range providers.\n     * If this is set to `true`, the client supports the new\n     * `FoldingRangeRegistrationOptions` return value for the corresponding\n     * server capability as well.\n     */\n    dynamicRegistration?: boolean;\n    /**\n     * The maximum number of folding ranges that the client prefers to\n     * receive per document.\n     * The value serves as a hint, servers are free to follow the limit.\n     */\n    rangeLimit?: number;\n    /**\n     * If set, the client signals that it only supports folding complete lines.\n     * If set, the client will ignore specified `startCharacter` and\n     * `endCharacter` properties in a FoldingRange.\n     */\n    lineFoldingOnly?: boolean;\n}\n\n/**\n * The document range formatting request is sent from the client to the server\n * to format a given range in a document.\n */\nexport declare interface DocumentRangeFormattingClientCapabilities {\n    /**\n     * Whether formatting supports dynamic registration.\n     */\n    dynamicRegistration?: boolean;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_selectionRange\n */\nexport declare interface SelectionRangeClientCapabilities {\n    /**\n     * Whether implementation supports dynamic registration for selection\n     * range providers.\n     * If set to `true`, the client supports the new\n     * `SelectionRangeRegistrationOptions` return value for the corresponding\n     * server capability as well.\n     */\n    dynamicRegistration?: boolean;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_signatureHelp\n */\nexport declare interface SignatureHelpClientCapabilities {\n    /**\n     * Whether signature help supports dynamic registration.\n     */\n    dynamicRegistration?: boolean;\n\n    /**\n     * The client supports the following `SignatureInformation`\n     * specific properties.\n     */\n    signatureInformation?: {\n      /**\n       * Client supports the follow content formats for the documentation\n       * property. The order describes the preferred format of the client.\n       */\n      documentationFormat?: MarkupKind[];\n\n      /**\n       * Client capabilities specific to parameter information.\n       */\n      parameterInformation?: {\n        /**\n         * The client supports processing label offsets instead of a\n         * simple label string.\n         *\n         * @since 3.14.0\n         */\n        labelOffsetSupport?: boolean;\n      };\n\n      /**\n       * The client supports the `activeParameter` property on\n       * `SignatureInformation` literal.\n       *\n       * @since 3.16.0 - proposed state\n       */\n      activeParameterSupport?: boolean;\n    };\n\n    /**\n     * The client supports to send additional context information for a\n     * `textDocument/signatureHelp` request. A client that opts into\n     * contextSupport will also support the `retriggerCharacters` on\n     * `SignatureHelpOptions`.\n     *\n     * @since 3.15.0\n     */\n    contextSupport?: boolean;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_implementation\n */\nexport declare interface ImplementationClientCapabilities {\n    /**\n     * Whether implementation supports dynamic registration.\n     * If this is set to `true`, the client supports the new\n     * `ImplementationRegistrationOptions` return value for the\n     * corresponding server capability as well.\n     */\n    dynamicRegistration?: boolean;\n\n    /**\n     * The client supports additional metadata in the form of definition links.\n     *\n     * @since 3.14.0\n     */\n    linkSupport?: boolean;\n}\n\n/**\n * The rename request is sent from the client to the server to ask the server to\n * compute a workspace change so that the client can perform a workspace-wide\n * rename of a symbol.\n */\nexport declare interface RenameClientCapabilities {\n    /**\n     * Whether rename supports dynamic registration.\n     */\n    dynamicRegistration?: boolean;\n\n    /**\n     * Client supports testing for validity of rename operations\n     * before execution.\n     *\n     * @since version 3.12.0\n     */\n    prepareSupport?: boolean;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_typeDefinition\n */\nexport declare interface TypeDefinitionClientCapabilities {\n    /**\n     * Whether implementation supports dynamic registration.\n     * If this is set to `true`, the client supports the new `\n     * TypeDefinitionRegistrationOptions` return value for the\n     * corresponding server capability as well.\n     */\n    dynamicRegistration?: boolean;\n\n    /**\n     * The client supports additional metadata in the form of definition links.\n     *\n     * @since 3.14.0\n     */\n    linkSupport?: boolean;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_didClose\n */\nexport declare interface TextDocumentSyncClientCapabilities {\n    /**\n     * Whether text document synchronization supports dynamic registration.\n     */\n    dynamicRegistration?: boolean;\n\n    /**\n     * The client supports sending will save notifications.\n     */\n    willSave?: boolean;\n\n    /**\n     * The client supports sending a will save request and\n     * waits for a response providing text edits which will\n     * be applied to the document before it is saved.\n     */\n    willSaveWaitUntil?: boolean;\n\n    /**\n     * The client supports did save notifications.\n     */\n    didSave?: boolean;\n}\n\n/**\n * Defines how the host (editor) should sync document changes\n * to the language server.\n */\nexport enum TextDocumentSyncKind {\n  /**\n   * Documents should not be synced at all.\n   */\n  None = 0,\n\n  /**\n   * Documents are synced by always sending the full content\n   * of the document.\n   */\n  Full = 1,\n\n  /**\n   * Documents are synced by sending the full content on open.\n   * After that only incremental updates to the document are\n   * send.\n   */\n  Incremental = 2,\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_didClose\n */\nexport declare interface TextDocumentSyncOptions {\n    /**\n     * Open and close notifications are sent to the server.\n     * If omitted, open close notification should not be sent.\n     */\n    openClose?: boolean;\n    /**\n     * Change notifications are sent to the server.\n     * See TextDocumentSyncKind.None, TextDocumentSyncKind.Full,\n     * and TextDocumentSyncKind.Incremental.\n     * If omitted, it defaults to TextDocumentSyncKind.None.\n     */\n    change?: number;\n    /**\n     * If present will save notifications are sent to the server.\n     * If omitted, the notification should not be sent.\n     */\n    willSave?: boolean;\n    /**\n     * If present will save wait until requests are sent to the server.\n     * If omitted, the request should not be sent.\n     */\n    willSaveWaitUntil?: boolean;\n    /**\n     * If present save notifications are sent to the server.\n     * If omitted, the notification should not be sent.\n     */\n    save?: boolean|SaveOptions;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_didSave\n */\nexport declare interface SaveOptions {\n    /**\n     * The client is supposed to include the content on save.\n     */\n    includeText?: boolean;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_definition\n */\nexport declare interface DefinitionClientCapabilities {\n    /**\n     * Whether definition supports dynamic registration.\n     */\n    dynamicRegistration?: boolean;\n\n    /**\n     * The client supports additional metadata in the form of definition links.\n     *\n     * @since 3.14.0\n     */\n    linkSupport?: boolean;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_declaration\n */\nexport declare interface DeclarationClientCapabilities {\n    /**\n     * Whether declaration supports dynamic registration.\n     * If this is set to `true`, the client supports the new\n     * `DeclarationRegistrationOptions` return value for the\n     * corresponding server capability as well.\n     */\n    dynamicRegistration?: boolean;\n\n    /**\n     * The client supports additional metadata in the form of declaration links.\n     */\n    linkSupport?: boolean;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_documentHighlight\n */\nexport declare interface DocumentHighlightClientCapabilities {\n    /**\n     * Whether document highlight supports dynamic registration.\n     */\n    dynamicRegistration?: boolean;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_references\n */\nexport declare interface ReferenceClientCapabilities {\n    /**\n     * Whether references supports dynamic registration.\n     */\n    dynamicRegistration?: boolean;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_documentSymbol\n */\nexport declare interface DocumentSymbolClientCapabilities {\n    /**\n     * Whether document symbol supports dynamic registration.\n     */\n    dynamicRegistration?: boolean;\n\n    /**\n     * Specific capabilities for the `SymbolKind` in the\n     * `textDocument/documentSymbol` 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 hierarchical document symbols.\n     */\n    hierarchicalDocumentSymbolSupport?: boolean;\n\n    /**\n     * The client supports tags on `SymbolInformation`. Tags are supported on\n     * `DocumentSymbol` if `hierarchicalDocumentSymbolSupport` is set to true.\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     * The client supports an additional label presented in the UI when\n     * registering a document symbol provider.\n     *\n     * @since 3.16.0\n     */\n    labelSupport?: boolean;\n}\n\n/**\n * The document on type formatting request is sent from the client to the server\n * to format parts of the document during typing.\n */\nexport declare interface DocumentOnTypeFormattingClientCapabilities {\n    /**\n     * Whether on type formatting supports dynamic registration.\n     */\n    dynamicRegistration?: boolean;\n}\n\n/**\n * The document formatting request is sent from the client to the server to\n * format a whole document.\n */\nexport declare interface DocumentFormattingClientCapabilities {\n    /**\n     * Whether formatting supports dynamic registration.\n     */\n    dynamicRegistration?: boolean;\n}\n\n/**\n * The document color request is sent from the client to the server to list all\n * color references found in a given text document. Along with the range, a\n * color value in RGB is returned. Clients can use the result to decorate color\n * references in an editor. For example: Color boxes showing the actual color\n * next to the reference Show a color picker when a color reference is edited\n */\nexport declare interface DocumentColorClientCapabilities {\n    /**\n     * Whether document color supports dynamic registration.\n     */\n    dynamicRegistration?: boolean;\n}\n\n/**\n * The document links request is sent from the client to the server to request\n * the location of links in a document.\n */\nexport declare interface DocumentLinkClientCapabilities {\n    /**\n     * Whether document link supports dynamic registration.\n     */\n    dynamicRegistration?: boolean;\n\n    /**\n     * Whether the client supports the `tooltip` property on `DocumentLink`.\n     *\n     * @since 3.15.0\n     */\n    tooltipSupport?: boolean;\n}\n\n/**\n * The CodeLens request is sent from the client to the server to compute\n * CodeLens for a given text document.\n */\nexport declare interface CodeLensClientCapabilities {\n    /**\n     * Whether CodeLens supports dynamic registration.\n     */\n    dynamicRegistration?: boolean;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_codeAction\n */\nexport declare interface CodeActionClientCapabilities {\n    /**\n     * Whether code action supports dynamic registration.\n     */\n    dynamicRegistration?: boolean;\n\n    /**\n     * The client supports code action literals as a valid\n     * response of the `textDocument/codeAction` request.\n     *\n     * @since 3.8.0\n     */\n    codeActionLiteralSupport?: {\n      /**\n       * The code action kind is supported with the following value\n       * set.\n       */\n      codeActionKind: {\n\n        /**\n         * The code action 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        valueSet: CodeActionKind[];\n      };\n    };\n\n    /**\n     * Whether code action supports the `isPreferred` property.\n     * @since 3.15.0\n     */\n    isPreferredSupport?: boolean;\n}\n\n/**\n * The kind of a code action.\n *\n * Kinds are a hierarchical list of identifiers separated by `.`,\n * e.g. `\"refactor.extract.function\"`.\n *\n * The set of kinds is open and the client needs to announce the kinds it\n * supports to the server during initialization.\n */\nexport enum CodeActionKind {\n\n  /**\n   * Empty kind.\n   */\n  Empty = '',\n\n  /**\n   * Base kind for quickfix actions: 'quickfix'.\n   */\n  QuickFix = 'quickfix',\n\n  /**\n   * Base kind for refactoring actions: 'refactor'.\n   */\n  Refactor = 'refactor',\n\n  /**\n   * Base kind for refactoring extraction actions: 'refactor.extract'.\n   *\n   * Example extract actions:\n   *\n   * - Extract method\n   * - Extract function\n   * - Extract variable\n   * - Extract interface from class\n   * - ...\n   */\n  RefactorExtract = 'refactor.extract',\n\n  /**\n   * Base kind for refactoring inline actions: 'refactor.inline'.\n   *\n   * Example inline actions:\n   *\n   * - Inline function\n   * - Inline variable\n   * - Inline constant\n   * - ...\n   */\n  RefactorInline = 'refactor.inline',\n\n  /**\n   * Base kind for refactoring rewrite actions: 'refactor.rewrite'.\n   *\n   * Example rewrite actions:\n   *\n   * - Convert JavaScript function to class\n   * - Add or remove parameter\n   * - Encapsulate field\n   * - Make method static\n   * - Move method to base class\n   * - ...\n   */\n  RefactorRewrite = 'refactor.rewrite',\n\n  /**\n   * Base kind for source actions: `source`.\n   *\n   * Source code actions apply to the entire file.\n   */\n  Source = 'source',\n\n  /**\n   * Base kind for an organize imports source action `source.organizeImports`.\n   */\n  SourceOrganizeImports = 'source.organizeImports',\n}\n\n/**\n * Contains additional diagnostic information about the context in which\n * a code action is run.\n */\nexport declare interface CodeActionContext {\n    /**\n     * An array of diagnostics known on the client side overlapping the range\n     * provided to the `textDocument/codeAction` request.\n     * They are provided so that the server knows which errors are currently\n     * presented to the user for the given range. There is no guarantee that\n     * these accurately reflect the error state of the resource.\n     * The primary parameter to compute code actions is the provided range.\n     */\n    diagnostics: protocol.Diagnostic[];\n\n    /**\n     * Requested kind of actions to return.\n     *\n     * Actions not of this kind are filtered out by the client before\n     * being shown, so servers can omit computing them.\n     */\n    only?: CodeActionKind[];\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_publishDiagnostics\n */\nexport declare interface PublishDiagnosticsClientCapabilities {\n    /**\n     * Whether the clients accepts diagnostics with related information.\n     */\n    relatedInformation?: boolean;\n\n    /**\n     * Client supports the tag property to provide meta data about a diagnostic.\n     * Clients supporting tags have to handle unknown tags gracefully.\n     *\n     * @since 3.15.0\n     */\n    tagSupport?: {\n      /**\n       * The tags supported by the client.\n       */\n      valueSet: protocol.DiagnosticTag[];\n    };\n\n    /**\n     * Whether the client interprets the version property of the\n     * `textDocument/publishDiagnostics` notification's parameter.\n     *\n     * @since 3.15.0\n     */\n    versionSupport?: boolean;\n}\n\n/**\n * Represents a collection of [completion items](#CompletionItem) to be\n * presented in the editor.\n */\nexport interface CompletionList {\n    /**\n     * This list it not complete. Further typing should result in recomputing\n     * this list.\n     */\n    isIncomplete: boolean;\n\n    /**\n     * The completion items.\n     */\n    items: CompletionItem[];\n}\n\n/**\n * Defines whether the insert text in a completion item should be interpreted as\n * plain text or a snippet.\n */\nexport enum InsertTextFormat {\n  /**\n   * The primary text to be inserted is treated as a plain string.\n   */\n  PlainText = 1,\n\n  /**\n   * The primary text to be inserted is treated as a snippet.\n   *\n   * A snippet can define tab stops and placeholders with `$1`, `$2`\n   * and `${3:foo}`. `$0` defines the final tab stop, it defaults to\n   * the end of the snippet. Placeholders with equal identifiers are linked,\n   * that is typing in one will update others too.\n   */\n  Snippet = 2,\n}\n\n/**\n * A special text edit to provide an insert and a replace operation.\n *\n * @since 3.16.0\n */\nexport interface InsertReplaceEdit {\n    /**\n     * The string to be inserted.\n     */\n    newText: string;\n\n    /**\n     * The range if the insert is requested\n     */\n    insert: protocol.Range;\n\n    /**\n     * The range if the replace is requested.\n     */\n    replace: protocol.Range;\n}\n\n/**\n * How whitespace and indentation is handled during completion\n * item insertion.\n *\n * @since 3.16.0\n */\nexport enum InsertTextMode {\n  /**\n   * The insertion or replace strings is taken as it is. If the\n   * value is multi line the lines below the cursor will be\n   * inserted using the indentation defined in the string value.\n   * The client will not apply any kind of adjustments to the\n   * string.\n   */\n  asIs = 1,\n\n  /**\n   * The editor adjusts leading whitespace of new lines so that\n   * they match the indentation up to the cursor of the line for\n   * which the item is accepted.\n   *\n   * Consider a line like this: <2tabs><cursor><3tabs>foo. Accepting a\n   * multi line completion item is indented using 2 tabs and all\n   * following lines inserted will be indented using 2 tabs as well.\n   */\n  adjustIndentation = 2,\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_completion\n */\nexport interface CompletionItem {\n    /**\n     * The label of this completion item. By default\n     * also the text that is inserted when selecting\n     * this completion.\n     */\n    label: string;\n\n    /**\n     * The kind of this completion item. Based of the kind\n     * an icon is chosen by the editor. The standardized set\n     * of available values is defined in `CompletionItemKind`.\n     */\n    kind?: CompletionItemKind;\n\n    /**\n     * Tags for this completion item.\n     *\n     * @since 3.15.0\n     */\n    tags?: CompletionItemTag[];\n\n    /**\n     * A human-readable string with additional information\n     * about this item, like type or symbol information.\n     */\n    detail?: string;\n\n    /**\n     * A human-readable string that represents a doc-comment.\n     */\n    documentation?: string|MarkupContent;\n\n    /**\n     * Indicates if this item is deprecated.\n     *\n     * @deprecated Use `tags` instead if supported.\n     */\n    deprecated?: boolean;\n\n    /**\n     * Select this item when showing.\n     *\n     * *Note* that only one completion item can be selected and that the\n     * tool / client decides which item that is. The rule is that the *first*\n     * item of those that match best is selected.\n     */\n    preselect?: boolean;\n\n    /**\n     * A string that should be used when comparing this item\n     * with other items. When `falsy` the label is used.\n     */\n    sortText?: string;\n\n    /**\n     * A string that should be used when filtering a set of\n     * completion items. When `falsy` the label is used.\n     */\n    filterText?: string;\n\n    /**\n     * A string that should be inserted into a document when selecting\n     * this completion. When `falsy` the label is used.\n     *\n     * The `insertText` is subject to interpretation by the client side.\n     * Some tools might not take the string literally. For example\n     * VS Code when code complete is requested in this example\n     * `con<cursor position>` and a completion item with an `insertText` of\n     * `console` is provided it will only insert `sole`. Therefore it is\n     * recommended to use `textEdit` instead since it avoids additional client\n     * side interpretation.\n     */\n    insertText?: string;\n\n    /**\n     * The format of the insert text. The format applies to both the\n     * `insertText` property and the `newText` property of a provided\n     * `textEdit`. If omitted defaults to `InsertTextFormat.PlainText`.\n     */\n    insertTextFormat?: InsertTextFormat;\n\n    /**\n     * How whitespace and indentation is handled during completion\n     * item insertion. If not provided the client's default value depends on\n     * the `textDocument.completion.insertTextMode` client capability.\n     *\n     * @since 3.16.0\n     */\n    insertTextMode?: InsertTextMode;\n\n    /**\n     * An edit which is applied to a document when selecting this completion.\n     * When an edit is provided the value of `insertText` is ignored.\n     *\n     * *Note:* The range of the edit must be a single line range and it must\n     * contain the position at which completion has been requested.\n     *\n     * Most editors support two different operations when accepting a completion\n     * item. One is to insert a completion text and the other is to replace an\n     * existing text with a completion text. Since this can usually not be\n     * predetermined by a server it can report both ranges. Clients need to\n     * signal support for `InsertReplaceEdits` via the\n     * `textDocument.completion.insertReplaceSupport` client capability\n     * property.\n     *\n     * *Note 1:* The text edit's range as well as both ranges from an insert\n     * replace edit must be a [single line] and they must contain the position\n     * at which completion has been requested.\n     * *Note 2:* If an `InsertReplaceEdit` is returned the edit's insert range\n     * must be a prefix of the edit's replace range, that means it must be\n     * contained and starting at the same position.\n     *\n     * @since 3.16.0 additional type `InsertReplaceEdit`\n     */\n    textEdit?: TextEdit|InsertReplaceEdit;\n\n    /**\n     * An optional array of additional text edits that are applied when\n     * selecting this completion. Edits must not overlap (including the same\n     * insert position) with the main edit nor with themselves.\n     *\n     * Additional text edits should be used to change text unrelated to the\n     * current cursor position (for example adding an import statement at the\n     * top of the file if the completion item will insert an unqualified type).\n     */\n    additionalTextEdits?: TextEdit[];\n\n    /**\n     * An optional set of characters that when pressed while this completion is\n     * active will accept it first and then type that character. *Note* that all\n     * commit characters should have `length=1` and that superfluous characters\n     * will be ignored.\n     */\n    commitCharacters?: string[];\n\n    /**\n     * An optional command that is executed *after* inserting this completion.\n     * *Note* that additional modifications to the current document should be\n     * described with the additionalTextEdits-property.\n     */\n    command?: protocol.Command;\n\n    /**\n     * A data entry field that is preserved on a completion item between\n     * a completion and a completion resolve request.\n     */\n    data?: unknown;\n}\n\n\n// tslint:disable:jsdoc-format\n/**\n * A `MarkupContent` literal represents a string value which content is\n * interpreted base on its kind flag. Currently the protocol supports\n * `plaintext` and `markdown` as markup kinds.\n *\n * If the kind is `markdown` then the value can contain fenced code blocks like\n * in GitHub issues.\n *\n * Here is an example how such a string can be constructed using\n * JavaScript / TypeScript:\n * ```typescript\n * let markdown: MarkdownContent = {\n *  kind: MarkupKind.Markdown,\n *  value: [\n *    '# Header',\n *    'Some text',\n *    '```typescript',\n *    'someCode();',\n *    '```'\n *  ].join('\\n')\n * };\n * ```\n *\n * *Please Note* that clients might sanitize the return markdown. A client could\n * decide to remove HTML from the markdown to avoid script execution.\n */\n// tslint:enable:jsdoc-format\nexport interface MarkupContent {\n    /**\n     * The type of the Markup\n     */\n    kind: MarkupKind;\n\n    /**\n     * The content itself\n     */\n    value: string;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_signatureHelp\n */\nexport interface SignatureHelpParams extends TextDocumentPositionParams,\n                                             protocol.WorkDoneProgressParams {\n    /**\n     * The signature help context. This is only available if the client\n     * specifies to send this using the client capability\n     * `textDocument.signatureHelp.contextSupport === true`\n     *\n     * @since 3.15.0\n     */\n    context?: SignatureHelpContext;\n}\n\n/**\n * How a signature help was triggered.\n *\n * @since 3.15.0\n */\nexport enum SignatureHelpTriggerKind {\n  /**\n   * Signature help was invoked manually by the user or by a command.\n   */\n  Invoked = 1,\n  /**\n   * Signature help was triggered by a trigger character.\n   */\n  TriggerCharacter = 2,\n  /**\n   * Signature help was triggered by the cursor moving or by the document\n   * content changing.\n   */\n  ContentChange = 3,\n}\n\n/**\n * Additional information about the context in which a signature help request\n * was triggered.\n *\n * @since 3.15.0\n */\nexport interface SignatureHelpContext {\n    /**\n     * Action that caused signature help to be triggered.\n     */\n    triggerKind: SignatureHelpTriggerKind;\n\n    /**\n     * Character that caused signature help to be triggered.\n     *\n     * This is undefined when triggerKind !==\n     * SignatureHelpTriggerKind.TriggerCharacter\n     */\n    triggerCharacter?: string;\n\n    /**\n     * `true` if signature help was already showing when it was triggered.\n     *\n     * Retriggers occur when the signature help is already active and can be\n     * caused by actions such as typing a trigger character, a cursor move, or\n     * document content changes.\n     */\n    isRetrigger: boolean;\n\n    /**\n     * The currently active `SignatureHelp`.\n     *\n     * The `activeSignatureHelp` has its `SignatureHelp.activeSignature` field\n     * updated based on the user navigating through available signatures.\n     */\n    activeSignatureHelp?: SignatureHelp;\n}\n\n/**\n * Signature help represents the signature of something\n * callable. There can be multiple signature but only one\n * active and only one active parameter.\n */\nexport interface SignatureHelp {\n    /**\n     * One or more signatures. If no signatures are available the signature help\n     * request should return `null`.\n     */\n    signatures: SignatureInformation[];\n\n    /**\n     * The active signature. If omitted or the value lies outside the\n     * range of `signatures` the value defaults to zero or is ignored if\n     * the `SignatureHelp` has no signatures.\n     *\n     * Whenever possible implementors should make an active decision about\n     * the active signature and shouldn't rely on a default value.\n     *\n     * In future version of the protocol this property might become\n     * mandatory to better express this.\n     */\n    activeSignature?: protocol.uinteger;\n\n    /**\n     * The active parameter of the active signature. If omitted or the value\n     * lies outside the range of `signatures[activeSignature].parameters`\n     * defaults to 0 if the active signature has parameters. If\n     * the active signature has no parameters it is ignored.\n     * In future version of the protocol this property might become\n     * mandatory to better express the active parameter if the\n     * active signature does have any.\n     */\n    activeParameter?: protocol.uinteger;\n}\n\n/**\n * Represents the signature of something callable. A signature\n * can have a label, like a function-name, a doc-comment, and\n * a set of parameters.\n */\nexport interface SignatureInformation {\n    /**\n     * The label of this signature. Will be shown in\n     * the UI.\n     */\n    label: string;\n\n    /**\n     * The human-readable doc-comment of this signature. Will be shown\n     * in the UI but can be omitted.\n     */\n    documentation?: string|MarkupContent;\n\n    /**\n     * The parameters of this signature.\n     */\n    parameters?: ParameterInformation[];\n\n    /**\n     * The index of the active parameter.\n     *\n     * If provided, this is used in place of `SignatureHelp.activeParameter`.\n     *\n     * @since 3.16.0\n     */\n    activeParameter?: protocol.uinteger;\n}\n\n/**\n * Represents a parameter of a callable-signature. A parameter can\n * have a label and a doc-comment.\n */\nexport interface ParameterInformation {\n    /**\n     * The label of this parameter information.\n     *\n     * Either a string or an inclusive start and exclusive end offsets within\n     * its containing signature label. (see SignatureInformation.label). The\n     * offsets are based on a UTF-16 string representation as `Position` and\n     * `Range` does.\n     *\n     * *Note*: a label of type string should be a substring of its containing\n     * signature label. Its intended use case is to highlight the parameter\n     * label part in the `SignatureInformation.label`.\n     */\n    label: string|[protocol.uinteger, protocol.uinteger];\n\n    /**\n     * The human-readable doc-comment of this parameter. Will be shown\n     * in the UI but can be omitted.\n     */\n    documentation?: string|MarkupContent;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-current/#textDocument_hover\n */\nexport interface HoverParams extends TextDocumentPositionParams,\n                                     protocol.WorkDoneProgressParams {}\n\n/**\n * The result of a hover request.\n */\nexport interface Hover {\n    /**\n     * The hover's content\n     */\n    contents: MarkupContent;\n\n    /**\n     * An optional range is a range inside a text document\n     * that is used to visualize a hover, e.g. by changing the background color.\n     */\n    range?: protocol.Range;\n}\n\n/**\n * https://microsoft.github.io/language-server-protocol/specifications/specification-3-17/#definitionParams\n */\nexport interface DefinitionParams extends TextDocumentPositionParams,\n                                          protocol.WorkDoneProgressParams,\n                                          protocol.PartialResultParams {}\n\n/**\n * Params for the custom 'echoDocument' comment which returns the current state\n * of the server's view of the LSP document.\n */\nexport interface EchoDocumentParams {}\n\n/**\n * Params for the CodeActionRequest\n */\nexport interface CodeActionParams extends protocol.WorkDoneProgressParams,\n                                          protocol.PartialResultParams {\n    /**\n     * The document in which the command was invoked.\n     */\n    textDocument: TextDocumentIdentifier;\n\n    /**\n     * The range for which the command was invoked.\n     */\n    range: protocol.Range;\n\n    /**\n     * Context carrying additional information.\n     */\n    context: CodeActionContext;\n}\n\n/**\n * Params for the RenameRequest\n */\nexport interface RenameParams extends TextDocumentPositionParams,\n                                      protocol.WorkDoneProgressParams {\n  /**\n   * The new name of the symbol. If the given name is not valid the\n   * request must return a [ResponseError](#ResponseError) with an\n   * appropriate message set.\n   */\n  newName: string;\n}\n\n/**\n * A code action represents a change that can be performed in code, e.g. to fix\n * a problem or to refactor code.\n *\n * A CodeAction must set either `edit` and/or a `command`. If both are supplied,\n * the `edit` is applied first, then the `command` is executed.\n */\nexport interface CodeAction {\n    /**\n     * A short, human-readable, title for this code action.\n     */\n    title: string;\n\n    /**\n     * The kind of the code action.\n     *\n     * Used to filter code actions.\n     */\n    kind?: CodeActionKind;\n\n    /**\n     * The diagnostics that this code action resolves.\n     */\n    diagnostics?: protocol.Diagnostic[];\n\n    /**\n     * Marks this as a preferred action. Preferred actions are used by the\n     * `auto fix` command and can be targeted by keybindings.\n     *\n     * A quick fix should be marked preferred if it properly addresses the\n     * underlying error. A refactoring should be marked preferred if it is the\n     * most reasonable choice of actions to take.\n     *\n     * @since 3.15.0\n     */\n    isPreferred?: boolean;\n\n    /**\n     * Marks that the code action cannot currently be applied.\n     *\n     * Clients should follow the following guidelines regarding disabled code\n     * actions:\n     *\n     * - Disabled code actions are not shown in automatic lightbulbs code\n     *   action menus.\n     *\n     * - Disabled actions are shown as faded out in the code action menu when\n     *   the user request a more specific type of code action, such as\n     *   refactorings.\n     *\n     * - If the user has a keybinding that auto applies a code action and only\n     *   a disabled code actions are returned, the client should show the user\n     *   an error message with `reason` in the editor.\n     *\n     * @since 3.16.0\n     */\n    disabled?: {\n\n      /**\n       * Human readable description of why the code action is currently\n       * disabled.\n       *\n       * This is displayed in the code actions UI.\n       */\n      reason: string;\n    };\n\n    /**\n     * The workspace edit this code action performs.\n     */\n    edit?: workspace.WorkspaceEdit;\n\n    /**\n     * A command this code action executes. If a code action\n     * provides an edit and a command, first the edit is\n     * executed and then the command.\n     */\n    command?: protocol.Command;\n\n    /**\n     * A data entry field that is preserved on a code action between\n     * a `textDocument/codeAction` and a `codeAction/resolve` request.\n     *\n     * @since 3.16.0\n     */\n    data?: unknown;\n}\n// tslint:enable:enforce-name-casing\n"]}
|
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
|
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 */\ninterface 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"]}
|
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
|
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
|
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
|
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
|
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
|
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
|
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.
|
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
|
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 |
+
}
|
web/node_modules/accepts/package.json
ADDED
@@ -0,0 +1,50 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
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 |
+
|
47 |
+
,"_resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.5.tgz"
|
48 |
+
,"_integrity": "sha1-63d99gEXI6OxTopywIBcjoZ0a9I="
|
49 |
+
,"_from": "[email protected]"
|
50 |
+
}
|
web/node_modules/after/.npmignore
ADDED
@@ -0,0 +1,2 @@
|
|
|
|
|
|
|
1 |
+
node_modules
|
2 |
+
.monitor
|
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
|
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.
|
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
|
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() {}
|
web/node_modules/after/package.json
ADDED
@@ -0,0 +1,32 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
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 |
+
|
29 |
+
,"_resolved": "https://registry.npmjs.org/after/-/after-0.8.2.tgz"
|
30 |
+
,"_integrity": "sha1-/ts5T58OAqqXaOcCvaI7UF+ufh8="
|
31 |
+
,"_from": "[email protected]"
|
32 |
+
}
|
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 |
+
|
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
|
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.
|
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
|
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.
|
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 |
+
};
|
web/node_modules/arraybuffer.slice/package.json
ADDED
@@ -0,0 +1,20 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
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 |
+
|
17 |
+
,"_resolved": "https://registry.npmjs.org/arraybuffer.slice/-/arraybuffer.slice-0.0.7.tgz"
|
18 |
+
,"_integrity": "sha512-wGUIVQXuehL5TCqQun8OW81jGzAWycqzFF8lFp+GOM5BXLYj3bKNsYC4daB7n6XjCqxQA/qgTJ+8ANR3acjrog=="
|
19 |
+
,"_from": "[email protected]"
|
20 |
+
}
|
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 |
+
});
|
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
|
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.
|
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}}]}}}}
|
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>
|
19 |
+
Branches: <span class="metric">92.86% <small>(13 / 14)</small></span>
|
20 |
+
Functions: <span class="metric">100% <small>(7 / 7)</small></span>
|
21 |
+
Lines: <span class="metric">100% <small>(37 / 37)</small></span>
|
22 |
+
Ignored: <span class="metric"><span class="ignore-none">none</span></span>
|
23 |
+
</h2>
|
24 |
+
<div class="path"><a href="../index.html">All files</a> » 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 / 37)</td>
|
48 |
+
<td data-value="92.86" class="pct high">92.86%</td>
|
49 |
+
<td data-value="14" class="abs high">(13 / 14)</td>
|
50 |
+
<td data-value="100" class="pct high">100%</td>
|
51 |
+
<td data-value="7" class="abs high">(7 / 7)</td>
|
52 |
+
<td data-value="100" class="pct high">100%</td>
|
53 |
+
<td data-value="37" class="abs high">(37 / 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>
|
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>
|
19 |
+
Branches: <span class="metric">92.86% <small>(13 / 14)</small></span>
|
20 |
+
Functions: <span class="metric">100% <small>(7 / 7)</small></span>
|
21 |
+
Lines: <span class="metric">100% <small>(37 / 37)</small></span>
|
22 |
+
Ignored: <span class="metric"><span class="ignore-none">none</span></span>
|
23 |
+
</h2>
|
24 |
+
<div class="path"><a href="../index.html">All files</a> » <a href="index.html">async-throttle/</a> » 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"> </span>
|
96 |
+
<span class="cline-any cline-neutral"> </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"> </span>
|
101 |
+
<span class="cline-any cline-neutral"> </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"> </span>
|
109 |
+
<span class="cline-any cline-neutral"> </span>
|
110 |
+
<span class="cline-any cline-yes">1</span>
|
111 |
+
<span class="cline-any cline-neutral"> </span>
|
112 |
+
<span class="cline-any cline-neutral"> </span>
|
113 |
+
<span class="cline-any cline-neutral"> </span>
|
114 |
+
<span class="cline-any cline-neutral"> </span>
|
115 |
+
<span class="cline-any cline-neutral"> </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"> </span>
|
122 |
+
<span class="cline-any cline-neutral"> </span>
|
123 |
+
<span class="cline-any cline-neutral"> </span>
|
124 |
+
<span class="cline-any cline-yes">1</span>
|
125 |
+
<span class="cline-any cline-neutral"> </span>
|
126 |
+
<span class="cline-any cline-yes">19</span>
|
127 |
+
<span class="cline-any cline-neutral"> </span>
|
128 |
+
<span class="cline-any cline-neutral"> </span>
|
129 |
+
<span class="cline-any cline-neutral"> </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"> </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"> </span>
|
140 |
+
<span class="cline-any cline-neutral"> </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"> </span>
|
146 |
+
<span class="cline-any cline-neutral"> </span>
|
147 |
+
<span class="cline-any cline-neutral"> </span>
|
148 |
+
<span class="cline-any cline-neutral"> </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"> </span>
|
154 |
+
<span class="cline-any cline-neutral"> </span>
|
155 |
+
<span class="cline-any cline-neutral"> </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"> </span>
|
160 |
+
<span class="cline-any cline-neutral"> </span>
|
161 |
+
<span class="cline-any cline-yes">1</span>
|
162 |
+
<span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">'use strict';
|
163 |
+
|
164 |
+
function Queue(options) {
|
165 |
+
if (!(this instanceof Queue)) {
|
166 |
+
return new Queue(options);
|
167 |
+
}
|
168 |
+
|
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 |
+
|
177 |
+
var arrayAddMethods = [
|
178 |
+
'push',
|
179 |
+
'unshift',
|
180 |
+
'splice'
|
181 |
+
];
|
182 |
+
|
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 |
+
|
191 |
+
Object.defineProperty(Queue.prototype, 'length', {
|
192 |
+
get: function() {
|
193 |
+
return this.pending + this.jobs.length;
|
194 |
+
}
|
195 |
+
});
|
196 |
+
|
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 |
+
|
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 |
+
|
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 |
+
|
223 |
+
function done() {
|
224 |
+
this.pending--;
|
225 |
+
this._run();
|
226 |
+
}
|
227 |
+
|
228 |
+
module.exports = Queue;
|
229 |
+
</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>
|
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; }
|
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>
|
19 |
+
Branches: <span class="metric">92.86% <small>(13 / 14)</small></span>
|
20 |
+
Functions: <span class="metric">100% <small>(7 / 7)</small></span>
|
21 |
+
Lines: <span class="metric">100% <small>(37 / 37)</small></span>
|
22 |
+
Ignored: <span class="metric"><span class="ignore-none">none</span></span>
|
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 / 37)</td>
|
48 |
+
<td data-value="92.86" class="pct high">92.86%</td>
|
49 |
+
<td data-value="14" class="abs high">(13 / 14)</td>
|
50 |
+
<td data-value="100" class="pct high">100%</td>
|
51 |
+
<td data-value="7" class="abs high">(7 / 7)</td>
|
52 |
+
<td data-value="100" class="pct high">100%</td>
|
53 |
+
<td data-value="37" class="abs high">(37 / 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>
|
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}
|
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"]);
|
web/node_modules/async-limiter/coverage/lcov-report/sort-arrow-sprite.png
ADDED
![]() |
web/node_modules/async-limiter/coverage/lcov-report/sorter.js
ADDED
@@ -0,0 +1,156 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
var addSorting = (function () {
|
2 |
+
"use strict";
|
3 |
+
var cols,
|
4 |
+
currentSort = {
|
5 |
+
index: 0,
|
6 |
+
desc: false
|
7 |
+
};
|
8 |
+
|
9 |
+
// returns the summary table element
|
10 |
+
function getTable() { return document.querySelector('.coverage-summary table'); }
|
11 |
+
// returns the thead element of the summary table
|
12 |
+
function getTableHeader() { return getTable().querySelector('thead tr'); }
|
13 |
+
// returns the tbody element of the summary table
|
14 |
+
function getTableBody() { return getTable().querySelector('tbody'); }
|
15 |
+
// returns the th element for nth column
|
16 |
+
function getNthColumn(n) { return getTableHeader().querySelectorAll('th')[n]; }
|
17 |
+
|
18 |
+
// loads all columns
|
19 |
+
function loadColumns() {
|
20 |
+
var colNodes = getTableHeader().querySelectorAll('th'),
|
21 |
+
colNode,
|
22 |
+
cols = [],
|
23 |
+
col,
|
24 |
+
i;
|
25 |
+
|
26 |
+
for (i = 0; i < colNodes.length; i += 1) {
|
27 |
+
colNode = colNodes[i];
|
28 |
+
col = {
|
29 |
+
key: colNode.getAttribute('data-col'),
|
30 |
+
sortable: !colNode.getAttribute('data-nosort'),
|
31 |
+
type: colNode.getAttribute('data-type') || 'string'
|
32 |
+
};
|
33 |
+
cols.push(col);
|
34 |
+
if (col.sortable) {
|
35 |
+
col.defaultDescSort = col.type === 'number';
|
36 |
+
colNode.innerHTML = colNode.innerHTML + '<span class="sorter"></span>';
|
37 |
+
}
|
38 |
+
}
|
39 |
+
return cols;
|
40 |
+
}
|
41 |
+
// attaches a data attribute to every tr element with an object
|
42 |
+
// of data values keyed by column name
|
43 |
+
function loadRowData(tableRow) {
|
44 |
+
var tableCols = tableRow.querySelectorAll('td'),
|
45 |
+
colNode,
|
46 |
+
col,
|
47 |
+
data = {},
|
48 |
+
i,
|
49 |
+
val;
|
50 |
+
for (i = 0; i < tableCols.length; i += 1) {
|
51 |
+
colNode = tableCols[i];
|
52 |
+
col = cols[i];
|
53 |
+
val = colNode.getAttribute('data-value');
|
54 |
+
if (col.type === 'number') {
|
55 |
+
val = Number(val);
|
56 |
+
}
|
57 |
+
data[col.key] = val;
|
58 |
+
}
|
59 |
+
return data;
|
60 |
+
}
|
61 |
+
// loads all row data
|
62 |
+
function loadData() {
|
63 |
+
var rows = getTableBody().querySelectorAll('tr'),
|
64 |
+
i;
|
65 |
+
|
66 |
+
for (i = 0; i < rows.length; i += 1) {
|
67 |
+
rows[i].data = loadRowData(rows[i]);
|
68 |
+
}
|
69 |
+
}
|
70 |
+
// sorts the table using the data for the ith column
|
71 |
+
function sortByIndex(index, desc) {
|
72 |
+
var key = cols[index].key,
|
73 |
+
sorter = function (a, b) {
|
74 |
+
a = a.data[key];
|
75 |
+
b = b.data[key];
|
76 |
+
return a < b ? -1 : a > b ? 1 : 0;
|
77 |
+
},
|
78 |
+
finalSorter = sorter,
|
79 |
+
tableBody = document.querySelector('.coverage-summary tbody'),
|
80 |
+
rowNodes = tableBody.querySelectorAll('tr'),
|
81 |
+
rows = [],
|
82 |
+
i;
|
83 |
+
|
84 |
+
if (desc) {
|
85 |
+
finalSorter = function (a, b) {
|
86 |
+
return -1 * sorter(a, b);
|
87 |
+
};
|
88 |
+
}
|
89 |
+
|
90 |
+
for (i = 0; i < rowNodes.length; i += 1) {
|
91 |
+
rows.push(rowNodes[i]);
|
92 |
+
tableBody.removeChild(rowNodes[i]);
|
93 |
+
}
|
94 |
+
|
95 |
+
rows.sort(finalSorter);
|
96 |
+
|
97 |
+
for (i = 0; i < rows.length; i += 1) {
|
98 |
+
tableBody.appendChild(rows[i]);
|
99 |
+
}
|
100 |
+
}
|
101 |
+
// removes sort indicators for current column being sorted
|
102 |
+
function removeSortIndicators() {
|
103 |
+
var col = getNthColumn(currentSort.index),
|
104 |
+
cls = col.className;
|
105 |
+
|
106 |
+
cls = cls.replace(/ sorted$/, '').replace(/ sorted-desc$/, '');
|
107 |
+
col.className = cls;
|
108 |
+
}
|
109 |
+
// adds sort indicators for current column being sorted
|
110 |
+
function addSortIndicators() {
|
111 |
+
getNthColumn(currentSort.index).className += currentSort.desc ? ' sorted-desc' : ' sorted';
|
112 |
+
}
|
113 |
+
// adds event listeners for all sorter widgets
|
114 |
+
function enableUI() {
|
115 |
+
var i,
|
116 |
+
el,
|
117 |
+
ithSorter = function ithSorter(i) {
|
118 |
+
var col = cols[i];
|
119 |
+
|
120 |
+
return function () {
|
121 |
+
var desc = col.defaultDescSort;
|
122 |
+
|
123 |
+
if (currentSort.index === i) {
|
124 |
+
desc = !currentSort.desc;
|
125 |
+
}
|
126 |
+
sortByIndex(i, desc);
|
127 |
+
removeSortIndicators();
|
128 |
+
currentSort.index = i;
|
129 |
+
currentSort.desc = desc;
|
130 |
+
addSortIndicators();
|
131 |
+
};
|
132 |
+
};
|
133 |
+
for (i =0 ; i < cols.length; i += 1) {
|
134 |
+
if (cols[i].sortable) {
|
135 |
+
el = getNthColumn(i).querySelector('.sorter');
|
136 |
+
if (el.addEventListener) {
|
137 |
+
el.addEventListener('click', ithSorter(i));
|
138 |
+
} else {
|
139 |
+
el.attachEvent('onclick', ithSorter(i));
|
140 |
+
}
|
141 |
+
}
|
142 |
+
}
|
143 |
+
}
|
144 |
+
// adds sorting functionality to the UI
|
145 |
+
return function () {
|
146 |
+
if (!getTable()) {
|
147 |
+
return;
|
148 |
+
}
|
149 |
+
cols = loadColumns();
|
150 |
+
loadData(cols);
|
151 |
+
addSortIndicators();
|
152 |
+
enableUI();
|
153 |
+
};
|
154 |
+
})();
|
155 |
+
|
156 |
+
window.addEventListener('load', addSorting);
|