New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

nuclide-logging

Package Overview
Dependencies
Maintainers
1
Versions
26
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

nuclide-logging - npm Package Compare versions

Comparing version 0.0.34 to 0.0.35

27

lib/config.js

@@ -1,10 +0,1 @@

/*
* Copyright (c) 2015-present, Facebook, Inc.
* All rights reserved.
*
* This source code is licensed under the license found in the LICENSE file in
* the root directory of this source tree.
*/
var getServerLogAppenderConfig = _asyncToGenerator(function* () {

@@ -37,2 +28,12 @@ // Skip config scribe_cat logger if

/*
* Copyright (c) 2015-present, Facebook, Inc.
* All rights reserved.
*
* This source code is licensed under the license found in the LICENSE file in
* the root directory of this source tree.
*/
'use babel';
var _require = require('nuclide-commons');

@@ -50,6 +51,8 @@

var LOG_FILE_PATH = undefined;
if (systemInfo.isRunningInWindows()) {
var LOG_FILE_PATH = path.join(os.tmpdir(), '/nuclide-' + USER + '-logs/nuclide.log');
LOG_FILE_PATH = path.join(os.tmpdir(), '/nuclide-' + USER + '-logs/nuclide.log');
} else {
var LOG_FILE_PATH = '/tmp/nuclide-' + USER + '-logs/nuclide.log';
LOG_FILE_PATH = '/tmp/nuclide-' + USER + '-logs/nuclide.log';
}

@@ -118,2 +121,2 @@

};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi92YXIvZm9sZGVycy82NC9uNHJoMDk2eDRwMWJrNndyd3prX3I1M21ya21sMjAvVC90bXAxVGZDWXFwdWJsaXNoX3BhY2thZ2VzL25wbS9udWNsaWRlLWxvZ2dpbmcvbGliL2NvbmZpZy5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxXQUFXLENBQUM7Ozs7Ozs7Ozs7SUE0QkcsMEJBQTBCLHFCQUF6QyxhQUE4RDs7Ozs7O0FBTTVELE1BQUksVUFBVSxDQUFDLGVBQWUsRUFBRSxJQUM1QixVQUFVLENBQUMsaUJBQWlCLEVBQUUsSUFDOUIsRUFBRSxNQUFNLFNBQVMsQ0FBQyxNQUFNLENBQUMsa0JBQWtCLENBQUMsQ0FBQSxBQUFDLElBQzdDLEVBQUUsTUFBTSxhQUFhLENBQUMsaUJBQWlCLEVBQUUsQ0FBQSxBQUFDLEVBQUU7QUFDOUMsV0FBTyxJQUFJLENBQUM7R0FDYjs7QUFFRCxTQUFPO0FBQ0wsUUFBSSxFQUFFLGdCQUFnQjtBQUN0QixTQUFLLEVBQUUsT0FBTztBQUNkLFlBQVEsRUFBRTtBQUNSLFVBQUksRUFBRSxrQkFBa0I7QUFDeEIsb0JBQWMsRUFBRSxrQkFBa0I7S0FDbkM7R0FDRixDQUFDO0NBQ0g7Ozs7Ozs7OztlQXRDd0QsT0FBTyxDQUFDLGlCQUFpQixDQUFDOztJQUE5RSxVQUFVLFlBQVYsVUFBVTtJQUFFLFNBQVMsWUFBVCxTQUFTO0lBQUUsVUFBVSxZQUFWLFVBQVU7SUFBRSxhQUFhLFlBQWIsYUFBYTs7QUFDckQsSUFBSSxFQUFFLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDO0FBQ3ZCLElBQUksSUFBSSxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQzs7SUFDdEIsSUFBSSxHQUFJLE9BQU8sQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDLEdBQUcsQ0FBdEMsSUFBSTs7QUFFVCxJQUFJLFVBQVUsQ0FBQyxrQkFBa0IsRUFBRSxFQUFFO0FBQ25DLE1BQUksYUFBYSxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLE1BQU0sRUFBRSxnQkFBYyxJQUFJLHVCQUFvQixDQUFDO0NBQ2pGLE1BQU07QUFDTCxNQUFJLGFBQWEscUJBQW1CLElBQUksc0JBQW1CLENBQUM7Q0FDN0Q7O0FBRUQsSUFBSSxZQUFZLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQUMsQ0FBQztBQUMvQyxJQUFJLHVCQUF1QixHQUFHLEtBQUssQ0FBQztBQUNwQyxJQUFJLGtCQUFrQixHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFLHlCQUF5QixDQUFDLENBQUM7O0FBRXpFLElBQUksa0JBQWtCLEdBQUcsYUFBYSxDQUFDOztBQTRCdkMsU0FBUyx1QkFBdUIsQ0FBQyxVQUFnQixFQUFVO0FBQ3pELE1BQUksZUFBZSxHQUFHLE9BQU8sQ0FBQyx3QkFBd0IsQ0FBQyxDQUFDLFFBQVEsQ0FBQztBQUNqRSxTQUFPLGFBQWEsR0FBRyxlQUFlLENBQUMsa0JBQWtCLEVBQUUsVUFBVSxDQUFDLENBQUM7Q0FDeEU7Ozs7O0FBS0QsU0FBUyx3QkFBd0IsR0FBVztBQUMxQyxTQUFPLHVCQUF1QixDQUFDLElBQUksSUFBSSxFQUFFLENBQUMsQ0FBQztDQUM1Qzs7QUFFRCxNQUFNLENBQUMsT0FBTyxHQUFHO0FBQ2YsQUFBTSxrQkFBZ0Isb0JBQUEsYUFBbUI7O0FBRXZDLFFBQUksQ0FBQyx1QkFBdUIsRUFBRTtBQUM1QixZQUFNLFNBQVMsQ0FBQyxNQUFNLENBQUMsWUFBWSxDQUFDLENBQUM7QUFDckMsNkJBQXVCLEdBQUcsSUFBSSxDQUFDO0tBQ2hDOztBQUVELFFBQU0sTUFBTSxHQUFHO0FBQ2IsZUFBUyxFQUFFLENBQ1Q7QUFDRSxZQUFJLEVBQUUsZ0JBQWdCO0FBQ3RCLGFBQUssRUFBRSxNQUFNO0FBQ2IsZ0JBQVEsRUFBRTtBQUNSLGNBQUksRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxtQkFBbUIsQ0FBQztTQUNoRDtPQUNGLEVBQ0Q7QUFDRSxZQUFJLEVBQUUsVUFBVTtBQUNoQiw0QkFBb0IsRUFBRSxJQUFJO0FBQzFCLGdCQUFRLEVBQUUsSUFBSTtBQUNkLGdCQUFRLEVBQUUsYUFBYTtBQUN2QixlQUFPLEVBQUUsa0JBQWtCO0FBQzNCLGNBQU0sRUFBRTtBQUNOLGNBQUksRUFBRSxTQUFTOzs7QUFHZixpQkFBTywyQkFBeUIsT0FBTyxDQUFDLEdBQUcsY0FBVztTQUN2RDtPQUNGLENBQ0Y7S0FDRixDQUFDOztBQUVGLFFBQUksdUJBQXVCLEdBQUcsTUFBTSwwQkFBMEIsRUFBRSxDQUFDO0FBQ2pFLFFBQUksdUJBQXVCLEVBQUU7QUFDM0IsWUFBTSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsdUJBQXVCLENBQUMsQ0FBQztLQUNoRDs7QUFFRCxXQUFPLE1BQU0sQ0FBQztHQUNmLENBQUE7QUFDRCwwQkFBd0IsRUFBeEIsd0JBQXdCO0FBQ3hCLGVBQWEsRUFBYixhQUFhO0FBQ2IsVUFBUSxFQUFFO0FBQ1IsMkJBQXVCLEVBQXZCLHVCQUF1QjtHQUN4QjtDQUNGLENBQUMiLCJmaWxlIjoiL3Zhci9mb2xkZXJzLzY0L240cmgwOTZ4NHAxYms2d3J3emtfcjUzbXJrbWwyMC9UL3RtcDFUZkNZcXB1Ymxpc2hfcGFja2FnZXMvbnBtL251Y2xpZGUtbG9nZ2luZy9saWIvY29uZmlnLmpzIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBiYWJlbCc7XG4vKiBAZmxvdyAqL1xuXG4vKlxuICogQ29weXJpZ2h0IChjKSAyMDE1LXByZXNlbnQsIEZhY2Vib29rLCBJbmMuXG4gKiBBbGwgcmlnaHRzIHJlc2VydmVkLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIGxpY2Vuc2UgZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBpblxuICogdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKi9cblxudmFyIHtjbGllbnRJbmZvLCBmc1Byb21pc2UsIHN5c3RlbUluZm8sIFNjcmliZVByb2Nlc3N9ID0gcmVxdWlyZSgnbnVjbGlkZS1jb21tb25zJyk7XG52YXIgb3MgPSByZXF1aXJlKCdvcycpO1xudmFyIHBhdGggPSByZXF1aXJlKCdwYXRoJyk7XG52YXIge1VTRVJ9ID0gcmVxdWlyZSgnbnVjbGlkZS1jb21tb25zJykuZW52O1xuXG5pZiAoc3lzdGVtSW5mby5pc1J1bm5pbmdJbldpbmRvd3MoKSkge1xuICB2YXIgTE9HX0ZJTEVfUEFUSCA9IHBhdGguam9pbihvcy50bXBkaXIoKSwgYC9udWNsaWRlLSR7VVNFUn0tbG9ncy9udWNsaWRlLmxvZ2ApO1xufSBlbHNlIHtcbiAgdmFyIExPR19GSUxFX1BBVEggPSBgL3RtcC9udWNsaWRlLSR7VVNFUn0tbG9ncy9udWNsaWRlLmxvZ2A7XG59XG5cbnZhciBsb2dEaXJlY3RvcnkgPSBwYXRoLmRpcm5hbWUoTE9HX0ZJTEVfUEFUSCk7XG52YXIgbG9nRGlyZWN0b3J5SW5pdGlhbGl6ZWQgPSBmYWxzZTtcbnZhciBzY3JpYmVBcHBlbmRlclBhdGggPSBwYXRoLmpvaW4oX19kaXJuYW1lLCAnLi4vZmIvc2NyaWJlQXBwZW5kZXIuanMnKTtcblxudmFyIExPRzRKU19EQVRFX0ZPUk1BVCA9ICcteXl5eS1NTS1kZCc7XG5cbmFzeW5jIGZ1bmN0aW9uIGdldFNlcnZlckxvZ0FwcGVuZGVyQ29uZmlnKCk6IFByb21pc2U8P09iamVjdD4ge1xuICAvLyBTa2lwIGNvbmZpZyBzY3JpYmVfY2F0IGxvZ2dlciBpZlxuICAvLyAxKSBydW5uaW5nIGluIHRlc3QgZW52aXJvbm1lbnRcbiAgLy8gMikgb3IgcnVubmluZyBpbiBBdG9tIGNsaWVudFxuICAvLyAzKSBvciBydW5uaW5nIGluIG9wZW4gc291cmNlZCB2ZXJzaW9uIG9mIG51Y2xpZGVcbiAgLy8gNCkgb3IgdGhlIHNjcmliZV9jYXQgY29tbWFuZCBpcyBtaXNzaW5nLlxuICBpZiAoY2xpZW50SW5mby5pc1J1bm5pbmdJblRlc3QoKSB8fFxuICAgICAgY2xpZW50SW5mby5pc1J1bm5pbmdJbkNsaWVudCgpIHx8XG4gICAgICAhKGF3YWl0IGZzUHJvbWlzZS5leGlzdHMoc2NyaWJlQXBwZW5kZXJQYXRoKSkgfHxcbiAgICAgICEoYXdhaXQgU2NyaWJlUHJvY2Vzcy5pc1NjcmliZUNhdE9uUGF0aCgpKSkge1xuICAgIHJldHVybiBudWxsO1xuICB9XG5cbiAgcmV0dXJuIHtcbiAgICB0eXBlOiAnbG9nTGV2ZWxGaWx0ZXInLFxuICAgIGxldmVsOiAnREVCVUcnLFxuICAgIGFwcGVuZGVyOiB7XG4gICAgICB0eXBlOiBzY3JpYmVBcHBlbmRlclBhdGgsXG4gICAgICBzY3JpYmVDYXRlZ29yeTogJ2Vycm9ybG9nX2Fyc2VuYWwnLFxuICAgIH0sXG4gIH07XG59XG5cbi8qKlxuICogQHJldHVybiBUaGUgYWJzb2x1dGUgcGF0aCB0byB0aGUgbG9nIGZpbGUgZm9yIHRoZSBzcGVjaWZpZWQgZGF0ZS5cbiAqL1xuZnVuY3Rpb24gZ2V0UGF0aFRvTG9nRmlsZUZvckRhdGUodGFyZ2V0RGF0ZTogRGF0ZSk6IHN0cmluZyB7XG4gIHZhciBsb2c0anNGb3JtYXR0ZXIgPSByZXF1aXJlKCdsb2c0anMvbGliL2RhdGVfZm9ybWF0JykuYXNTdHJpbmc7XG4gIHJldHVybiBMT0dfRklMRV9QQVRIICsgbG9nNGpzRm9ybWF0dGVyKExPRzRKU19EQVRFX0ZPUk1BVCwgdGFyZ2V0RGF0ZSk7XG59XG5cbi8qKlxuICogQHJldHVybiBUaGUgYWJzb2x1dGUgcGF0aCB0byB0aGUgbG9nIGZpbGUgZm9yIHRvZGF5LlxuICovXG5mdW5jdGlvbiBnZXRQYXRoVG9Mb2dGaWxlRm9yVG9kYXkoKTogc3RyaW5nIHtcbiAgcmV0dXJuIGdldFBhdGhUb0xvZ0ZpbGVGb3JEYXRlKG5ldyBEYXRlKCkpO1xufVxuXG5tb2R1bGUuZXhwb3J0cyA9IHtcbiAgYXN5bmMgZ2V0RGVmYXVsdENvbmZpZygpOiBQcm9taXNlPG1peGVkPiB7XG5cbiAgICBpZiAoIWxvZ0RpcmVjdG9yeUluaXRpYWxpemVkKSB7XG4gICAgICBhd2FpdCBmc1Byb21pc2UubWtkaXJwKGxvZ0RpcmVjdG9yeSk7XG4gICAgICBsb2dEaXJlY3RvcnlJbml0aWFsaXplZCA9IHRydWU7XG4gICAgfVxuXG4gICAgY29uc3QgY29uZmlnID0ge1xuICAgICAgYXBwZW5kZXJzOiBbXG4gICAgICAgIHtcbiAgICAgICAgICB0eXBlOiAnbG9nTGV2ZWxGaWx0ZXInLFxuICAgICAgICAgIGxldmVsOiAnSU5GTycsXG4gICAgICAgICAgYXBwZW5kZXI6IHtcbiAgICAgICAgICAgIHR5cGU6IHBhdGguam9pbihfX2Rpcm5hbWUsICcuL2NvbnNvbGVBcHBlbmRlcicpLFxuICAgICAgICAgIH0sXG4gICAgICAgIH0sXG4gICAgICAgIHtcbiAgICAgICAgICB0eXBlOiAnZGF0ZUZpbGUnLFxuICAgICAgICAgIGFsd2F5c0luY2x1ZGVQYXR0ZXJuOiB0cnVlLFxuICAgICAgICAgIGFic29sdXRlOiB0cnVlLFxuICAgICAgICAgIGZpbGVuYW1lOiBMT0dfRklMRV9QQVRILFxuICAgICAgICAgIHBhdHRlcm46IExPRzRKU19EQVRFX0ZPUk1BVCxcbiAgICAgICAgICBsYXlvdXQ6IHtcbiAgICAgICAgICAgIHR5cGU6ICdwYXR0ZXJuJyxcbiAgICAgICAgICAgIC8vIEZvcm1hdCBsb2cgaW4gZm9sbG93aW5nIHBhdHRlcm46XG4gICAgICAgICAgICAvLyB5eXl5LU1NLWRkIEhIOm1tOnNzLm1pbCAkTGV2ZWwgKHBpZDokcGlkKSAkY2F0ZWdyb3kgLSAkbWVzc2FnZS5cbiAgICAgICAgICAgIHBhdHRlcm46IGAlZHtJU084NjAxfSAlcCAocGlkOiR7cHJvY2Vzcy5waWR9KSAlYyAtICVtYCxcbiAgICAgICAgICB9LFxuICAgICAgICB9LFxuICAgICAgXSxcbiAgICB9O1xuXG4gICAgdmFyIHNlcnZlckxvZ0FwcGVuZGVyQ29uZmlnID0gYXdhaXQgZ2V0U2VydmVyTG9nQXBwZW5kZXJDb25maWcoKTtcbiAgICBpZiAoc2VydmVyTG9nQXBwZW5kZXJDb25maWcpIHtcbiAgICAgIGNvbmZpZy5hcHBlbmRlcnMucHVzaChzZXJ2ZXJMb2dBcHBlbmRlckNvbmZpZyk7XG4gICAgfVxuXG4gICAgcmV0dXJuIGNvbmZpZztcbiAgfSxcbiAgZ2V0UGF0aFRvTG9nRmlsZUZvclRvZGF5LFxuICBMT0dfRklMRV9QQVRILFxuICBfX3Rlc3RfXzoge1xuICAgIGdldFBhdGhUb0xvZ0ZpbGVGb3JEYXRlLFxuICB9LFxufTtcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi92YXIvZm9sZGVycy94Zi9yc3BoNF9jNTczMTVyczU3eHhzZHNrcnhudjM2dDAvVC90bXBwZmw1Mm5wdWJsaXNoX3BhY2thZ2VzL25wbS9udWNsaWRlLWxvZ2dpbmcvbGliL2NvbmZpZy5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiSUE4QmUsMEJBQTBCLHFCQUF6QyxhQUE4RDs7Ozs7O0FBTTVELE1BQUksVUFBVSxDQUFDLGVBQWUsRUFBRSxJQUM1QixVQUFVLENBQUMsaUJBQWlCLEVBQUUsSUFDOUIsRUFBRSxNQUFNLFNBQVMsQ0FBQyxNQUFNLENBQUMsa0JBQWtCLENBQUMsQ0FBQSxBQUFDLElBQzdDLEVBQUUsTUFBTSxhQUFhLENBQUMsaUJBQWlCLEVBQUUsQ0FBQSxBQUFDLEVBQUU7QUFDOUMsV0FBTyxJQUFJLENBQUM7R0FDYjs7QUFFRCxTQUFPO0FBQ0wsUUFBSSxFQUFFLGdCQUFnQjtBQUN0QixTQUFLLEVBQUUsT0FBTztBQUNkLFlBQVEsRUFBRTtBQUNSLFVBQUksRUFBRSxrQkFBa0I7QUFDeEIsb0JBQWMsRUFBRSxrQkFBa0I7S0FDbkM7R0FDRixDQUFDO0NBQ0g7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBbkRELFdBQVcsQ0FBQzs7ZUFZK0MsT0FBTyxDQUFDLGlCQUFpQixDQUFDOztJQUE5RSxVQUFVLFlBQVYsVUFBVTtJQUFFLFNBQVMsWUFBVCxTQUFTO0lBQUUsVUFBVSxZQUFWLFVBQVU7SUFBRSxhQUFhLFlBQWIsYUFBYTs7QUFDdkQsSUFBTSxFQUFFLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDO0FBQ3pCLElBQU0sSUFBSSxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQzs7SUFDdEIsSUFBSSxHQUFJLE9BQU8sQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDLEdBQUcsQ0FBdEMsSUFBSTs7QUFDWCxJQUFJLGFBQWEsWUFBQSxDQUFDOztBQUVsQixJQUFJLFVBQVUsQ0FBQyxrQkFBa0IsRUFBRSxFQUFFO0FBQ25DLGVBQWEsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxNQUFNLEVBQUUsZ0JBQWMsSUFBSSx1QkFBb0IsQ0FBQztDQUM3RSxNQUFNO0FBQ0wsZUFBYSxxQkFBbUIsSUFBSSxzQkFBbUIsQ0FBQztDQUN6RDs7QUFFRCxJQUFNLFlBQVksR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxDQUFDO0FBQ2pELElBQUksdUJBQXVCLEdBQUcsS0FBSyxDQUFDO0FBQ3BDLElBQU0sa0JBQWtCLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUseUJBQXlCLENBQUMsQ0FBQzs7QUFFM0UsSUFBTSxrQkFBa0IsR0FBRyxhQUFhLENBQUM7O0FBNEJ6QyxTQUFTLHVCQUF1QixDQUFDLFVBQWdCLEVBQVU7QUFDekQsTUFBTSxlQUFlLEdBQUcsT0FBTyxDQUFDLHdCQUF3QixDQUFDLENBQUMsUUFBUSxDQUFDO0FBQ25FLFNBQU8sYUFBYSxHQUFHLGVBQWUsQ0FBQyxrQkFBa0IsRUFBRSxVQUFVLENBQUMsQ0FBQztDQUN4RTs7Ozs7QUFLRCxTQUFTLHdCQUF3QixHQUFXO0FBQzFDLFNBQU8sdUJBQXVCLENBQUMsSUFBSSxJQUFJLEVBQUUsQ0FBQyxDQUFDO0NBQzVDOztBQUVELE1BQU0sQ0FBQyxPQUFPLEdBQUc7QUFDZixBQUFNLGtCQUFnQixvQkFBQSxhQUE2Qjs7QUFFakQsUUFBSSxDQUFDLHVCQUF1QixFQUFFO0FBQzVCLFlBQU0sU0FBUyxDQUFDLE1BQU0sQ0FBQyxZQUFZLENBQUMsQ0FBQztBQUNyQyw2QkFBdUIsR0FBRyxJQUFJLENBQUM7S0FDaEM7O0FBRUQsUUFBTSxNQUFNLEdBQUc7QUFDYixlQUFTLEVBQUUsQ0FDVDtBQUNFLFlBQUksRUFBRSxnQkFBZ0I7QUFDdEIsYUFBSyxFQUFFLE1BQU07QUFDYixnQkFBUSxFQUFFO0FBQ1IsY0FBSSxFQUFFLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFLG1CQUFtQixDQUFDO1NBQ2hEO09BQ0YsRUFDRDtBQUNFLFlBQUksRUFBRSxVQUFVO0FBQ2hCLDRCQUFvQixFQUFFLElBQUk7QUFDMUIsZ0JBQVEsRUFBRSxJQUFJO0FBQ2QsZ0JBQVEsRUFBRSxhQUFhO0FBQ3ZCLGVBQU8sRUFBRSxrQkFBa0I7QUFDM0IsY0FBTSxFQUFFO0FBQ04sY0FBSSxFQUFFLFNBQVM7OztBQUdmLGlCQUFPLDJCQUF5QixPQUFPLENBQUMsR0FBRyxjQUFXO1NBQ3ZEO09BQ0YsQ0FDRjtLQUNGLENBQUM7O0FBRUYsUUFBTSx1QkFBdUIsR0FBRyxNQUFNLDBCQUEwQixFQUFFLENBQUM7QUFDbkUsUUFBSSx1QkFBdUIsRUFBRTtBQUMzQixZQUFNLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyx1QkFBdUIsQ0FBQyxDQUFDO0tBQ2hEOztBQUVELFdBQU8sTUFBTSxDQUFDO0dBQ2YsQ0FBQTtBQUNELDBCQUF3QixFQUF4Qix3QkFBd0I7QUFDeEIsZUFBYSxFQUFiLGFBQWE7QUFDYixVQUFRLEVBQUU7QUFDUiwyQkFBdUIsRUFBdkIsdUJBQXVCO0dBQ3hCO0NBQ0YsQ0FBQyIsImZpbGUiOiIvdmFyL2ZvbGRlcnMveGYvcnNwaDRfYzU3MzE1cnM1N3h4c2Rza3J4bnYzNnQwL1QvdG1wcGZsNTJucHVibGlzaF9wYWNrYWdlcy9ucG0vbnVjbGlkZS1sb2dnaW5nL2xpYi9jb25maWcuanMiLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGJhYmVsJztcbi8qIEBmbG93ICovXG5cbi8qXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTUtcHJlc2VudCwgRmFjZWJvb2ssIEluYy5cbiAqIEFsbCByaWdodHMgcmVzZXJ2ZWQuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgbGljZW5zZSBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGluXG4gKiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqL1xuXG5pbXBvcnQgdHlwZSB7TG9nZ2luZ0FwcGVuZGVyfSBmcm9tICcuL3R5cGVzJztcbmNvbnN0IHtjbGllbnRJbmZvLCBmc1Byb21pc2UsIHN5c3RlbUluZm8sIFNjcmliZVByb2Nlc3N9ID0gcmVxdWlyZSgnbnVjbGlkZS1jb21tb25zJyk7XG5jb25zdCBvcyA9IHJlcXVpcmUoJ29zJyk7XG5jb25zdCBwYXRoID0gcmVxdWlyZSgncGF0aCcpO1xuY29uc3Qge1VTRVJ9ID0gcmVxdWlyZSgnbnVjbGlkZS1jb21tb25zJykuZW52O1xubGV0IExPR19GSUxFX1BBVEg7XG5cbmlmIChzeXN0ZW1JbmZvLmlzUnVubmluZ0luV2luZG93cygpKSB7XG4gIExPR19GSUxFX1BBVEggPSBwYXRoLmpvaW4ob3MudG1wZGlyKCksIGAvbnVjbGlkZS0ke1VTRVJ9LWxvZ3MvbnVjbGlkZS5sb2dgKTtcbn0gZWxzZSB7XG4gIExPR19GSUxFX1BBVEggPSBgL3RtcC9udWNsaWRlLSR7VVNFUn0tbG9ncy9udWNsaWRlLmxvZ2A7XG59XG5cbmNvbnN0IGxvZ0RpcmVjdG9yeSA9IHBhdGguZGlybmFtZShMT0dfRklMRV9QQVRIKTtcbmxldCBsb2dEaXJlY3RvcnlJbml0aWFsaXplZCA9IGZhbHNlO1xuY29uc3Qgc2NyaWJlQXBwZW5kZXJQYXRoID0gcGF0aC5qb2luKF9fZGlybmFtZSwgJy4uL2ZiL3NjcmliZUFwcGVuZGVyLmpzJyk7XG5cbmNvbnN0IExPRzRKU19EQVRFX0ZPUk1BVCA9ICcteXl5eS1NTS1kZCc7XG5cbmFzeW5jIGZ1bmN0aW9uIGdldFNlcnZlckxvZ0FwcGVuZGVyQ29uZmlnKCk6IFByb21pc2U8P09iamVjdD4ge1xuICAvLyBTa2lwIGNvbmZpZyBzY3JpYmVfY2F0IGxvZ2dlciBpZlxuICAvLyAxKSBydW5uaW5nIGluIHRlc3QgZW52aXJvbm1lbnRcbiAgLy8gMikgb3IgcnVubmluZyBpbiBBdG9tIGNsaWVudFxuICAvLyAzKSBvciBydW5uaW5nIGluIG9wZW4gc291cmNlZCB2ZXJzaW9uIG9mIG51Y2xpZGVcbiAgLy8gNCkgb3IgdGhlIHNjcmliZV9jYXQgY29tbWFuZCBpcyBtaXNzaW5nLlxuICBpZiAoY2xpZW50SW5mby5pc1J1bm5pbmdJblRlc3QoKSB8fFxuICAgICAgY2xpZW50SW5mby5pc1J1bm5pbmdJbkNsaWVudCgpIHx8XG4gICAgICAhKGF3YWl0IGZzUHJvbWlzZS5leGlzdHMoc2NyaWJlQXBwZW5kZXJQYXRoKSkgfHxcbiAgICAgICEoYXdhaXQgU2NyaWJlUHJvY2Vzcy5pc1NjcmliZUNhdE9uUGF0aCgpKSkge1xuICAgIHJldHVybiBudWxsO1xuICB9XG5cbiAgcmV0dXJuIHtcbiAgICB0eXBlOiAnbG9nTGV2ZWxGaWx0ZXInLFxuICAgIGxldmVsOiAnREVCVUcnLFxuICAgIGFwcGVuZGVyOiB7XG4gICAgICB0eXBlOiBzY3JpYmVBcHBlbmRlclBhdGgsXG4gICAgICBzY3JpYmVDYXRlZ29yeTogJ2Vycm9ybG9nX2Fyc2VuYWwnLFxuICAgIH0sXG4gIH07XG59XG5cbi8qKlxuICogQHJldHVybiBUaGUgYWJzb2x1dGUgcGF0aCB0byB0aGUgbG9nIGZpbGUgZm9yIHRoZSBzcGVjaWZpZWQgZGF0ZS5cbiAqL1xuZnVuY3Rpb24gZ2V0UGF0aFRvTG9nRmlsZUZvckRhdGUodGFyZ2V0RGF0ZTogRGF0ZSk6IHN0cmluZyB7XG4gIGNvbnN0IGxvZzRqc0Zvcm1hdHRlciA9IHJlcXVpcmUoJ2xvZzRqcy9saWIvZGF0ZV9mb3JtYXQnKS5hc1N0cmluZztcbiAgcmV0dXJuIExPR19GSUxFX1BBVEggKyBsb2c0anNGb3JtYXR0ZXIoTE9HNEpTX0RBVEVfRk9STUFULCB0YXJnZXREYXRlKTtcbn1cblxuLyoqXG4gKiBAcmV0dXJuIFRoZSBhYnNvbHV0ZSBwYXRoIHRvIHRoZSBsb2cgZmlsZSBmb3IgdG9kYXkuXG4gKi9cbmZ1bmN0aW9uIGdldFBhdGhUb0xvZ0ZpbGVGb3JUb2RheSgpOiBzdHJpbmcge1xuICByZXR1cm4gZ2V0UGF0aFRvTG9nRmlsZUZvckRhdGUobmV3IERhdGUoKSk7XG59XG5cbm1vZHVsZS5leHBvcnRzID0ge1xuICBhc3luYyBnZXREZWZhdWx0Q29uZmlnKCk6IFByb21pc2U8TG9nZ2luZ0FwcGVuZGVyPiB7XG5cbiAgICBpZiAoIWxvZ0RpcmVjdG9yeUluaXRpYWxpemVkKSB7XG4gICAgICBhd2FpdCBmc1Byb21pc2UubWtkaXJwKGxvZ0RpcmVjdG9yeSk7XG4gICAgICBsb2dEaXJlY3RvcnlJbml0aWFsaXplZCA9IHRydWU7XG4gICAgfVxuXG4gICAgY29uc3QgY29uZmlnID0ge1xuICAgICAgYXBwZW5kZXJzOiBbXG4gICAgICAgIHtcbiAgICAgICAgICB0eXBlOiAnbG9nTGV2ZWxGaWx0ZXInLFxuICAgICAgICAgIGxldmVsOiAnSU5GTycsXG4gICAgICAgICAgYXBwZW5kZXI6IHtcbiAgICAgICAgICAgIHR5cGU6IHBhdGguam9pbihfX2Rpcm5hbWUsICcuL2NvbnNvbGVBcHBlbmRlcicpLFxuICAgICAgICAgIH0sXG4gICAgICAgIH0sXG4gICAgICAgIHtcbiAgICAgICAgICB0eXBlOiAnZGF0ZUZpbGUnLFxuICAgICAgICAgIGFsd2F5c0luY2x1ZGVQYXR0ZXJuOiB0cnVlLFxuICAgICAgICAgIGFic29sdXRlOiB0cnVlLFxuICAgICAgICAgIGZpbGVuYW1lOiBMT0dfRklMRV9QQVRILFxuICAgICAgICAgIHBhdHRlcm46IExPRzRKU19EQVRFX0ZPUk1BVCxcbiAgICAgICAgICBsYXlvdXQ6IHtcbiAgICAgICAgICAgIHR5cGU6ICdwYXR0ZXJuJyxcbiAgICAgICAgICAgIC8vIEZvcm1hdCBsb2cgaW4gZm9sbG93aW5nIHBhdHRlcm46XG4gICAgICAgICAgICAvLyB5eXl5LU1NLWRkIEhIOm1tOnNzLm1pbCAkTGV2ZWwgKHBpZDokcGlkKSAkY2F0ZWdyb3kgLSAkbWVzc2FnZS5cbiAgICAgICAgICAgIHBhdHRlcm46IGAlZHtJU084NjAxfSAlcCAocGlkOiR7cHJvY2Vzcy5waWR9KSAlYyAtICVtYCxcbiAgICAgICAgICB9LFxuICAgICAgICB9LFxuICAgICAgXSxcbiAgICB9O1xuXG4gICAgY29uc3Qgc2VydmVyTG9nQXBwZW5kZXJDb25maWcgPSBhd2FpdCBnZXRTZXJ2ZXJMb2dBcHBlbmRlckNvbmZpZygpO1xuICAgIGlmIChzZXJ2ZXJMb2dBcHBlbmRlckNvbmZpZykge1xuICAgICAgY29uZmlnLmFwcGVuZGVycy5wdXNoKHNlcnZlckxvZ0FwcGVuZGVyQ29uZmlnKTtcbiAgICB9XG5cbiAgICByZXR1cm4gY29uZmlnO1xuICB9LFxuICBnZXRQYXRoVG9Mb2dGaWxlRm9yVG9kYXksXG4gIExPR19GSUxFX1BBVEgsXG4gIF9fdGVzdF9fOiB7XG4gICAgZ2V0UGF0aFRvTG9nRmlsZUZvckRhdGUsXG4gIH0sXG59O1xuIl19

@@ -40,2 +40,2 @@

};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi92YXIvZm9sZGVycy82NC9uNHJoMDk2eDRwMWJrNndyd3prX3I1M21ya21sMjAvVC90bXAxVGZDWXFwdWJsaXNoX3BhY2thZ2VzL25wbS9udWNsaWRlLWxvZ2dpbmcvbGliL2NvbnNvbGVBcHBlbmRlci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxXQUFXLENBQUM7Ozs7Ozs7OztBQVVaLElBQUksSUFBSSxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQzs7QUFFM0IsU0FBUyxNQUFNLENBQUMsWUFBaUIsRUFBYztBQUM3QyxNQUFJLFNBQVMsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUN6QixpQkFBaUIsRUFDakIsWUFBWSxDQUFDLFNBQVMsQ0FBQyxXQUFXLEVBQUUsRUFDcEMsWUFBWSxDQUFDLEtBQUssRUFDbEIsWUFBWSxDQUFDLFlBQVksQ0FBQyxDQUFDOztBQUU3QixNQUFJLElBQUksR0FBRyxZQUFZLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDOzs7O0FBSXJDLE1BQUksSUFBSSxDQUFDLE1BQU0sR0FBRyxDQUFDLElBQUksT0FBTyxJQUFJLENBQUMsQ0FBQyxDQUFDLEtBQUssUUFBUSxFQUFFO0FBQ2xELFFBQUksQ0FBQyxDQUFDLENBQUMsR0FBRyxTQUFTLEdBQUcsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO0dBQy9CLE1BQU07QUFDTCxRQUFJLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxDQUFDO0dBQ3pCO0FBQ0QsU0FBTyxJQUFJLENBQUM7Q0FDYjs7Ozs7O0FBTUQsU0FBUyxlQUFlLEdBQWdDO0FBQ3RELFNBQU8sVUFBQyxZQUFZLEVBQUs7QUFDdkIsV0FBTyxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsT0FBTyxFQUFFLE1BQU0sQ0FBQyxZQUFZLENBQUMsQ0FBQyxDQUFDO0dBQ2xELENBQUM7Q0FDSDs7QUFFRCxNQUFNLENBQUMsT0FBTyxHQUFHO0FBQ2YsVUFBUSxFQUFFLGVBQWU7QUFDekIsV0FBUyxFQUFFLGVBQWU7Q0FDM0IsQ0FBQyIsImZpbGUiOiIvdmFyL2ZvbGRlcnMvNjQvbjRyaDA5Nng0cDFiazZ3cnd6a19yNTNtcmttbDIwL1QvdG1wMVRmQ1lxcHVibGlzaF9wYWNrYWdlcy9ucG0vbnVjbGlkZS1sb2dnaW5nL2xpYi9jb25zb2xlQXBwZW5kZXIuanMiLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGJhYmVsJztcbi8qIEBmbG93ICovXG5cbi8qXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTUtcHJlc2VudCwgRmFjZWJvb2ssIEluYy5cbiAqIEFsbCByaWdodHMgcmVzZXJ2ZWQuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgbGljZW5zZSBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGluXG4gKiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqL1xudmFyIHV0aWwgPSByZXF1aXJlKCd1dGlsJyk7XG5cbmZ1bmN0aW9uIGxheW91dChsb2dnaW5nRXZlbnQ6IGFueSk6IEFycmF5PGFueT4ge1xuICB2YXIgZXZlbnRJbmZvID0gdXRpbC5mb3JtYXQoXG4gICAgJ1slc10gWyVzXSAlcyAtICcsXG4gICAgbG9nZ2luZ0V2ZW50LnN0YXJ0VGltZS50b0lTT1N0cmluZygpLFxuICAgIGxvZ2dpbmdFdmVudC5sZXZlbCxcbiAgICBsb2dnaW5nRXZlbnQuY2F0ZWdvcnlOYW1lKTtcblxuICB2YXIgZGF0YSA9IGxvZ2dpbmdFdmVudC5kYXRhLnNsaWNlKCk7XG5cbiAgLy8gU2luY2UgY29uc29sZS5sb2cgc3VwcG9ydCBzdHJpbmcgZm9ybWF0IGFzIGZpcnN0IHBhcmFtZXRlciwgd2Ugc2hvdWxkIHByZXNlcnZlIHRoaXMgYmVoYXZpb3JcbiAgLy8gYnkgY29uY2F0aW5nIGV2ZW50SW5mbyB3aXRoIGZpcnN0IHBhcmFtZXRlciBpZiBpdCBpcyBzdHJpbmcuXG4gIGlmIChkYXRhLmxlbmd0aCA+IDAgJiYgdHlwZW9mIGRhdGFbMF0gPT09ICdzdHJpbmcnKSB7XG4gICAgZGF0YVswXSA9IGV2ZW50SW5mbyArIGRhdGFbMF07XG4gIH0gZWxzZSB7XG4gICAgZGF0YS51bnNoaWZ0KGV2ZW50SW5mbyk7XG4gIH1cbiAgcmV0dXJuIGRhdGE7XG59XG5cbi8qKlxuICogQ29tcGFyaW5nIHRvIGxvZzRqcydzIGNvbnNvbGUgYXBwZW5kZXIoaHR0cHM6Ly9mYnVybC5jb20vNjk4NjE2NjkpLCB5b3UgY2FuIGV4cGFuZCBhbmQgZXhwbG9yZVxuICogdGhlIG9iamVjdCBpbiBjb25zb2xlIGxvZ2dlZCBieSB0aGlzIEFwcGVuZGVyLlxuICovXG5mdW5jdGlvbiBjb25zb2xlQXBwZW5kZXIoKTogKGxvZ2dpbmdFdmVudDogYW55KSA9PiB2b2lkIHtcbiAgcmV0dXJuIChsb2dnaW5nRXZlbnQpID0+IHtcbiAgICBjb25zb2xlLmxvZy5hcHBseShjb25zb2xlLCBsYXlvdXQobG9nZ2luZ0V2ZW50KSk7IC8vIGVzbGludC1kaXNhYmxlLWxpbmUgbm8tY29uc29sZVxuICB9O1xufVxuXG5tb2R1bGUuZXhwb3J0cyA9IHtcbiAgYXBwZW5kZXI6IGNvbnNvbGVBcHBlbmRlcixcbiAgY29uZmlndXJlOiBjb25zb2xlQXBwZW5kZXIsXG59O1xuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi92YXIvZm9sZGVycy94Zi9yc3BoNF9jNTczMTVyczU3eHhzZHNrcnhudjM2dDAvVC90bXBwZmw1Mm5wdWJsaXNoX3BhY2thZ2VzL25wbS9udWNsaWRlLWxvZ2dpbmcvbGliL2NvbnNvbGVBcHBlbmRlci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxXQUFXLENBQUM7Ozs7Ozs7OztBQVVaLElBQU0sSUFBSSxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQzs7QUFFN0IsU0FBUyxNQUFNLENBQUMsWUFBaUIsRUFBYztBQUM3QyxNQUFNLFNBQVMsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUMzQixpQkFBaUIsRUFDakIsWUFBWSxDQUFDLFNBQVMsQ0FBQyxXQUFXLEVBQUUsRUFDcEMsWUFBWSxDQUFDLEtBQUssRUFDbEIsWUFBWSxDQUFDLFlBQVksQ0FBQyxDQUFDOztBQUU3QixNQUFNLElBQUksR0FBRyxZQUFZLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDOzs7O0FBSXZDLE1BQUksSUFBSSxDQUFDLE1BQU0sR0FBRyxDQUFDLElBQUksT0FBTyxJQUFJLENBQUMsQ0FBQyxDQUFDLEtBQUssUUFBUSxFQUFFO0FBQ2xELFFBQUksQ0FBQyxDQUFDLENBQUMsR0FBRyxTQUFTLEdBQUcsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO0dBQy9CLE1BQU07QUFDTCxRQUFJLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxDQUFDO0dBQ3pCO0FBQ0QsU0FBTyxJQUFJLENBQUM7Q0FDYjs7Ozs7O0FBTUQsU0FBUyxlQUFlLEdBQWdDO0FBQ3RELFNBQU8sVUFBQyxZQUFZLEVBQUs7QUFDdkIsV0FBTyxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsT0FBTyxFQUFFLE1BQU0sQ0FBQyxZQUFZLENBQUMsQ0FBQyxDQUFDO0dBQ2xELENBQUM7Q0FDSDs7QUFFRCxNQUFNLENBQUMsT0FBTyxHQUFHO0FBQ2YsVUFBUSxFQUFFLGVBQWU7QUFDekIsV0FBUyxFQUFFLGVBQWU7Q0FDM0IsQ0FBQyIsImZpbGUiOiIvdmFyL2ZvbGRlcnMveGYvcnNwaDRfYzU3MzE1cnM1N3h4c2Rza3J4bnYzNnQwL1QvdG1wcGZsNTJucHVibGlzaF9wYWNrYWdlcy9ucG0vbnVjbGlkZS1sb2dnaW5nL2xpYi9jb25zb2xlQXBwZW5kZXIuanMiLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGJhYmVsJztcbi8qIEBmbG93ICovXG5cbi8qXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTUtcHJlc2VudCwgRmFjZWJvb2ssIEluYy5cbiAqIEFsbCByaWdodHMgcmVzZXJ2ZWQuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgbGljZW5zZSBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGluXG4gKiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqL1xuY29uc3QgdXRpbCA9IHJlcXVpcmUoJ3V0aWwnKTtcblxuZnVuY3Rpb24gbGF5b3V0KGxvZ2dpbmdFdmVudDogYW55KTogQXJyYXk8YW55PiB7XG4gIGNvbnN0IGV2ZW50SW5mbyA9IHV0aWwuZm9ybWF0KFxuICAgICdbJXNdIFslc10gJXMgLSAnLFxuICAgIGxvZ2dpbmdFdmVudC5zdGFydFRpbWUudG9JU09TdHJpbmcoKSxcbiAgICBsb2dnaW5nRXZlbnQubGV2ZWwsXG4gICAgbG9nZ2luZ0V2ZW50LmNhdGVnb3J5TmFtZSk7XG5cbiAgY29uc3QgZGF0YSA9IGxvZ2dpbmdFdmVudC5kYXRhLnNsaWNlKCk7XG5cbiAgLy8gU2luY2UgY29uc29sZS5sb2cgc3VwcG9ydCBzdHJpbmcgZm9ybWF0IGFzIGZpcnN0IHBhcmFtZXRlciwgd2Ugc2hvdWxkIHByZXNlcnZlIHRoaXMgYmVoYXZpb3JcbiAgLy8gYnkgY29uY2F0aW5nIGV2ZW50SW5mbyB3aXRoIGZpcnN0IHBhcmFtZXRlciBpZiBpdCBpcyBzdHJpbmcuXG4gIGlmIChkYXRhLmxlbmd0aCA+IDAgJiYgdHlwZW9mIGRhdGFbMF0gPT09ICdzdHJpbmcnKSB7XG4gICAgZGF0YVswXSA9IGV2ZW50SW5mbyArIGRhdGFbMF07XG4gIH0gZWxzZSB7XG4gICAgZGF0YS51bnNoaWZ0KGV2ZW50SW5mbyk7XG4gIH1cbiAgcmV0dXJuIGRhdGE7XG59XG5cbi8qKlxuICogQ29tcGFyaW5nIHRvIGxvZzRqcydzIGNvbnNvbGUgYXBwZW5kZXIoaHR0cHM6Ly9mYnVybC5jb20vNjk4NjE2NjkpLCB5b3UgY2FuIGV4cGFuZCBhbmQgZXhwbG9yZVxuICogdGhlIG9iamVjdCBpbiBjb25zb2xlIGxvZ2dlZCBieSB0aGlzIEFwcGVuZGVyLlxuICovXG5mdW5jdGlvbiBjb25zb2xlQXBwZW5kZXIoKTogKGxvZ2dpbmdFdmVudDogYW55KSA9PiB2b2lkIHtcbiAgcmV0dXJuIChsb2dnaW5nRXZlbnQpID0+IHtcbiAgICBjb25zb2xlLmxvZy5hcHBseShjb25zb2xlLCBsYXlvdXQobG9nZ2luZ0V2ZW50KSk7IC8vIGVzbGludC1kaXNhYmxlLWxpbmUgbm8tY29uc29sZVxuICB9O1xufVxuXG5tb2R1bGUuZXhwb3J0cyA9IHtcbiAgYXBwZW5kZXI6IGNvbnNvbGVBcHBlbmRlcixcbiAgY29uZmlndXJlOiBjb25zb2xlQXBwZW5kZXIsXG59O1xuIl19
Object.defineProperty(exports, '__esModule', {
value: true
});
exports.flushLogsAndExit = flushLogsAndExit;
exports.updateConfig = updateConfig;
exports.initialUpdateConfig = initialUpdateConfig;
exports.getLogger = getLogger;

@@ -47,2 +49,9 @@ exports.getCategoryLogger = getCategoryLogger;

function flushLogsAndExit(exitCode) {
var log4js = require('log4js');
log4js.shutdown(function () {
return process.exit(exitCode);
});
}
/**

@@ -109,9 +118,6 @@ * Get log4js logger instance which is also singleton per category.

*/
function initialUpdateConfig() {
var defaultConfigPromise = undefined;
require('nuclide-commons').singleton.get(INITIAL_UPDATE_CONFIG_KEY, _asyncToGenerator(function* () {
if (!defaultConfigPromise) {
defaultConfigPromise = require('./config').getDefaultConfig();
}
var defaultConfig = yield defaultConfigPromise;
return require('nuclide-commons').singleton.get(INITIAL_UPDATE_CONFIG_KEY, _asyncToGenerator(function* () {
var defaultConfig = yield require('./config').getDefaultConfig();
updateConfig(defaultConfig);

@@ -179,2 +185,2 @@ }));

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["/var/folders/64/n4rh096x4p1bk6wrwzk_r53mrkml20/T/tmp1TfCYqpublish_packages/npm/nuclide-logging/lib/main.js"],"names":[],"mappings":"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","file":"/var/folders/64/n4rh096x4p1bk6wrwzk_r53mrkml20/T/tmp1TfCYqpublish_packages/npm/nuclide-logging/lib/main.js","sourcesContent":["'use babel';\n/* @flow */\n\n/*\n * Copyright (c) 2015-present, Facebook, Inc.\n * All rights reserved.\n *\n * This source code is licensed under the license found in the LICENSE file in\n * the root directory of this source tree.\n */\n\n/**\n * This designed for logging on both Nuclide client and Nuclide server. It is based on [log4js]\n * (https://www.npmjs.com/package/log4js) with the ability to lazy initialize and update config\n * after initialized.\n * To make sure we only have one instance of log4js logger initialized globally, we save the logger\n * to `global` object.\n */\nimport addPrepareStackTraceHook from './stacktrace';\nimport invariant from 'assert';\n\nimport type {Logger} from './types';\n\n/* Listed in order of severity. */\ntype Level = 'trace' | 'debug' | 'info' | 'warn' | 'error' | 'fatal';\n\nconst DEFAULT_LOGGER_CATEGORY = 'nuclide';\nconst INITIAL_UPDATE_CONFIG_KEY = '_initial_update_config_key_';\n\nfunction getCategory(category: ?string): string {\n  return category ? category : DEFAULT_LOGGER_CATEGORY;\n}\n\n/**\n * Get log4js logger instance which is also singleton per category.\n * log4js.getLogger() API internally should already provide singleton per category guarantee\n * see https://github.com/nomiddlename/log4js-node/blob/master/lib/log4js.js#L120 for details.\n */\nfunction getLog4jsLogger(category: string): Object {\n  const log4js = require('log4js');\n  return log4js.getLogger(category);\n}\n\nexport function updateConfig(config: any, options: any): void {\n  // update config takes affect global to all existing and future loggers.\n  const log4js = require('log4js');\n  log4js.configure(config, options);\n}\n\n// Create a lazy logger that will not initialize the underlying log4js logger until\n// `lazyLogger.$level(...)` is called. This way, another package could require nuclide-logging\n// during activation without worrying about introducing a significant startup cost.\nfunction createLazyLogger(category: string): Logger {\n  function createLazyLoggerMethod(level: Level): (...args: Array<any>) => mixed {\n    return function(...args: Array<any>) {\n      const logger = getLog4jsLogger(category);\n      invariant(logger);\n      logger[level].apply(logger, args);\n    };\n  }\n\n  function setLoggerLevelHelper(level: string): void {\n    const logger = getLog4jsLogger(category);\n    invariant(logger);\n    logger.setLevel(level);\n  }\n\n  function isLevelEnabledHelper(level: string): void {\n    const logger = getLog4jsLogger(category);\n    invariant(logger);\n    return logger.isLevelEnabled(level);\n  }\n\n  return {\n    debug: createLazyLoggerMethod('debug'),\n    error: createLazyLoggerMethod('error'),\n    fatal: createLazyLoggerMethod('fatal'),\n    info: createLazyLoggerMethod('info'),\n    trace: createLazyLoggerMethod('trace'),\n    warn: createLazyLoggerMethod('warn'),\n    isLevelEnabled: isLevelEnabledHelper,\n    setLevel: setLoggerLevelHelper,\n  };\n}\n\n/**\n * Push initial default config to log4js.\n * Execute only once.\n */\nfunction initialUpdateConfig(): void {\n  let defaultConfigPromise;\n  require('nuclide-commons').singleton.get(\n    INITIAL_UPDATE_CONFIG_KEY,\n    async () => {\n      if (!defaultConfigPromise) {\n        defaultConfigPromise = require('./config').getDefaultConfig();\n      }\n      const defaultConfig = await defaultConfigPromise;\n      updateConfig(defaultConfig);\n    });\n}\n\n// Get Logger instance which is singleton per logger category.\nexport function getLogger(category: ?string): Logger {\n  addPrepareStackTraceHook();\n  initialUpdateConfig();\n\n  const loggerCategory = getCategory(category);\n  return require('nuclide-commons').singleton.get(\n    loggerCategory,\n    () => {\n      return createLazyLogger(loggerCategory);\n    },\n  );\n}\n\n// Utility function that returns a wrapper logger for input category.\nexport function getCategoryLogger(category: string): Object {\n  function setLogLevel(level: string): void {\n    getLogger(category).setLevel(level);\n  }\n\n  function logHelper(level: string, message: string): void {\n    const logger = getLogger(category);\n    // isLevelEnabled() is required to reduce the amount of logging to\n    // log4js which greatly improves performance.\n    if (logger.isLevelEnabled(level)) {\n      logger[level](message);\n    }\n  }\n\n  function log(message: string): void {\n    logHelper('debug', message);\n  }\n\n  function logInfo(message: string): void {\n    logHelper('info', message);\n  }\n\n  function logError(message: string): void {\n    logHelper('error', message);\n  }\n\n  function logErrorAndThrow(message: string): void {\n    logError(message);\n    logError(new Error().stack);\n    throw new Error(message);\n  }\n\n  return {\n    log,\n    logInfo,\n    logError,\n    logErrorAndThrow,\n    setLogLevel,\n  };\n}\n\nexport function getPathToLogFileForToday(): string {\n  return require('./config').getPathToLogFileForToday();\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["/var/folders/xf/rsph4_c57315rs57xxsdskrxnv36t0/T/tmppfl52npublish_packages/npm/nuclide-logging/lib/main.js"],"names":[],"mappings":"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","file":"/var/folders/xf/rsph4_c57315rs57xxsdskrxnv36t0/T/tmppfl52npublish_packages/npm/nuclide-logging/lib/main.js","sourcesContent":["'use babel';\n/* @flow */\n\n/*\n * Copyright (c) 2015-present, Facebook, Inc.\n * All rights reserved.\n *\n * This source code is licensed under the license found in the LICENSE file in\n * the root directory of this source tree.\n */\n\n/**\n * This designed for logging on both Nuclide client and Nuclide server. It is based on [log4js]\n * (https://www.npmjs.com/package/log4js) with the ability to lazy initialize and update config\n * after initialized.\n * To make sure we only have one instance of log4js logger initialized globally, we save the logger\n * to `global` object.\n */\nimport addPrepareStackTraceHook from './stacktrace';\nimport invariant from 'assert';\n\nimport type {Logger} from './types';\n\n/* Listed in order of severity. */\ntype Level = 'trace' | 'debug' | 'info' | 'warn' | 'error' | 'fatal';\n\nconst DEFAULT_LOGGER_CATEGORY = 'nuclide';\nconst INITIAL_UPDATE_CONFIG_KEY = '_initial_update_config_key_';\n\nfunction getCategory(category: ?string): string {\n  return category ? category : DEFAULT_LOGGER_CATEGORY;\n}\n\nexport function flushLogsAndExit(exitCode: number): void {\n  const log4js = require('log4js');\n  log4js.shutdown(() => process.exit(exitCode));\n}\n\n/**\n * Get log4js logger instance which is also singleton per category.\n * log4js.getLogger() API internally should already provide singleton per category guarantee\n * see https://github.com/nomiddlename/log4js-node/blob/master/lib/log4js.js#L120 for details.\n */\nfunction getLog4jsLogger(category: string): Object {\n  const log4js = require('log4js');\n  return log4js.getLogger(category);\n}\n\nexport function updateConfig(config: any, options: any): void {\n  // update config takes affect global to all existing and future loggers.\n  const log4js = require('log4js');\n  log4js.configure(config, options);\n}\n\n// Create a lazy logger that will not initialize the underlying log4js logger until\n// `lazyLogger.$level(...)` is called. This way, another package could require nuclide-logging\n// during activation without worrying about introducing a significant startup cost.\nfunction createLazyLogger(category: string): Logger {\n  function createLazyLoggerMethod(level: Level): (...args: Array<any>) => mixed {\n    return function(...args: Array<any>) {\n      const logger = getLog4jsLogger(category);\n      invariant(logger);\n      logger[level].apply(logger, args);\n    };\n  }\n\n  function setLoggerLevelHelper(level: string): void {\n    const logger = getLog4jsLogger(category);\n    invariant(logger);\n    logger.setLevel(level);\n  }\n\n  function isLevelEnabledHelper(level: string): void {\n    const logger = getLog4jsLogger(category);\n    invariant(logger);\n    return logger.isLevelEnabled(level);\n  }\n\n  return {\n    debug: createLazyLoggerMethod('debug'),\n    error: createLazyLoggerMethod('error'),\n    fatal: createLazyLoggerMethod('fatal'),\n    info: createLazyLoggerMethod('info'),\n    trace: createLazyLoggerMethod('trace'),\n    warn: createLazyLoggerMethod('warn'),\n    isLevelEnabled: isLevelEnabledHelper,\n    setLevel: setLoggerLevelHelper,\n  };\n}\n\n/**\n * Push initial default config to log4js.\n * Execute only once.\n */\nexport function initialUpdateConfig(): Promise<void> {\n  return require('nuclide-commons').singleton.get(\n    INITIAL_UPDATE_CONFIG_KEY,\n    async () => {\n      const defaultConfig = await require('./config').getDefaultConfig();\n      updateConfig(defaultConfig);\n    });\n}\n\n// Get Logger instance which is singleton per logger category.\nexport function getLogger(category: ?string): Logger {\n  addPrepareStackTraceHook();\n  initialUpdateConfig();\n\n  const loggerCategory = getCategory(category);\n  return require('nuclide-commons').singleton.get(\n    loggerCategory,\n    () => {\n      return createLazyLogger(loggerCategory);\n    },\n  );\n}\n\n// Utility function that returns a wrapper logger for input category.\nexport function getCategoryLogger(category: string): Object {\n  function setLogLevel(level: string): void {\n    getLogger(category).setLevel(level);\n  }\n\n  function logHelper(level: string, message: string): void {\n    const logger = getLogger(category);\n    // isLevelEnabled() is required to reduce the amount of logging to\n    // log4js which greatly improves performance.\n    if (logger.isLevelEnabled(level)) {\n      logger[level](message);\n    }\n  }\n\n  function log(message: string): void {\n    logHelper('debug', message);\n  }\n\n  function logInfo(message: string): void {\n    logHelper('info', message);\n  }\n\n  function logError(message: string): void {\n    logHelper('error', message);\n  }\n\n  function logErrorAndThrow(message: string): void {\n    logError(message);\n    logError(new Error().stack);\n    throw new Error(message);\n  }\n\n  return {\n    log,\n    logInfo,\n    logError,\n    logErrorAndThrow,\n    setLogLevel,\n  };\n}\n\nexport function getPathToLogFileForToday(): string {\n  return require('./config').getPathToLogFileForToday();\n}\n"]}

@@ -17,3 +17,3 @@ Object.defineProperty(exports, '__esModule', {

var hookedPrepareStackTrace;
var hookedPrepareStackTrace = undefined;

@@ -50,2 +50,13 @@ /**

});
// TODO (chenshen) t8789330.
// Atom added getRawStack to Error.prototype to get Error's structured stacktrace
// (https://github.com/atom/grim/blob/master/src/grim.coffee#L43). However, this
// doesn't work well with our customization of stacktrace. So here we temporarily
// walk around this by following hack, until https://github.com/atom/atom/issues/9641
// get addressed.
/* eslint-disable no-extend-native */
/* $FlowFixMe */
Error.prototype.getRawStack = null;
/* eslint-enable no-extend-native */
return true;

@@ -106,2 +117,2 @@ });

exports.__test__ = __test__;
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["/var/folders/64/n4rh096x4p1bk6wrwzk_r53mrkml20/T/tmp1TfCYqpublish_packages/npm/nuclide-logging/lib/stacktrace.js"],"names":[],"mappings":";;;;;;;;;;;qBA6BwB,wBAAwB;AA7BhD,WAAW,CAAC;;AAcZ,IAAI,8BAA8B,GAAG,mCAAmC,CAAC;;AAEzE,IAAI,uBAAmD,CAAC;;;;;;;;;;;;;;AAazC,SAAS,wBAAwB,GAAS;AACvD,SAAO,CAAC,iBAAiB,CAAC,CAAC,SAAS,CAAC,GAAG,CACtC,8BAA8B,EAC9B,YAAM;AACJ,2BAAuB,GAAG,6BAA6B,CAAC,KAAK,CAAC,iBAAiB,IAC1E,wBAAwB,CAAC,CAAC;;;;;;AAM/B,UAAM,CAAC,cAAc,CAAC,KAAK,EAAE,mBAAmB,EAAE;AAChD,SAAG,EAAA,eAAG;AACJ,eAAO,uBAAuB,CAAC;OAChC;AACD,SAAG,EAAA,aAAC,QAAQ,EAAE;AACZ,+BAAuB,GAAG,6BAA6B,CAAC,QAAQ,IAC3D,wBAAwB,CAAC,CAAC;OAChC;AACD,gBAAU,EAAE,KAAK;AACjB,kBAAY,EAAE,IAAI;KACnB,CAAC,CAAC;AACH,WAAO,IAAI,CAAC;GACb,CACF,CAAC;CACH;;;;;;AAMD,SAAS,6BAA6B,CACpC,iBAA4C,EACjB;;AAE3B,MAAI,iBAAiB,CAAC,IAAI,KAAK,gCAAgC,EAAE;AAC/D,WAAO,iBAAiB,CAAC;GAC1B;;AAED,MAAI,cAAc,GAAG,SAAS,8BAA8B,CAC1D,KAAY,EACZ,MAA4B,EACvB;AACL,4BAAwB,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;AACxC,WAAO,iBAAiB,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;GACzC,CAAC;;AAEF,SAAO,cAAc,CAAC;CACvB;;AAED,SAAS,wBAAwB,CAAC,KAAY,EAAE,MAA4B,EAAQ;;AAElF,OAAK,CAAC,YAAY,CAAC,GAAG,MAAM,CAAC,GAAG,CAAC,UAAA,KAAK,EAAI;AACxC,WAAO;AACL,kBAAY,EAAE,KAAK,CAAC,eAAe,EAAE;AACrC,gBAAU,EAAE,KAAK,CAAC,aAAa,EAAE;AACjC,cAAQ,EAAE,KAAK,CAAC,WAAW,EAAE;AAC7B,gBAAU,EAAE,KAAK,CAAC,aAAa,EAAE;AACjC,kBAAY,EAAE,KAAK,CAAC,eAAe,EAAE;AACrC,gBAAU,EAAE,KAAK,CAAC,aAAa,EAAE;AACjC,gBAAU,EAAE,KAAK,CAAC,UAAU,EAAE;AAC9B,YAAM,EAAE,KAAK,CAAC,MAAM,EAAE;AACtB,cAAQ,EAAE,KAAK,CAAC,QAAQ,EAAE;AAC1B,mBAAa,EAAE,KAAK,CAAC,aAAa,EAAE;KACrC,CAAC;GACH,CAAC,CAAC;CACJ;;AAED,SAAS,wBAAwB,CAAC,KAAY,EAAE,MAA4B,EAAU;AACpF,MAAI,mBAAmB,GAAG,KAAK,CAAC,OAAO,GAAM,KAAK,CAAC,IAAI,UAAK,KAAK,CAAC,OAAO,QAAQ,KAAK,CAAC,IAAI,AAAE,CAAC;AAC9F,QAAM,CAAC,OAAO,CAAC,UAAA,KAAK,EAAI;AACtB,uBAAmB,kBAAgB,KAAK,CAAC,QAAQ,EAAE,AAAE,CAAC;GACvD,CAAC,CAAC;AACH,SAAO,mBAAmB,CAAC;CAC5B;;AAEM,IAAI,QAAQ,GAAG;AACpB,+BAA6B,EAA7B,6BAA6B;AAC7B,8BAA4B,EAAA,wCAAG;AAC7B,WAAO,CAAC,iBAAiB,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,8BAA8B,CAAC,CAAC;GAC5E;CACF,CAAC","file":"/var/folders/64/n4rh096x4p1bk6wrwzk_r53mrkml20/T/tmp1TfCYqpublish_packages/npm/nuclide-logging/lib/stacktrace.js","sourcesContent":["'use babel';\n/* @flow */\n\n/*\n * Copyright (c) 2015-present, Facebook, Inc.\n * All rights reserved.\n *\n * This source code is licensed under the license found in the LICENSE file in\n * the root directory of this source tree.\n */\nimport type {node$CallSite} from './types';\n\ntype PrepareStackTraceFunction = (error: Error, frames: Array<node$CallSite>) => any;\n\nvar PREPARE_STACK_TRACE_HOOKED_KEY = '_nuclide_error_stack_trace_hooked';\n\nvar hookedPrepareStackTrace: ?PrepareStackTraceFunction;\n\n/**\n * v8 provided a way to customize Error stacktrace generation by overwriting\n * Error.prepareStackTrace (https://code.google.com/p/v8/wiki/JavaScriptStackTraceApi).\n * Here we added a hook to Error.prepareStackTrace to achieve following goals:\n *  1) Whenever `error.stack` is called, error.stackTrace will be generated.\n *  2) Other module's customization to Error.prepareStackTrace, no matter before or after the hook\n *     is added, will still work as expected.\n * In this way, other module could still overwrite Error.prepareStackTrace to customize stacktrace.\n * This is required as Atom's builtin coffeescript package need to show coffeescript stacktrace by\n * customize Error.prepareStackTrace.\n */\nexport default function addPrepareStackTraceHook(): void {\n  require('nuclide-commons').singleton.get(\n    PREPARE_STACK_TRACE_HOOKED_KEY,\n    () => {\n      hookedPrepareStackTrace = createHookedPrepareStackTrace(Error.prepareStackTrace\n        || defaultPrepareStackTrace);\n\n      // Hook Error.prepareStackTrace by leveraging get/set accessor. In this way, writing to\n      // Error.prepareStackTrace will put the new prepareStackTrace functions in a wrapper that\n      // calls the hook.\n      // $FlowIssue\n      Object.defineProperty(Error, 'prepareStackTrace', {\n        get() {\n          return hookedPrepareStackTrace;\n        },\n        set(newValue) {\n          hookedPrepareStackTrace = createHookedPrepareStackTrace(newValue\n            || defaultPrepareStackTrace);\n        },\n        enumerable: false,\n        configurable: true,\n      });\n      return true;\n    },\n  );\n}\n\n/**\n * Create a wrapper that calls to structuredStackTraceHook first, then return the result of\n * prepareStackTrace.\n */\nfunction createHookedPrepareStackTrace(\n  prepareStackTrace: PrepareStackTraceFunction,\n): PrepareStackTraceFunction {\n  // If the prepareStackTrace is already been hooked, just return it.\n  if (prepareStackTrace.name === 'nuclideHookedPrepareStackTrace') {\n    return prepareStackTrace;\n  }\n\n  var hookedFunction = function nuclideHookedPrepareStackTrace(\n    error: Error,\n    frames: Array<node$CallSite>,\n  ): any {\n    structuredStackTraceHook(error, frames);\n    return prepareStackTrace(error, frames);\n  };\n\n  return hookedFunction;\n}\n\nfunction structuredStackTraceHook(error: Error, frames: Array<node$CallSite>): void {\n  // $FlowFixMe\n  error['stackTrace'] = frames.map(frame => {\n    return {\n      functionName: frame.getFunctionName(),\n      methodName: frame.getMethodName(),\n      fileName: frame.getFileName(),\n      lineNumber: frame.getLineNumber(),\n      columnNumber: frame.getColumnNumber(),\n      evalOrigin: frame.getEvalOrigin(),\n      isTopLevel: frame.isToplevel(),\n      isEval: frame.isEval(),\n      isNative: frame.isNative(),\n      isConstructor: frame.isConstructor(),\n    };\n  });\n}\n\nfunction defaultPrepareStackTrace(error: Error, frames: Array<node$CallSite>): string {\n  var formattedStackTrace = error.message ? `${error.name}: ${error.message}` : `${error.name}`;\n  frames.forEach(frame => {\n    formattedStackTrace += `\\n    at ${frame.toString()}`;\n  });\n  return formattedStackTrace;\n}\n\nexport var __test__ = {\n  createHookedPrepareStackTrace,\n  resetPrepareStackTraceHooked() {\n    require('nuclide-commons').singleton.clear(PREPARE_STACK_TRACE_HOOKED_KEY);\n  },\n};\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["/var/folders/xf/rsph4_c57315rs57xxsdskrxnv36t0/T/tmppfl52npublish_packages/npm/nuclide-logging/lib/stacktrace.js"],"names":[],"mappings":";;;;;;;;;;;qBA6BwB,wBAAwB;AA7BhD,WAAW,CAAC;;AAcZ,IAAM,8BAA8B,GAAG,mCAAmC,CAAC;;AAE3E,IAAI,uBAAmD,YAAA,CAAC;;;;;;;;;;;;;;AAazC,SAAS,wBAAwB,GAAS;AACvD,SAAO,CAAC,iBAAiB,CAAC,CAAC,SAAS,CAAC,GAAG,CACtC,8BAA8B,EAC9B,YAAM;AACJ,2BAAuB,GAAG,6BAA6B,CAAC,KAAK,CAAC,iBAAiB,IAC1E,wBAAwB,CAAC,CAAC;;;;;;AAM/B,UAAM,CAAC,cAAc,CAAC,KAAK,EAAE,mBAAmB,EAAE;AAChD,SAAG,EAAA,eAAG;AACJ,eAAO,uBAAuB,CAAC;OAChC;AACD,SAAG,EAAA,aAAC,QAAQ,EAAE;AACZ,+BAAuB,GAAG,6BAA6B,CAAC,QAAQ,IAC3D,wBAAwB,CAAC,CAAC;OAChC;AACD,gBAAU,EAAE,KAAK;AACjB,kBAAY,EAAE,IAAI;KACnB,CAAC,CAAC;;;;;;;;;;AAUH,SAAK,CAAC,SAAS,CAAC,WAAW,GAAG,IAAI,CAAC;;AAEnC,WAAO,IAAI,CAAC;GACb,CACF,CAAC;CACH;;;;;;AAMD,SAAS,6BAA6B,CACpC,iBAA4C,EACjB;;AAE3B,MAAI,iBAAiB,CAAC,IAAI,KAAK,gCAAgC,EAAE;AAC/D,WAAO,iBAAiB,CAAC;GAC1B;;AAED,MAAM,cAAc,GAAG,SAAS,8BAA8B,CAC5D,KAAY,EACZ,MAA4B,EACvB;AACL,4BAAwB,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;AACxC,WAAO,iBAAiB,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;GACzC,CAAC;;AAEF,SAAO,cAAc,CAAC;CACvB;;AAED,SAAS,wBAAwB,CAAC,KAAY,EAAE,MAA4B,EAAQ;;AAElF,OAAK,CAAC,YAAY,CAAC,GAAG,MAAM,CAAC,GAAG,CAAC,UAAA,KAAK,EAAI;AACxC,WAAO;AACL,kBAAY,EAAE,KAAK,CAAC,eAAe,EAAE;AACrC,gBAAU,EAAE,KAAK,CAAC,aAAa,EAAE;AACjC,cAAQ,EAAE,KAAK,CAAC,WAAW,EAAE;AAC7B,gBAAU,EAAE,KAAK,CAAC,aAAa,EAAE;AACjC,kBAAY,EAAE,KAAK,CAAC,eAAe,EAAE;AACrC,gBAAU,EAAE,KAAK,CAAC,aAAa,EAAE;AACjC,gBAAU,EAAE,KAAK,CAAC,UAAU,EAAE;AAC9B,YAAM,EAAE,KAAK,CAAC,MAAM,EAAE;AACtB,cAAQ,EAAE,KAAK,CAAC,QAAQ,EAAE;AAC1B,mBAAa,EAAE,KAAK,CAAC,aAAa,EAAE;KACrC,CAAC;GACH,CAAC,CAAC;CACJ;;AAED,SAAS,wBAAwB,CAAC,KAAY,EAAE,MAA4B,EAAU;AACpF,MAAI,mBAAmB,GAAG,KAAK,CAAC,OAAO,GAAM,KAAK,CAAC,IAAI,UAAK,KAAK,CAAC,OAAO,QAAQ,KAAK,CAAC,IAAI,AAAE,CAAC;AAC9F,QAAM,CAAC,OAAO,CAAC,UAAA,KAAK,EAAI;AACtB,uBAAmB,kBAAgB,KAAK,CAAC,QAAQ,EAAE,AAAE,CAAC;GACvD,CAAC,CAAC;AACH,SAAO,mBAAmB,CAAC;CAC5B;;AAEM,IAAM,QAAQ,GAAG;AACtB,+BAA6B,EAA7B,6BAA6B;AAC7B,8BAA4B,EAAA,wCAAG;AAC7B,WAAO,CAAC,iBAAiB,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,8BAA8B,CAAC,CAAC;GAC5E;CACF,CAAC","file":"/var/folders/xf/rsph4_c57315rs57xxsdskrxnv36t0/T/tmppfl52npublish_packages/npm/nuclide-logging/lib/stacktrace.js","sourcesContent":["'use babel';\n/* @flow */\n\n/*\n * Copyright (c) 2015-present, Facebook, Inc.\n * All rights reserved.\n *\n * This source code is licensed under the license found in the LICENSE file in\n * the root directory of this source tree.\n */\nimport type {node$CallSite} from './types';\n\ntype PrepareStackTraceFunction = (error: Error, frames: Array<node$CallSite>) => any;\n\nconst PREPARE_STACK_TRACE_HOOKED_KEY = '_nuclide_error_stack_trace_hooked';\n\nlet hookedPrepareStackTrace: ?PrepareStackTraceFunction;\n\n/**\n * v8 provided a way to customize Error stacktrace generation by overwriting\n * Error.prepareStackTrace (https://code.google.com/p/v8/wiki/JavaScriptStackTraceApi).\n * Here we added a hook to Error.prepareStackTrace to achieve following goals:\n *  1) Whenever `error.stack` is called, error.stackTrace will be generated.\n *  2) Other module's customization to Error.prepareStackTrace, no matter before or after the hook\n *     is added, will still work as expected.\n * In this way, other module could still overwrite Error.prepareStackTrace to customize stacktrace.\n * This is required as Atom's builtin coffeescript package need to show coffeescript stacktrace by\n * customize Error.prepareStackTrace.\n */\nexport default function addPrepareStackTraceHook(): void {\n  require('nuclide-commons').singleton.get(\n    PREPARE_STACK_TRACE_HOOKED_KEY,\n    () => {\n      hookedPrepareStackTrace = createHookedPrepareStackTrace(Error.prepareStackTrace\n        || defaultPrepareStackTrace);\n\n      // Hook Error.prepareStackTrace by leveraging get/set accessor. In this way, writing to\n      // Error.prepareStackTrace will put the new prepareStackTrace functions in a wrapper that\n      // calls the hook.\n      // $FlowIssue\n      Object.defineProperty(Error, 'prepareStackTrace', {\n        get() {\n          return hookedPrepareStackTrace;\n        },\n        set(newValue) {\n          hookedPrepareStackTrace = createHookedPrepareStackTrace(newValue\n            || defaultPrepareStackTrace);\n        },\n        enumerable: false,\n        configurable: true,\n      });\n\n      // TODO (chenshen) t8789330.\n      // Atom added getRawStack to Error.prototype to get Error's structured stacktrace\n      // (https://github.com/atom/grim/blob/master/src/grim.coffee#L43). However, this\n      // doesn't work well with our customization of stacktrace. So here we temporarily\n      // walk around this by following hack, until https://github.com/atom/atom/issues/9641\n      // get addressed.\n      /* eslint-disable no-extend-native */\n      /* $FlowFixMe */\n      Error.prototype.getRawStack = null;\n      /* eslint-enable no-extend-native */\n      return true;\n    },\n  );\n}\n\n/**\n * Create a wrapper that calls to structuredStackTraceHook first, then return the result of\n * prepareStackTrace.\n */\nfunction createHookedPrepareStackTrace(\n  prepareStackTrace: PrepareStackTraceFunction,\n): PrepareStackTraceFunction {\n  // If the prepareStackTrace is already been hooked, just return it.\n  if (prepareStackTrace.name === 'nuclideHookedPrepareStackTrace') {\n    return prepareStackTrace;\n  }\n\n  const hookedFunction = function nuclideHookedPrepareStackTrace(\n    error: Error,\n    frames: Array<node$CallSite>,\n  ): any {\n    structuredStackTraceHook(error, frames);\n    return prepareStackTrace(error, frames);\n  };\n\n  return hookedFunction;\n}\n\nfunction structuredStackTraceHook(error: Error, frames: Array<node$CallSite>): void {\n  // $FlowFixMe\n  error['stackTrace'] = frames.map(frame => {\n    return {\n      functionName: frame.getFunctionName(),\n      methodName: frame.getMethodName(),\n      fileName: frame.getFileName(),\n      lineNumber: frame.getLineNumber(),\n      columnNumber: frame.getColumnNumber(),\n      evalOrigin: frame.getEvalOrigin(),\n      isTopLevel: frame.isToplevel(),\n      isEval: frame.isEval(),\n      isNative: frame.isNative(),\n      isConstructor: frame.isConstructor(),\n    };\n  });\n}\n\nfunction defaultPrepareStackTrace(error: Error, frames: Array<node$CallSite>): string {\n  let formattedStackTrace = error.message ? `${error.name}: ${error.message}` : `${error.name}`;\n  frames.forEach(frame => {\n    formattedStackTrace += `\\n    at ${frame.toString()}`;\n  });\n  return formattedStackTrace;\n}\n\nexport const __test__ = {\n  createHookedPrepareStackTrace,\n  resetPrepareStackTraceHooked() {\n    require('nuclide-commons').singleton.clear(PREPARE_STACK_TRACE_HOOKED_KEY);\n  },\n};\n"]}

@@ -13,2 +13,2 @@

});
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi92YXIvZm9sZGVycy82NC9uNHJoMDk2eDRwMWJrNndyd3prX3I1M21ya21sMjAvVC90bXAxVGZDWXFwdWJsaXNoX3BhY2thZ2VzL25wbS9udWNsaWRlLWxvZ2dpbmcvbGliL3R5cGVzLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLFdBQVcsQ0FBQyIsImZpbGUiOiIvdmFyL2ZvbGRlcnMvNjQvbjRyaDA5Nng0cDFiazZ3cnd6a19yNTNtcmttbDIwL1QvdG1wMVRmQ1lxcHVibGlzaF9wYWNrYWdlcy9ucG0vbnVjbGlkZS1sb2dnaW5nL2xpYi90eXBlcy5qcyIsInNvdXJjZXNDb250ZW50IjpbIid1c2UgYmFiZWwnO1xuLyogQGZsb3cgKi9cblxuLypcbiAqIENvcHlyaWdodCAoYykgMjAxNS1wcmVzZW50LCBGYWNlYm9vaywgSW5jLlxuICogQWxsIHJpZ2h0cyByZXNlcnZlZC5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBsaWNlbnNlIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgaW5cbiAqIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICovXG5cbmV4cG9ydCB0eXBlIG5vZGUkQ2FsbFNpdGUgPSB7XG4gIHRvU3RyaW5nKCk6ID9zdHJpbmc7XG4gIGdldEZ1bmN0aW9uTmFtZSgpOiA/c3RyaW5nO1xuICBnZXRNZXRob2ROYW1lKCk6ID9zdHJpbmc7XG4gIGdldEZpbGVOYW1lKCk6ID9zdHJpbmc7XG4gIGdldExpbmVOdW1iZXIoKTogP251bWJlcjtcbiAgZ2V0Q29sdW1uTnVtYmVyKCk6ID9udW1iZXI7XG4gIGdldEV2YWxPcmlnaW4oKTogP3N0cmluZztcbiAgaXNUb3BsZXZlbCgpOiBib29sZWFuO1xuICBpc0V2YWwoKTogYm9vbGVhbjtcbiAgaXNOYXRpdmUoKTogYm9vbGVhbjtcbiAgaXNDb25zdHJ1Y3RvcigpOiBib29sZWFuO1xufVxuXG5leHBvcnQgdHlwZSBMb2dnZXIgPSB7XG4gIGRlYnVnKC4uLmFyZ3M6IEFycmF5PGFueT4pOiBtaXhlZDtcbiAgZXJyb3IoLi4uYXJnczogQXJyYXk8YW55Pik6IG1peGVkO1xuICBmYXRhbCguLi5hcmdzOiBBcnJheTxhbnk+KTogbWl4ZWQ7XG4gIGluZm8oLi4uYXJnczogQXJyYXk8YW55Pik6IG1peGVkO1xuICB0cmFjZSguLi5hcmdzOiBBcnJheTxhbnk+KTogbWl4ZWQ7XG4gIHdhcm4oLi4uYXJnczogQXJyYXk8YW55Pik6IG1peGVkO1xuICBpc0xldmVsRW5hYmxlZChsZXZlbDogc3RyaW5nKTogbWl4ZWQ7XG4gIHNldExldmVsKGxldmVsOiBzdHJpbmcpOiBtaXhlZDtcbn1cblxuZXhwb3J0IHR5cGUgTG9nZ2luZ0V2ZW50ID0ge1xuICBzdGFydFRpbWU6IERhdGU7XG4gIGNhdGVnb3J5TmFtZTogc3RyaW5nO1xuICBkYXRhOiBBcnJheTxhbnk+O1xuICBsZXZlbDoge1xuICAgIGxldmVsOiBudW1iZXI7XG4gICAgbGV2ZWxTdHI6IHN0cmluZztcbiAgfTtcbiAgbG9nZ2VyPzoge1xuICAgIGNhdGVnb3J5OiBzdHJpbmc7XG4gIH07XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi92YXIvZm9sZGVycy94Zi9yc3BoNF9jNTczMTVyczU3eHhzZHNrcnhudjM2dDAvVC90bXBwZmw1Mm5wdWJsaXNoX3BhY2thZ2VzL25wbS9udWNsaWRlLWxvZ2dpbmcvbGliL3R5cGVzLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLFdBQVcsQ0FBQyIsImZpbGUiOiIvdmFyL2ZvbGRlcnMveGYvcnNwaDRfYzU3MzE1cnM1N3h4c2Rza3J4bnYzNnQwL1QvdG1wcGZsNTJucHVibGlzaF9wYWNrYWdlcy9ucG0vbnVjbGlkZS1sb2dnaW5nL2xpYi90eXBlcy5qcyIsInNvdXJjZXNDb250ZW50IjpbIid1c2UgYmFiZWwnO1xuLyogQGZsb3cgKi9cblxuLypcbiAqIENvcHlyaWdodCAoYykgMjAxNS1wcmVzZW50LCBGYWNlYm9vaywgSW5jLlxuICogQWxsIHJpZ2h0cyByZXNlcnZlZC5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBsaWNlbnNlIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgaW5cbiAqIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICovXG5cbmV4cG9ydCB0eXBlIG5vZGUkQ2FsbFNpdGUgPSB7XG4gIHRvU3RyaW5nKCk6ID9zdHJpbmc7XG4gIGdldEZ1bmN0aW9uTmFtZSgpOiA/c3RyaW5nO1xuICBnZXRNZXRob2ROYW1lKCk6ID9zdHJpbmc7XG4gIGdldEZpbGVOYW1lKCk6ID9zdHJpbmc7XG4gIGdldExpbmVOdW1iZXIoKTogP251bWJlcjtcbiAgZ2V0Q29sdW1uTnVtYmVyKCk6ID9udW1iZXI7XG4gIGdldEV2YWxPcmlnaW4oKTogP3N0cmluZztcbiAgaXNUb3BsZXZlbCgpOiBib29sZWFuO1xuICBpc0V2YWwoKTogYm9vbGVhbjtcbiAgaXNOYXRpdmUoKTogYm9vbGVhbjtcbiAgaXNDb25zdHJ1Y3RvcigpOiBib29sZWFuO1xufVxuXG5leHBvcnQgdHlwZSBMb2dnZXIgPSB7XG4gIGRlYnVnKC4uLmFyZ3M6IEFycmF5PGFueT4pOiBtaXhlZDtcbiAgZXJyb3IoLi4uYXJnczogQXJyYXk8YW55Pik6IG1peGVkO1xuICBmYXRhbCguLi5hcmdzOiBBcnJheTxhbnk+KTogbWl4ZWQ7XG4gIGluZm8oLi4uYXJnczogQXJyYXk8YW55Pik6IG1peGVkO1xuICB0cmFjZSguLi5hcmdzOiBBcnJheTxhbnk+KTogbWl4ZWQ7XG4gIHdhcm4oLi4uYXJnczogQXJyYXk8YW55Pik6IG1peGVkO1xuICBpc0xldmVsRW5hYmxlZChsZXZlbDogc3RyaW5nKTogbWl4ZWQ7XG4gIHNldExldmVsKGxldmVsOiBzdHJpbmcpOiBtaXhlZDtcbn1cblxuZXhwb3J0IHR5cGUgTG9nZ2luZ0V2ZW50ID0ge1xuICBzdGFydFRpbWU6IERhdGU7XG4gIGNhdGVnb3J5TmFtZTogc3RyaW5nO1xuICBkYXRhOiBBcnJheTxhbnk+O1xuICBsZXZlbDoge1xuICAgIGxldmVsOiBudW1iZXI7XG4gICAgbGV2ZWxTdHI6IHN0cmluZztcbiAgfTtcbiAgbG9nZ2VyPzoge1xuICAgIGNhdGVnb3J5OiBzdHJpbmc7XG4gIH07XG4gIHN0b3JhZ2VLZXk/OiBzdHJpbmc7XG4gIHJ1bnRpbWU/OiBhbnk7XG59XG5cbmV4cG9ydCB0eXBlIExvZ2dpbmdBcHBlbmRlciA9IHtcbiAgYXBwZW5kZXJzOiBhbnk7XG59XG4iXX0=

@@ -80,3 +80,3 @@ Object.defineProperty(exports, '__esModule', {

function deserializeLoggingEvent(loggingEventString) {
var loggingEvent;
var loggingEvent = undefined;
try {

@@ -97,2 +97,2 @@ loggingEvent = JSON.parse(loggingEventString);

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi92YXIvZm9sZGVycy82NC9uNHJoMDk2eDRwMWJrNndyd3prX3I1M21ya21sMjAvVC90bXAxVGZDWXFwdWJsaXNoX3BhY2thZ2VzL25wbS9udWNsaWRlLWxvZ2dpbmcvbGliL3V0aWxzLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O3NCQVdtQixRQUFROzs7Ozs7Ozs7Ozs7QUFYM0IsV0FBVyxDQUFDOztBQXVCTCxTQUFTLHlCQUF5QixDQUFDLFlBQTBCLEVBQWdCO0FBQ2xGLE1BQUksZ0JBQWdCLGdCQUFPLFlBQVksQ0FBQyxDQUFDO0FBQ3pDLGtCQUFnQixDQUFDLElBQUksR0FBRyxDQUFDLGdCQUFnQixDQUFDLElBQUksSUFBSSxFQUFFLENBQUEsQ0FBRSxLQUFLLEVBQUUsQ0FBQzs7QUFFOUQsTUFBSSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBQSxJQUFJO1dBQUksSUFBSSxZQUFZLEtBQUs7R0FBQSxDQUFDLEVBQUU7QUFDOUQsb0JBQWdCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLEtBQUssQ0FBQyxzQkFBc0IsQ0FBQyxDQUFDLENBQUM7R0FDL0Q7O0FBRUQsa0JBQWdCLENBQUMsSUFBSSxHQUFHLGdCQUFnQixDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsVUFBQSxJQUFJLEVBQUk7QUFDeEQsUUFBSSxJQUFJLFlBQVksS0FBSyxFQUFFO0FBQ3pCLGFBQU87QUFDTCxZQUFJLEVBQUUsSUFBSSxDQUFDLElBQUk7QUFDZixlQUFPLEVBQUUsSUFBSSxDQUFDLE9BQU87QUFDckIsYUFBSyxFQUFFLElBQUksQ0FBQyxLQUFLO0FBQ2pCLGtCQUFVLEVBQUUsSUFBSSxDQUFDLFVBQVU7T0FDNUIsQ0FBQztLQUNIO0FBQ0QsV0FBTyxJQUFJLENBQUM7R0FDYixDQUFDLENBQUM7O0FBRUgsU0FBTyxnQkFBZ0IsQ0FBQztDQUN6Qjs7Ozs7O0FBS00sU0FBUyxxQkFBcUIsQ0FBQyxZQUFtQixFQUFVO0FBQ2pFLFNBQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQyxZQUFZLENBQUMsQ0FBQztDQUNyQzs7Ozs7Ozs7Ozs7OztBQVlNLFNBQVMsdUJBQXVCLENBQUMsa0JBQTBCLEVBQWdCO0FBQ2hGLE1BQUksWUFBWSxDQUFDO0FBQ2pCLE1BQUk7QUFDRixnQkFBWSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsa0JBQWtCLENBQUMsQ0FBQztBQUM5QyxnQkFBWSxDQUFDLFNBQVMsR0FBRyxJQUFJLElBQUksQ0FBQyxZQUFZLENBQUMsU0FBUyxDQUFDLENBQUM7QUFDMUQsZ0JBQVksQ0FBQyxLQUFLLEdBQUcsb0JBQU8sTUFBTSxDQUFDLE9BQU8sQ0FBQyxZQUFZLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDO0dBQ3pFLENBQUMsT0FBTyxDQUFDLEVBQUU7O0FBRVYsZ0JBQVksR0FBRztBQUNiLGVBQVMsRUFBRSxJQUFJLElBQUksRUFBRTtBQUNyQixrQkFBWSxFQUFFLFFBQVE7QUFDdEIsV0FBSyxFQUFFLG9CQUFPLE1BQU0sQ0FBQyxLQUFLO0FBQzFCLFVBQUksRUFBRSxDQUFDLHNCQUFzQixFQUFFLGtCQUFrQixDQUFDO0tBQ25ELENBQUM7R0FDSDtBQUNELFNBQU8sWUFBWSxDQUFDO0NBQ3JCIiwiZmlsZSI6Ii92YXIvZm9sZGVycy82NC9uNHJoMDk2eDRwMWJrNndyd3prX3I1M21ya21sMjAvVC90bXAxVGZDWXFwdWJsaXNoX3BhY2thZ2VzL25wbS9udWNsaWRlLWxvZ2dpbmcvbGliL3V0aWxzLmpzIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBiYWJlbCc7XG4vKiBAZmxvdyAqL1xuXG4vKlxuICogQ29weXJpZ2h0IChjKSAyMDE1LXByZXNlbnQsIEZhY2Vib29rLCBJbmMuXG4gKiBBbGwgcmlnaHRzIHJlc2VydmVkLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIGxpY2Vuc2UgZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBpblxuICogdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKi9cblxuaW1wb3J0IGxvZzRqcyBmcm9tICdsb2c0anMnO1xuXG5pbXBvcnQgdHlwZSB7TG9nZ2luZ0V2ZW50fSBmcm9tICcuL3R5cGVzJztcblxuLyoqXG4gKiBKU09OLnN0cmluZ2lmeSBjYW4ndCBzdHJpbmdpZnkgaW5zdGFuY2Ugb2YgRXJyb3IuIFRvIHNvbHZlIHRoaXMgcHJvYmxlbSwgd2VcbiAqIHBhdGNoIHRoZSBlcnJvcnMgaW4gbG9nZ2luZ0V2ZW50LmRhdGEgYW5kIGNvbnZlcnQgaXQgdG8gYW4gT2JqZWN0IHdpdGggJ25hbWUnLCAnbWVzc2FnZScsXG4gKiAnc3RhY2snIGFuZCAnc3RhY2tUcmFjZScgYXMgZmllbGRzLlxuICogSWYgdGhlcmUgaXMgbm8gZXJyb3IgYXR0YWNoZWQgdG8gbG9nZ2luZ0V2ZW50LmRhdGEsIHdlIGNyZWF0ZSBhIG5ldyBlcnJvciBhbmQgYXBwZW5kIGl0IHRvXG4gKiBsb2dnaW5nRXZlbnQuZGF0YSwgc28gdGhhdCB3ZSBjb3VsZCBnZXQgc3RhY2sgaW5mb3JtYXRpb24gd2hpY2ggaGVscHMgY2F0ZWdvcml6YXRpb24gaW5cbiAqIGxvZ3ZpZXcuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBwYXRjaEVycm9yc09mTG9nZ2luZ0V2ZW50KGxvZ2dpbmdFdmVudDogTG9nZ2luZ0V2ZW50KTogTG9nZ2luZ0V2ZW50IHtcbiAgdmFyIGxvZ2dpbmdFdmVudENvcHkgPSB7Li4ubG9nZ2luZ0V2ZW50fTtcbiAgbG9nZ2luZ0V2ZW50Q29weS5kYXRhID0gKGxvZ2dpbmdFdmVudENvcHkuZGF0YSB8fCBbXSkuc2xpY2UoKTtcblxuICBpZiAoIWxvZ2dpbmdFdmVudENvcHkuZGF0YS5zb21lKGl0ZW0gPT4gaXRlbSBpbnN0YW5jZW9mIEVycm9yKSkge1xuICAgIGxvZ2dpbmdFdmVudENvcHkuZGF0YS5wdXNoKG5ldyBFcnJvcignQXV0byBnZW5lcmF0ZWQgRXJyb3InKSk7XG4gIH1cblxuICBsb2dnaW5nRXZlbnRDb3B5LmRhdGEgPSBsb2dnaW5nRXZlbnRDb3B5LmRhdGEubWFwKGl0ZW0gPT4ge1xuICAgIGlmIChpdGVtIGluc3RhbmNlb2YgRXJyb3IpIHtcbiAgICAgIHJldHVybiB7XG4gICAgICAgIG5hbWU6IGl0ZW0ubmFtZSxcbiAgICAgICAgbWVzc2FnZTogaXRlbS5tZXNzYWdlLFxuICAgICAgICBzdGFjazogaXRlbS5zdGFjayxcbiAgICAgICAgc3RhY2tUcmFjZTogaXRlbS5zdGFja1RyYWNlLFxuICAgICAgfTtcbiAgICB9XG4gICAgcmV0dXJuIGl0ZW07XG4gIH0pO1xuXG4gIHJldHVybiBsb2dnaW5nRXZlbnRDb3B5O1xufVxuXG4vKipcbiAqIFRha2VzIGEgbG9nZ2luZ0V2ZW50IG9iamVjdCwgcmV0dXJucyBzdHJpbmcgcmVwcmVzZW50YXRpb24gb2YgaXQuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBzZXJpYWxpemVMb2dnaW5nRXZlbnQobG9nZ2luZ0V2ZW50OiBtaXhlZCk6IHN0cmluZyB7XG4gIHJldHVybiBKU09OLnN0cmluZ2lmeShsb2dnaW5nRXZlbnQpO1xufVxuXG4vKipcbiAqIFRha2VzIGEgc3RyaW5nLCByZXR1cm5zIGFuIG9iamVjdCB3aXRoIHRoZSBjb3JyZWN0IGxvZyBwcm9wZXJ0aWVzLlxuICpcbiAqIFRoaXMgbWV0aG9kIGhhcyBiZWVuIFwiYm9ycm93ZWRcIiBmcm9tIHRoZSBgbXVsdGlwcm9jZXNzYCBhcHBlbmRlclxuICogYnkgYG5vbWlkZGxlbmFtZWAgKGh0dHBzOi8vZ2l0aHViLmNvbS9ub21pZGRsZW5hbWUvbG9nNGpzLW5vZGUvYmxvYi9tYXN0ZXIvbGliL2FwcGVuZGVycy9tdWx0aXByb2Nlc3MuanMpXG4gKlxuICogQXBwYXJlbnRseSwgbm9kZS5qcyBzZXJpYWxpemVzIGV2ZXJ5dGhpbmcgdG8gc3RyaW5ncyB3aGVuIHVzaW5nIGBwcm9jZXNzLnNlbmQoKWAsXG4gKiBzbyB3ZSBuZWVkIHNtYXJ0IGRlc2VyaWFsaXphdGlvbiB0aGF0IHdpbGwgcmVjcmVhdGUgbG9nIGRhdGUgYW5kIGxldmVsIGZvciBmdXJ0aGVyIHByb2Nlc3NpbmcgYnlcbiAqIGxvZzRqcyBpbnRlcm5hbHMuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBkZXNlcmlhbGl6ZUxvZ2dpbmdFdmVudChsb2dnaW5nRXZlbnRTdHJpbmc6IHN0cmluZyk6IExvZ2dpbmdFdmVudCB7XG4gIHZhciBsb2dnaW5nRXZlbnQ7XG4gIHRyeSB7XG4gICAgbG9nZ2luZ0V2ZW50ID0gSlNPTi5wYXJzZShsb2dnaW5nRXZlbnRTdHJpbmcpO1xuICAgIGxvZ2dpbmdFdmVudC5zdGFydFRpbWUgPSBuZXcgRGF0ZShsb2dnaW5nRXZlbnQuc3RhcnRUaW1lKTtcbiAgICBsb2dnaW5nRXZlbnQubGV2ZWwgPSBsb2c0anMubGV2ZWxzLnRvTGV2ZWwobG9nZ2luZ0V2ZW50LmxldmVsLmxldmVsU3RyKTtcbiAgfSBjYXRjaCAoZSkge1xuICAgIC8vIEpTT04ucGFyc2UgZmFpbGVkLCBqdXN0IGxvZyB0aGUgY29udGVudHMgcHJvYmFibHkgYSBuYXVnaHR5LlxuICAgIGxvZ2dpbmdFdmVudCA9IHtcbiAgICAgIHN0YXJ0VGltZTogbmV3IERhdGUoKSxcbiAgICAgIGNhdGVnb3J5TmFtZTogJ2xvZzRqcycsXG4gICAgICBsZXZlbDogbG9nNGpzLmxldmVscy5FUlJPUixcbiAgICAgIGRhdGE6IFsnVW5hYmxlIHRvIHBhcnNlIGxvZzonLCBsb2dnaW5nRXZlbnRTdHJpbmddLFxuICAgIH07XG4gIH1cbiAgcmV0dXJuIGxvZ2dpbmdFdmVudDtcbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi92YXIvZm9sZGVycy94Zi9yc3BoNF9jNTczMTVyczU3eHhzZHNrcnhudjM2dDAvVC90bXBwZmw1Mm5wdWJsaXNoX3BhY2thZ2VzL25wbS9udWNsaWRlLWxvZ2dpbmcvbGliL3V0aWxzLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O3NCQVdtQixRQUFROzs7Ozs7Ozs7Ozs7QUFYM0IsV0FBVyxDQUFDOztBQXVCTCxTQUFTLHlCQUF5QixDQUFDLFlBQTBCLEVBQWdCO0FBQ2xGLE1BQU0sZ0JBQWdCLGdCQUFPLFlBQVksQ0FBQyxDQUFDO0FBQzNDLGtCQUFnQixDQUFDLElBQUksR0FBRyxDQUFDLGdCQUFnQixDQUFDLElBQUksSUFBSSxFQUFFLENBQUEsQ0FBRSxLQUFLLEVBQUUsQ0FBQzs7QUFFOUQsTUFBSSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBQSxJQUFJO1dBQUksSUFBSSxZQUFZLEtBQUs7R0FBQSxDQUFDLEVBQUU7QUFDOUQsb0JBQWdCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLEtBQUssQ0FBQyxzQkFBc0IsQ0FBQyxDQUFDLENBQUM7R0FDL0Q7O0FBRUQsa0JBQWdCLENBQUMsSUFBSSxHQUFHLGdCQUFnQixDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsVUFBQSxJQUFJLEVBQUk7QUFDeEQsUUFBSSxJQUFJLFlBQVksS0FBSyxFQUFFO0FBQ3pCLGFBQU87QUFDTCxZQUFJLEVBQUUsSUFBSSxDQUFDLElBQUk7QUFDZixlQUFPLEVBQUUsSUFBSSxDQUFDLE9BQU87QUFDckIsYUFBSyxFQUFFLElBQUksQ0FBQyxLQUFLO0FBQ2pCLGtCQUFVLEVBQUUsSUFBSSxDQUFDLFVBQVU7T0FDNUIsQ0FBQztLQUNIO0FBQ0QsV0FBTyxJQUFJLENBQUM7R0FDYixDQUFDLENBQUM7O0FBRUgsU0FBTyxnQkFBZ0IsQ0FBQztDQUN6Qjs7Ozs7O0FBS00sU0FBUyxxQkFBcUIsQ0FBQyxZQUFtQixFQUFVO0FBQ2pFLFNBQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQyxZQUFZLENBQUMsQ0FBQztDQUNyQzs7Ozs7Ozs7Ozs7OztBQVlNLFNBQVMsdUJBQXVCLENBQUMsa0JBQTBCLEVBQWdCO0FBQ2hGLE1BQUksWUFBWSxZQUFBLENBQUM7QUFDakIsTUFBSTtBQUNGLGdCQUFZLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO0FBQzlDLGdCQUFZLENBQUMsU0FBUyxHQUFHLElBQUksSUFBSSxDQUFDLFlBQVksQ0FBQyxTQUFTLENBQUMsQ0FBQztBQUMxRCxnQkFBWSxDQUFDLEtBQUssR0FBRyxvQkFBTyxNQUFNLENBQUMsT0FBTyxDQUFDLFlBQVksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLENBQUM7R0FDekUsQ0FBQyxPQUFPLENBQUMsRUFBRTs7QUFFVixnQkFBWSxHQUFHO0FBQ2IsZUFBUyxFQUFFLElBQUksSUFBSSxFQUFFO0FBQ3JCLGtCQUFZLEVBQUUsUUFBUTtBQUN0QixXQUFLLEVBQUUsb0JBQU8sTUFBTSxDQUFDLEtBQUs7QUFDMUIsVUFBSSxFQUFFLENBQUMsc0JBQXNCLEVBQUUsa0JBQWtCLENBQUM7S0FDbkQsQ0FBQztHQUNIO0FBQ0QsU0FBTyxZQUFZLENBQUM7Q0FDckIiLCJmaWxlIjoiL3Zhci9mb2xkZXJzL3hmL3JzcGg0X2M1NzMxNXJzNTd4eHNkc2tyeG52MzZ0MC9UL3RtcHBmbDUybnB1Ymxpc2hfcGFja2FnZXMvbnBtL251Y2xpZGUtbG9nZ2luZy9saWIvdXRpbHMuanMiLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGJhYmVsJztcbi8qIEBmbG93ICovXG5cbi8qXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTUtcHJlc2VudCwgRmFjZWJvb2ssIEluYy5cbiAqIEFsbCByaWdodHMgcmVzZXJ2ZWQuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgbGljZW5zZSBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGluXG4gKiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqL1xuXG5pbXBvcnQgbG9nNGpzIGZyb20gJ2xvZzRqcyc7XG5cbmltcG9ydCB0eXBlIHtMb2dnaW5nRXZlbnR9IGZyb20gJy4vdHlwZXMnO1xuXG4vKipcbiAqIEpTT04uc3RyaW5naWZ5IGNhbid0IHN0cmluZ2lmeSBpbnN0YW5jZSBvZiBFcnJvci4gVG8gc29sdmUgdGhpcyBwcm9ibGVtLCB3ZVxuICogcGF0Y2ggdGhlIGVycm9ycyBpbiBsb2dnaW5nRXZlbnQuZGF0YSBhbmQgY29udmVydCBpdCB0byBhbiBPYmplY3Qgd2l0aCAnbmFtZScsICdtZXNzYWdlJyxcbiAqICdzdGFjaycgYW5kICdzdGFja1RyYWNlJyBhcyBmaWVsZHMuXG4gKiBJZiB0aGVyZSBpcyBubyBlcnJvciBhdHRhY2hlZCB0byBsb2dnaW5nRXZlbnQuZGF0YSwgd2UgY3JlYXRlIGEgbmV3IGVycm9yIGFuZCBhcHBlbmQgaXQgdG9cbiAqIGxvZ2dpbmdFdmVudC5kYXRhLCBzbyB0aGF0IHdlIGNvdWxkIGdldCBzdGFjayBpbmZvcm1hdGlvbiB3aGljaCBoZWxwcyBjYXRlZ29yaXphdGlvbiBpblxuICogbG9ndmlldy5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHBhdGNoRXJyb3JzT2ZMb2dnaW5nRXZlbnQobG9nZ2luZ0V2ZW50OiBMb2dnaW5nRXZlbnQpOiBMb2dnaW5nRXZlbnQge1xuICBjb25zdCBsb2dnaW5nRXZlbnRDb3B5ID0gey4uLmxvZ2dpbmdFdmVudH07XG4gIGxvZ2dpbmdFdmVudENvcHkuZGF0YSA9IChsb2dnaW5nRXZlbnRDb3B5LmRhdGEgfHwgW10pLnNsaWNlKCk7XG5cbiAgaWYgKCFsb2dnaW5nRXZlbnRDb3B5LmRhdGEuc29tZShpdGVtID0+IGl0ZW0gaW5zdGFuY2VvZiBFcnJvcikpIHtcbiAgICBsb2dnaW5nRXZlbnRDb3B5LmRhdGEucHVzaChuZXcgRXJyb3IoJ0F1dG8gZ2VuZXJhdGVkIEVycm9yJykpO1xuICB9XG5cbiAgbG9nZ2luZ0V2ZW50Q29weS5kYXRhID0gbG9nZ2luZ0V2ZW50Q29weS5kYXRhLm1hcChpdGVtID0+IHtcbiAgICBpZiAoaXRlbSBpbnN0YW5jZW9mIEVycm9yKSB7XG4gICAgICByZXR1cm4ge1xuICAgICAgICBuYW1lOiBpdGVtLm5hbWUsXG4gICAgICAgIG1lc3NhZ2U6IGl0ZW0ubWVzc2FnZSxcbiAgICAgICAgc3RhY2s6IGl0ZW0uc3RhY2ssXG4gICAgICAgIHN0YWNrVHJhY2U6IGl0ZW0uc3RhY2tUcmFjZSxcbiAgICAgIH07XG4gICAgfVxuICAgIHJldHVybiBpdGVtO1xuICB9KTtcblxuICByZXR1cm4gbG9nZ2luZ0V2ZW50Q29weTtcbn1cblxuLyoqXG4gKiBUYWtlcyBhIGxvZ2dpbmdFdmVudCBvYmplY3QsIHJldHVybnMgc3RyaW5nIHJlcHJlc2VudGF0aW9uIG9mIGl0LlxuICovXG5leHBvcnQgZnVuY3Rpb24gc2VyaWFsaXplTG9nZ2luZ0V2ZW50KGxvZ2dpbmdFdmVudDogbWl4ZWQpOiBzdHJpbmcge1xuICByZXR1cm4gSlNPTi5zdHJpbmdpZnkobG9nZ2luZ0V2ZW50KTtcbn1cblxuLyoqXG4gKiBUYWtlcyBhIHN0cmluZywgcmV0dXJucyBhbiBvYmplY3Qgd2l0aCB0aGUgY29ycmVjdCBsb2cgcHJvcGVydGllcy5cbiAqXG4gKiBUaGlzIG1ldGhvZCBoYXMgYmVlbiBcImJvcnJvd2VkXCIgZnJvbSB0aGUgYG11bHRpcHJvY2Vzc2AgYXBwZW5kZXJcbiAqIGJ5IGBub21pZGRsZW5hbWVgIChodHRwczovL2dpdGh1Yi5jb20vbm9taWRkbGVuYW1lL2xvZzRqcy1ub2RlL2Jsb2IvbWFzdGVyL2xpYi9hcHBlbmRlcnMvbXVsdGlwcm9jZXNzLmpzKVxuICpcbiAqIEFwcGFyZW50bHksIG5vZGUuanMgc2VyaWFsaXplcyBldmVyeXRoaW5nIHRvIHN0cmluZ3Mgd2hlbiB1c2luZyBgcHJvY2Vzcy5zZW5kKClgLFxuICogc28gd2UgbmVlZCBzbWFydCBkZXNlcmlhbGl6YXRpb24gdGhhdCB3aWxsIHJlY3JlYXRlIGxvZyBkYXRlIGFuZCBsZXZlbCBmb3IgZnVydGhlciBwcm9jZXNzaW5nIGJ5XG4gKiBsb2c0anMgaW50ZXJuYWxzLlxuICovXG5leHBvcnQgZnVuY3Rpb24gZGVzZXJpYWxpemVMb2dnaW5nRXZlbnQobG9nZ2luZ0V2ZW50U3RyaW5nOiBzdHJpbmcpOiBMb2dnaW5nRXZlbnQge1xuICBsZXQgbG9nZ2luZ0V2ZW50O1xuICB0cnkge1xuICAgIGxvZ2dpbmdFdmVudCA9IEpTT04ucGFyc2UobG9nZ2luZ0V2ZW50U3RyaW5nKTtcbiAgICBsb2dnaW5nRXZlbnQuc3RhcnRUaW1lID0gbmV3IERhdGUobG9nZ2luZ0V2ZW50LnN0YXJ0VGltZSk7XG4gICAgbG9nZ2luZ0V2ZW50LmxldmVsID0gbG9nNGpzLmxldmVscy50b0xldmVsKGxvZ2dpbmdFdmVudC5sZXZlbC5sZXZlbFN0cik7XG4gIH0gY2F0Y2ggKGUpIHtcbiAgICAvLyBKU09OLnBhcnNlIGZhaWxlZCwganVzdCBsb2cgdGhlIGNvbnRlbnRzIHByb2JhYmx5IGEgbmF1Z2h0eS5cbiAgICBsb2dnaW5nRXZlbnQgPSB7XG4gICAgICBzdGFydFRpbWU6IG5ldyBEYXRlKCksXG4gICAgICBjYXRlZ29yeU5hbWU6ICdsb2c0anMnLFxuICAgICAgbGV2ZWw6IGxvZzRqcy5sZXZlbHMuRVJST1IsXG4gICAgICBkYXRhOiBbJ1VuYWJsZSB0byBwYXJzZSBsb2c6JywgbG9nZ2luZ0V2ZW50U3RyaW5nXSxcbiAgICB9O1xuICB9XG4gIHJldHVybiBsb2dnaW5nRXZlbnQ7XG59XG4iXX0=
{
"dependencies": {
"log4js": "0.6.21",
"nuclide-commons": "0.0.34"
"log4js": "0.6.27",
"nuclide-commons": "0.0.35"
},
"description": "Provides logging on both Nuclide client and Nuclide server",
"devDependencies": {
"nuclide-external-interfaces": "0.0.34",
"nuclide-jasmine": "0.0.34"
"nuclide-jasmine": "0.0.35"
},

@@ -16,3 +15,2 @@ "license": "SEE LICENSE IN LICENSE",

"customDeps": "fb/package.json",
"flowCheck": true,
"packageType": "Node",

@@ -25,3 +23,3 @@ "testRunner": "npm"

},
"version": "0.0.34"
"version": "0.0.35"
}

@@ -16,9 +16,9 @@ 'use babel';

describe('getPathToLogFileForDate', () => {
var {getPathToLogFileForDate} = __test__;
const {getPathToLogFileForDate} = __test__;
it('returns the file path to the log file for today.', () => {
var YEAR = 2015;
var MONTH = 0; // January
var DATE = 2;
var targetDate = new Date(YEAR, MONTH, DATE);
var expectedString = LOG_FILE_PATH + '-2015-01-02';
const YEAR = 2015;
const MONTH = 0; // January
const DATE = 2;
const targetDate = new Date(YEAR, MONTH, DATE);
const expectedString = LOG_FILE_PATH + '-2015-01-02';
expect(getPathToLogFileForDate(targetDate)).toEqual(expectedString);

@@ -25,0 +25,0 @@ });

@@ -15,3 +15,3 @@ 'use babel';

var STACK_FRAME_PROPERTIES = [
const STACK_FRAME_PROPERTIES = [
'functionName', 'methodName', 'fileName', 'lineNumber', 'columnNumber', 'evalOrigin',

@@ -26,3 +26,3 @@ 'isTopLevel', 'isEval', 'isNative', 'isConstructor',

e.stackTrace.forEach(frame => {
var keys = Object.keys(frame);
const keys = Object.keys(frame);
STACK_FRAME_PROPERTIES.forEach(property => {

@@ -42,5 +42,5 @@ expect(keys.indexOf(property) >= 0).toBe(true);

it('creates hooked prepareStackTrace', () => {
var {createHookedPrepareStackTrace} = __test__;
var prepareStackTrace = (error, frames) => 'test';
var hooked = createHookedPrepareStackTrace(prepareStackTrace);
const {createHookedPrepareStackTrace} = __test__;
const prepareStackTrace = (error, frames) => 'test';
const hooked = createHookedPrepareStackTrace(prepareStackTrace);
expect(hooked.name).toBe('nuclideHookedPrepareStackTrace');

@@ -51,9 +51,9 @@ expect(hooked !== prepareStackTrace).toBe(true);

it('does\'t hook a hooked function again', () => {
var {createHookedPrepareStackTrace} = __test__;
var prepareStackTrace = (error, frames) => 'test';
var hooked = createHookedPrepareStackTrace(prepareStackTrace);
const {createHookedPrepareStackTrace} = __test__;
const prepareStackTrace = (error, frames) => 'test';
const hooked = createHookedPrepareStackTrace(prepareStackTrace);
expect(hooked.name).toBe('nuclideHookedPrepareStackTrace');
expect(hooked !== prepareStackTrace).toBe(true);
var hookedTwice = createHookedPrepareStackTrace(hooked);
const hookedTwice = createHookedPrepareStackTrace(hooked);
expect(hookedTwice.name).toBe('nuclideHookedPrepareStackTrace');

@@ -65,3 +65,3 @@ expect(hookedTwice).toBe(hooked);

addPrepareStackTraceHook();
var e = new Error();
const e = new Error();
// e.stackTrace won't be availabe until e.stack is called.

@@ -76,3 +76,3 @@ // $FlowIssue

var customizedStack = 'There is no spoon';
const customizedStack = 'There is no spoon';
// $FlowFixMe

@@ -83,3 +83,3 @@ Error.prepareStackTrace = (_, frames) => {

var e = new Error();
let e = new Error();
// e.stack is customized.

@@ -103,3 +103,3 @@ expect(e.stack).toBe(customizedStack);

var e = new Error();
let e = new Error();
// $FlowIssue

@@ -111,6 +111,6 @@ expect(e.stackTrace).toBe(undefined);

// $FlowFixMe
var originalPrepareStackTrace = Error.prepareStackTrace;
const originalPrepareStackTrace = Error.prepareStackTrace;
// Add customization and verify it works.
var customizedStack = 'There is no spoon';
const customizedStack = 'There is no spoon';
// $FlowFixMe

@@ -117,0 +117,0 @@ Error.prepareStackTrace = (_, frames) => {

@@ -49,8 +49,8 @@ 'use babel';

it('patches error of loggingEvent', () => {
var error = new Error('test');
var loggingEventWithError = createLoggingEvent(error);
const error = new Error('test');
const loggingEventWithError = createLoggingEvent(error);
expect(loggingEventWithError.data[0] instanceof Error).toBe(true);
expect(loggingEventWithError.data[0]).toBe(error);
var patchedLoggingEventWithError = patchErrorsOfLoggingEvent(loggingEventWithError);
const patchedLoggingEventWithError = patchErrorsOfLoggingEvent(loggingEventWithError);
expect(patchedLoggingEventWithError.data[0] instanceof Error).toBe(false);

@@ -62,5 +62,5 @@ expect(typeof patchedLoggingEventWithError.data[0].stack).toBe('string');

it('addes error if no error exists in loggingEvent.data', () => {
var loggingEventWithoutError = createLoggingEvent();
const loggingEventWithoutError = createLoggingEvent();
expect(loggingEventWithoutError.data.length).toBe(0);
var patchedLoggingEventWithoutError = patchErrorsOfLoggingEvent(loggingEventWithoutError);
const patchedLoggingEventWithoutError = patchErrorsOfLoggingEvent(loggingEventWithoutError);
expect(typeof patchedLoggingEventWithoutError.data[0].stack).toBe('string');

@@ -70,8 +70,8 @@ });

it('Test serialization/deserialization utils.', () => {
var loggingEvent = patchErrorsOfLoggingEvent(createLoggingEvent(new Error('123')));
const loggingEvent = patchErrorsOfLoggingEvent(createLoggingEvent(new Error('123')));
var serialization = serializeLoggingEvent(loggingEvent);
const serialization = serializeLoggingEvent(loggingEvent);
expect(typeof serialization === 'string').toBe(true);
var deserialization = deserializeLoggingEvent(serialization);
const deserialization = deserializeLoggingEvent(serialization);
expect(deserialization.startTime.toString()).toEqual(loggingEvent.startTime.toString());

@@ -78,0 +78,0 @@ expect(deserialization.categoryName).toEqual(loggingEvent.categoryName);

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc