first commit
This commit is contained in:
113
build/node_modules/prepack/lib/serializer/utils.js
generated
vendored
Normal file
113
build/node_modules/prepack/lib/serializer/utils.js
generated
vendored
Normal file
@@ -0,0 +1,113 @@
|
||||
"use strict";
|
||||
|
||||
Object.defineProperty(exports, "__esModule", {
|
||||
value: true
|
||||
});
|
||||
exports.getSuggestedArrayLiteralLength = getSuggestedArrayLiteralLength;
|
||||
exports.commonAncestorOf = commonAncestorOf;
|
||||
exports.getOrDefault = getOrDefault;
|
||||
|
||||
var _invariant = require("../invariant.js");
|
||||
|
||||
var _invariant2 = _interopRequireDefault(_invariant);
|
||||
|
||||
var _index = require("../methods/index.js");
|
||||
|
||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||||
|
||||
/**
|
||||
* Get index property list length by searching array properties list for the max index key value plus 1.
|
||||
*/
|
||||
/**
|
||||
* Copyright (c) 2017-present, Facebook, Inc.
|
||||
* All rights reserved.
|
||||
*
|
||||
* This source code is licensed under the BSD-style license found in the
|
||||
* LICENSE file in the root directory of this source tree. An additional grant
|
||||
* of patent rights can be found in the PATENTS file in the same directory.
|
||||
*/
|
||||
|
||||
function getSuggestedArrayLiteralLength(realm, val) {
|
||||
(0, _invariant2.default)((0, _index.IsArray)(realm, val));
|
||||
|
||||
var length = 0;
|
||||
var _iteratorNormalCompletion = true;
|
||||
var _didIteratorError = false;
|
||||
var _iteratorError = undefined;
|
||||
|
||||
try {
|
||||
for (var _iterator = val.properties.keys()[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
|
||||
var key = _step.value;
|
||||
|
||||
if ((0, _index.IsArrayIndex)(realm, key) && Number(key) >= length) {
|
||||
length = Number(key) + 1;
|
||||
}
|
||||
}
|
||||
} catch (err) {
|
||||
_didIteratorError = true;
|
||||
_iteratorError = err;
|
||||
} finally {
|
||||
try {
|
||||
if (!_iteratorNormalCompletion && _iterator.return) {
|
||||
_iterator.return();
|
||||
}
|
||||
} finally {
|
||||
if (_didIteratorError) {
|
||||
throw _iteratorError;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return length;
|
||||
}
|
||||
|
||||
function commonAncestorOf(node1, node2) {
|
||||
if (node1 === node2) return node1;
|
||||
// First get the path length to the root node for both nodes while also checking if
|
||||
// either node is the parent of the other.
|
||||
var n1 = node1,
|
||||
n2 = node2,
|
||||
count1 = 0,
|
||||
count2 = 0;
|
||||
while (true) {
|
||||
var p1 = n1 && n1.getParent();
|
||||
var p2 = n2 && n2.getParent();
|
||||
if (p1 === node2) return node2;
|
||||
if (p2 === node1) return node1;
|
||||
if (p1) count1++;
|
||||
if (p2) count2++;
|
||||
if (!p1 && !p2) break;
|
||||
n1 = p1;
|
||||
n2 = p2;
|
||||
}
|
||||
// Now shorten the longest path to the same length as the shorter path
|
||||
n1 = node1;
|
||||
while (count1 > count2) {
|
||||
(0, _invariant2.default)(n1 !== undefined);
|
||||
n1 = n1.getParent();
|
||||
count1--;
|
||||
}
|
||||
n2 = node2;
|
||||
while (count1 < count2) {
|
||||
(0, _invariant2.default)(n2 !== undefined);
|
||||
n2 = n2.getParent();
|
||||
count2--;
|
||||
}
|
||||
// Now run up both paths in tandem, stopping at the first common entry
|
||||
while (n1 !== n2) {
|
||||
(0, _invariant2.default)(n1 !== undefined);
|
||||
n1 = n1.getParent();
|
||||
(0, _invariant2.default)(n2 !== undefined);
|
||||
n2 = n2.getParent();
|
||||
}
|
||||
return n1;
|
||||
}
|
||||
|
||||
// Gets map[key] with default value provided by defaultFn
|
||||
function getOrDefault(map, key, defaultFn) {
|
||||
var value = map.get(key);
|
||||
if (value === undefined) map.set(key, value = defaultFn());
|
||||
(0, _invariant2.default)(value !== undefined);
|
||||
return value;
|
||||
}
|
||||
//# sourceMappingURL=utils.js.map
|
||||
Reference in New Issue
Block a user