declare namespace Profiling { interface RawProfileBase { endValue: number; startValue: number; name: string; threadID: number; unit: string; spans?: Span[]; threadID: number; } // Android traces follow this format interface EventedProfile extends RawProfileBase { events: ReadonlyArray; type: 'evented'; } // iOS traces follow this format interface SampledProfile extends RawProfileBase { weights: number[]; samples: number[][]; type: 'sampled'; } interface NodeProfile extends Profiling.SampledProfile { frames: Profiling.FrameInfo[]; } type Event = {at: number; frame: number; type: 'O' | 'C'}; type Span = { duration_ms: number; name: string; queue_label: string; relative_start_ms: number; thread_id: number; children?: Span[]; }; type FrameInfo = { key: string | number; name: string; file?: string; line?: number; column?: number; is_application?: boolean; image?: string; resource?: string; threadId?: number; // nodejs only columnNumber?: number; lineNumber?: number; scriptName?: string; scriptId?: number; }; type ProfileTypes = | EventedProfile | SampledProfile | JSSelfProfiling.Trace | NodeProfile; type ImportedProfiles = { name: string; profileID: string; activeProfileIndex: number; profiles: ProfileTypes[]; }; // This extends speedscope's schema - we are keeping this as is, but we are likely to diverge as we add more // sentry related features to the flamegraphs. This should happen after the MVP integration type Schema = { profileID: string; profiles: ReadonlyArray; projectID: number; shared: { frames: ReadonlyArray>; }; activeProfileIndex?: number; metadata: { androidAPILevel: number; deviceClassification: string; deviceLocale: string; deviceManufacturer: string; deviceModel: string; deviceOSName: string; deviceOSVersion: string; durationNS: number; environment: string; organizationID: number; platform: string; profileID: string; projectID: number; received: string; traceID: string; transactionID: string; transactionName: string; version: string; }; }; }