- Improved output significantly.

This commit is contained in:
ccremers 2005-12-27 12:24:12 +00:00
parent 5ff71fa661
commit 397298290b
2 changed files with 58 additions and 50 deletions

View File

@ -385,7 +385,7 @@ timersPrint (const System sys)
/* modern version: claim label is tuple (protocname, label) */ /* modern version: claim label is tuple (protocname, label) */
/* first print protocol.role */ /* first print protocol.role */
termPrint (TermOp1 (cl_scan->label)); termPrint (TermOp1 (cl_scan->label));
eprintf ("\t"); eprintf (",");
termPrint (cl_scan->rolename); termPrint (cl_scan->rolename);
eprintf ("\t"); eprintf ("\t");
/* second print event_label */ /* second print event_label */
@ -404,36 +404,44 @@ timersPrint (const System sys)
termPrint (cl_scan->label); termPrint (cl_scan->label);
eprintf (")\t"); eprintf (")\t");
} }
/* print counts etc. */
eprintf ("found:\t"); /* now report the status */
statesFormat (cl_scan->count); eprintf ("attacks: ");
if (cl_scan->count > 0) if (cl_scan->count > 0 && cl_scan->failed > 0)
{ {
if (cl_scan->failed > 0) /* there is an attack */
eprintf ("yes\t(at least %i)", cl_scan->failed);
}
else
{
/* no attack */
eprintf ("no\t");
/* subcases */
if (cl_scan->count == 0)
{ {
eprintf ("\t"); /* not encountered */
eprintf ("failed:\t"); eprintf ("(does not occur)");
statesFormat (cl_scan->failed);
} }
else else
{ {
eprintf ("\tcorrect: "); /* does occur */
if (cl_scan->complete) if (cl_scan->complete)
{ {
eprintf ("complete_proof"); /* complete proof */
eprintf ("(proof of correctness)");
} }
else else
{ {
eprintf ("bounded_proof"); /* only due to bounds */
eprintf ("(no attack within bounds)");
if (cl_scan->timebound) if (cl_scan->timebound)
eprintf ("\ttime=%i", get_time_limit ()); eprintf ("\ttime=%i", get_time_limit ());
} }
} }
} }
else
{ /* proceed to next claim */
eprintf ("\tcorrect: does_not_occur");
}
eprintf ("\n"); eprintf ("\n");
} }
cl_scan = cl_scan->next; cl_scan = cl_scan->next;

View File

@ -274,7 +274,7 @@ switcher (const int process, int index)
/* ================== /* ==================
* Generic options * Generic options
*/ */
if (detect ('a', "arachne", 0)) if (detect ('A', "arachne", 0))
{ {
if (!process) if (!process)
{ {
@ -337,11 +337,11 @@ switcher (const int process, int index)
} }
} }
if (detect ('P', "proof", 0)) if (detect ('p', "proof", 0))
{ {
if (!process) if (!process)
{ {
helptext ("-P,--proof", "show explicit proof"); helptext ("-p,--proof", "show explicit proof");
} }
else else
{ {
@ -351,6 +351,33 @@ switcher (const int process, int index)
} }
} }
if (detect ('c', "class", 0))
{
if (!process)
{
helptext ("-c,--class",
"generate full class (show uninstantiated variables)");
}
else
{
switches.concrete = false;
return index;
}
}
if (detect (' ', "concrete", 0))
{
if (!process)
{
/* this is now the default */
}
else
{
switches.concrete = true;
return index;
}
}
/* ================== /* ==================
* Bounding options * Bounding options
*/ */
@ -426,11 +453,11 @@ switcher (const int process, int index)
} }
} }
if (detect ('A', "all-attacks", 0)) if (detect ('a', "all-attacks", 0))
{ {
if (!process) if (!process)
{ {
helptext ("-A,--all-attacks", helptext ("-a,--all-attacks",
"generate all attacks instead of just one"); "generate all attacks instead of just one");
} }
else else
@ -455,12 +482,12 @@ switcher (const int process, int index)
} }
} }
if (detect ('p', "prune", 1)) if (detect ('P', "prune", 1))
{ {
if (!process) if (!process)
{ {
/* not very important /* not very important
helptext ("-p,--prune=<int>", "pruning method when an attack is found [2]"); helptext ("-P,--prune=<int>", "pruning method when an attack is found [2]");
*/ */
} }
else else
@ -692,33 +719,6 @@ switcher (const int process, int index)
} }
} }
if (detect ('C', "class", 0))
{
if (!process)
{
helptext ("-C,--class",
"generate full class (show uninstantiated variables)");
}
else
{
switches.concrete = false;
return index;
}
}
if (detect (' ', "concrete", 0))
{
if (!process)
{
/* this is now the default */
}
else
{
switches.concrete = true;
return index;
}
}
#ifdef DEBUG #ifdef DEBUG
/* ================== /* ==================
* Experimental options * Experimental options