Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[do not merge] WIP Exceptions #348

Closed
wants to merge 299 commits into from
Closed
Changes from 9 commits
Commits
Show all changes
299 commits
Select commit Hold shift + click to select a range
ee09caf
Allows for hello.dfy to fully compile into Java code
Jun 14, 2019
57b1e1c
fix resolved comments
Jun 14, 2019
4572251
Testing tuple implementation for Java
Jun 7, 2019
7471f69
Add support for unsigned numerics
Jun 12, 2019
e725973
Change DafnyString implmentation to use String internally
Jun 12, 2019
de0c0ab
Allows for Hello.dfy to work completely
Jun 17, 2019
23ba5a0
Recursively compiles Java files in the relevant directory
Jun 18, 2019
41d9713
Add functionality for program to run if it has a main method and flag…
Jun 18, 2019
b10dff5
Merge branch 'java-compiler' of ssh://git.amazon.com:2222/pkg/Dafny i…
Jun 20, 2019
d06d346
Successfully compile Calls.dfy to Java
Jun 21, 2019
6e6b1ba
Successfully compile and run Class.dfy into Java
Jun 25, 2019
90a0cc3
Address comments in CR-10022662 Revision 1
Jun 26, 2019
55e70f3
Add support for dynamically adding tuple sizes
Jun 20, 2019
f5111b3
Add support for dynamically adding tuple sizes
Jun 20, 2019
8280897
Add EmitDatatypeValue"
Jun 21, 2019
7362e4b
Restructure compilation list so __default is added to _System
Jun 21, 2019
6ed3950
Add dynamic compilation of Tuple0
Jun 21, 2019
8ee55fd
Add compilation for abstract class for algebraic datatypes
Jun 24, 2019
54adbfc
Add object methods to algebraic types without type parameters
Jun 24, 2019
72d10e4
Add datatype support with fields
Jun 25, 2019
096e064
Auto-format code after pushing tuples
Jun 27, 2019
c402020
No logical changes, moved relevant unimplemented functions up in file
Jun 26, 2019
72f96c2
Implement lambda functions, IIFE0, tail-recursion, and for-each loops
Jun 27, 2019
0befbc1
Allows Dt.dfy to successfully compile and run in Java
Jun 29, 2019
860f115
pb/compiler-java-cs in one commit
Jun 6, 2019
f643912
forreal please work
Jun 6, 2019
e404277
addressed CR-9317576 comments
Jun 6, 2019
0528dad
Added Java Classes For Dafny Types
Jun 6, 2019
a6a113b
removed uneccessary functionality from DafnySet
Jun 6, 2019
dae0fc7
finished implementing ClassWriter.CreateMethod
Jun 6, 2019
501b07d
addressed comments in CR-9354201
Jun 6, 2019
36e5c81
few TODO comments removed
Jun 6, 2019
2b49911
module headers printed out properly, example:
Jun 7, 2019
7756330
Improve Java implementation of Dafny datatypes.
Jun 7, 2019
622ac47
Edited csharp Multiset to use BigInteger for multiplicity
Jun 11, 2019
934163c
Add BigOrdinal Support
Jun 12, 2019
b94b349
add set to mset conversion
Jun 13, 2019
fd0e96d
finished most of ClassWriter class functions
Jun 10, 2019
1836397
Add functions to emit literal expressions
Jun 11, 2019
4dd4400
implements few more functions called from TrExpr in Compiler.cs
Jun 12, 2019
72066dd
Adds more functions that retrieve data from Collection types
Jun 13, 2019
1897cfc
Adjusts indents to have 2 spaces instead of 4
Jun 13, 2019
1970e6f
Adds Java functionality for bitwise Rotate operation
Jun 13, 2019
022d7a6
Allows for hello.dfy to fully compile into Java code
Jun 14, 2019
f13aba2
fix resolved comments
Jun 14, 2019
56531d5
Testing tuple implementation for Java
Jun 7, 2019
894b5d7
Add support for unsigned numerics
Jun 12, 2019
9635764
Change DafnyString implmentation to use String internally
Jun 12, 2019
994a1a3
Allows for Hello.dfy to work completely
Jun 17, 2019
eac8cd1
Recursively compiles Java files in the relevant directory
Jun 18, 2019
02362fa
Add functionality for program to run if it has a main method and flag…
Jun 18, 2019
8e533c7
pb/compiler-java-cs in one commit
Jun 6, 2019
f31bb87
forreal please work
Jun 6, 2019
c6c9975
Successfully compile Calls.dfy to Java
Jun 21, 2019
4e821ea
Successfully compile and run Class.dfy into Java
Jun 25, 2019
44cd381
Address comments in CR-10022662 Revision 1
Jun 26, 2019
4dd96e5
Add support for dynamically adding tuple sizes
Jun 20, 2019
88481f7
Add support for dynamically adding tuple sizes
Jun 20, 2019
0310a79
Add EmitDatatypeValue"
Jun 21, 2019
4515b90
Restructure compilation list so __default is added to _System
Jun 21, 2019
09ee768
Add dynamic compilation of Tuple0
Jun 21, 2019
607e856
Add compilation for abstract class for algebraic datatypes
Jun 24, 2019
c434e5c
Add object methods to algebraic types without type parameters
Jun 24, 2019
ee22a10
Add datatype support with fields
Jun 25, 2019
185e594
No logical changes, moved relevant unimplemented functions up in file
Jun 26, 2019
d1c74cc
Implement lambda functions, IIFE0, tail-recursion, and for-each loops
Jun 27, 2019
ca49433
Allows Dt.dfy to successfully compile and run in Java
Jun 29, 2019
e9072dc
Fix merge conflicts
Jul 2, 2019
4f08547
Tracks DafnyClasses folder in Binaries
Jul 3, 2019
0ef0884
Add functionality for externs, but no partial externs yet, and Java n…
Jul 2, 2019
10a7af9
No logical changes, removed extraneous code
Jul 2, 2019
4d6cbd4
Allows Ghosts.dfy to compile successfully, plus retroactive fixes
Jul 2, 2019
1052373
Allow for Java compilation on non-Unix machines, and error code checking
Jul 3, 2019
412a952
Add euclidean division support
Jun 19, 2019
158c719
Add euclidean modulus
Jun 19, 2019
5b429e2
chnage method names to support overloading
Jun 20, 2019
1bef382
Defined specifications for Euclidean Divisions
Jun 26, 2019
38ccc73
Change tests to run in JDK 8
Jun 26, 2019
461be55
Copy c# code into java compiler to be refactored for java
Jun 25, 2019
acd5644
Allow set method to compile
Jun 25, 2019
50a63fd
Allow multisets method to compile
Jun 26, 2019
88e84d3
Allow sequence method to compile completely
Jun 26, 2019
1bc007b
Allow strings method to compile
Jun 26, 2019
7f3e43f
Allow Map method to compile
Jun 27, 2019
e8d77c5
Add Dafnymap class
Jun 27, 2019
9248844
Resolve merge conflicts from rebasing
Jun 27, 2019
b8d5651
Allow InterplayBetweenSeqCharAndString to compile
Jun 27, 2019
8ca3f2d
Allow Collections to compile completely
Jun 28, 2019
e4a3949
Allows collections to run without errors
Jun 29, 2019
bf810d7
Allow compiled class to run with correct output
Jul 1, 2019
a01df92
Revisions to make program compile with better type checking
Jul 8, 2019
526d569
Change size casting to use valueOf instead
Jul 8, 2019
77fad89
Fix a few lines for more optimal design
Jul 8, 2019
6af26df
Fix mistakes when solving merge conflicts in rebase
Jul 8, 2019
3e738ee
Copied DafnyClasses files from Test to Binaries
Jul 9, 2019
d376535
Modify wrapper classes to match functionality
Jul 9, 2019
0c9728c
Fix java casting in operators
Jul 9, 2019
f02507c
Further edits to java classes to match functionality
Jul 10, 2019
baab596
Allow Numbers.dfy to compile completely
Jul 10, 2019
c0b28af
Allows Arrays.dfy to compile and javac can now run on Windows
Jul 9, 2019
ab9d87c
Address comments on CR-10533809 R1
Jul 10, 2019
da5600d
Resolve merge conflicts from java-compiler, add Helpers.java from Jac…
Jul 10, 2019
04bcbf9
Allows Forall.dfy to compile
Jul 12, 2019
6780e2b
Remove comment that throws exception when compile fails
Jul 12, 2019
9a8a632
create skeleton for methods needed in let.dfy
Jul 8, 2019
fdc62b7
Allo Let.dfy to compile completely and run correctly
Jul 9, 2019
5703e3d
Fix mistakes when selecting wrong version from merge conflict
Jul 10, 2019
3dc3710
Merge branch 'java-compiler-needs-master' into java-compiler
Jul 12, 2019
46087ab
Merge branch 'java-compiler' of ssh://git.amazon.com:2222/pkg/Dafny i…
Jul 12, 2019
16b4241
Fixes #315
mschlaipfer Jul 12, 2019
284a801
Add bigrational class
Jul 1, 2019
45d36ab
Allow Numbers.dfy to compile with correct math
Jul 10, 2019
a8f0489
Improve code abstraction
Jul 11, 2019
99f34e9
Add revised versions of classes to binaries;
Jul 16, 2019
6696727
Merge branch 'js/numbers_fix' into java-compiler
Jul 16, 2019
89cb689
Merge branch 'js/numbers_fix' into java-compiler
Jul 16, 2019
592ed43
Merge branch 'java-compiler' of ssh://git.amazon.com:2222/pkg/Dafny i…
Jul 23, 2019
d955fe9
Allow TypeParams to fully compile
Jul 15, 2019
0ff3d2e
Allow getDefault to work with non-generic types
Jul 17, 2019
41e57db
Allow typeparams to compile with default values
Jul 18, 2019
d6b198b
Allow type params to compile and run with correct output
Jul 18, 2019
2add0b1
Improve code abstraction and file structure
Jul 22, 2019
3c48222
Eliminate all uses of SupportsAmb...
Jul 23, 2019
aa1605d
Address comments from previous CRs
Jul 12, 2019
7b79487
Allows Comprehensions.dfy to compile fully
Jul 15, 2019
f14f8e4
Allows S3EncryptionClient compile to Java code, unknown if correct, S…
Jul 16, 2019
92a918d
Fix issue with calling static generic methods
Jul 17, 2019
12b146f
Fix string interpolation code style
Jul 17, 2019
f2801e4
Fixes type errors from S3EncryptionClient, change in directory struct…
Jul 19, 2019
f07cf11
Fix bug regarding tuple type declarations
Jul 19, 2019
e067933
Does not create empty package files anymore, and empty packages are n…
Jul 19, 2019
6085b10
Fix issue of datatypes with single constructors, prevent repeating im…
Jul 22, 2019
214b3d6
Avoids creating empty Java file if there is no main method
Jul 22, 2019
0619387
Allows Comprehensions.dfy to compile fully
Jul 15, 2019
e466b97
Do not create/import empty package files
Jul 19, 2019
ee1e61f
Fix type errors from S3EncryptionClient, change in directory structur…
Jul 19, 2019
9e45e6d
Fix typenames and dynamically created DafnyClasses when compiling S3E…
Jul 23, 2019
d7f9504
Add method in DafnyByte to return signed byte value
Jul 23, 2019
4c4a6ba
Merge Jack's changes and ensure all dfy files in Test/comp compile
Jul 24, 2019
ab13196
Delete old Java-compile output folder before writing new files
Jul 24, 2019
084ea8b
Allows Vihang's Base64.dfy to compile successfully
Jul 24, 2019
735bebf
Fix TypeName_Companion method in Compiler-java.cs
Jul 25, 2019
5391f39
Compile S3EncryptionClient without compile-time errors
Jul 25, 2019
7829ca8
Allows Vihang's Base64.dfy to compile successfully
Jul 24, 2019
d1c080c
Compile Yucca successfully
Jul 25, 2019
925ad44
Run S3EncryptionClient successfully
Jul 26, 2019
7e4e99e
Run full S3EncryptionClient successfully
Jul 29, 2019
b6ab8c1
Run full S3EncryptionClient successfully
Jul 29, 2019
b28c0ef
NO LOGICAL CHANGES: Add comment
Jul 30, 2019
7aba53b
Add java testing to lit testing suite
Jul 25, 2019
11de646
Allow java files to compile without warnings
Jul 25, 2019
0e69ab1
Allow Arrays.dfy to compile withour warnings
Jul 25, 2019
0014aea
Fix explosive union expect
Jul 25, 2019
e4fc786
Allow ghosts.dfy to compile without warnings
Jul 26, 2019
517168f
Allow test suite to run java files with correct output
Jul 26, 2019
5500f19
Fix final touchups for test suite
Jul 29, 2019
11f2bb3
Update Java classes tester to match live
Jul 30, 2019
9c515f7
Fix multiset update to avoid duplicate work
Jul 30, 2019
4933a60
Run formatter
Jul 30, 2019
388dbc2
Add byteValue to Ubyte
Jul 30, 2019
70ae188
Add type parameter to sequence
Jul 30, 2019
04b5049
Fix bug in SequenceTest
Jul 31, 2019
4c3aa17
Add string interpolation, remove excess whitespace
Jul 31, 2019
0ccad91
Add more Byte/UByte tests
Aug 1, 2019
85657ac
Correct wrong binary ops
Aug 2, 2019
1d168bc
Move DafnyClasses from Binaries to DafnyRuntime
Aug 2, 2019
0b50af2
Use JAR file for DafnyClasses
Aug 2, 2019
a3aaf80
Fix Ghosts.dfy NullPointerException
Aug 5, 2019
029f6cf
Remove formatting changes
Aug 5, 2019
56ff578
Factor out classpath setting code
Aug 5, 2019
36d7ba6
Fix Ghosts.dfy NullPointerException
Aug 5, 2019
3f05a40
NO LOGICAL CHANGES: Revert DafnyRuntime.cs copy to master
Aug 6, 2019
76a2427
Merge branch 'java-compiler-to-master' into java-compiler
Aug 6, 2019
098a56a
Do not wrap `const`s in `Lit`s
amaurremi Jul 31, 2019
c46cc3d
Motivating examples for functional extensionality
amaurremi Aug 1, 2019
dc49ab2
Add unsigned conversions
Aug 7, 2019
a9485a3
Added test to clarify expressivity of no `Lit` around `const`s. Minor…
amaurremi Aug 7, 2019
77ce20d
use platform.system() instead of os.name to detect whether to use mono
samuelgruetter Aug 8, 2019
e78e60e
Merge branch 'java-compiler-to-master' into java-compiler
Aug 8, 2019
62d6f35
Merge branch 'java-compiler' of ssh://git.amazon.com:2222/pkg/Dafny i…
Aug 8, 2019
43187f2
Fix character compare binary operations
Aug 7, 2019
b2a1d04
Fix UByte addition/subtraction
Aug 7, 2019
92a163b
Delete explosiveunion, get DafnyRuntime.cs from master
Aug 9, 2019
3ae95ac
exceptions syntactic sugar first step: `:-` in var update as an alias…
samuelgruetter Aug 9, 2019
6b01ee7
rerun Coco
samuelgruetter Aug 9, 2019
021e34f
enable `:-` in var decls too
samuelgruetter Aug 9, 2019
722b4c2
rerun Coco
samuelgruetter Aug 9, 2019
6b67561
Pass all tests in comp
Aug 10, 2019
f06e6d3
Move Java unit tests to DafnyRuntimeJava
Aug 10, 2019
9d6aaca
desugaring of `:-` statements
samuelgruetter Aug 10, 2019
0153015
Fix null-dereference crash
RustanLeino Aug 10, 2019
05bd4e4
Reformatting test files
amaurremi Aug 8, 2019
716faee
Modify .travis.yml to run jdk8, TEST
Aug 12, 2019
6b0c0d6
Suppress deprecation warning, revert .travis.yml
Aug 12, 2019
da277a2
Fix suppresswarning bug
Aug 12, 2019
78d166a
Merge pull request #345 from samuelgruetter/lit_cygwin
RustanLeino Aug 12, 2019
88a0e18
test interaction of desugaring with parser, typechecker and verifyer
samuelgruetter Aug 12, 2019
e240864
implement EnsureSupportsNonVoidErrorHandling and use it to improve er…
samuelgruetter Aug 13, 2019
8149af8
Merge pull request #349 from RustanLeino/fix-null-crash
RustanLeino Aug 13, 2019
4d685bd
Use WriteLine instead of newline
Aug 13, 2019
5fbca18
fix whitespace and remove naming of `:-` in grammar
samuelgruetter Aug 13, 2019
4ae3882
rerun coco
samuelgruetter Aug 13, 2019
297e38f
Fix Bitvectors.dfy
Aug 9, 2019
9e4080d
Fix dafny0/ArrayElementInitCompile.dfy
Aug 10, 2019
c0997fe
address comments by @RustanLeino
samuelgruetter Aug 13, 2019
c938c6d
Merge pull request #344 from amaurremi/lit-and-funext
RustanLeino Aug 14, 2019
227bbd1
Merge branch 'master' into fix-315
RustanLeino Aug 14, 2019
be0a7f1
Fix Bitvectors.dfy
Aug 9, 2019
7e0f2e3
Merge pull request #317 from mschlaipfer/fix-315
RustanLeino Aug 14, 2019
051e810
Typecheck variables in the Requires clause of lambda functions (handles)
amaurremi Aug 14, 2019
eda3580
Fix misc. bugs
Aug 14, 2019
f7d1d0a
Fix dafny0/NonZeroInitializationCompile.dfy
Aug 14, 2019
4d3c1c8
implement `:-` without LHS, and
samuelgruetter Aug 14, 2019
2b7a25d
rerun coco
samuelgruetter Aug 14, 2019
f172fc4
also commit VoidOutcome
samuelgruetter Aug 15, 2019
c6fda17
update .gitignore
samuelgruetter Aug 15, 2019
26895c6
Merge pull request #355 from amaurremi/typecheck-in-requires-clause
RustanLeino Aug 15, 2019
aed7e14
Remove tab character from main
Aug 15, 2019
92a32cf
Fix Array functions
Aug 9, 2019
e30ef12
Add missing multset functionality
Aug 9, 2019
210f683
Add more specifics for + and - ops
Aug 13, 2019
d7dd5e6
Order varaibles to allow java compilation
Aug 14, 2019
08b135a
Fix add/subtract bug
Aug 15, 2019
c9b7f23
Address PR comments
Aug 15, 2019
f63ffdb
enable test for statement-level where RHS of `:-` is an expression
samuelgruetter Aug 15, 2019
c88079e
Remove global variable MemberSelectObjIsTrait
Aug 16, 2019
f41387d
Remove unecessary methods from numerics
Aug 16, 2019
fc796bc
Update test cases
Aug 16, 2019
db753f4
Add safet checks to tuples
Aug 16, 2019
f9dea17
Merge branch 'java-compiler' of ssh://git.amazon.com:2222/pkg/Dafny i…
Aug 16, 2019
b643abf
Merge pull request #347 from psbang/java-compiler
RustanLeino Aug 16, 2019
923f812
Add syntax for type members of (co)datatypes and newtypes.
RustanLeino Aug 10, 2019
711fa94
Resolve members of (co)datatypes and newtypes
RustanLeino Aug 10, 2019
5becaed
Verify members of (co)datatypes and newtypes
RustanLeino Aug 10, 2019
023df3b
time lit tests
samuelgruetter Aug 16, 2019
7774dfb
Compile type members for (co)datatypes and newtypes
RustanLeino Aug 10, 2019
3f5237f
Fix C# compile name-clashes
RustanLeino Aug 11, 2019
fa2e37a
Refactor NeedsCustomReceiver expression in compiler
RustanLeino Aug 15, 2019
2b8d0f7
first try at parsing `:-` on expression level,
samuelgruetter Aug 17, 2019
b6f9aa1
Failed attempt at fixing the "LL1 warning in UnaryExpression: lbrace
samuelgruetter Aug 17, 2019
40c7bd2
Revert failed attempt
samuelgruetter Aug 17, 2019
b3fb175
remove unused IToken Colon field from UserSuppliedAttributes
samuelgruetter Aug 17, 2019
ec15c40
New approach to disambiguate between attribute and set display:
samuelgruetter Aug 17, 2019
cb744f8
rerun coco
samuelgruetter Aug 17, 2019
735827e
Merge pull request #350 from RustanLeino/type-members
RustanLeino Aug 17, 2019
d3ee64e
Merge pull request #357 from samuelgruetter/time-lit
RustanLeino Aug 17, 2019
d294979
replace tabs by spaces in Dafny.atg
samuelgruetter Aug 17, 2019
6158d4a
Finally, a parser for `:-` on expression level without Coco warnings
samuelgruetter Aug 17, 2019
eb631f1
rerun coco
samuelgruetter Aug 17, 2019
2bc839b
Merge old exceptions branch in new exceptions branch forked from master
samuelgruetter Aug 17, 2019
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
12 changes: 6 additions & 6 deletions Binaries/DafnyClasses/DafnyEuclidean.java
Original file line number Diff line number Diff line change
@@ -116,7 +116,7 @@ public static int EuclideanModulus(int a, int b) {
assert b != 0 : "Precondition Failure";
if (0 <= a) {
// +a: a % b'
if (b == Integer.MIN_VALUE) return (int) new DafnyUInt(a).modulus(new DafnyUInt(b)).value();
if (b == Integer.MIN_VALUE) return (int) new DafnyUInt(a).mod(new DafnyUInt(b)).value();
else if (b < 0) return a % -b;
else return a % b;
} else {
@@ -126,10 +126,10 @@ public static int EuclideanModulus(int a, int b) {
if (a == Integer.MIN_VALUE || b == Integer.MIN_VALUE) {
if (a == b) return 0;
else if (b == Integer.MIN_VALUE) {
return new DafnyUInt(b).subtract(new DafnyUInt(-a).modulus(new DafnyUInt(b))).value();
return new DafnyUInt(b).subtract(new DafnyUInt(-a).mod(new DafnyUInt(b))).value();
} else {
int bp = b < 0 ? -b : b;
return new DafnyUInt(bp).subtract(new DafnyUInt(a).modulus(new DafnyUInt(bp))).value();
return new DafnyUInt(bp).subtract(new DafnyUInt(a).mod(new DafnyUInt(bp))).value();
}
} else {
int bp = b < 0 ? -b : b;
@@ -143,7 +143,7 @@ public static long EuclideanModulus(long a, long b) {
assert b != 0 : "Precondition Failure";
if (0 <= a) {
// +a: a % b'
if (b == Long.MIN_VALUE) return (int) new DafnyULong(a).modulus(new DafnyULong(b)).value();
if (b == Long.MIN_VALUE) return (int) new DafnyULong(a).mod(new DafnyULong(b)).value();
else if (b < 0) return a % -b;
else return a % b;
} else {
@@ -153,10 +153,10 @@ public static long EuclideanModulus(long a, long b) {
if (a == Long.MIN_VALUE || b == Long.MIN_VALUE) {
if (a == b) return 0;
else if (b == Long.MIN_VALUE) {
return new DafnyULong(b).subtract(new DafnyULong(-a).modulus(new DafnyULong(b))).value();
return new DafnyULong(b).subtract(new DafnyULong(-a).mod(new DafnyULong(b))).value();
} else {
long bp = b < 0 ? -b : b;
return new DafnyULong(bp).subtract(new DafnyULong(a).modulus(new DafnyULong(bp))).value();
return new DafnyULong(bp).subtract(new DafnyULong(a).mod(new DafnyULong(bp))).value();
}
} else {
long bp = b < 0 ? -b : b;
Binary file added Binaries/DafnyClasses/DafnyMultiset.class
Binary file not shown.
141 changes: 106 additions & 35 deletions Source/Dafny/Compiler-java.cs
Original file line number Diff line number Diff line change
@@ -302,7 +302,7 @@ protected BlockTargetWriter CreateMethod(Method m, bool createBody, TargetWriter
}

protected void DeclareField(string name, bool isStatic, bool isConst, Type type, Bpl.IToken tok, string rhs, TargetWriter wr) {
wr.WriteLine("public {0}{1} {2} = {3};", isStatic ? "static " : "", TypeName(type, wr, tok), name, (rhs != null) ? rhs : DefaultValue(type, wr, tok));
wr.WriteLine("public {0}{1} {2} = {3};", isStatic ? "static " : "", TypeName(type, wr, tok), name, (rhs != null) ? $"new {TypeName(type, wr, tok)}({rhs})" : DefaultValue(type, wr, tok));
}

string TypeParameters(List<TypeParameter> targs) {
@@ -327,8 +327,8 @@ protected override string TypeName(Type type, TextWriter wr, Bpl.IToken tok, Mem
return "Character";
} else if (xType is IntType || xType is BigOrdinalType) {
return "BigInteger";
} else if (xType is RealType) {
return "BigDecimal";
} else if (xType is RealType) {
return "BigRational";
} else if (xType is BitvectorType) {
var t = (BitvectorType)xType;
return t.NativeType != null ? GetNativeTypeName(t.NativeType) : "BigInteger";
@@ -486,9 +486,27 @@ protected override void EmitLiteralExpr(TextWriter wr, LiteralExpr e) {
wr.Write((BigInteger)e.Value + literalSuffix);
} else if (e.Value is BigInteger i) {
wr.Write("new BigInteger(\"{0}\")", i);
} else if (e.Value is Basetypes.BigDec n) {
wr.Write("new BigDecimal(\"{0}E{1}\")", n.Mantissa, n.Exponent);
} else {
} else if (e.Value is Basetypes.BigDec n){
if (0 <= n.Exponent){
wr.Write("new DafnyClasses.BigRational(new BigInteger(\"{0}", n.Mantissa);
for (int j = 0; j < n.Exponent; j++){
wr.Write("0");
}

wr.Write("\"), BigInteger.ONE)");
}
else{
wr.Write("new DafnyClasses.BigRational(");
wr.Write($"new BigInteger(\"{n.Mantissa}\")");
wr.Write(", new BigInteger(\"1");
for (int j = n.Exponent; j < 0; j++){
wr.Write("0");
}

wr.Write("\"))");
}
}
else {
Contract.Assert(false); throw new cce.UnreachableException(); // unexpected literal
}
}
@@ -524,25 +542,25 @@ protected override void GetNativeInfo(NativeType.Selection sel, out string name,
needsCastAfterArithmetic = false;
switch (sel) {
case NativeType.Selection.Byte:
name = "Dafny.DafnyByte";
name = "DafnyClasses.DafnyByte";
break;
case NativeType.Selection.SByte:
name = "Byte";
break;
case NativeType.Selection.UShort:
name = "Dafny.DafnyUShort";
name = "DafnyClasses.DafnyUShort";
break;
case NativeType.Selection.Short:
name = "Short";
break;
case NativeType.Selection.UInt:
name = "Dafny.DafnyUInt";
name = "DafnyClasses.DafnyUInt";
break;
case NativeType.Selection.Int:
name = "Integer";
break;
case NativeType.Selection.ULong:
name = "Dafny.DafnyULong";
name = "DafnyClasses.DafnyULong";
break;
case NativeType.Selection.Number:
case NativeType.Selection.Long:
@@ -616,19 +634,19 @@ protected override void GetSpecialFieldInfo(SpecialField.ID id, object idParam,
compiledName = "toBigInteger()";
break;
case SpecialField.ID.IsLimit:
preString = "Dafny.BigOrdinal.IsLimit(";
preString = "DafnyClasses.DafnyBigOrdinal.IsLimit(";
postString = ")";
break;
case SpecialField.ID.IsSucc:
preString = "Dafny.BigOrdinal.IsSucc(";
preString = "DafnyClasses.DafnyBigOrdinal.IsSucc(";
postString = ")";
break;
case SpecialField.ID.Offset:
preString = "Dafny.BigOrdinal.Offset(";
preString = "DafnyClasses.DafnyBigOrdinal.Offset(";
postString = ")";
break;
case SpecialField.ID.IsNat:
preString = "Dafny.BigOrdinal.IsNat(";
preString = "DafnyClasses.DafnyBigOrdinal.IsNat(";
postString = ")";
break;
case SpecialField.ID.Keys:
@@ -805,12 +823,12 @@ protected override void EmitRotate(Expression e0, Expression e1, bool isRotateLe
wr.Write("(" + nativeName + ")(");
}
wr.Write("(");
EmitShift(e0, e1, isRotateLeft ? "<<" : ">>", isRotateLeft, nativeType, true, wr, inLetExprBody, tr);
EmitShift(e0, e1, isRotateLeft ? ".shiftLeft" : ".shiftRight", isRotateLeft, nativeType, true, wr, inLetExprBody, tr);
wr.Write(")");
wr.Write (" | ");
wr.Write (".or");
wr.Write("(");
EmitShift(e0, e1, isRotateLeft ? ">>" : "<<", !isRotateLeft, nativeType, false, wr, inLetExprBody, tr);
wr.Write(")");
EmitShift(e0, e1, isRotateLeft ? ".shiftRight" : ".shiftLeft", !isRotateLeft, nativeType, false, wr, inLetExprBody, tr);
wr.Write(")))");
if (needsCast) {
wr.Write(")");
}
@@ -826,9 +844,9 @@ void EmitShift(Expression e0, Expression e1, string op, bool truncate, NativeTyp
if (!firstOp) {
wr.Write("({0} - ", bv.Width);
}
wr.Write("(int) (");
wr.Write("(");
tr(e1, wr, inLetExprBody);
wr.Write(")");
wr.Write(".intValue()");
if (!firstOp) {
wr.Write(")");
}
@@ -851,18 +869,24 @@ protected override TargetWriter EmitBitvectorTruncation(BitvectorType bvType, bo
// --- After
// do the truncation, if needed
if (bvType.NativeType == null) {
wr.Write(") & ((new BigInteger(1) << {0}) - 1))", bvType.Width);
wr.Write(").and((BigInteger.ONE.shiftLeft({0})).subtract(BigInteger.ONE)))", bvType.Width);
} else {
if (bvType.NativeType.Bitwidth != bvType.Width) {
// print in hex, because that looks nice
wr.Write(") & ({2})0x{0:X}{1})", (1UL << bvType.Width) - 1, literalSuffix, nativeName);
var t = RepresentableByInt(bvType.NativeType) ? "" : "L";
wr.Write($").and(new {nativeName}(0x{(1UL << bvType.Width) - 1:X}{literalSuffix}{t})))");
} else {
wr.Write("))"); // close the parentheses for the cast
}
}
return middle;
}

private static bool RepresentableByInt(NativeType n){
return !(n.Sel.Equals(NativeType.Selection.ULong) || n.Sel.Equals(NativeType.Selection.Long)
|| n.Sel.Equals(NativeType.Selection.Number));
}

protected override void DeclareDatatype(DatatypeDecl dt, TargetWriter wr) {
if (dt is TupleTypeDecl){
tuples.Add(((TupleTypeDecl) dt).Dims);
@@ -872,7 +896,22 @@ protected override void DeclareDatatype(DatatypeDecl dt, TargetWriter wr) {
CompileDatatypeConstructors(dt, wr);
}
}


protected override void TrBvExpr(Expression expr, TargetWriter wr, bool inLetExprBody){
var bv = expr.Type.AsBitVectorType;
if (bv != null && expr is LiteralExpr){
if (bv.NativeType != null){
wr.Write($"new {GetNativeTypeName(bv.NativeType)}({((LiteralExpr)expr).Value})");
}
else{
wr.Write($"BigInteger.valueOf({((LiteralExpr)expr).Value})");
}
}
else{
TrParenExpr(expr, wr, inLetExprBody);
}
}

void CompileDatatypeBase(DatatypeDecl dt, TargetWriter wr) {
string DtT = dt.CompileName;
string DtT_protected = IdProtect(DtT);
@@ -1206,7 +1245,7 @@ string DtCreateName(DatatypeCtor ctor) {
protected override void EmitPrintStmt(TargetWriter wr, Expression arg) {
wr.Write("System.out.print(");
TrExpr(arg, wr, false);
if (arg is StringLiteralExpr || TypeName(arg.Type, wr, null) == DafnySeqClass + "<Character>"){
if (arg.Type.AsCollectionType != null && arg.Type.AsCollectionType.AsSeqType.Arg is CharType){
wr.Write(".verbatimString()");
}
wr.WriteLine(");");
@@ -1450,6 +1489,28 @@ protected override void EmitAssignment(out TargetWriter wLhs, Type /*?*/ lhsType
w.Write(")");
EndStmt(wr);
}

protected override TargetWriter EmitCoercionIfNecessary(Type/*?*/ from, Type/*?*/ to, Bpl.IToken tok, TargetWriter wr) {
if (to == null) {
return wr;
}

from = from?.NormalizeExpand();
to = to.NormalizeExpand();
if (from is BitvectorType && to is BitvectorType && ((BitvectorType)from).NativeType != null){
string p;
string s;
bool b;
GetNativeInfo(((BitvectorType)from).NativeType.Sel, out p, out s, out b);
wr.Write($"new {p}(");
var w = wr.Fork();
wr.Write(")");
return w;
}

return wr;
}


protected override void EmitDatatypeValue(DatatypeValue dtv, string arguments, TargetWriter wr) {
var dt = dtv.Ctor.EnclosingDatatype;
@@ -1488,7 +1549,8 @@ protected override void EmitUnaryExpr(ResolvedUnaryOp op, Expression expr, bool
TrParenExpr("!", expr, wr, inLetExprBody);
break;
case ResolvedUnaryOp.BitwiseNot:
TrParenExpr("~", expr, wr, inLetExprBody);
TrParenExpr("", expr, wr, inLetExprBody);
wr.Write(".not()");
break;
case ResolvedUnaryOp.Cardinality:
if (expr.Type.AsCollectionType is MultiSetType){
@@ -1614,20 +1676,28 @@ protected override void CompileBinOp(BinaryExpr.ResolvedOpcode op, Expression e0
convertE1_to_int = true;
break;
case BinaryExpr.ResolvedOpcode.Add:
callString = "add";
truncateResult = true;
if (resultType.IsCharType){
preOpString = "(char) (";
postOpString = ".intValue())";
postOpString = ")";
opString = "+";
}
else{
callString = "add";
}

break;
case BinaryExpr.ResolvedOpcode.Sub:
callString = "subtract";
truncateResult = true;
if (resultType.IsCharType){
preOpString = "(char) (";
postOpString = ".intValue())";
opString = "-";
postOpString = ")";
}if (resultType is UserDefinedType){
opString = "-";
}
else{
callString = "subtract";
}

break;
@@ -1894,10 +1964,10 @@ public override string TypeInitializationValue(Type type, TextWriter wr, Bpl.ITo
} else if (xType is IntType || xType is BigOrdinalType) {
return "new BigInteger(\"0\")";
} else if (xType is RealType) {
return "BigDecimal.ZERO";
return "BigRational.ZERO";
} else if (xType is BitvectorType) {
var t = (BitvectorType)xType;
return t.NativeType != null ? "0" : "new BigInteger(\"0\")";
return t.NativeType != null ? $"new {GetNativeTypeName(t.NativeType)}(0)" : "BigInteger.ZERO";
} else if (xType is CollectionType) {
return "new " + TypeName(xType, wr, tok) + "()";
}
@@ -1914,7 +1984,10 @@ public override string TypeInitializationValue(Type type, TextWriter wr, Bpl.ITo
if (td.Witness != null) {
return TypeName_UDT(FullTypeName(udt), udt.TypeArgs, wr, udt.tok) + ".Witness";
} else if (td.NativeType != null) {
return "0";
string s = RepresentableByInt(td.NativeType)
? ""
: "L";
return $"0{s}";
} else {
return TypeInitializationValue(td.BaseType, wr, tok, inAutoInitContext);
}
@@ -2374,10 +2447,8 @@ protected override TargetWriter EmitAddTupleToList(string ingredients, string tu
}

protected override void EmitExprAsInt(Expression expr, bool inLetExprBody, TargetWriter wr){
wr.Write("(");
wr.Write("({0})", TypeName(expr.Type.NormalizeExpand(), wr, Bpl.Token.NoToken));
TrParenExpr(expr, wr, inLetExprBody);
wr.Write(").intValue()");
wr.Write(".intValue()");
}

protected override void EmitTupleSelect(string prefix, int i, TargetWriter wr) {
15 changes: 13 additions & 2 deletions Source/Dafny/Compiler.cs
Original file line number Diff line number Diff line change
@@ -3445,6 +3445,12 @@ protected void TrParenExpr(Expression expr, TargetWriter wr, bool inLetExprBody)
TrExpr(expr, wr, inLetExprBody);
wr.Write(")");
}

protected virtual void TrBvExpr(Expression expr, TargetWriter wr, bool inLetExprBody){
Contract.Requires(expr != null);
Contract.Requires(wr != null);
TrParenExpr(expr, wr, inLetExprBody);
}

/// <summary>
/// Before calling TrExprList(exprs), the caller must have spilled the let variables declared in expressions in "exprs".
@@ -3697,9 +3703,14 @@ protected void TrExpr(Expression expr, TargetWriter wr, bool inLetExprBody){
}
else if (callString != null){
wr.Write(preOpString);
TrParenExpr(e0, wr, inLetExprBody);
TrBvExpr(e0, wr, inLetExprBody);
wr.Write(".{0}(", callString);
TrExpr(e1, wr, inLetExprBody);
if (convertE1_to_int){
EmitExprAsInt(e1, inLetExprBody, wr);
}
else{
TrBvExpr(e1, wr, inLetExprBody);
}
wr.Write(")");
wr.Write(postOpString);
}
2 changes: 1 addition & 1 deletion Source/Dafny/Resolver.cs
Original file line number Diff line number Diff line change
@@ -2160,7 +2160,7 @@ public void ResolveTopLevelDecls_Signatures(ModuleDefinition def, ModuleSignatur
new NativeType("uint", 0, 0x1_0000_0000, 32, NativeType.Selection.UInt, DafnyOptions.CompilationTarget.Csharp | DafnyOptions.CompilationTarget.Go | DafnyOptions.CompilationTarget.Java),
new NativeType("int", -0x8000_0000, 0x8000_0000, 0, NativeType.Selection.Int, DafnyOptions.CompilationTarget.Csharp | DafnyOptions.CompilationTarget.Go | DafnyOptions.CompilationTarget.Java),
new NativeType("number", -0x20_0000_0000_0000, 0x20_0000_0000_0001, 0, NativeType.Selection.Number,
DafnyOptions.CompilationTarget.Csharp | DafnyOptions.CompilationTarget.JavaScript | DafnyOptions.CompilationTarget.Go), // JavaScript integers
DafnyOptions.CompilationTarget.Csharp | DafnyOptions.CompilationTarget.JavaScript | DafnyOptions.CompilationTarget.Go | DafnyOptions.CompilationTarget.Java), // JavaScript integers
new NativeType("ulong", 0, new BigInteger(0x1_0000_0000) * new BigInteger(0x1_0000_0000), 64, NativeType.Selection.ULong, DafnyOptions.CompilationTarget.Csharp | DafnyOptions.CompilationTarget.Go | DafnyOptions.CompilationTarget.Java),
new NativeType("long", Int64.MinValue, 0x8000_0000_0000_0000, 0, NativeType.Selection.Long, DafnyOptions.CompilationTarget.Csharp | DafnyOptions.CompilationTarget.Go | DafnyOptions.CompilationTarget.Java),
};
Loading