scyther/src/binding.h

77 lines
2.3 KiB
C
Raw Normal View History

/*
* Scyther : An automatic verifier for security protocols.
2012-04-24 12:56:51 +01:00
* Copyright (C) 2007-2012 Cas Cremers
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
2004-08-15 12:55:22 +01:00
#ifndef BINDINGS
#define BINDINGS
2004-08-17 12:03:18 +01:00
#include "term.h"
#include "termmap.h"
2004-08-17 12:03:18 +01:00
#include "system.h"
2006-01-02 21:06:08 +00:00
//! Binding structure
2004-08-17 16:52:52 +01:00
/*
* Idea is the ev_from *has to* precede the ev_to
2008-08-21 15:58:12 +01:00
*
* @TODO: blocked is no longer used. For evaluations, it may be considered
* false (no binding is ever blocked).
2004-08-17 16:52:52 +01:00
*/
struct binding
{
int done; //!< Iff true, it is bound
int blocked; //!< Iff true, ignore it
2004-08-17 16:52:52 +01:00
2006-01-02 21:06:08 +00:00
int run_from; //!< origination run
int ev_from; //!< step in origination run
2004-08-17 16:52:52 +01:00
2006-01-02 21:06:08 +00:00
int run_to; //!< destination run
int ev_to; //!< step in destination run
2004-08-17 16:52:52 +01:00
2006-01-02 21:06:08 +00:00
Term term; //!< Binding term
int level; //!< ???
2004-08-17 16:52:52 +01:00
};
2006-01-02 21:06:08 +00:00
typedef struct binding *Binding; //!< pointer to binding structure
2004-08-17 16:52:52 +01:00
2004-08-15 12:55:22 +01:00
void bindingInit (const System mysys);
void bindingDone ();
int binding_print (Binding b);
int valid_binding (Binding b);
int same_binding (const Binding b1, const Binding b2);
2004-08-15 12:55:22 +01:00
int goal_add (Term term, const int run, const int ev, const int level);
int goal_add_fixed (Term term, const int run, const int ev, const int fromrun,
const int fromev);
void goal_remove_last (int n);
2004-08-17 16:52:52 +01:00
int goal_bind (const Binding b, const int run, const int ev);
void goal_unbind (const Binding b);
int binding_block (Binding b);
int binding_unblock (Binding b);
int labels_ordered (Termmap runs, Termlist labels);
2004-08-17 16:52:52 +01:00
int iterate_bindings (int (*func) (Binding b));
int iterate_preceding_bindings (const int run, const int ev,
int (*func) (Binding b));
2012-05-01 13:46:01 +01:00
int non_redundant ();
int countBindingsDone ();
2004-08-17 16:52:52 +01:00
2004-08-15 12:55:22 +01:00
#endif