@loaders.gl/3d-tiles 3.4.0-alpha.3 → 3.4.0-alpha.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/dist.min.js +124 -77
- package/dist/es5/lib/classes/tile-3d-batch-table-hierarchy.js.map +1 -1
- package/dist/es5/lib/classes/tile-3d-batch-table.js.map +1 -1
- package/dist/es5/lib/classes/tile-3d-feature-table.js.map +1 -1
- package/dist/es5/lib/encoders/encode-3d-tile-instanced-model.js.map +1 -1
- package/dist/es5/lib/encoders/encode-3d-tile-point-cloud.js.map +1 -1
- package/dist/es5/lib/encoders/encode-3d-tile.js.map +1 -1
- package/dist/es5/lib/ion/ion.js.map +1 -1
- package/dist/es5/lib/parsers/helpers/normalize-3d-tile-normals.js.map +1 -1
- package/dist/es5/lib/parsers/helpers/normalize-3d-tile-positions.js.map +1 -1
- package/dist/es5/lib/parsers/helpers/parse-3d-implicit-tiles.js.map +1 -1
- package/dist/es5/lib/parsers/helpers/parse-3d-tile-gltf-view.js +4 -3
- package/dist/es5/lib/parsers/helpers/parse-3d-tile-gltf-view.js.map +1 -1
- package/dist/es5/lib/parsers/helpers/parse-3d-tile-header.js.map +1 -1
- package/dist/es5/lib/parsers/helpers/parse-3d-tile-subtree.js.map +1 -1
- package/dist/es5/lib/parsers/helpers/parse-3d-tile-tables.js.map +1 -1
- package/dist/es5/lib/parsers/parse-3d-tile-gltf.js +2 -1
- package/dist/es5/lib/parsers/parse-3d-tile-gltf.js.map +1 -1
- package/dist/es5/lib/parsers/parse-3d-tile-header.js +1 -1
- package/dist/es5/lib/parsers/parse-3d-tile-header.js.map +1 -1
- package/dist/es5/lib/parsers/parse-3d-tile-instanced-model.js.map +1 -1
- package/dist/es5/lib/parsers/parse-3d-tile-point-cloud.js.map +1 -1
- package/dist/es5/lib/parsers/parse-3d-tile.js.map +1 -1
- package/dist/es5/lib/utils/s2/s2-token-functions.js.map +1 -1
- package/dist/es5/lib/utils/s2/s2geometry/s2-geometry.js.map +1 -1
- package/dist/es5/lib/utils/version.js +1 -1
- package/dist/es5/tiles-3d-loader.js +4 -3
- package/dist/es5/tiles-3d-loader.js.map +1 -1
- package/dist/esm/lib/classes/tile-3d-batch-table-hierarchy.js.map +1 -1
- package/dist/esm/lib/classes/tile-3d-batch-table.js.map +1 -1
- package/dist/esm/lib/classes/tile-3d-feature-table.js.map +1 -1
- package/dist/esm/lib/encoders/encode-3d-tile-instanced-model.js.map +1 -1
- package/dist/esm/lib/encoders/encode-3d-tile-point-cloud.js.map +1 -1
- package/dist/esm/lib/encoders/encode-3d-tile.js.map +1 -1
- package/dist/esm/lib/ion/ion.js.map +1 -1
- package/dist/esm/lib/parsers/helpers/normalize-3d-tile-normals.js.map +1 -1
- package/dist/esm/lib/parsers/helpers/normalize-3d-tile-positions.js.map +1 -1
- package/dist/esm/lib/parsers/helpers/parse-3d-implicit-tiles.js.map +1 -1
- package/dist/esm/lib/parsers/helpers/parse-3d-tile-gltf-view.js +2 -1
- package/dist/esm/lib/parsers/helpers/parse-3d-tile-gltf-view.js.map +1 -1
- package/dist/esm/lib/parsers/helpers/parse-3d-tile-header.js.map +1 -1
- package/dist/esm/lib/parsers/helpers/parse-3d-tile-subtree.js.map +1 -1
- package/dist/esm/lib/parsers/helpers/parse-3d-tile-tables.js.map +1 -1
- package/dist/esm/lib/parsers/parse-3d-tile-gltf.js +2 -1
- package/dist/esm/lib/parsers/parse-3d-tile-gltf.js.map +1 -1
- package/dist/esm/lib/parsers/parse-3d-tile-header.js +1 -1
- package/dist/esm/lib/parsers/parse-3d-tile-header.js.map +1 -1
- package/dist/esm/lib/parsers/parse-3d-tile-instanced-model.js.map +1 -1
- package/dist/esm/lib/parsers/parse-3d-tile-point-cloud.js.map +1 -1
- package/dist/esm/lib/parsers/parse-3d-tile.js.map +1 -1
- package/dist/esm/lib/utils/s2/s2-token-functions.js.map +1 -1
- package/dist/esm/lib/utils/s2/s2geometry/s2-geometry.js.map +1 -1
- package/dist/esm/lib/utils/version.js +1 -1
- package/dist/esm/tiles-3d-loader.js +1 -0
- package/dist/esm/tiles-3d-loader.js.map +1 -1
- package/dist/lib/parsers/helpers/parse-3d-tile-gltf-view.d.ts.map +1 -1
- package/dist/lib/parsers/helpers/parse-3d-tile-gltf-view.js +1 -0
- package/dist/lib/parsers/helpers/parse-3d-tile-subtree.js +1 -1
- package/dist/lib/parsers/parse-3d-tile-gltf.d.ts.map +1 -1
- package/dist/lib/parsers/parse-3d-tile-gltf.js +1 -0
- package/dist/lib/parsers/parse-3d-tile-header.js +1 -1
- package/dist/tiles-3d-loader.js +1 -0
- package/package.json +7 -7
- package/src/lib/parsers/helpers/parse-3d-tile-gltf-view.ts +2 -1
- package/src/lib/parsers/helpers/parse-3d-tile-subtree.ts +1 -1
- package/src/lib/parsers/parse-3d-tile-gltf.ts +2 -1
- package/src/lib/parsers/parse-3d-tile-header.ts +1 -1
- package/src/tiles-3d-loader.ts +2 -0
package/dist/dist.min.js
CHANGED
|
@@ -5341,39 +5341,60 @@
|
|
|
5341
5341
|
}
|
|
5342
5342
|
});
|
|
5343
5343
|
|
|
5344
|
+
// ../core/src/lib/utils/url-utils.ts
|
|
5345
|
+
function extractQueryString(url) {
|
|
5346
|
+
const matches3 = url.match(QUERY_STRING_PATTERN);
|
|
5347
|
+
return matches3 && matches3[0];
|
|
5348
|
+
}
|
|
5349
|
+
function stripQueryString(url) {
|
|
5350
|
+
return url.replace(QUERY_STRING_PATTERN, "");
|
|
5351
|
+
}
|
|
5352
|
+
var QUERY_STRING_PATTERN;
|
|
5353
|
+
var init_url_utils = __esm({
|
|
5354
|
+
"../core/src/lib/utils/url-utils.ts"() {
|
|
5355
|
+
QUERY_STRING_PATTERN = /\?.*/;
|
|
5356
|
+
}
|
|
5357
|
+
});
|
|
5358
|
+
|
|
5344
5359
|
// ../core/src/lib/utils/resource-utils.ts
|
|
5345
|
-
function
|
|
5360
|
+
function getResourceUrl(resource) {
|
|
5346
5361
|
if (isResponse(resource)) {
|
|
5347
|
-
const
|
|
5348
|
-
|
|
5349
|
-
return {
|
|
5350
|
-
url,
|
|
5351
|
-
type: parseMIMEType(contentTypeHeader) || parseMIMETypeFromURL(url)
|
|
5352
|
-
};
|
|
5362
|
+
const response = resource;
|
|
5363
|
+
return response.url;
|
|
5353
5364
|
}
|
|
5354
5365
|
if (isBlob(resource)) {
|
|
5355
|
-
|
|
5356
|
-
|
|
5357
|
-
type: resource.type || ""
|
|
5358
|
-
};
|
|
5366
|
+
const blob = resource;
|
|
5367
|
+
return blob.name || "";
|
|
5359
5368
|
}
|
|
5360
5369
|
if (typeof resource === "string") {
|
|
5361
|
-
return
|
|
5362
|
-
url: stripQueryString(resource),
|
|
5363
|
-
type: parseMIMETypeFromURL(resource)
|
|
5364
|
-
};
|
|
5370
|
+
return resource;
|
|
5365
5371
|
}
|
|
5366
|
-
return
|
|
5367
|
-
|
|
5368
|
-
|
|
5369
|
-
|
|
5372
|
+
return "";
|
|
5373
|
+
}
|
|
5374
|
+
function getResourceMIMEType(resource) {
|
|
5375
|
+
if (isResponse(resource)) {
|
|
5376
|
+
const response = resource;
|
|
5377
|
+
const contentTypeHeader = response.headers.get("content-type") || "";
|
|
5378
|
+
const noQueryUrl = stripQueryString(response.url);
|
|
5379
|
+
return parseMIMEType(contentTypeHeader) || parseMIMETypeFromURL(noQueryUrl);
|
|
5380
|
+
}
|
|
5381
|
+
if (isBlob(resource)) {
|
|
5382
|
+
const blob = resource;
|
|
5383
|
+
return blob.type || "";
|
|
5384
|
+
}
|
|
5385
|
+
if (typeof resource === "string") {
|
|
5386
|
+
return parseMIMETypeFromURL(resource);
|
|
5387
|
+
}
|
|
5388
|
+
return "";
|
|
5370
5389
|
}
|
|
5371
5390
|
function getResourceContentLength(resource) {
|
|
5372
5391
|
if (isResponse(resource)) {
|
|
5373
|
-
|
|
5392
|
+
const response = resource;
|
|
5393
|
+
return response.headers["content-length"] || -1;
|
|
5374
5394
|
}
|
|
5375
5395
|
if (isBlob(resource)) {
|
|
5376
|
-
|
|
5396
|
+
const blob = resource;
|
|
5397
|
+
return blob.size;
|
|
5377
5398
|
}
|
|
5378
5399
|
if (typeof resource === "string") {
|
|
5379
5400
|
return resource.length;
|
|
@@ -5386,15 +5407,11 @@
|
|
|
5386
5407
|
}
|
|
5387
5408
|
return -1;
|
|
5388
5409
|
}
|
|
5389
|
-
function stripQueryString(url) {
|
|
5390
|
-
return url.replace(QUERY_STRING_PATTERN, "");
|
|
5391
|
-
}
|
|
5392
|
-
var QUERY_STRING_PATTERN;
|
|
5393
5410
|
var init_resource_utils = __esm({
|
|
5394
5411
|
"../core/src/lib/utils/resource-utils.ts"() {
|
|
5395
5412
|
init_is_type();
|
|
5396
5413
|
init_mime_type_utils();
|
|
5397
|
-
|
|
5414
|
+
init_url_utils();
|
|
5398
5415
|
}
|
|
5399
5416
|
});
|
|
5400
5417
|
|
|
@@ -5408,7 +5425,8 @@
|
|
|
5408
5425
|
if (contentLength >= 0) {
|
|
5409
5426
|
headers["content-length"] = String(contentLength);
|
|
5410
5427
|
}
|
|
5411
|
-
const
|
|
5428
|
+
const url = getResourceUrl(resource);
|
|
5429
|
+
const type = getResourceMIMEType(resource);
|
|
5412
5430
|
if (type) {
|
|
5413
5431
|
headers["content-type"] = type;
|
|
5414
5432
|
}
|
|
@@ -5497,7 +5515,7 @@
|
|
|
5497
5515
|
}
|
|
5498
5516
|
});
|
|
5499
5517
|
|
|
5500
|
-
//
|
|
5518
|
+
// ../../node_modules/@probe.gl/env/dist/lib/is-electron.js
|
|
5501
5519
|
function isElectron(mockUserAgent) {
|
|
5502
5520
|
if (typeof window !== "undefined" && typeof window.process === "object" && window.process.type === "renderer") {
|
|
5503
5521
|
return true;
|
|
@@ -5513,54 +5531,54 @@
|
|
|
5513
5531
|
return false;
|
|
5514
5532
|
}
|
|
5515
5533
|
var init_is_electron = __esm({
|
|
5516
|
-
"
|
|
5534
|
+
"../../node_modules/@probe.gl/env/dist/lib/is-electron.js"() {
|
|
5517
5535
|
}
|
|
5518
5536
|
});
|
|
5519
5537
|
|
|
5520
|
-
//
|
|
5538
|
+
// ../../node_modules/@probe.gl/env/dist/lib/is-browser.js
|
|
5521
5539
|
function isBrowser3() {
|
|
5522
5540
|
const isNode = typeof process === "object" && String(process) === "[object process]" && !process.browser;
|
|
5523
5541
|
return !isNode || isElectron();
|
|
5524
5542
|
}
|
|
5525
5543
|
var init_is_browser = __esm({
|
|
5526
|
-
"
|
|
5544
|
+
"../../node_modules/@probe.gl/env/dist/lib/is-browser.js"() {
|
|
5527
5545
|
init_is_electron();
|
|
5528
5546
|
}
|
|
5529
5547
|
});
|
|
5530
5548
|
|
|
5531
|
-
//
|
|
5532
|
-
var
|
|
5549
|
+
// ../../node_modules/@probe.gl/env/dist/lib/globals.js
|
|
5550
|
+
var self_3, window_3, document_3, process_, console_, navigator_;
|
|
5533
5551
|
var init_globals3 = __esm({
|
|
5534
|
-
"
|
|
5535
|
-
|
|
5536
|
-
|
|
5537
|
-
|
|
5538
|
-
|
|
5539
|
-
|
|
5540
|
-
|
|
5552
|
+
"../../node_modules/@probe.gl/env/dist/lib/globals.js"() {
|
|
5553
|
+
self_3 = globalThis.self || globalThis.window || globalThis.global;
|
|
5554
|
+
window_3 = globalThis.window || globalThis.self || globalThis.global;
|
|
5555
|
+
document_3 = globalThis.document || {};
|
|
5556
|
+
process_ = globalThis.process || {};
|
|
5557
|
+
console_ = globalThis.console;
|
|
5558
|
+
navigator_ = globalThis.navigator || {};
|
|
5541
5559
|
}
|
|
5542
5560
|
});
|
|
5543
5561
|
|
|
5544
|
-
//
|
|
5562
|
+
// ../../node_modules/@probe.gl/env/dist/utils/globals.js
|
|
5545
5563
|
var VERSION3, isBrowser4;
|
|
5546
5564
|
var init_globals4 = __esm({
|
|
5547
|
-
"
|
|
5565
|
+
"../../node_modules/@probe.gl/env/dist/utils/globals.js"() {
|
|
5548
5566
|
init_is_browser();
|
|
5549
5567
|
VERSION3 = typeof __VERSION__ !== "undefined" ? __VERSION__ : "untranspiled source";
|
|
5550
5568
|
isBrowser4 = isBrowser3();
|
|
5551
5569
|
}
|
|
5552
5570
|
});
|
|
5553
5571
|
|
|
5554
|
-
//
|
|
5572
|
+
// ../../node_modules/@probe.gl/env/dist/index.js
|
|
5555
5573
|
var init_dist = __esm({
|
|
5556
|
-
"
|
|
5574
|
+
"../../node_modules/@probe.gl/env/dist/index.js"() {
|
|
5557
5575
|
init_globals4();
|
|
5558
5576
|
init_globals3();
|
|
5559
5577
|
init_is_browser();
|
|
5560
5578
|
}
|
|
5561
5579
|
});
|
|
5562
5580
|
|
|
5563
|
-
//
|
|
5581
|
+
// ../../node_modules/@probe.gl/log/dist/utils/local-storage.js
|
|
5564
5582
|
function getStorage(type) {
|
|
5565
5583
|
try {
|
|
5566
5584
|
const storage = window[type];
|
|
@@ -5574,7 +5592,7 @@
|
|
|
5574
5592
|
}
|
|
5575
5593
|
var LocalStorage;
|
|
5576
5594
|
var init_local_storage = __esm({
|
|
5577
|
-
"
|
|
5595
|
+
"../../node_modules/@probe.gl/log/dist/utils/local-storage.js"() {
|
|
5578
5596
|
init_defineProperty();
|
|
5579
5597
|
LocalStorage = class {
|
|
5580
5598
|
constructor(id, defaultConfig) {
|
|
@@ -5610,7 +5628,7 @@
|
|
|
5610
5628
|
}
|
|
5611
5629
|
});
|
|
5612
5630
|
|
|
5613
|
-
//
|
|
5631
|
+
// ../../node_modules/@probe.gl/log/dist/utils/formatters.js
|
|
5614
5632
|
function formatTime(ms) {
|
|
5615
5633
|
let formatted;
|
|
5616
5634
|
if (ms < 10) {
|
|
@@ -5641,11 +5659,11 @@
|
|
|
5641
5659
|
return ["".concat(message, " %c+"), style];
|
|
5642
5660
|
}
|
|
5643
5661
|
var init_formatters = __esm({
|
|
5644
|
-
"
|
|
5662
|
+
"../../node_modules/@probe.gl/log/dist/utils/formatters.js"() {
|
|
5645
5663
|
}
|
|
5646
5664
|
});
|
|
5647
5665
|
|
|
5648
|
-
//
|
|
5666
|
+
// ../../node_modules/@probe.gl/log/dist/utils/color.js
|
|
5649
5667
|
function getColor(color) {
|
|
5650
5668
|
if (typeof color !== "string") {
|
|
5651
5669
|
return color;
|
|
@@ -5668,7 +5686,7 @@
|
|
|
5668
5686
|
}
|
|
5669
5687
|
var COLOR, BACKGROUND_INCREMENT;
|
|
5670
5688
|
var init_color = __esm({
|
|
5671
|
-
"
|
|
5689
|
+
"../../node_modules/@probe.gl/log/dist/utils/color.js"() {
|
|
5672
5690
|
init_dist();
|
|
5673
5691
|
(function(COLOR2) {
|
|
5674
5692
|
COLOR2[COLOR2["BLACK"] = 30] = "BLACK";
|
|
@@ -5692,7 +5710,7 @@
|
|
|
5692
5710
|
}
|
|
5693
5711
|
});
|
|
5694
5712
|
|
|
5695
|
-
//
|
|
5713
|
+
// ../../node_modules/@probe.gl/log/dist/utils/autobind.js
|
|
5696
5714
|
function autobind(obj) {
|
|
5697
5715
|
let predefined = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : ["constructor"];
|
|
5698
5716
|
const proto = Object.getPrototypeOf(obj);
|
|
@@ -5708,30 +5726,30 @@
|
|
|
5708
5726
|
}
|
|
5709
5727
|
}
|
|
5710
5728
|
var init_autobind = __esm({
|
|
5711
|
-
"
|
|
5729
|
+
"../../node_modules/@probe.gl/log/dist/utils/autobind.js"() {
|
|
5712
5730
|
}
|
|
5713
5731
|
});
|
|
5714
5732
|
|
|
5715
|
-
//
|
|
5733
|
+
// ../../node_modules/@probe.gl/log/dist/utils/assert.js
|
|
5716
5734
|
function assert5(condition, message) {
|
|
5717
5735
|
if (!condition) {
|
|
5718
5736
|
throw new Error(message || "Assertion failed");
|
|
5719
5737
|
}
|
|
5720
5738
|
}
|
|
5721
5739
|
var init_assert4 = __esm({
|
|
5722
|
-
"
|
|
5740
|
+
"../../node_modules/@probe.gl/log/dist/utils/assert.js"() {
|
|
5723
5741
|
}
|
|
5724
5742
|
});
|
|
5725
5743
|
|
|
5726
|
-
//
|
|
5744
|
+
// ../../node_modules/@probe.gl/log/dist/utils/hi-res-timestamp.js
|
|
5727
5745
|
function getHiResTimestamp() {
|
|
5728
5746
|
let timestamp;
|
|
5729
|
-
if (isBrowser3() &&
|
|
5747
|
+
if (isBrowser3() && window_3.performance) {
|
|
5730
5748
|
var _window$performance, _window$performance$n;
|
|
5731
|
-
timestamp =
|
|
5732
|
-
} else if ("hrtime" in
|
|
5749
|
+
timestamp = window_3 === null || window_3 === void 0 ? void 0 : (_window$performance = window_3.performance) === null || _window$performance === void 0 ? void 0 : (_window$performance$n = _window$performance.now) === null || _window$performance$n === void 0 ? void 0 : _window$performance$n.call(_window$performance);
|
|
5750
|
+
} else if ("hrtime" in process_) {
|
|
5733
5751
|
var _process$hrtime;
|
|
5734
|
-
const timeParts =
|
|
5752
|
+
const timeParts = process_ === null || process_ === void 0 ? void 0 : (_process$hrtime = process_.hrtime) === null || _process$hrtime === void 0 ? void 0 : _process$hrtime.call(process_);
|
|
5735
5753
|
timestamp = timeParts[0] * 1e3 + timeParts[1] / 1e6;
|
|
5736
5754
|
} else {
|
|
5737
5755
|
timestamp = Date.now();
|
|
@@ -5739,12 +5757,12 @@
|
|
|
5739
5757
|
return timestamp;
|
|
5740
5758
|
}
|
|
5741
5759
|
var init_hi_res_timestamp = __esm({
|
|
5742
|
-
"
|
|
5760
|
+
"../../node_modules/@probe.gl/log/dist/utils/hi-res-timestamp.js"() {
|
|
5743
5761
|
init_dist();
|
|
5744
5762
|
}
|
|
5745
5763
|
});
|
|
5746
5764
|
|
|
5747
|
-
//
|
|
5765
|
+
// ../../node_modules/@probe.gl/log/dist/log.js
|
|
5748
5766
|
function noop() {
|
|
5749
5767
|
}
|
|
5750
5768
|
function normalizeLogLevel(logLevel) {
|
|
@@ -5851,7 +5869,7 @@
|
|
|
5851
5869
|
}
|
|
5852
5870
|
var originalConsole, DEFAULT_LOG_CONFIGURATION, cache, ONCE, Log;
|
|
5853
5871
|
var init_log = __esm({
|
|
5854
|
-
"
|
|
5872
|
+
"../../node_modules/@probe.gl/log/dist/log.js"() {
|
|
5855
5873
|
init_defineProperty();
|
|
5856
5874
|
init_dist();
|
|
5857
5875
|
init_local_storage();
|
|
@@ -6090,10 +6108,10 @@
|
|
|
6090
6108
|
}
|
|
6091
6109
|
});
|
|
6092
6110
|
|
|
6093
|
-
//
|
|
6111
|
+
// ../../node_modules/@probe.gl/log/dist/index.js
|
|
6094
6112
|
var dist_default;
|
|
6095
6113
|
var init_dist2 = __esm({
|
|
6096
|
-
"
|
|
6114
|
+
"../../node_modules/@probe.gl/log/dist/index.js"() {
|
|
6097
6115
|
init_log();
|
|
6098
6116
|
init_log();
|
|
6099
6117
|
dist_default = new Log({
|
|
@@ -6394,8 +6412,9 @@
|
|
|
6394
6412
|
return loader;
|
|
6395
6413
|
}
|
|
6396
6414
|
function selectLoaderInternal(data, loaders, options, context) {
|
|
6397
|
-
const
|
|
6398
|
-
const
|
|
6415
|
+
const url = getResourceUrl(data);
|
|
6416
|
+
const type = getResourceMIMEType(data);
|
|
6417
|
+
const testUrl = stripQueryString(url) || context?.url;
|
|
6399
6418
|
let loader = null;
|
|
6400
6419
|
let reason = "";
|
|
6401
6420
|
if (options?.mimeType) {
|
|
@@ -6424,7 +6443,8 @@
|
|
|
6424
6443
|
return true;
|
|
6425
6444
|
}
|
|
6426
6445
|
function getNoValidLoaderMessage(data) {
|
|
6427
|
-
const
|
|
6446
|
+
const url = getResourceUrl(data);
|
|
6447
|
+
const type = getResourceMIMEType(data);
|
|
6428
6448
|
let message = "No valid loader found (";
|
|
6429
6449
|
message += url ? `${path_exports.filename(url)}, ` : "no url provided, ";
|
|
6430
6450
|
message += `MIME type: ${type ? `"${type}"` : "not provided"}, `;
|
|
@@ -6543,6 +6563,7 @@
|
|
|
6543
6563
|
init_resource_utils();
|
|
6544
6564
|
init_register_loaders();
|
|
6545
6565
|
init_is_type();
|
|
6566
|
+
init_url_utils();
|
|
6546
6567
|
EXT_PATTERN = /\.([^.]+)$/;
|
|
6547
6568
|
}
|
|
6548
6569
|
});
|
|
@@ -6755,18 +6776,25 @@
|
|
|
6755
6776
|
});
|
|
6756
6777
|
|
|
6757
6778
|
// ../core/src/lib/loader-utils/loader-context.ts
|
|
6758
|
-
function getLoaderContext(context, options,
|
|
6759
|
-
if (
|
|
6760
|
-
return
|
|
6779
|
+
function getLoaderContext(context, options, parentContext) {
|
|
6780
|
+
if (parentContext) {
|
|
6781
|
+
return parentContext;
|
|
6761
6782
|
}
|
|
6762
|
-
const
|
|
6783
|
+
const newContext = {
|
|
6763
6784
|
fetch: getFetchFunction(options, context),
|
|
6764
6785
|
...context
|
|
6765
6786
|
};
|
|
6766
|
-
if (
|
|
6767
|
-
|
|
6787
|
+
if (newContext.url) {
|
|
6788
|
+
const baseUrl = stripQueryString(newContext.url);
|
|
6789
|
+
newContext.baseUrl = baseUrl;
|
|
6790
|
+
newContext.queryString = extractQueryString(newContext.url);
|
|
6791
|
+
newContext.filename = path_exports.filename(baseUrl);
|
|
6792
|
+
newContext.baseUrl = path_exports.dirname(baseUrl);
|
|
6768
6793
|
}
|
|
6769
|
-
|
|
6794
|
+
if (!Array.isArray(newContext.loaders)) {
|
|
6795
|
+
newContext.loaders = null;
|
|
6796
|
+
}
|
|
6797
|
+
return newContext;
|
|
6770
6798
|
}
|
|
6771
6799
|
function getLoadersFromContext(loaders, context) {
|
|
6772
6800
|
if (!context && loaders && !Array.isArray(loaders)) {
|
|
@@ -6785,6 +6813,8 @@
|
|
|
6785
6813
|
var init_loader_context = __esm({
|
|
6786
6814
|
"../core/src/lib/loader-utils/loader-context.ts"() {
|
|
6787
6815
|
init_get_fetch_function();
|
|
6816
|
+
init_url_utils();
|
|
6817
|
+
init_src2();
|
|
6788
6818
|
}
|
|
6789
6819
|
});
|
|
6790
6820
|
|
|
@@ -6798,7 +6828,7 @@
|
|
|
6798
6828
|
}
|
|
6799
6829
|
data = await data;
|
|
6800
6830
|
options = options || {};
|
|
6801
|
-
const
|
|
6831
|
+
const url = getResourceUrl(data);
|
|
6802
6832
|
const typedLoaders = loaders;
|
|
6803
6833
|
const candidateLoaders = getLoadersFromContext(typedLoaders, context);
|
|
6804
6834
|
const loader = await selectLoader(data, candidateLoaders, options);
|
|
@@ -6806,7 +6836,7 @@
|
|
|
6806
6836
|
return null;
|
|
6807
6837
|
}
|
|
6808
6838
|
options = normalizeOptions(options, loader, candidateLoaders, url);
|
|
6809
|
-
context = getLoaderContext({ url, parse, loaders: candidateLoaders }, options, context);
|
|
6839
|
+
context = getLoaderContext({ url, parse, loaders: candidateLoaders }, options, context || null);
|
|
6810
6840
|
return await parseWithLoader(loader, data, options, context);
|
|
6811
6841
|
}
|
|
6812
6842
|
async function parseWithLoader(loader, data, options, context) {
|
|
@@ -10312,6 +10342,19 @@
|
|
|
10312
10342
|
assert8(byteLength >= 0 && byteLength <= bufferView.byteLength);
|
|
10313
10343
|
return { ArrayType, length: length4, byteLength };
|
|
10314
10344
|
}
|
|
10345
|
+
function getMemoryUsageGLTF(gltf) {
|
|
10346
|
+
let { images, bufferViews } = gltf;
|
|
10347
|
+
images = images || [];
|
|
10348
|
+
bufferViews = bufferViews || [];
|
|
10349
|
+
const imageBufferViews = images.map((i2) => i2.bufferView);
|
|
10350
|
+
bufferViews = bufferViews.filter((view) => !imageBufferViews.includes(view));
|
|
10351
|
+
const bufferMemory = bufferViews.reduce((acc, view) => acc + view.byteLength, 0);
|
|
10352
|
+
const pixelCount = images.reduce((acc, image) => {
|
|
10353
|
+
const { width, height } = image.image;
|
|
10354
|
+
return acc + width * height;
|
|
10355
|
+
}, 0);
|
|
10356
|
+
return bufferMemory + Math.ceil(4 * pixelCount * 1.33);
|
|
10357
|
+
}
|
|
10315
10358
|
var TYPES, ARRAY_CONSTRUCTOR_TO_WEBGL_CONSTANT, ARRAY_TO_COMPONENT_TYPE, ATTRIBUTE_TYPE_TO_COMPONENTS, ATTRIBUTE_COMPONENT_TYPE_TO_BYTE_SIZE, ATTRIBUTE_COMPONENT_TYPE_TO_ARRAY;
|
|
10316
10359
|
var init_gltf_utils = __esm({
|
|
10317
10360
|
"../gltf/src/lib/gltf-utils/gltf-utils.ts"() {
|
|
@@ -12557,6 +12600,7 @@
|
|
|
12557
12600
|
var init_src10 = __esm({
|
|
12558
12601
|
"../gltf/src/index.ts"() {
|
|
12559
12602
|
init_gltf_loader();
|
|
12603
|
+
init_gltf_utils();
|
|
12560
12604
|
}
|
|
12561
12605
|
});
|
|
12562
12606
|
|
|
@@ -12588,6 +12632,7 @@
|
|
|
12588
12632
|
}
|
|
12589
12633
|
if (tile.gltfArrayBuffer) {
|
|
12590
12634
|
tile.gltf = await parse5(tile.gltfArrayBuffer, GLTFLoader, options, context);
|
|
12635
|
+
tile.gpuMemoryUsageInBytes = getMemoryUsageGLTF(tile.gltf);
|
|
12591
12636
|
delete tile.gltfArrayBuffer;
|
|
12592
12637
|
delete tile.gltfByteOffset;
|
|
12593
12638
|
delete tile.gltfByteLength;
|
|
@@ -12830,6 +12875,7 @@
|
|
|
12830
12875
|
tile.gltfUpAxis = options["3d-tiles"] && options["3d-tiles"].assetGltfUpAxis ? options["3d-tiles"].assetGltfUpAxis : "Y";
|
|
12831
12876
|
const { parse: parse5 } = context;
|
|
12832
12877
|
tile.gltf = await parse5(arrayBuffer, GLTFLoader, options, context);
|
|
12878
|
+
tile.gpuMemoryUsageInBytes = getMemoryUsageGLTF(tile.gltf);
|
|
12833
12879
|
}
|
|
12834
12880
|
var init_parse_3d_tile_gltf = __esm({
|
|
12835
12881
|
"src/lib/parsers/parse-3d-tile-gltf.ts"() {
|
|
@@ -14410,7 +14456,7 @@
|
|
|
14410
14456
|
if (!tile.contentUrl) {
|
|
14411
14457
|
return TILE_TYPE.EMPTY;
|
|
14412
14458
|
}
|
|
14413
|
-
const contentUrl = tile.contentUrl;
|
|
14459
|
+
const contentUrl = tile.contentUrl.split("?")[0];
|
|
14414
14460
|
const fileExtension = contentUrl.split(".").pop();
|
|
14415
14461
|
switch (fileExtension) {
|
|
14416
14462
|
case "pnts":
|
|
@@ -14578,6 +14624,7 @@
|
|
|
14578
14624
|
const tilesetJson = JSON.parse(new TextDecoder().decode(data));
|
|
14579
14625
|
tilesetJson.loader = options.loader || Tiles3DLoader;
|
|
14580
14626
|
tilesetJson.url = context.url;
|
|
14627
|
+
tilesetJson.queryString = context.queryString;
|
|
14581
14628
|
tilesetJson.basePath = getBaseUri(tilesetJson);
|
|
14582
14629
|
tilesetJson.root = await normalizeTileHeaders(tilesetJson, options);
|
|
14583
14630
|
tilesetJson.type = TILESET_TYPE.TILES3D;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tile-3d-batch-table-hierarchy.js","names":["defined","x","undefined","initializeHierarchy","batchTable","jsonHeader","binaryBody","hierarchy","getExtension","legacyHierarchy","HIERARCHY","console","warn","extensions","initializeHierarchyValues","hierarchyJson","i","classId","binaryAccessor","instancesLength","classes","classIds","parentCounts","parentIds","parentIdsLength","byteOffset","componentType","defaultValue","GL","UNSIGNED_SHORT","type","AttributeType","SCALAR","getBinaryAccessor","createArrayBufferView","buffer","parentIndexes","Uint16Array","classesLength","length","classInstancesLength","properties","instances","binaryProperties","getBinaryProperties","combine","classCounts","Array","fill","classIndexes","validateHierarchy","traverseHierarchy","instanceIndex","endConditionCallback","traverseHierarchyMultipleParents","traverseHierarchySingleParent","visited","scratchVisited","Math","max","visitedMarker","marker","stack","scratchStack","push","pop","result","parentCount","parentIndex","parentId","hasParent","Error","scratchValidateStack","validateInstance","assert","concat","indexOf"],"sources":["../../../../src/lib/classes/tile-3d-batch-table-hierarchy.ts"],"sourcesContent":["// This file is derived from the Cesium code base under Apache 2 license\n// See LICENSE.md and https://github.com/AnalyticalGraphicsInc/cesium/blob/master/LICENSE.md\n\n// TODO - Finish hierarchy suypport: this file is only half ported\n/* eslint-disable */\n// @ts-nocheck\nconst defined = (x) => x !== undefined;\n\nexport function initializeHierarchy(batchTable, jsonHeader, binaryBody) {\n if (!jsonHeader) {\n return null;\n }\n\n let hierarchy = batchTable.getExtension('3DTILES_batch_table_hierarchy');\n\n const legacyHierarchy = jsonHeader.HIERARCHY;\n if (legacyHierarchy) {\n // eslint-disable-next-line\n console.warn('3D Tile Parser: HIERARCHY is deprecated. Use 3DTILES_batch_table_hierarchy.');\n jsonHeader.extensions = jsonHeader.extensions || {};\n jsonHeader.extensions['3DTILES_batch_table_hierarchy'] = legacyHierarchy;\n hierarchy = legacyHierarchy;\n }\n\n if (!hierarchy) {\n return null;\n }\n\n return initializeHierarchyValues(hierarchy, binaryBody);\n}\n\n// eslint-disable-next-line max-statements\nfunction initializeHierarchyValues(hierarchyJson, binaryBody) {\n let i;\n let classId;\n let binaryAccessor;\n\n const instancesLength = hierarchyJson.instancesLength;\n const classes = hierarchyJson.classes;\n let classIds = hierarchyJson.classIds;\n let parentCounts = hierarchyJson.parentCounts;\n let parentIds = hierarchyJson.parentIds;\n let parentIdsLength = instancesLength;\n\n if (defined(classIds.byteOffset)) {\n classIds.componentType = defaultValue(classIds.componentType, GL.UNSIGNED_SHORT);\n classIds.type = AttributeType.SCALAR;\n binaryAccessor = getBinaryAccessor(classIds);\n classIds = binaryAccessor.createArrayBufferView(\n binaryBody.buffer,\n binaryBody.byteOffset + classIds.byteOffset,\n instancesLength\n );\n }\n\n let parentIndexes;\n if (defined(parentCounts)) {\n if (defined(parentCounts.byteOffset)) {\n parentCounts.componentType = defaultValue(parentCounts.componentType, GL.UNSIGNED_SHORT);\n parentCounts.type = AttributeType.SCALAR;\n binaryAccessor = getBinaryAccessor(parentCounts);\n parentCounts = binaryAccessor.createArrayBufferView(\n binaryBody.buffer,\n binaryBody.byteOffset + parentCounts.byteOffset,\n instancesLength\n );\n }\n parentIndexes = new Uint16Array(instancesLength);\n parentIdsLength = 0;\n for (i = 0; i < instancesLength; ++i) {\n parentIndexes[i] = parentIdsLength;\n parentIdsLength += parentCounts[i];\n }\n }\n\n if (defined(parentIds) && defined(parentIds.byteOffset)) {\n parentIds.componentType = defaultValue(parentIds.componentType, GL.UNSIGNED_SHORT);\n parentIds.type = AttributeType.SCALAR;\n binaryAccessor = getBinaryAccessor(parentIds);\n parentIds = binaryAccessor.createArrayBufferView(\n binaryBody.buffer,\n binaryBody.byteOffset + parentIds.byteOffset,\n parentIdsLength\n );\n }\n\n const classesLength = classes.length;\n for (i = 0; i < classesLength; ++i) {\n const classInstancesLength = classes[i].length;\n const properties = classes[i].instances;\n const binaryProperties = getBinaryProperties(classInstancesLength, properties, binaryBody);\n classes[i].instances = combine(binaryProperties, properties);\n }\n\n const classCounts = new Array(classesLength).fill(0);\n const classIndexes = new Uint16Array(instancesLength);\n for (i = 0; i < instancesLength; ++i) {\n classId = classIds[i];\n classIndexes[i] = classCounts[classId];\n ++classCounts[classId];\n }\n\n const hierarchy = {\n classes,\n classIds,\n classIndexes,\n parentCounts,\n parentIndexes,\n parentIds\n };\n\n validateHierarchy(hierarchy);\n\n return hierarchy;\n}\n\n// HELPER CODE\n\n// Traverse over the hierarchy and process each instance with the endConditionCallback.\n// When the endConditionCallback returns a value, the traversal stops and that value is returned.\nexport function traverseHierarchy(hierarchy, instanceIndex, endConditionCallback) {\n if (!hierarchy) {\n return;\n }\n\n const parentCounts = hierarchy.parentCounts;\n const parentIds = hierarchy.parentIds;\n if (parentIds) {\n return endConditionCallback(hierarchy, instanceIndex);\n }\n if (parentCounts > 0) {\n return traverseHierarchyMultipleParents(hierarchy, instanceIndex, endConditionCallback);\n }\n return traverseHierarchySingleParent(hierarchy, instanceIndex, endConditionCallback);\n}\n\n// eslint-disable-next-line max-statements\nfunction traverseHierarchyMultipleParents(hierarchy, instanceIndex, endConditionCallback) {\n const classIds = hierarchy.classIds;\n const parentCounts = hierarchy.parentCounts;\n const parentIds = hierarchy.parentIds;\n const parentIndexes = hierarchy.parentIndexes;\n const instancesLength = classIds.length;\n\n // Ignore instances that have already been visited. This occurs in diamond inheritance situations.\n // Use a marker value to indicate that an instance has been visited, which increments with each run.\n // This is more efficient than clearing the visited array every time.\n const visited = scratchVisited;\n visited.length = Math.max(visited.length, instancesLength);\n const visitedMarker = ++marker;\n\n const stack = scratchStack;\n stack.length = 0;\n stack.push(instanceIndex);\n\n while (stack.length > 0) {\n instanceIndex = stack.pop();\n if (visited[instanceIndex] === visitedMarker) {\n // This instance has already been visited, stop traversal\n continue;\n }\n visited[instanceIndex] = visitedMarker;\n const result = endConditionCallback(hierarchy, instanceIndex);\n if (defined(result)) {\n // The end condition was met, stop the traversal and return the result\n return result;\n }\n const parentCount = parentCounts[instanceIndex];\n const parentIndex = parentIndexes[instanceIndex];\n for (let i = 0; i < parentCount; ++i) {\n const parentId = parentIds[parentIndex + i];\n // Stop the traversal when the instance has no parent (its parentId equals itself)\n // else add the parent to the stack to continue the traversal.\n if (parentId !== instanceIndex) {\n stack.push(parentId);\n }\n }\n }\n\n return null;\n}\n\nfunction traverseHierarchySingleParent(hierarchy, instanceIndex, endConditionCallback) {\n let hasParent = true;\n while (hasParent) {\n const result = endConditionCallback(hierarchy, instanceIndex);\n if (defined(result)) {\n // The end condition was met, stop the traversal and return the result\n return result;\n }\n const parentId = hierarchy.parentIds[instanceIndex];\n hasParent = parentId !== instanceIndex;\n instanceIndex = parentId;\n }\n throw new Error('traverseHierarchySingleParent');\n}\n\n// DEBUG CODE\n\nfunction validateHierarchy(hierarchy) {\n const scratchValidateStack = [];\n\n const classIds = hierarchy.classIds;\n const instancesLength = classIds.length;\n\n for (let i = 0; i < instancesLength; ++i) {\n validateInstance(hierarchy, i, stack);\n }\n}\n\nfunction validateInstance(hierarchy, instanceIndex, stack) {\n const parentCounts = hierarchy.parentCounts;\n const parentIds = hierarchy.parentIds;\n const parentIndexes = hierarchy.parentIndexes;\n const classIds = hierarchy.classIds;\n const instancesLength = classIds.length;\n\n if (!defined(parentIds)) {\n // No need to validate if there are no parents\n return;\n }\n\n assert(\n instanceIndex < instancesLength,\n `Parent index ${instanceIndex} exceeds the total number of instances: ${instancesLength}`\n );\n assert(\n stack.indexOf(instanceIndex) === -1,\n 'Circular dependency detected in the batch table hierarchy.'\n );\n\n stack.push(instanceIndex);\n const parentCount = defined(parentCounts) ? parentCounts[instanceIndex] : 1;\n const parentIndex = defined(parentCounts) ? parentIndexes[instanceIndex] : instanceIndex;\n for (let i = 0; i < parentCount; ++i) {\n const parentId = parentIds[parentIndex + i];\n // Stop the traversal when the instance has no parent (its parentId equals itself), else continue the traversal.\n if (parentId !== instanceIndex) {\n validateInstance(hierarchy, parentId, stack);\n }\n }\n stack.pop(instanceIndex);\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"tile-3d-batch-table-hierarchy.js","names":["defined","x","undefined","initializeHierarchy","batchTable","jsonHeader","binaryBody","hierarchy","getExtension","legacyHierarchy","HIERARCHY","console","warn","extensions","initializeHierarchyValues","hierarchyJson","i","classId","binaryAccessor","instancesLength","classes","classIds","parentCounts","parentIds","parentIdsLength","byteOffset","componentType","defaultValue","GL","UNSIGNED_SHORT","type","AttributeType","SCALAR","getBinaryAccessor","createArrayBufferView","buffer","parentIndexes","Uint16Array","classesLength","length","classInstancesLength","properties","instances","binaryProperties","getBinaryProperties","combine","classCounts","Array","fill","classIndexes","validateHierarchy","traverseHierarchy","instanceIndex","endConditionCallback","traverseHierarchyMultipleParents","traverseHierarchySingleParent","visited","scratchVisited","Math","max","visitedMarker","marker","stack","scratchStack","push","pop","result","parentCount","parentIndex","parentId","hasParent","Error","scratchValidateStack","validateInstance","assert","concat","indexOf"],"sources":["../../../../src/lib/classes/tile-3d-batch-table-hierarchy.ts"],"sourcesContent":["// This file is derived from the Cesium code base under Apache 2 license\n// See LICENSE.md and https://github.com/AnalyticalGraphicsInc/cesium/blob/master/LICENSE.md\n\n// TODO - Finish hierarchy suypport: this file is only half ported\n/* eslint-disable */\n// @ts-nocheck\nconst defined = (x) => x !== undefined;\n\nexport function initializeHierarchy(batchTable, jsonHeader, binaryBody) {\n if (!jsonHeader) {\n return null;\n }\n\n let hierarchy = batchTable.getExtension('3DTILES_batch_table_hierarchy');\n\n const legacyHierarchy = jsonHeader.HIERARCHY;\n if (legacyHierarchy) {\n // eslint-disable-next-line\n console.warn('3D Tile Parser: HIERARCHY is deprecated. Use 3DTILES_batch_table_hierarchy.');\n jsonHeader.extensions = jsonHeader.extensions || {};\n jsonHeader.extensions['3DTILES_batch_table_hierarchy'] = legacyHierarchy;\n hierarchy = legacyHierarchy;\n }\n\n if (!hierarchy) {\n return null;\n }\n\n return initializeHierarchyValues(hierarchy, binaryBody);\n}\n\n// eslint-disable-next-line max-statements\nfunction initializeHierarchyValues(hierarchyJson, binaryBody) {\n let i;\n let classId;\n let binaryAccessor;\n\n const instancesLength = hierarchyJson.instancesLength;\n const classes = hierarchyJson.classes;\n let classIds = hierarchyJson.classIds;\n let parentCounts = hierarchyJson.parentCounts;\n let parentIds = hierarchyJson.parentIds;\n let parentIdsLength = instancesLength;\n\n if (defined(classIds.byteOffset)) {\n classIds.componentType = defaultValue(classIds.componentType, GL.UNSIGNED_SHORT);\n classIds.type = AttributeType.SCALAR;\n binaryAccessor = getBinaryAccessor(classIds);\n classIds = binaryAccessor.createArrayBufferView(\n binaryBody.buffer,\n binaryBody.byteOffset + classIds.byteOffset,\n instancesLength\n );\n }\n\n let parentIndexes;\n if (defined(parentCounts)) {\n if (defined(parentCounts.byteOffset)) {\n parentCounts.componentType = defaultValue(parentCounts.componentType, GL.UNSIGNED_SHORT);\n parentCounts.type = AttributeType.SCALAR;\n binaryAccessor = getBinaryAccessor(parentCounts);\n parentCounts = binaryAccessor.createArrayBufferView(\n binaryBody.buffer,\n binaryBody.byteOffset + parentCounts.byteOffset,\n instancesLength\n );\n }\n parentIndexes = new Uint16Array(instancesLength);\n parentIdsLength = 0;\n for (i = 0; i < instancesLength; ++i) {\n parentIndexes[i] = parentIdsLength;\n parentIdsLength += parentCounts[i];\n }\n }\n\n if (defined(parentIds) && defined(parentIds.byteOffset)) {\n parentIds.componentType = defaultValue(parentIds.componentType, GL.UNSIGNED_SHORT);\n parentIds.type = AttributeType.SCALAR;\n binaryAccessor = getBinaryAccessor(parentIds);\n parentIds = binaryAccessor.createArrayBufferView(\n binaryBody.buffer,\n binaryBody.byteOffset + parentIds.byteOffset,\n parentIdsLength\n );\n }\n\n const classesLength = classes.length;\n for (i = 0; i < classesLength; ++i) {\n const classInstancesLength = classes[i].length;\n const properties = classes[i].instances;\n const binaryProperties = getBinaryProperties(classInstancesLength, properties, binaryBody);\n classes[i].instances = combine(binaryProperties, properties);\n }\n\n const classCounts = new Array(classesLength).fill(0);\n const classIndexes = new Uint16Array(instancesLength);\n for (i = 0; i < instancesLength; ++i) {\n classId = classIds[i];\n classIndexes[i] = classCounts[classId];\n ++classCounts[classId];\n }\n\n const hierarchy = {\n classes,\n classIds,\n classIndexes,\n parentCounts,\n parentIndexes,\n parentIds\n };\n\n validateHierarchy(hierarchy);\n\n return hierarchy;\n}\n\n// HELPER CODE\n\n// Traverse over the hierarchy and process each instance with the endConditionCallback.\n// When the endConditionCallback returns a value, the traversal stops and that value is returned.\nexport function traverseHierarchy(hierarchy, instanceIndex, endConditionCallback) {\n if (!hierarchy) {\n return;\n }\n\n const parentCounts = hierarchy.parentCounts;\n const parentIds = hierarchy.parentIds;\n if (parentIds) {\n return endConditionCallback(hierarchy, instanceIndex);\n }\n if (parentCounts > 0) {\n return traverseHierarchyMultipleParents(hierarchy, instanceIndex, endConditionCallback);\n }\n return traverseHierarchySingleParent(hierarchy, instanceIndex, endConditionCallback);\n}\n\n// eslint-disable-next-line max-statements\nfunction traverseHierarchyMultipleParents(hierarchy, instanceIndex, endConditionCallback) {\n const classIds = hierarchy.classIds;\n const parentCounts = hierarchy.parentCounts;\n const parentIds = hierarchy.parentIds;\n const parentIndexes = hierarchy.parentIndexes;\n const instancesLength = classIds.length;\n\n // Ignore instances that have already been visited. This occurs in diamond inheritance situations.\n // Use a marker value to indicate that an instance has been visited, which increments with each run.\n // This is more efficient than clearing the visited array every time.\n const visited = scratchVisited;\n visited.length = Math.max(visited.length, instancesLength);\n const visitedMarker = ++marker;\n\n const stack = scratchStack;\n stack.length = 0;\n stack.push(instanceIndex);\n\n while (stack.length > 0) {\n instanceIndex = stack.pop();\n if (visited[instanceIndex] === visitedMarker) {\n // This instance has already been visited, stop traversal\n continue;\n }\n visited[instanceIndex] = visitedMarker;\n const result = endConditionCallback(hierarchy, instanceIndex);\n if (defined(result)) {\n // The end condition was met, stop the traversal and return the result\n return result;\n }\n const parentCount = parentCounts[instanceIndex];\n const parentIndex = parentIndexes[instanceIndex];\n for (let i = 0; i < parentCount; ++i) {\n const parentId = parentIds[parentIndex + i];\n // Stop the traversal when the instance has no parent (its parentId equals itself)\n // else add the parent to the stack to continue the traversal.\n if (parentId !== instanceIndex) {\n stack.push(parentId);\n }\n }\n }\n\n return null;\n}\n\nfunction traverseHierarchySingleParent(hierarchy, instanceIndex, endConditionCallback) {\n let hasParent = true;\n while (hasParent) {\n const result = endConditionCallback(hierarchy, instanceIndex);\n if (defined(result)) {\n // The end condition was met, stop the traversal and return the result\n return result;\n }\n const parentId = hierarchy.parentIds[instanceIndex];\n hasParent = parentId !== instanceIndex;\n instanceIndex = parentId;\n }\n throw new Error('traverseHierarchySingleParent');\n}\n\n// DEBUG CODE\n\nfunction validateHierarchy(hierarchy) {\n const scratchValidateStack = [];\n\n const classIds = hierarchy.classIds;\n const instancesLength = classIds.length;\n\n for (let i = 0; i < instancesLength; ++i) {\n validateInstance(hierarchy, i, stack);\n }\n}\n\nfunction validateInstance(hierarchy, instanceIndex, stack) {\n const parentCounts = hierarchy.parentCounts;\n const parentIds = hierarchy.parentIds;\n const parentIndexes = hierarchy.parentIndexes;\n const classIds = hierarchy.classIds;\n const instancesLength = classIds.length;\n\n if (!defined(parentIds)) {\n // No need to validate if there are no parents\n return;\n }\n\n assert(\n instanceIndex < instancesLength,\n `Parent index ${instanceIndex} exceeds the total number of instances: ${instancesLength}`\n );\n assert(\n stack.indexOf(instanceIndex) === -1,\n 'Circular dependency detected in the batch table hierarchy.'\n );\n\n stack.push(instanceIndex);\n const parentCount = defined(parentCounts) ? parentCounts[instanceIndex] : 1;\n const parentIndex = defined(parentCounts) ? parentIndexes[instanceIndex] : instanceIndex;\n for (let i = 0; i < parentCount; ++i) {\n const parentId = parentIds[parentIndex + i];\n // Stop the traversal when the instance has no parent (its parentId equals itself), else continue the traversal.\n if (parentId !== instanceIndex) {\n validateInstance(hierarchy, parentId, stack);\n }\n }\n stack.pop(instanceIndex);\n}\n"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tile-3d-batch-table.js","names":["_loaderUtils","require","_tile3dAccessorUtils","_tile3dBatchTableHierarchy","defined","x","undefined","clone","y","IGNORED_PROPERTY_FIELDS","HIERARCHY","extensions","extras","Tile3DBatchTableParser","json","binary","featureCount","_this$json","options","arguments","length","_classCallCheck2","default","_defineProperty2","assert","_extensions","_properties","propertyName","_binaryProperties","_initializeBinaryProperties","_hierarchy","initializeHierarchy","_createClass2","key","value","getExtension","extensionName","memorySizeInBytes","isClass","batchId","className","_checkBatchId","result","traverseHierarchy","hierarchy","instanceIndex","classId","classIds","instanceClass","classes","name","isExactClass","getExactClassName","hasProperty","_hasPropertyInHierarchy","getPropertyNames","results","_results","propertyNames","Object","keys","push","apply","_getPropertyNamesInHierarchy","getProperty","binaryProperty","_getBinaryProperty","propertyValues","hierarchyProperty","_getHierarchyProperty","setProperty","_setBinaryProperty","_setHierarchyProperty","Array","valid","Error","index","unpack","typedArray","pack","binaryProperties","property","_initializeBinaryProperty","tile3DAccessor","concat","type","accessor","createTypedArrayFromAccessor","buffer","byteOffset","values","componentCount","size","unpacker","packer","instances","hasOwnProperty","indexOf","_this","indexInClass","classIndexes","batchTable","_this2","exports"],"sources":["../../../../src/lib/classes/tile-3d-batch-table.ts"],"sourcesContent":["// This file is derived from the Cesium code base under Apache 2 license\n// See LICENSE.md and https://github.com/AnalyticalGraphicsInc/cesium/blob/master/LICENSE.md\n\nimport {assert} from '@loaders.gl/loader-utils';\n\nimport {createTypedArrayFromAccessor} from './helpers/tile-3d-accessor-utils';\nimport {initializeHierarchy, traverseHierarchy} from './tile-3d-batch-table-hierarchy';\n\nfunction defined(x) {\n return x !== undefined && x !== null;\n}\n\nconst clone = (x, y) => x;\n\n// These top level fields in the batch table json are not properties\nconst IGNORED_PROPERTY_FIELDS = {\n HIERARCHY: true, // Deprecated HIERARCHY property\n extensions: true,\n extras: true\n};\n\n// The size of this array equals the maximum instance count among all loaded tiles, which has the potential to be large.\nexport default class Tile3DBatchTableParser {\n json;\n binary;\n featureCount;\n _extensions;\n // Copy all top-level property fields from the json object, ignoring special fields\n _properties;\n _binaryProperties;\n // TODO: hierarchy support is only partially implemented and not tested\n _hierarchy;\n\n constructor(json, binary, featureCount, options = {}) {\n assert(featureCount >= 0);\n this.json = json || {};\n this.binary = binary;\n this.featureCount = featureCount;\n\n this._extensions = this.json?.extensions || {};\n\n // Copy all top-level property fields from the json object, ignoring special fields\n this._properties = {};\n for (const propertyName in this.json) {\n if (!IGNORED_PROPERTY_FIELDS[propertyName]) {\n this._properties[propertyName] = this.json[propertyName];\n }\n }\n\n this._binaryProperties = this._initializeBinaryProperties();\n\n // TODO: hierarchy support is only partially implemented and not tested\n if (options['3DTILES_batch_table_hierarchy']) {\n this._hierarchy = initializeHierarchy(this, this.json, this.binary);\n }\n }\n\n getExtension(extensionName) {\n return this.json && this.json.extensions && this.json.extensions[extensionName];\n }\n\n memorySizeInBytes(): number {\n return 0;\n }\n\n isClass(batchId, className: string): boolean {\n this._checkBatchId(batchId);\n assert(typeof className === 'string', className);\n\n // extension: 3DTILES_batch_table_hierarchy\n if (this._hierarchy) {\n // PERFORMANCE_IDEA : cache results in the ancestor classes\n // to speed up this check if this area becomes a hotspot\n // PERFORMANCE_IDEA : treat class names as integers for faster comparisons\n const result = traverseHierarchy(this._hierarchy, batchId, (hierarchy, instanceIndex) => {\n const classId = hierarchy.classIds[instanceIndex];\n const instanceClass = hierarchy.classes[classId];\n return instanceClass.name === className;\n });\n return defined(result);\n }\n\n return false;\n }\n\n isExactClass(batchId, className) {\n assert(typeof className === 'string', className);\n\n return this.getExactClassName(batchId) === className;\n }\n\n getExactClassName(batchId) {\n this._checkBatchId(batchId);\n\n // extension: 3DTILES_batch_table_hierarchy\n if (this._hierarchy) {\n const classId = this._hierarchy.classIds[batchId];\n const instanceClass = this._hierarchy.classes[classId];\n return instanceClass.name;\n }\n\n return undefined;\n }\n\n hasProperty(batchId, name) {\n this._checkBatchId(batchId);\n assert(typeof name === 'string', name);\n\n return defined(this._properties[name]) || this._hasPropertyInHierarchy(batchId, name);\n }\n\n getPropertyNames(batchId, results) {\n this._checkBatchId(batchId);\n\n results = defined(results) ? results : [];\n results.length = 0;\n\n const propertyNames = Object.keys(this._properties);\n results.push(...propertyNames);\n\n if (this._hierarchy) {\n this._getPropertyNamesInHierarchy(batchId, results);\n }\n\n return results;\n }\n\n getProperty(batchId, name) {\n this._checkBatchId(batchId);\n assert(typeof name === 'string', name);\n\n if (this._binaryProperties) {\n const binaryProperty = this._binaryProperties[name];\n if (defined(binaryProperty)) {\n return this._getBinaryProperty(binaryProperty, batchId);\n }\n }\n\n const propertyValues = this._properties[name];\n if (defined(propertyValues)) {\n return clone(propertyValues[batchId], true);\n }\n\n // EXTENSION: 3DTILES_batch_table_hierarchy\n if (this._hierarchy) {\n const hierarchyProperty = this._getHierarchyProperty(batchId, name);\n if (defined(hierarchyProperty)) {\n return hierarchyProperty;\n }\n }\n\n return undefined;\n }\n\n setProperty(batchId, name, value) {\n const featureCount = this.featureCount;\n\n this._checkBatchId(batchId);\n assert(typeof name === 'string', name);\n\n if (this._binaryProperties) {\n const binaryProperty = this._binaryProperties[name];\n if (binaryProperty) {\n this._setBinaryProperty(binaryProperty, batchId, value);\n return;\n }\n }\n\n // EXTENSION: 3DTILES_batch_table_hierarchy\n if (this._hierarchy) {\n if (this._setHierarchyProperty(this, batchId, name, value)) {\n return;\n }\n }\n\n let propertyValues = this._properties[name];\n if (!defined(propertyValues)) {\n // Property does not exist. Create it.\n this._properties[name] = new Array(featureCount);\n propertyValues = this._properties[name];\n }\n\n propertyValues[batchId] = clone(value, true);\n }\n\n // PRIVATE METHODS\n\n _checkBatchId(batchId) {\n const valid = batchId >= 0 && batchId < this.featureCount;\n if (!valid) {\n throw new Error('batchId not in range [0, featureCount - 1].');\n }\n }\n\n _getBinaryProperty(binaryProperty, index) {\n return binaryProperty.unpack(binaryProperty.typedArray, index);\n }\n\n _setBinaryProperty(binaryProperty, index, value) {\n binaryProperty.pack(value, binaryProperty.typedArray, index);\n }\n\n _initializeBinaryProperties() {\n let binaryProperties: Record<string, any> | null = null;\n for (const name in this._properties) {\n const property = this._properties[name];\n const binaryProperty = this._initializeBinaryProperty(name, property);\n // Store any information needed to access the binary data, including the typed array,\n // componentCount (e.g. a VEC4 would be 4), and the type used to pack and unpack (e.g. Cartesian4).\n if (binaryProperty) {\n binaryProperties = binaryProperties || {};\n binaryProperties[name] = binaryProperty;\n }\n }\n return binaryProperties;\n }\n\n _initializeBinaryProperty(name, property) {\n if ('byteOffset' in property) {\n // This is a binary property\n const tile3DAccessor = property;\n\n assert(this.binary, `Property ${name} requires a batch table binary.`);\n assert(tile3DAccessor.type, `Property ${name} requires a type.`);\n\n const accessor = createTypedArrayFromAccessor(\n tile3DAccessor,\n this.binary.buffer,\n this.binary.byteOffset | 0,\n this.featureCount\n );\n\n // Store any information needed to access the binary data, including the typed array,\n // componentCount (e.g. a VEC4 would be 4), and the type used to pack and unpack (e.g. Cartesian4).\n return {\n typedArray: accessor.values,\n componentCount: accessor.size,\n unpack: accessor.unpacker,\n pack: accessor.packer\n };\n }\n\n return null;\n }\n\n // EXTENSION SUPPORT: 3DTILES_batch_table_hierarchy\n\n _hasPropertyInHierarchy(batchId, name) {\n if (!this._hierarchy) {\n return false;\n }\n\n const result = traverseHierarchy(this._hierarchy, batchId, (hierarchy, instanceIndex) => {\n const classId = hierarchy.classIds[instanceIndex];\n const instances = hierarchy.classes[classId].instances;\n return defined(instances[name]);\n });\n\n return defined(result);\n }\n\n _getPropertyNamesInHierarchy(batchId, results) {\n traverseHierarchy(this._hierarchy, batchId, (hierarchy, instanceIndex) => {\n const classId = hierarchy.classIds[instanceIndex];\n const instances = hierarchy.classes[classId].instances;\n for (const name in instances) {\n if (instances.hasOwnProperty(name)) {\n if (results.indexOf(name) === -1) {\n results.push(name);\n }\n }\n }\n });\n }\n\n _getHierarchyProperty(batchId, name) {\n return traverseHierarchy(this._hierarchy, batchId, (hierarchy, instanceIndex) => {\n const classId = hierarchy.classIds[instanceIndex];\n const instanceClass = hierarchy.classes[classId];\n const indexInClass = hierarchy.classIndexes[instanceIndex];\n const propertyValues = instanceClass.instances[name];\n if (defined(propertyValues)) {\n if (defined(propertyValues.typedArray)) {\n return this._getBinaryProperty(propertyValues, indexInClass);\n }\n return clone(propertyValues[indexInClass], true);\n }\n return null;\n });\n }\n\n _setHierarchyProperty(batchTable, batchId, name, value) {\n const result = traverseHierarchy(this._hierarchy, batchId, (hierarchy, instanceIndex) => {\n const classId = hierarchy.classIds[instanceIndex];\n const instanceClass = hierarchy.classes[classId];\n const indexInClass = hierarchy.classIndexes[instanceIndex];\n const propertyValues = instanceClass.instances[name];\n if (defined(propertyValues)) {\n assert(instanceIndex === batchId, `Inherited property \"${name}\" is read-only.`);\n if (defined(propertyValues.typedArray)) {\n this._setBinaryProperty(propertyValues, indexInClass, value);\n } else {\n propertyValues[indexInClass] = clone(value, true);\n }\n return true;\n }\n return false;\n });\n return defined(result);\n }\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"tile-3d-batch-table.js","names":["_loaderUtils","require","_tile3dAccessorUtils","_tile3dBatchTableHierarchy","defined","x","undefined","clone","y","IGNORED_PROPERTY_FIELDS","HIERARCHY","extensions","extras","Tile3DBatchTableParser","json","binary","featureCount","_this$json","options","arguments","length","_classCallCheck2","default","_defineProperty2","assert","_extensions","_properties","propertyName","_binaryProperties","_initializeBinaryProperties","_hierarchy","initializeHierarchy","_createClass2","key","value","getExtension","extensionName","memorySizeInBytes","isClass","batchId","className","_checkBatchId","result","traverseHierarchy","hierarchy","instanceIndex","classId","classIds","instanceClass","classes","name","isExactClass","getExactClassName","hasProperty","_hasPropertyInHierarchy","getPropertyNames","results","_results","propertyNames","Object","keys","push","apply","_getPropertyNamesInHierarchy","getProperty","binaryProperty","_getBinaryProperty","propertyValues","hierarchyProperty","_getHierarchyProperty","setProperty","_setBinaryProperty","_setHierarchyProperty","Array","valid","Error","index","unpack","typedArray","pack","binaryProperties","property","_initializeBinaryProperty","tile3DAccessor","concat","type","accessor","createTypedArrayFromAccessor","buffer","byteOffset","values","componentCount","size","unpacker","packer","instances","hasOwnProperty","indexOf","_this","indexInClass","classIndexes","batchTable","_this2","exports"],"sources":["../../../../src/lib/classes/tile-3d-batch-table.ts"],"sourcesContent":["// This file is derived from the Cesium code base under Apache 2 license\n// See LICENSE.md and https://github.com/AnalyticalGraphicsInc/cesium/blob/master/LICENSE.md\n\nimport {assert} from '@loaders.gl/loader-utils';\n\nimport {createTypedArrayFromAccessor} from './helpers/tile-3d-accessor-utils';\nimport {initializeHierarchy, traverseHierarchy} from './tile-3d-batch-table-hierarchy';\n\nfunction defined(x) {\n return x !== undefined && x !== null;\n}\n\nconst clone = (x, y) => x;\n\n// These top level fields in the batch table json are not properties\nconst IGNORED_PROPERTY_FIELDS = {\n HIERARCHY: true, // Deprecated HIERARCHY property\n extensions: true,\n extras: true\n};\n\n// The size of this array equals the maximum instance count among all loaded tiles, which has the potential to be large.\nexport default class Tile3DBatchTableParser {\n json;\n binary;\n featureCount;\n _extensions;\n // Copy all top-level property fields from the json object, ignoring special fields\n _properties;\n _binaryProperties;\n // TODO: hierarchy support is only partially implemented and not tested\n _hierarchy;\n\n constructor(json, binary, featureCount, options = {}) {\n assert(featureCount >= 0);\n this.json = json || {};\n this.binary = binary;\n this.featureCount = featureCount;\n\n this._extensions = this.json?.extensions || {};\n\n // Copy all top-level property fields from the json object, ignoring special fields\n this._properties = {};\n for (const propertyName in this.json) {\n if (!IGNORED_PROPERTY_FIELDS[propertyName]) {\n this._properties[propertyName] = this.json[propertyName];\n }\n }\n\n this._binaryProperties = this._initializeBinaryProperties();\n\n // TODO: hierarchy support is only partially implemented and not tested\n if (options['3DTILES_batch_table_hierarchy']) {\n this._hierarchy = initializeHierarchy(this, this.json, this.binary);\n }\n }\n\n getExtension(extensionName) {\n return this.json && this.json.extensions && this.json.extensions[extensionName];\n }\n\n memorySizeInBytes(): number {\n return 0;\n }\n\n isClass(batchId, className: string): boolean {\n this._checkBatchId(batchId);\n assert(typeof className === 'string', className);\n\n // extension: 3DTILES_batch_table_hierarchy\n if (this._hierarchy) {\n // PERFORMANCE_IDEA : cache results in the ancestor classes\n // to speed up this check if this area becomes a hotspot\n // PERFORMANCE_IDEA : treat class names as integers for faster comparisons\n const result = traverseHierarchy(this._hierarchy, batchId, (hierarchy, instanceIndex) => {\n const classId = hierarchy.classIds[instanceIndex];\n const instanceClass = hierarchy.classes[classId];\n return instanceClass.name === className;\n });\n return defined(result);\n }\n\n return false;\n }\n\n isExactClass(batchId, className) {\n assert(typeof className === 'string', className);\n\n return this.getExactClassName(batchId) === className;\n }\n\n getExactClassName(batchId) {\n this._checkBatchId(batchId);\n\n // extension: 3DTILES_batch_table_hierarchy\n if (this._hierarchy) {\n const classId = this._hierarchy.classIds[batchId];\n const instanceClass = this._hierarchy.classes[classId];\n return instanceClass.name;\n }\n\n return undefined;\n }\n\n hasProperty(batchId, name) {\n this._checkBatchId(batchId);\n assert(typeof name === 'string', name);\n\n return defined(this._properties[name]) || this._hasPropertyInHierarchy(batchId, name);\n }\n\n getPropertyNames(batchId, results) {\n this._checkBatchId(batchId);\n\n results = defined(results) ? results : [];\n results.length = 0;\n\n const propertyNames = Object.keys(this._properties);\n results.push(...propertyNames);\n\n if (this._hierarchy) {\n this._getPropertyNamesInHierarchy(batchId, results);\n }\n\n return results;\n }\n\n getProperty(batchId, name) {\n this._checkBatchId(batchId);\n assert(typeof name === 'string', name);\n\n if (this._binaryProperties) {\n const binaryProperty = this._binaryProperties[name];\n if (defined(binaryProperty)) {\n return this._getBinaryProperty(binaryProperty, batchId);\n }\n }\n\n const propertyValues = this._properties[name];\n if (defined(propertyValues)) {\n return clone(propertyValues[batchId], true);\n }\n\n // EXTENSION: 3DTILES_batch_table_hierarchy\n if (this._hierarchy) {\n const hierarchyProperty = this._getHierarchyProperty(batchId, name);\n if (defined(hierarchyProperty)) {\n return hierarchyProperty;\n }\n }\n\n return undefined;\n }\n\n setProperty(batchId, name, value) {\n const featureCount = this.featureCount;\n\n this._checkBatchId(batchId);\n assert(typeof name === 'string', name);\n\n if (this._binaryProperties) {\n const binaryProperty = this._binaryProperties[name];\n if (binaryProperty) {\n this._setBinaryProperty(binaryProperty, batchId, value);\n return;\n }\n }\n\n // EXTENSION: 3DTILES_batch_table_hierarchy\n if (this._hierarchy) {\n if (this._setHierarchyProperty(this, batchId, name, value)) {\n return;\n }\n }\n\n let propertyValues = this._properties[name];\n if (!defined(propertyValues)) {\n // Property does not exist. Create it.\n this._properties[name] = new Array(featureCount);\n propertyValues = this._properties[name];\n }\n\n propertyValues[batchId] = clone(value, true);\n }\n\n // PRIVATE METHODS\n\n _checkBatchId(batchId) {\n const valid = batchId >= 0 && batchId < this.featureCount;\n if (!valid) {\n throw new Error('batchId not in range [0, featureCount - 1].');\n }\n }\n\n _getBinaryProperty(binaryProperty, index) {\n return binaryProperty.unpack(binaryProperty.typedArray, index);\n }\n\n _setBinaryProperty(binaryProperty, index, value) {\n binaryProperty.pack(value, binaryProperty.typedArray, index);\n }\n\n _initializeBinaryProperties() {\n let binaryProperties: Record<string, any> | null = null;\n for (const name in this._properties) {\n const property = this._properties[name];\n const binaryProperty = this._initializeBinaryProperty(name, property);\n // Store any information needed to access the binary data, including the typed array,\n // componentCount (e.g. a VEC4 would be 4), and the type used to pack and unpack (e.g. Cartesian4).\n if (binaryProperty) {\n binaryProperties = binaryProperties || {};\n binaryProperties[name] = binaryProperty;\n }\n }\n return binaryProperties;\n }\n\n _initializeBinaryProperty(name, property) {\n if ('byteOffset' in property) {\n // This is a binary property\n const tile3DAccessor = property;\n\n assert(this.binary, `Property ${name} requires a batch table binary.`);\n assert(tile3DAccessor.type, `Property ${name} requires a type.`);\n\n const accessor = createTypedArrayFromAccessor(\n tile3DAccessor,\n this.binary.buffer,\n this.binary.byteOffset | 0,\n this.featureCount\n );\n\n // Store any information needed to access the binary data, including the typed array,\n // componentCount (e.g. a VEC4 would be 4), and the type used to pack and unpack (e.g. Cartesian4).\n return {\n typedArray: accessor.values,\n componentCount: accessor.size,\n unpack: accessor.unpacker,\n pack: accessor.packer\n };\n }\n\n return null;\n }\n\n // EXTENSION SUPPORT: 3DTILES_batch_table_hierarchy\n\n _hasPropertyInHierarchy(batchId, name) {\n if (!this._hierarchy) {\n return false;\n }\n\n const result = traverseHierarchy(this._hierarchy, batchId, (hierarchy, instanceIndex) => {\n const classId = hierarchy.classIds[instanceIndex];\n const instances = hierarchy.classes[classId].instances;\n return defined(instances[name]);\n });\n\n return defined(result);\n }\n\n _getPropertyNamesInHierarchy(batchId, results) {\n traverseHierarchy(this._hierarchy, batchId, (hierarchy, instanceIndex) => {\n const classId = hierarchy.classIds[instanceIndex];\n const instances = hierarchy.classes[classId].instances;\n for (const name in instances) {\n if (instances.hasOwnProperty(name)) {\n if (results.indexOf(name) === -1) {\n results.push(name);\n }\n }\n }\n });\n }\n\n _getHierarchyProperty(batchId, name) {\n return traverseHierarchy(this._hierarchy, batchId, (hierarchy, instanceIndex) => {\n const classId = hierarchy.classIds[instanceIndex];\n const instanceClass = hierarchy.classes[classId];\n const indexInClass = hierarchy.classIndexes[instanceIndex];\n const propertyValues = instanceClass.instances[name];\n if (defined(propertyValues)) {\n if (defined(propertyValues.typedArray)) {\n return this._getBinaryProperty(propertyValues, indexInClass);\n }\n return clone(propertyValues[indexInClass], true);\n }\n return null;\n });\n }\n\n _setHierarchyProperty(batchTable, batchId, name, value) {\n const result = traverseHierarchy(this._hierarchy, batchId, (hierarchy, instanceIndex) => {\n const classId = hierarchy.classIds[instanceIndex];\n const instanceClass = hierarchy.classes[classId];\n const indexInClass = hierarchy.classIndexes[instanceIndex];\n const propertyValues = instanceClass.instances[name];\n if (defined(propertyValues)) {\n assert(instanceIndex === batchId, `Inherited property \"${name}\" is read-only.`);\n if (defined(propertyValues.typedArray)) {\n this._setBinaryProperty(propertyValues, indexInClass, value);\n } else {\n propertyValues[indexInClass] = clone(value, true);\n }\n return true;\n }\n return false;\n });\n return defined(result);\n }\n}\n"],"mappings":"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"}
|