From: Brian Norris Date: Thu, 4 Apr 2013 08:25:34 +0000 (-0700) Subject: model: add variable arguments for bug messages X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=c0c175fd2688c46595d5aadf029026e147ec80c2;p=cdsspec-compiler.git model: add variable arguments for bug messages --- diff --git a/model.cc b/model.cc index feda416..cbd5617 100644 --- a/model.cc +++ b/model.cc @@ -2,6 +2,7 @@ #include #include #include +#include #include "model.h" #include "action.h" @@ -419,9 +420,16 @@ bool ModelChecker::is_complete_execution() const * @param msg Descriptive message for the bug (do not include newline char) * @return True if bug is immediately-feasible */ -bool ModelChecker::assert_bug(const char *msg) +bool ModelChecker::assert_bug(const char *msg, ...) { - priv->bugs.push_back(new bug_message(msg)); + char str[800]; + + va_list ap; + va_start(ap, msg); + vsnprintf(str, sizeof(str), msg, ap); + va_end(ap); + + priv->bugs.push_back(new bug_message(str)); if (isfeasibleprefix()) { set_assert(); diff --git a/model.h b/model.h index 7327280..8fdfc47 100644 --- a/model.h +++ b/model.h @@ -132,7 +132,7 @@ public: void check_promises(thread_id_t tid, ClockVector *old_cv, ClockVector *merge_cv); bool isfeasibleprefix() const; - bool assert_bug(const char *msg); + bool assert_bug(const char *msg, ...); void assert_user_bug(const char *msg); const model_params params;