# This script parses the logcat lines produced by the Tuning Fork DebugBackend
# which are base64 encoded serializations of TuningForkLogEvent protos.
# Usage:
# adb logcat -d | python parselogcat.py
import sys
import re
# To generate python files from the proto files:
# export TF_PROTO_DIR=../../src/tuningfork/proto/
# protoc --python_out=. -I$TF_PROTO_DIR $TF_PROTO_DIR/tuningfork.proto
# protoc --python_out=. -I$TF_PROTO_DIR $TF_PROTO_DIR/tuningfork_clearcut_log.proto
# export TF_DEV_PROTO_DIR=<somewhere>
# protoc --python_out=. -I$TF_DEV_PROTO_DIR $TF_DEV_PROTO_DIR/dev_tuningfork.proto
# 'pip install protobuf' if you get a 'No module named protobuf' error
import tuningfork_clearcut_log_pb2 as tcl
import dev_tuningfork_pb2 as tf
# Example logcat line:
#11-30 15:32:22.892 13781 16553 I TuningFork.Clearcut: (TCL1/1)GgAqHAgAEgAaFgAAAAAAAAAAAAAAAAAAAAAAAAAAAEg=
tflogcat_regex = r"(\S+ \S+).*TuningFork.*\(TCL(.+)/(.+)\)(.*)"
def flatten(s):
return ', '.join(s.strip().split('\n'))
def prettyPrint(tclevent):
fp =tf.FidelityParams()
fp.ParseFromString(tclevent.fidelityparams)
print "fidelityparams: ", flatten(str(fp))
for h in tclevent.histograms:
print "histograms {"
print " instrument_id: ", h.instrument_id
a = tf.Annotation()
a.ParseFromString(h.annotation)
print " annotation: ", flatten(str(a))
for c in h.counts:
print " counts: ", c
print "}"
ser = ""
def getTCLEvent(i, n, ser_in):
global ser
if i==1:
ser = ""
ser += ser_in
if i<>n:
return
l = tcl.TuningForkLogEvent()
l.ParseFromString(ser.decode("base64"))
return l
def readStdin():
for logcat_lines in sys.stdin.readlines():
m = re.match(tflogcat_regex, logcat_lines)
if m:
subparts = m.groups()
tstamp = subparts[0]
tclevent = getTCLEvent(int(subparts[1]),int(subparts[2]),subparts[3])
if tclevent:
prettyPrint(tclevent)
def main():
readStdin()
if __name__ == "__main__":
main()