Merge changes from topic "presubmit-am-27c23569716e478691fb069b3ff6e988" into tm-dev
* changes: Freeze objects for performance Use lazy file for LayerTraceEntry
This commit is contained in:
committed by
Android (Google) Code Review
commit
e78dd74bd6
@@ -356,8 +356,12 @@ export default {
|
|||||||
}
|
}
|
||||||
decodedFileTypes.add(dataType);
|
decodedFileTypes.add(dataType);
|
||||||
|
|
||||||
|
const frozenData = Object.freeze(decodedFile.data.data);
|
||||||
|
delete decodedFile.data.data;
|
||||||
|
decodedFile.data.data = frozenData;
|
||||||
|
|
||||||
this.$set(this.dataFiles,
|
this.$set(this.dataFiles,
|
||||||
dataType, decodedFile.data);
|
dataType, Object.freeze(decodedFile.data));
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO(b/169305853): Remove this once we have magic numbers or another
|
// TODO(b/169305853): Remove this once we have magic numbers or another
|
||||||
@@ -369,7 +373,11 @@ export default {
|
|||||||
|
|
||||||
const selectedFile =
|
const selectedFile =
|
||||||
this.getMostLikelyCandidateFile(dataType, files);
|
this.getMostLikelyCandidateFile(dataType, files);
|
||||||
this.$set(this.dataFiles, dataType, selectedFile);
|
const frozenData = Object.freeze(selectedFile.data);
|
||||||
|
delete selectedFile.data;
|
||||||
|
selectedFile.data = frozenData;
|
||||||
|
|
||||||
|
this.$set(this.dataFiles, dataType, Object.freeze(selectedFile));
|
||||||
|
|
||||||
// Remove selected file from overriden list
|
// Remove selected file from overriden list
|
||||||
const index = files.indexOf(selectedFile);
|
const index = files.indexOf(selectedFile);
|
||||||
|
|||||||
@@ -23,7 +23,7 @@ export default abstract class DumpBase implements IDump {
|
|||||||
this._files = files;
|
this._files = files;
|
||||||
}
|
}
|
||||||
|
|
||||||
get files(): any[] {
|
get files(): readonly any[] {
|
||||||
return Object.values(this._files).flat();
|
return Object.values(this._files).flat();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -31,6 +31,6 @@ export default abstract class DumpBase implements IDump {
|
|||||||
}
|
}
|
||||||
|
|
||||||
interface IDump {
|
interface IDump {
|
||||||
files: Array<Object>;
|
files: readonly Object[];
|
||||||
type: String,
|
type: String,
|
||||||
}
|
}
|
||||||
@@ -15,12 +15,12 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
import { LayersTrace } from "./common"
|
import { LayersTrace } from "./common"
|
||||||
import LayerTraceEntry from './layers/LayerTraceEntry'
|
import LayerTraceEntryLazy from './layers/LayerTraceEntryLazy'
|
||||||
|
|
||||||
LayersTrace.fromProto = function (proto: any): LayersTrace {
|
LayersTrace.fromProto = function (proto: any): LayersTrace {
|
||||||
const entries = []
|
const entries = []
|
||||||
for (const entryProto of proto.entry) {
|
for (const entryProto of proto.entry) {
|
||||||
const transformedEntry = LayerTraceEntry.fromProto(
|
const transformedEntry = new LayerTraceEntryLazy(
|
||||||
/* protos */ entryProto.layers.layers,
|
/* protos */ entryProto.layers.layers,
|
||||||
/* displays */ entryProto.displays,
|
/* displays */ entryProto.displays,
|
||||||
/* timestamp */ entryProto.elapsedRealtimeNanos,
|
/* timestamp */ entryProto.elapsedRealtimeNanos,
|
||||||
|
|||||||
@@ -56,6 +56,8 @@ const WindowToken = require('flicker').com.android.server.wm.traces.common.
|
|||||||
// SF
|
// SF
|
||||||
const Layer = require('flicker').com.android.server.wm.traces.common.
|
const Layer = require('flicker').com.android.server.wm.traces.common.
|
||||||
layers.Layer;
|
layers.Layer;
|
||||||
|
const AbstractLayerTraceEntry = require('flicker').com.android.server.wm.traces.common.
|
||||||
|
layers.AbstractLayerTraceEntry;
|
||||||
const LayerTraceEntry = require('flicker').com.android.server.wm.traces.common.
|
const LayerTraceEntry = require('flicker').com.android.server.wm.traces.common.
|
||||||
layers.LayerTraceEntry;
|
layers.LayerTraceEntry;
|
||||||
const LayerTraceEntryBuilder = require('flicker').com.android.server.wm.traces.
|
const LayerTraceEntryBuilder = require('flicker').com.android.server.wm.traces.
|
||||||
@@ -270,6 +272,7 @@ export {
|
|||||||
WindowManagerTrace,
|
WindowManagerTrace,
|
||||||
WindowManagerState,
|
WindowManagerState,
|
||||||
// SF
|
// SF
|
||||||
|
AbstractLayerTraceEntry,
|
||||||
Layer,
|
Layer,
|
||||||
LayerTraceEntry,
|
LayerTraceEntry,
|
||||||
LayerTraceEntryBuilder,
|
LayerTraceEntryBuilder,
|
||||||
|
|||||||
114
tools/winscope/src/flickerlib/layers/LayerTraceEntryLazy.ts
Normal file
114
tools/winscope/src/flickerlib/layers/LayerTraceEntryLazy.ts
Normal file
@@ -0,0 +1,114 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2021, The Android Open Source Project
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
import { AbstractLayerTraceEntry } from "../common";
|
||||||
|
import LayerTraceEntry from "./LayerTraceEntry";
|
||||||
|
|
||||||
|
class LayerTraceEntryLazy extends AbstractLayerTraceEntry {
|
||||||
|
private _isInitialized: boolean = false;
|
||||||
|
private _layersProto: any[];
|
||||||
|
private _displayProtos: any[];
|
||||||
|
timestamp: number;
|
||||||
|
timestampMs: string;
|
||||||
|
hwcBlob: string;
|
||||||
|
where: string;
|
||||||
|
private _lazyLayerTraceEntry: LayerTraceEntry;
|
||||||
|
|
||||||
|
constructor (layersProto: any[], displayProtos: any[],
|
||||||
|
timestamp: number, hwcBlob: string, where: string = '') {
|
||||||
|
super();
|
||||||
|
this._layersProto = layersProto;
|
||||||
|
this._displayProtos = displayProtos;
|
||||||
|
this.timestamp = timestamp;
|
||||||
|
this.timestampMs = timestamp.toString();
|
||||||
|
this.hwcBlob = hwcBlob;
|
||||||
|
this.where = where;
|
||||||
|
|
||||||
|
this.declareLazyProperties();
|
||||||
|
}
|
||||||
|
|
||||||
|
private initialize() {
|
||||||
|
if (this._isInitialized) return;
|
||||||
|
|
||||||
|
this._isInitialized = true;
|
||||||
|
this._lazyLayerTraceEntry = LayerTraceEntry.fromProto(
|
||||||
|
this._layersProto, this._displayProtos, this.timestamp,
|
||||||
|
this.hwcBlob, this.where);
|
||||||
|
this._layersProto = [];
|
||||||
|
this._displayProtos = [];
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private declareLazyProperties() {
|
||||||
|
Object.defineProperty(this, 'kind', {configurable: true, enumerable: true, get: function () {
|
||||||
|
this.initialize();
|
||||||
|
return this._lazyLayerTraceEntry.kind;
|
||||||
|
}});
|
||||||
|
|
||||||
|
Object.defineProperty(this, 'timestampMs', {configurable: true, enumerable: true, get: function () {
|
||||||
|
this.initialize();
|
||||||
|
return this._lazyLayerTraceEntry.timestampMs;
|
||||||
|
}});
|
||||||
|
|
||||||
|
Object.defineProperty(this, 'rects', {configurable: true, enumerable: true, get: function () {
|
||||||
|
this.initialize();
|
||||||
|
return this._lazyLayerTraceEntry.rects;
|
||||||
|
}});
|
||||||
|
|
||||||
|
Object.defineProperty(this, 'proto', {configurable: true, enumerable: true, get: function () {
|
||||||
|
this.initialize();
|
||||||
|
return this._lazyLayerTraceEntry.proto;
|
||||||
|
}});
|
||||||
|
|
||||||
|
Object.defineProperty(this, 'shortName', {configurable: true, enumerable: true, get: function () {
|
||||||
|
this.initialize();
|
||||||
|
return this._lazyLayerTraceEntry.shortName;
|
||||||
|
}});
|
||||||
|
|
||||||
|
Object.defineProperty(this, 'isVisible', {configurable: true, enumerable: true, get: function () {
|
||||||
|
this.initialize();
|
||||||
|
return this._lazyLayerTraceEntry.isVisible;
|
||||||
|
}});
|
||||||
|
|
||||||
|
Object.defineProperty(this, 'flattenedLayers', {configurable: true, enumerable: true, get: function () {
|
||||||
|
this.initialize();
|
||||||
|
return this._lazyLayerTraceEntry.flattenedLayers;
|
||||||
|
}});
|
||||||
|
|
||||||
|
Object.defineProperty(this, 'stableId', {configurable: true, enumerable: true, get: function () {
|
||||||
|
this.initialize();
|
||||||
|
return this._lazyLayerTraceEntry.stableId;
|
||||||
|
}});
|
||||||
|
|
||||||
|
Object.defineProperty(this, 'visibleLayers', {configurable: true, enumerable: true, get: function () {
|
||||||
|
this.initialize();
|
||||||
|
return this._lazyLayerTraceEntry.visibleLayers;
|
||||||
|
}});
|
||||||
|
|
||||||
|
Object.defineProperty(this, 'children', {configurable: true, enumerable: true, get: function () {
|
||||||
|
this.initialize();
|
||||||
|
return this._lazyLayerTraceEntry.children;
|
||||||
|
}});
|
||||||
|
|
||||||
|
Object.defineProperty(this, 'displays', {configurable: true, enumerable: true, get: function () {
|
||||||
|
this.initialize();
|
||||||
|
return this._lazyLayerTraceEntry.displays;
|
||||||
|
}});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export default LayerTraceEntryLazy;
|
||||||
@@ -165,7 +165,9 @@ const store = new Vuex.Store({
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (Object.keys(traceFiles).length > 0 && typeInfo.constructor) {
|
if (Object.keys(traceFiles).length > 0 && typeInfo.constructor) {
|
||||||
traces[traceType] = new typeInfo.constructor(traceFiles);
|
const newObj = new typeInfo.constructor(traceFiles);
|
||||||
|
newObj.data = Object.freeze(newObj.data);
|
||||||
|
traces[traceType] = newObj;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -198,7 +200,9 @@ const store = new Vuex.Store({
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (Object.keys(dumpFiles).length > 0 && typeInfo.constructor) {
|
if (Object.keys(dumpFiles).length > 0 && typeInfo.constructor) {
|
||||||
dumps[dumpType] = new typeInfo.constructor(dumpFiles);
|
const newObj = new typeInfo.constructor(dumpFiles);
|
||||||
|
newObj.data = Object.freeze(newObj.data);
|
||||||
|
dumps[dumpType] = newObj;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -19,15 +19,15 @@ import TraceBase from './TraceBase';
|
|||||||
import { LayersTrace } from '@/flickerlib';
|
import { LayersTrace } from '@/flickerlib';
|
||||||
|
|
||||||
export default class SurfaceFlinger extends TraceBase {
|
export default class SurfaceFlinger extends TraceBase {
|
||||||
sfTraceFile: Object;
|
readonly sfTraceFile: Object;
|
||||||
tagGenerationTrace: Object;
|
readonly tagGenerationTrace: Object;
|
||||||
|
|
||||||
constructor(files) {
|
constructor(files) {
|
||||||
const sfTraceFile = files[FILE_TYPES.SURFACE_FLINGER_TRACE];
|
const sfTraceFile = Object.freeze(files[FILE_TYPES.SURFACE_FLINGER_TRACE]);
|
||||||
const tagGenerationTrace = files[FILE_TYPES.SURFACE_FLINGER_TRACE].tagGenerationTrace;
|
const tagGenerationTrace = files[FILE_TYPES.SURFACE_FLINGER_TRACE].tagGenerationTrace;
|
||||||
super(sfTraceFile.data, sfTraceFile.timeline, files);
|
super(sfTraceFile.data, sfTraceFile.timeline, files);
|
||||||
|
|
||||||
this.tagGenerationTrace = tagGenerationTrace;
|
this.tagGenerationTrace = Object.freeze(tagGenerationTrace);
|
||||||
this.sfTraceFile = sfTraceFile;
|
this.sfTraceFile = sfTraceFile;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -23,9 +23,9 @@ import JSZip from 'jszip';
|
|||||||
|
|
||||||
export default abstract class Trace implements ITrace {
|
export default abstract class Trace implements ITrace {
|
||||||
selectedIndex: Number;
|
selectedIndex: Number;
|
||||||
data: Object;
|
readonly data: Object;
|
||||||
timeline: Array<Number>;
|
readonly timeline: Array<Number>;
|
||||||
_files: File[];
|
readonly _files: File[];
|
||||||
|
|
||||||
constructor(data: any, timeline: Number[], files: any[]) {
|
constructor(data: any, timeline: Number[], files: any[]) {
|
||||||
this.selectedIndex = 0;
|
this.selectedIndex = 0;
|
||||||
@@ -34,7 +34,7 @@ export default abstract class Trace implements ITrace {
|
|||||||
this._files = files;
|
this._files = files;
|
||||||
}
|
}
|
||||||
|
|
||||||
get files(): File[] {
|
get files(): readonly File[] {
|
||||||
return Object.values(this._files).flat();
|
return Object.values(this._files).flat();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -64,6 +64,6 @@ export default abstract class Trace implements ITrace {
|
|||||||
}
|
}
|
||||||
|
|
||||||
interface ITrace {
|
interface ITrace {
|
||||||
files: Array<Object>;
|
files: readonly Object[];
|
||||||
type: String,
|
type: String,
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user