X-Git-Url: http://plrg.eecs.uci.edu/git/?a=blobdiff_plain;f=traceanalysis.h;h=3f8c768868c03db71906808e92934fce93f51dfb;hb=52eaf0382899b8dd65486fc8c0933d7cae6c98bf;hp=8376bbcf10c1fa433f18ff8bb8501727e649a15f;hpb=5178739a27add5e59a1213c9ac90e73397c1a23d;p=c11tester.git diff --git a/traceanalysis.h b/traceanalysis.h index 8376bbcf..3f8c7688 100644 --- a/traceanalysis.h +++ b/traceanalysis.h @@ -2,9 +2,49 @@ #define TRACE_ANALYSIS_H #include "model.h" + class TraceAnalysis { - public: +public: + /** setExecution is called once after installation with a reference to + * the ModelExecution object. */ + + virtual void setExecution(ModelExecution * execution) = 0; + + /** analyze is called once for each feasible trace with the complete + * action_list object. */ + virtual void analyze(action_list_t *) = 0; + + /** name returns the analysis name string */ + + virtual const char * name() = 0; + + /** Each analysis option is passed into the option method. This + * occurs before installation (i.e., you don't have a + * ModelExecution object yet). A TraceAnalysis object should + * support the option "help" */ + + virtual bool option(char *) = 0; + + /** The finish method is called once at the end. This should be + * used to print out results. */ + + virtual void finish() = 0; + + /** This method is used to inspect the normal/abnormal model + * action. */ + virtual void inspectModelAction(ModelAction *act) {} + + /** This method will be called by when a plugin is installed by the + * model checker. */ + virtual void actionAtInstallation() {} + + /** This method will be called when the model checker finishes the + * executions; With this method, the model checker can alter the + * state of the plugin and then the plugin can choose whether or not + * restart the model checker. */ + virtual void actionAtModelCheckingFinish() {} + SNAPSHOTALLOC }; #endif