Freeze objects for performance
Frozen objects don't trigger Vue's reactive Observers and are significantly faster. With this changes, winscope can now load traces with over 100mb Bug: 211049519 Test: build winscope and open a large trace Change-Id: Iec9f91e408db734ce884cf846d5c2826ff346484
This commit is contained in:
@@ -356,8 +356,12 @@ export default {
|
||||
}
|
||||
decodedFileTypes.add(dataType);
|
||||
|
||||
const frozenData = Object.freeze(decodedFile.data.data);
|
||||
delete decodedFile.data.data;
|
||||
decodedFile.data.data = frozenData;
|
||||
|
||||
this.$set(this.dataFiles,
|
||||
dataType, decodedFile.data);
|
||||
dataType, Object.freeze(decodedFile.data));
|
||||
}
|
||||
|
||||
// TODO(b/169305853): Remove this once we have magic numbers or another
|
||||
@@ -369,7 +373,11 @@ export default {
|
||||
|
||||
const selectedFile =
|
||||
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
|
||||
const index = files.indexOf(selectedFile);
|
||||
|
||||
@@ -23,7 +23,7 @@ export default abstract class DumpBase implements IDump {
|
||||
this._files = files;
|
||||
}
|
||||
|
||||
get files(): any[] {
|
||||
get files(): readonly any[] {
|
||||
return Object.values(this._files).flat();
|
||||
}
|
||||
|
||||
@@ -31,6 +31,6 @@ export default abstract class DumpBase implements IDump {
|
||||
}
|
||||
|
||||
interface IDump {
|
||||
files: Array<Object>;
|
||||
files: readonly Object[];
|
||||
type: String,
|
||||
}
|
||||
@@ -165,7 +165,9 @@ const store = new Vuex.Store({
|
||||
}
|
||||
|
||||
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) {
|
||||
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';
|
||||
|
||||
export default class SurfaceFlinger extends TraceBase {
|
||||
sfTraceFile: Object;
|
||||
tagGenerationTrace: Object;
|
||||
readonly sfTraceFile: Object;
|
||||
readonly tagGenerationTrace: Object;
|
||||
|
||||
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;
|
||||
super(sfTraceFile.data, sfTraceFile.timeline, files);
|
||||
|
||||
this.tagGenerationTrace = tagGenerationTrace;
|
||||
this.tagGenerationTrace = Object.freeze(tagGenerationTrace);
|
||||
this.sfTraceFile = sfTraceFile;
|
||||
}
|
||||
|
||||
|
||||
@@ -23,9 +23,9 @@ import JSZip from 'jszip';
|
||||
|
||||
export default abstract class Trace implements ITrace {
|
||||
selectedIndex: Number;
|
||||
data: Object;
|
||||
timeline: Array<Number>;
|
||||
_files: File[];
|
||||
readonly data: Object;
|
||||
readonly timeline: Array<Number>;
|
||||
readonly _files: File[];
|
||||
|
||||
constructor(data: any, timeline: Number[], files: any[]) {
|
||||
this.selectedIndex = 0;
|
||||
@@ -34,7 +34,7 @@ export default abstract class Trace implements ITrace {
|
||||
this._files = files;
|
||||
}
|
||||
|
||||
get files(): File[] {
|
||||
get files(): readonly File[] {
|
||||
return Object.values(this._files).flat();
|
||||
}
|
||||
|
||||
@@ -64,6 +64,6 @@ export default abstract class Trace implements ITrace {
|
||||
}
|
||||
|
||||
interface ITrace {
|
||||
files: Array<Object>;
|
||||
files: readonly Object[];
|
||||
type: String,
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user