summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGravatar MichalMoskal <unknown>2010-08-18 01:09:33 +0000
committerGravatar MichalMoskal <unknown>2010-08-18 01:09:33 +0000
commitce2156e0b37f2efdb2e17aa1998c1c6a71adf062 (patch)
tree6b6ff0b7d7051f264ad54f6a1a3636db19221740
parent024e1669cac41a45ba0d825035a25d32a1562a67 (diff)
Change Synonym type printing to what it was, use a workaround in TypeToString() instead. Add test for /typeEncoding:m.
-rw-r--r--Source/Core/AbsyType.ssc5
-rw-r--r--Source/VCExpr/SimplifyLikeLineariser.cs11
-rw-r--r--Test/test2/Answer29
-rw-r--r--Test/test2/TypeEncodingM.bpl25
-rw-r--r--Test/test2/runtest.bat6
5 files changed, 70 insertions, 6 deletions
diff --git a/Source/Core/AbsyType.ssc b/Source/Core/AbsyType.ssc
index 6079163a..55b8913f 100644
--- a/Source/Core/AbsyType.ssc
+++ b/Source/Core/AbsyType.ssc
@@ -63,7 +63,7 @@ namespace Microsoft.Boogie
}
return buffer.ToString();
}
-
+
//----------- Equality ----------------------------------
[Pure][Reads(ReadsAttribute.Reads.Nothing)]
@@ -2131,8 +2131,7 @@ namespace Microsoft.Boogie
public override void Emit(TokenTextWriter! stream, int contextBindingStrength)
{
stream.SetToken(this);
- ExpandedType.Emit(stream, contextBindingStrength);
- // CtorType.EmitCtorType(this.Decl.Name, Arguments, stream, contextBindingStrength);
+ CtorType.EmitCtorType(this.Decl.Name, Arguments, stream, contextBindingStrength);
}
//----------- Resolution ----------------------------------
diff --git a/Source/VCExpr/SimplifyLikeLineariser.cs b/Source/VCExpr/SimplifyLikeLineariser.cs
index 84cf0454..01fd37c9 100644
--- a/Source/VCExpr/SimplifyLikeLineariser.cs
+++ b/Source/VCExpr/SimplifyLikeLineariser.cs
@@ -251,9 +251,14 @@ Contract.Ensures(Contract.Result<string>() != null);
}
return buffer.ToString();
}
- public static string TypeToString(Type t){
-Contract.Requires(t != null);
-Contract.Ensures(Contract.Result<string>() != null);
+ public static string TypeToString(Type t)
+ {
+ Contract.Requires(t != null);
+ Contract.Ensures(Contract.Result<string>() != null);
+ TypeSynonymAnnotation syn = t as TypeSynonymAnnotation;
+ if (syn != null)
+ return TypeToString(syn.ExpandedType);
+
if (t.IsBool)
return "$bool";
else if (t.IsInt)
diff --git a/Test/test2/Answer b/Test/test2/Answer
index a9329010..5cea9721 100644
--- a/Test/test2/Answer
+++ b/Test/test2/Answer
@@ -380,6 +380,35 @@ Execution trace:
LambdaPoly.bpl(34,5): anon5_Else
Boogie program verifier finished with 1 verified, 3 errors
+
+-------------------- Arrays.bpl /typeEncoding:m --------------------
+Arrays.bpl(46,5): Error BP5003: A postcondition might not hold at this return statement.
+Arrays.bpl(38,3): Related location: This is the postcondition that might not hold.
+Execution trace:
+ Arrays.bpl(42,3): start
+Arrays.bpl(127,5): Error BP5003: A postcondition might not hold at this return statement.
+Arrays.bpl(119,3): Related location: This is the postcondition that might not hold.
+Execution trace:
+ Arrays.bpl(123,3): start
+
+Boogie program verifier finished with 8 verified, 2 errors
+
+-------------------- Lambda.bpl /typeEncoding:m --------------------
+Lambda.bpl(37,3): Error BP5001: This assertion might not hold.
+Execution trace:
+ Lambda.bpl(36,5): anon0
+Lambda.bpl(38,3): Error BP5001: This assertion might not hold.
+Execution trace:
+ Lambda.bpl(36,5): anon0
+
+Boogie program verifier finished with 4 verified, 2 errors
+
+-------------------- TypeEncodingM.bpl /typeEncoding:m --------------------
+TypeEncodingM.bpl(24,3): Error BP5001: This assertion might not hold.
+Execution trace:
+ TypeEncodingM.bpl(11,9): anon0
+
+Boogie program verifier finished with 0 verified, 1 error
-------------------- sk_hack.bpl --------------------
Boogie program verifier finished with 1 verified, 0 errors
diff --git a/Test/test2/TypeEncodingM.bpl b/Test/test2/TypeEncodingM.bpl
new file mode 100644
index 00000000..01c95f7a
--- /dev/null
+++ b/Test/test2/TypeEncodingM.bpl
@@ -0,0 +1,25 @@
+type TT;
+
+procedure A()
+{
+ var M : [int]bool;
+ var N : [int,int]bool;
+ var Z : [int,bool]TT;
+ var t : TT;
+
+
+ M[10] := true;
+ M[20] := false;
+ N[10,20] := true;
+ N[10,21] := false;
+ N[11,20] := false;
+
+ assert M[10];
+ assert !M[20];
+
+ assert N[10,20];
+ assert !N[11,20];
+ assert !N[10,21];
+
+ assert Z[10,true] == t;
+}
diff --git a/Test/test2/runtest.bat b/Test/test2/runtest.bat
index dbe5b726..f704e263 100644
--- a/Test/test2/runtest.bat
+++ b/Test/test2/runtest.bat
@@ -17,6 +17,12 @@ for %%f in (FormulaTerm.bpl FormulaTerm2.bpl Passification.bpl B.bpl
%BGEXE% %* /noinfer %%f
)
+for %%f in (Arrays.bpl Lambda.bpl TypeEncodingM.bpl ) do (
+ echo.
+ echo -------------------- %%f /typeEncoding:m --------------------
+ %BGEXE% %* /noinfer /typeEncoding:m %%f
+)
+
echo -------------------- sk_hack.bpl --------------------
%BGEXE% %* /noinfer /bv:z sk_hack.bpl