Iavor S. Diatchki
424d02eb27
Fix copy-paste error in normalization of LenFromThenTo
2017-02-08 16:30:04 -08:00
Iavor S. Diatchki
568a26b9aa
Restore functionality of Panic
2017-02-08 16:29:45 -08:00
Iavor S. Diatchki
3c15d086d1
Merge branch 'master' into wip/solver
2017-02-08 16:24:46 -08:00
Iavor S. Diatchki
8c19abb452
Merge branch 'master' of github.com:GaloisInc/cryptol
2017-02-08 16:19:00 -08:00
Iavor S. Diatchki
6bef779780
Add a flag to control if batch execution stops on the first error or not.
...
This is off by default.
2017-02-08 16:18:50 -08:00
Iavor S. Diatchki
fa37734956
Add a flag to control if we show prover timing stats or not.
2017-02-08 16:08:20 -08:00
Iavor S. Diatchki
3c2c9a857a
Fix test to account for printing of operators' precedences.
2017-02-08 16:07:54 -08:00
Iavor S. Diatchki
710355176a
More rules and things; external solver disabled; we can at least load ChaCha
2017-02-08 15:08:50 -08:00
Iavor S. Diatchki
90c6adbfcd
Goals as Sets works again.
2017-02-03 17:10:50 -08:00
Iavor S. Diatchki
336ea625b0
In InferM types don't contain thunks.
2017-02-03 15:56:19 -08:00
Iavor S. Diatchki
44085b4c5d
Keep maintaining evaluated invariant
2017-02-03 14:21:24 -08:00
Iavor S. Diatchki
5ebf13212a
Remove extra layer of simplification.
...
We should not be inferring unevaluated types.
XXX: The whole ECast story is probably broken now, as we evaluate substitutions
directly, but we don't do the corresponding rewrites on terms.
XXX: Do we need ECast at all?
2017-02-03 13:52:33 -08:00
Iavor S. Diatchki
5c3a258d7f
Rewrites for some more common cases
2017-02-03 13:25:42 -08:00
Iavor S. Diatchki
984108b68d
Move simplification of types into SimpleSolver + some quick eqn rewrites.
2017-02-03 12:13:39 -08:00
Brian Huffman
140ab21f11
Add new unoptimized reference interpreter; use in REPL with ":eval <expr>"
2017-02-03 09:02:25 -08:00
Brian Huffman
44692d1f33
Fix typos in comments
2017-02-03 09:00:14 -08:00
Brian Huffman
f0e3ca2d69
Simplify shifter
function; eliminate compiler warnings.
2017-02-02 10:37:37 -08:00
Iavor S. Diatchki
18ac6507ef
Remove unused stuff, and define more reasonable comparisons on types.
2017-02-01 15:00:49 -08:00
Iavor S. Diatchki
f3db823f3e
Checkpoint: (broken, but builds)
2017-02-01 11:43:01 -08:00
Aaron Tomb
13b704f840
Remove references to sbv repository
2017-02-01 09:09:59 -08:00
Iavor S. Diatchki
b788079244
More aggressive goal simplification.
2017-01-31 14:12:53 -08:00
Iavor S. Diatchki
12bb2c30c8
Merge branch 'master' into wip/solver
2017-01-31 10:15:49 -08:00
Iavor S. Diatchki
ee1c8c796b
Switch to using the official sbv release.
2017-01-31 10:04:34 -08:00
Iavor S. Diatchki
baa19ce362
Checkpoint.
2017-01-30 18:14:10 -08:00
Iavor S. Diatchki
9bb61ec9a2
Add PTrue and Error to the syntax (not yet used)
2017-01-30 10:55:08 -08:00
Iavor S. Diatchki
c3ce33f5a6
Remove old stuff
2017-01-30 10:54:45 -08:00
Iavor S. Diatchki
10cf6f16e3
Print stats about the prover. Fixes #392
2017-01-27 16:14:37 -08:00
Iavor S. Diatchki
ecdb774abb
Show information about precedence and fixity in the operator help. Fixes #391
2017-01-27 10:59:17 -08:00
Iavor S. Diatchki
09dc9b4655
Distinguish success and failure when returning to the OS. Fixes #390
...
Currently we only distinguish between success and failure, but in the
future we could add more error codes if that would be useful.
XXX: Mostly the code is written to return an `CommandExitCode` and then
exit at the top level, but there are a few functions that exit directly
(e.g., the setup function). It would be nice to clean that up.
2017-01-27 10:37:20 -08:00
Brian Huffman
08a7982a46
Use correct default value for symbolic indexing. Fixes #388 .
...
We now use the zero value of the element type as the
default; previously we were incorrectly using the zero
value of the *index* type.
2016-12-13 17:40:57 -08:00
Robert Dockins
e48f430b30
Fix a mismatch when eta-expanding infinite streams that was
...
causing Cryptol to panic. We now expect the `TVStream` type
constructor when eta-expanding streams, which is correct.
Fixes #386
2016-11-17 18:15:58 -08:00
Robert Dockins
5b502eccd7
Fix the concrete implementation of the 'pdiv' and 'pmod' primitives
...
to correctly handle the special case where the length of the dividend
is less than the degree of the divisor polynomial. In this special case
the quotient is always zero and the remainder is equal to the dividend
(zero extended if necessary to fit the output type).
Fixes #384
2016-10-04 15:15:56 -07:00
Brian Huffman
dafd48cad0
Simplify type of primitive function 'pmult'. Fixes #366 .
...
Old: (fin a, fin b) => [a] -> [b] -> [max 1 (a + b) - 1]
New: (fin a, fin b) => [1 + a] -> [1 + b] -> [1 + a + b]
2016-09-20 15:13:40 -07:00
Brian Huffman
2300a73a76
Add regression test for issue #382 .
2016-09-20 11:25:01 -07:00
Brian Huffman
d895c97c8b
expect* functions use correct argument order for mismatch
...
The `Type` argument is always the "expected" type (not the
"inferred" type) and so it should be the first argument to
`TypeMismatch` or `unify`.
Fixes #382 .
2016-09-20 11:24:24 -07:00
Brian Huffman
6c2f0fc399
Fix typo: "defintion" -> "definition"
2016-09-20 10:22:16 -07:00
Brian Huffman
0c116c5fa7
Show missing/unexpected field names on type mismatch errors
...
Fixes #357 .
However, sometimes it shows the types in the wrong order
due to issue #382 .
2016-09-20 09:39:00 -07:00
Brian Huffman
7ccea5dd98
Rename function "endComent" to "endComment"
2016-09-19 15:20:33 -07:00
Brian Huffman
22bb49b3b5
Add regression test for issue #368 .
2016-09-19 11:57:06 -07:00
Brian Huffman
60fd82f22b
Allow *,+,-,!,^^ to be defined with infix patterns.
...
Now the declaration "x * y = rhs" can be used to define
a function named (*) without causing a parse error.
Note that "x # y = rhs" cannot be used to define (#),
as it parses as a pattern binding that defines x and y.
Fixes #368 .
2016-09-19 11:56:42 -07:00
Brian Huffman
6247faa2c8
Add '.' and ':' to the set of allowable operator symbols.
...
This fixes part of #368 .
2016-09-19 11:50:30 -07:00
robdockins
7a4cbc8e03
Merge pull request #374 from thoughtpolice/fix-terminal-use
...
Fix up terminal title usage and color output
2016-09-15 09:51:58 -07:00
Brian Huffman
6d6a6ca90c
Preserve parens when parsing list enumeration arguments.
...
List enumeration arguments are parsed as expressions and
then converted to types afterward. Previously parenthesis
productions were dropped; e.g. "[1..(2+2)*(3+3)]" was
parsed as "[1..2+2*3+3]" before resolving infix precedence.
This is now fixed.
Fixes #379 .
2016-09-14 15:13:38 -07:00
Robert Dockins
a048690e3a
Use more efficent algorithms based on barrel-shifters for implementing
...
shifts and rotates in the symbolic backend.
Fixes #376
2016-08-25 12:04:58 -07:00
Robert Dockins
14af3690c6
Update the SIV example to avoid issue #375 .
2016-08-23 14:08:15 -07:00
Robert Dockins
cd9ffed00b
Update examples to use (/\) instead of (&&) where appropriate,
...
and to squash other warnings related to the upcomming precedence change.
2016-08-22 18:14:44 -07:00
Robert Dockins
e9c8b6ccd1
Add regression test for bitshift operations
2016-08-22 15:36:16 -07:00
Robert Dockins
fd164aa1f9
Repair the implementation of the shift and rotate operations in the
...
symbolic simulator. They were previously calculating incorrect
answers for certain bit sequences.
2016-08-22 14:41:23 -07:00
Robert Dockins
3c270cb5ce
Fix a typo in the implementation of the (>>) primitive. This was causing
...
incorrect cacluations when applied to certain bit sequences.
2016-08-22 14:29:42 -07:00
Austin Seipp
1f4b9518a3
Add a --color command line option
...
This command has three options: 'auto', 'none', and 'always'. They're
fairly self explanatory. 'auto' is the default, and detects that the
terminal output is not equal to `dumb`, and that `stdout` is a
terminal handle.
The choice of option has no impact on whether the title sequence is
sent to the ANSI terminal. That is always detected automatically and
independently of this option.
Signed-off-by: Austin Seipp <aseipp@pobox.com>
2016-08-19 19:17:58 +00:00