5 // Alexander Chebaturkin (chebaturkin@gmail.com)
7 // Copyright (C) 2011 Alexander Chebaturkin
9 // Permission is hereby granted, free of charge, to any person obtaining
10 // a copy of this software and associated documentation files (the
11 // "Software"), to deal in the Software without restriction, including
12 // without limitation the rights to use, copy, modify, merge, publish,
13 // distribute, sublicense, and/or sell copies of the Software, and to
14 // permit persons to whom the Software is furnished to do so, subject to
15 // the following conditions:
17 // The above copyright notice and this permission notice shall be
18 // included in all copies or substantial portions of the Software.
20 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
21 // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
22 // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
23 // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
24 // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
25 // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
26 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
30 using Mono.CodeContracts.Static.Analysis;
31 using Mono.CodeContracts.Static.ControlFlow;
32 using Mono.CodeContracts.Static.DataStructures;
34 namespace Mono.CodeContracts.Static.Proving {
35 class BasicFacts<Expression, Variable> : IFactQuery<BoxedExpression, Variable> {
36 protected IExpressionContextProvider<Expression, Variable> ContextProvider;
37 protected IFactBase<Variable> FactBase;
38 protected Predicate<APC> isUnreachable;
40 public BasicFacts (IExpressionContextProvider<Expression, Variable> contextProvider, IFactBase<Variable> factBase, Predicate<APC> isUnreachable)
42 this.ContextProvider = contextProvider;
43 this.FactBase = factBase;
44 this.isUnreachable = isUnreachable;
47 #region Implementation of IFactBase<Variable>
48 public ProofOutcome IsNull (APC pc, Variable variable)
50 return this.FactBase.IsNull (pc, variable);
53 public ProofOutcome IsNonNull (APC pc, Variable variable)
55 return this.FactBase.IsNonNull (pc, variable);
58 public bool IsUnreachable (APC pc)
60 if (this.isUnreachable != null && this.isUnreachable (pc))
63 return this.FactBase.IsUnreachable (pc);
66 protected static bool TryVariable (BoxedExpression e, out Variable v)
68 object underlyingVariable = e.UnderlyingVariable;
69 if (underlyingVariable is Variable) {
70 v = (Variable) underlyingVariable;
74 v = default(Variable);
79 #region Implementation of IFactQuery<BoxedExpression,Variable>
80 public virtual ProofOutcome IsNull (APC pc, BoxedExpression expr)
83 if (TryVariable (expr, out v)) {
84 ProofOutcome outcome = this.FactBase.IsNull (pc, v);
85 if (outcome != ProofOutcome.Top)
88 return ProofOutcome.Top;
91 public virtual ProofOutcome IsNonNull (APC pc, BoxedExpression expr)
94 if (TryVariable (expr, out v)) {
95 ProofOutcome outcome = this.FactBase.IsNonNull (pc, v);
96 if (outcome != ProofOutcome.Top)
99 return ProofOutcome.Top;
102 public ProofOutcome IsTrue (APC pc, BoxedExpression expr)
104 return IsNonZero (pc, expr);
107 public ProofOutcome IsTrueImply (APC pc, LispList<BoxedExpression> positiveAssumptions, LispList<BoxedExpression> negativeAssumptions, BoxedExpression goal)
109 ProofOutcome outcome = IsTrue (pc, goal);
111 case ProofOutcome.True:
112 case ProofOutcome.Bottom:
115 return ProofOutcome.Top;
119 public ProofOutcome IsGreaterEqualToZero (APC pc, BoxedExpression expr)
121 return ProofOutcome.Top;
124 public ProofOutcome IsLessThan (APC pc, BoxedExpression expr, BoxedExpression right)
126 return ProofOutcome.Top;
129 public ProofOutcome IsNonZero (APC pc, BoxedExpression expr)
131 return IsNonNull (pc, expr);