X-Git-Url: http://git.efficios.com/?p=babeltrace.git;a=blobdiff_plain;f=bindings%2Fpython%2Fexamples%2Fexample-api-test.py;h=1ff742e77ae386bb11e609171d83a294060a1840;hp=570e23e5a9ebab50763d2543904c8edefaf7894c;hb=cb1fcc68fd8c397ad94691ced4a70b3307f7a86b;hpb=24d5c942785816bc3c6ad926dc1272510c38948d diff --git a/bindings/python/examples/example-api-test.py b/bindings/python/examples/example-api-test.py index 570e23e5..1ff742e7 100644 --- a/bindings/python/examples/example-api-test.py +++ b/bindings/python/examples/example-api-test.py @@ -27,50 +27,32 @@ from babeltrace import * if len(sys.argv) < 2: raise TypeError("Usage: python example-api-test.py path/to/file") -# Create context and add trace: -ctx = Context() -trace_handle = ctx.add_trace(sys.argv[1], "ctf") +# Create TraceCollection and add trace: +traces = TraceCollection() +trace_handle = traces.add_trace(sys.argv[1], "ctf") if trace_handle is None: raise IOError("Error adding trace") # Listing events -lst = CTFReader.get_event_decl_list(trace_handle, ctx) +lst = event_declaration_list(trace_handle, traces) print("--- Event list ---") for item in lst: - print("event : {}".format(item.get_name())) + print("event : {}".format(item.name)) print("--- Done ---") -# Iter trace -bp = IterPos(SEEK_BEGIN) -ctf_it = CTFReader.Iterator(ctx,bp) -event = ctf_it.read_event() +for event in traces.events: + print("TS: {}, {} : {}".format(event.timestamp, event.cycles, event.name)) -while(event is not None): - print("TS: {}, {} : {}".format(event.get_timestamp(), - event.get_cycles(), event.get_name())) - - if event.get_name() == "sched_switch": - prev_field = event.get_field("prev_comm") - if prev_field is None: + if event.name == "sched_switch": + prev_comm = event["prev_comm"] + if prev_comm is None: print("ERROR: Missing prev_comm context info") else: - prev_comm = prev_field[0].get_value() - if prev_comm is not None: - print("sched_switch prev_comm: {}".format(prev_comm)) + print("sched_switch prev_comm: {}".format(prev_comm)) - if event.get_name() == "exit_syscall": - ret_field = event.get_field("ret") - if ret_field is None: + if event.name == "exit_syscall": + ret_code = event["ret"] + if ret_code is None: print("ERROR: Unable to extract ret") else: - ret_code = ret_field[0].get_value() - if ret_code is not None: - print("exit_syscall ret: {}".format(ret_code)) - - ret = ctf_it.next() - if ret < 0: - break - else: - event = ctf_it.read_event() - -del ctf_it + print("exit_syscall ret: {}".format(ret_code))