chrome-devtools-frontend
Version:
Chrome DevTools UI
47 lines (36 loc) • 1.48 kB
text/typescript
// Copyright 2017 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
import * as Trace from '../../models/trace/trace.js';
import {TimelineUIUtils} from './TimelineUIUtils.js';
export class IsLong extends Trace.Extras.TraceFilter.TraceFilter {
#minimumRecordDurationMilli = Trace.Types.Timing.Milli(0);
setMinimumRecordDuration(value: Trace.Types.Timing.Milli): void {
this.#minimumRecordDurationMilli = value;
}
accept(event: Trace.Types.Events.Event): boolean {
const {duration} = Trace.Helpers.Timing.eventTimingsMilliSeconds(event);
return duration >= this.#minimumRecordDurationMilli;
}
}
export class Category extends Trace.Extras.TraceFilter.TraceFilter {
accept(event: Trace.Types.Events.Event): boolean {
return !TimelineUIUtils.eventStyle(event).category.hidden;
}
}
export class TimelineRegExp extends Trace.Extras.TraceFilter.TraceFilter {
private regExpInternal!: RegExp|null;
constructor(regExp?: RegExp) {
super();
this.setRegExp(regExp || null);
}
setRegExp(regExp: RegExp|null): void {
this.regExpInternal = regExp;
}
regExp(): RegExp|null {
return this.regExpInternal;
}
accept(event: Trace.Types.Events.Event, parsedTrace?: Trace.Handlers.Types.ParsedTrace): boolean {
return !this.regExpInternal || TimelineUIUtils.testContentMatching(event, this.regExpInternal, parsedTrace);
}
}