1 /*
2  * Copyright (C) 2023 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 package android.tools.traces.parsers.wm
18 
19 import android.tools.Timestamp
20 import android.tools.Timestamps
21 import android.tools.parsers.AbstractTraceParser
22 import android.tools.traces.wm.WindowManagerState
23 import android.tools.traces.wm.WindowManagerTrace
24 import com.android.server.wm.nano.WindowManagerTraceFileProto
25 import com.android.server.wm.nano.WindowManagerTraceProto
26 
27 /** Parser for [WindowManagerTrace] objects containing traces */
28 open class LegacyWindowManagerTraceParser(private val legacyTrace: Boolean = false) :
29     AbstractTraceParser<
30         WindowManagerTraceFileProto,
31         WindowManagerTraceProto,
32         WindowManagerState,
33         WindowManagerTrace,
34     >() {
35     private var realToElapsedTimeOffsetNanos = 0L
36 
37     override val traceName: String = "WM Trace"
38 
doDecodeByteArraynull39     override fun doDecodeByteArray(bytes: ByteArray): WindowManagerTraceFileProto =
40         WindowManagerTraceFileProto.parseFrom(bytes)
41 
42     override fun createTrace(entries: Collection<WindowManagerState>): WindowManagerTrace =
43         WindowManagerTrace(entries)
44 
45     override fun getEntries(input: WindowManagerTraceFileProto) = input.entry.toList()
46 
47     override fun getTimestamp(entry: WindowManagerTraceProto): Timestamp {
48         require(legacyTrace || realToElapsedTimeOffsetNanos != 0L)
49         return Timestamps.from(
50             elapsedNanos = entry.elapsedRealtimeNanos,
51             unixNanos = entry.elapsedRealtimeNanos + realToElapsedTimeOffsetNanos,
52         )
53     }
54 
onBeforeParsenull55     override fun onBeforeParse(input: WindowManagerTraceFileProto) {
56         realToElapsedTimeOffsetNanos = input.realToElapsedTimeOffsetNanos
57     }
58 
doParseEntrynull59     override fun doParseEntry(entry: WindowManagerTraceProto): WindowManagerState {
60         return WindowManagerStateBuilder()
61             .atPlace(entry.where)
62             .forTimestamp(entry.elapsedRealtimeNanos)
63             .withRealTimeOffset(realToElapsedTimeOffsetNanos)
64             .forProto(entry.windowManagerService)
65             .build()
66     }
67 }
68