From: Brian Norris Date: Mon, 4 Mar 2013 04:34:26 +0000 (-0800) Subject: model: add promise printing to execution summaries X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=28617f0ed2d16491c86d040b323bfe07dcdf2421;p=cdsspec-compiler.git model: add promise printing to execution summaries --- diff --git a/model.cc b/model.cc index c713d1e..62550da 100644 --- a/model.cc +++ b/model.cc @@ -2872,6 +2872,14 @@ void ModelChecker::print_summary() const print_infeasibility(" INFEASIBLE"); print_list(action_trace); model_print("\n"); + if (!promises->empty()) { + model_print("Pending promises:\n"); + for (unsigned int i = 0; i < promises->size(); i++) { + model_print(" [P%u] ", i); + (*promises)[i]->print(); + } + model_print("\n"); + } } /** diff --git a/promise.cc b/promise.cc index c1f1c5c..26a1095 100644 --- a/promise.cc +++ b/promise.cc @@ -101,10 +101,16 @@ bool Promise::thread_is_available(thread_id_t tid) const /** @brief Print debug info about the Promise */ void Promise::print() const { - model_print("Promised value %#" PRIx64 ", first read from thread %d, available threads to resolve: ", fv.value, id_to_int(get_reader(0)->get_tid())); + model_print("Promised value %#" PRIx64 ", first read from thread %d, available threads to resolve: ", + fv.value, id_to_int(get_reader(0)->get_tid())); + bool failed = true; for (unsigned int i = 0; i < available_thread.size(); i++) - if (available_thread[i]) + if (available_thread[i]) { model_print("[%d]", i); + failed = false; + } + if (failed) + model_print("(none)"); model_print("\n"); }