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

WIP: Draft version constraint generation #5472

Merged
merged 51 commits into from
May 20, 2020
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
51 commits
Select commit Hold shift + click to select a range
040ef56
Draft version constraint generation
Gertjan423 Apr 7, 2020
0205507
Some code cleanup
Gertjan423 Apr 8, 2020
3476a5e
Substitution functions
Gertjan423 Apr 9, 2020
4675fdd
Template generation
Gertjan423 Apr 9, 2020
afc3766
Reformatted
Gertjan423 Apr 9, 2020
c329b37
Attempt to fix failing check
Gertjan423 Apr 9, 2020
f3e4d17
Rework generation for value definitions into 2 phase approach
Gertjan423 Apr 15, 2020
a7ef445
Various small changes
Gertjan423 Apr 16, 2020
c99827d
Rework delta to env state
Gertjan423 Apr 16, 2020
28eb1bb
Incorporate data type definitions
Gertjan423 Apr 17, 2020
80bb27a
Various constraint generation bug fixes and improvements
Gertjan423 Apr 21, 2020
220d21d
First part of constraint solving
Gertjan423 Apr 21, 2020
2bad89e
Minor bugfixes
Gertjan423 Apr 22, 2020
733f929
Added simple-smt to bazel
Gertjan423 Apr 22, 2020
5545943
Depend on z3
cocreature Apr 22, 2020
b736d85
Working pipeline
Gertjan423 Apr 23, 2020
4bc25cb
Fix overwriting value definitions, and delayed choice bindings
Gertjan423 Apr 23, 2020
310d7b0
Keep track of contract id's after fetching
Gertjan423 Apr 24, 2020
4b08356
Renaming of choice parameters
Gertjan423 Apr 24, 2020
e04944f
Cleanup
Gertjan423 Apr 24, 2020
18b0b97
Reals instead of ints
Gertjan423 Apr 27, 2020
2f3bf70
Various TODOs
Gertjan423 Apr 27, 2020
0911a90
Added function documentation
Gertjan423 Apr 27, 2020
6651d8d
Small bugfix
Gertjan423 Apr 29, 2020
a8e6c94
Conditionals and forward references
Gertjan423 Apr 29, 2020
50c56c3
Small missing arithmetic
Gertjan423 May 6, 2020
d880fa5
More small missing arithmetic
Gertjan423 May 6, 2020
aef855a
Fix daml 1.0.1 bug
Gertjan423 May 6, 2020
6c86c22
Read arguments and support fields in different templates
Gertjan423 May 7, 2020
1c21ff2
Proper verify output for testing, generate counter example, proper va…
Gertjan423 May 7, 2020
a33365c
Working testing framework, with some basic test cases
Gertjan423 May 8, 2020
64370c2
Testing: build daml instead of storing dar files
Gertjan423 May 12, 2020
f3bee74
Proper handling of update types; constraint synonyms
Gertjan423 May 11, 2020
13eb8a4
Additional equality constraints after create update
Gertjan423 May 14, 2020
16aa3e3
Make assertion print conditional
Gertjan423 May 14, 2020
642c1b9
Various improvements from PR feedback
Gertjan423 May 14, 2020
c791f31
Apply suggestions from code review
Gertjan423 May 14, 2020
ba1fad5
Small fix: Add missing import
Gertjan423 May 14, 2020
344eca8
Small fix: convert numerics
Gertjan423 May 15, 2020
1cdf6e4
Replace PRSelf with correct package reference
Gertjan423 May 15, 2020
cdbed09
Style fixes
Gertjan423 May 15, 2020
c62c276
Rework conditionals to remove When
Gertjan423 May 19, 2020
ed91ada
Cleanup test daml files
Gertjan423 May 19, 2020
b803eb9
Merge branch 'master' into daml-lf-verification
Gertjan423 May 19, 2020
a3ee542
Small style fixes
Gertjan423 May 19, 2020
91c989c
Bugfix after merge
Gertjan423 May 19, 2020
337b0ca
Attempt to fix bazel windows error
Gertjan423 May 19, 2020
49563b0
Attempt #2 to fix bazel windows error
Gertjan423 May 19, 2020
ae4a276
Attempt #3 to fix bazel windows error
Gertjan423 May 19, 2020
77ea060
Attempt #4 to fix bazel windows error
Gertjan423 May 19, 2020
2d7c840
Attempt #5 to fix bazel windows error
Gertjan423 May 19, 2020
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
Prev Previous commit
Next Next commit
Read arguments and support fields in different templates
  • Loading branch information
Gertjan423 committed May 7, 2020
commit 6c86c22fe208e741cbb9d08ceadc5370d99e7a69
20 changes: 7 additions & 13 deletions compiler/daml-lf-verify/src/DA/Daml/LF/Verify.hs
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
-- | Static verification of DAML packages.
module DA.Daml.LF.Verify ( main ) where

import Data.Text
import Options.Applicative

import DA.Daml.LF.Ast.Base
Expand All @@ -15,22 +16,15 @@ import DA.Daml.LF.Verify.Read
import DA.Daml.LF.Verify.Context
import DA.Bazel.Runfiles

-- TODO: temporarily hardcoded
-- TODO: Allow for choice and field in different templates.
templName :: TypeConName
templName = TypeConName ["Iou"]

choiceName :: ChoiceName
choiceName = ChoiceName "Iou_Merge"

fieldName :: FieldName
fieldName = FieldName "content"

main :: IO ()
main = do
Options{..} <- execParser optionsParserInfo
let choiceTmpl = TypeConName [pack optChoiceTmpl]
choiceName = ChoiceName (pack optChoiceName)
fieldTmpl = TypeConName [pack optFieldTmpl]
fieldName = FieldName (pack optFieldName)
solver <- locateRunfiles "z3_nix/bin/z3"
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Note that this only works in our Bazel setup. We need to figure out what we do if we ship things to users. Not sure if we want to ship an SMT solver so a reasonable option might be to let users pass a path to the SMT solver they want to use.

pkgs <- readPackages optInputDars
pkgs <- readPackages [optInputDar]
putStrLn "Start value gathering"
case runEnv (genPackages pkgs) (emptyEnv :: Env 'ValueGathering) of
Gertjan423 marked this conversation as resolved.
Show resolved Hide resolved
Left err-> putStrLn "Value phase finished with error: " >> print err
Gertjan423 marked this conversation as resolved.
Show resolved Hide resolved
Expand All @@ -44,7 +38,7 @@ main = do
putStrLn "Start choice solving"
let env4 = solveChoiceReferences env3
putStrLn "Start constraint solving phase"
let cset = constructConstr env4 templName choiceName fieldName
let cset = constructConstr env4 choiceTmpl choiceName fieldTmpl fieldName
putStr "Create: " >> print (_cCres cset)
putStr "Archive: " >> print (_cArcs cset)
solveConstr solver cset
30 changes: 25 additions & 5 deletions compiler/daml-lf-verify/src/DA/Daml/LF/Verify/Read.hs
Original file line number Diff line number Diff line change
Expand Up @@ -24,15 +24,35 @@ import Options.Applicative
import DA.Daml.LF.Ast

data Options = Options
{ optInputDars :: [FilePath]
{ optInputDar :: FilePath
, optChoiceTmpl :: String
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Might be easier to understand if you already use the proper LF type here.

, optChoiceName :: String
, optFieldTmpl :: String
, optFieldName :: String
}

optionsParser :: Parser Options
optionsParser = Options
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Having so many positional arguments will probably become an issue in the future because it's easy to mix them up. But let's fix that in a follow-up PR.

<$> some ( argument str
( metavar "DAR-FILES"
<> help "DAR files to analyse"
) )
<$> argument str
( metavar "DAR-FILE"
<> help "DAR file to analyse"
)
<*> argument str
( metavar "CHOICE-TEMPLATE"
<> help "Template of the choice to analyse"
)
<*> argument str
( metavar "CHOICE-NAME"
<> help "Name of the choice to analyse"
)
<*> argument str
( metavar "FIELD-TEMPLATE"
<> help "Template of the field to verify"
)
<*> argument str
( metavar "FIELD-NAME"
<> help "Name of the field to verify"
)

optionsParserInfo :: ParserInfo Options
optionsParserInfo = info (optionsParser <**> helper)
Expand Down
10 changes: 6 additions & 4 deletions compiler/daml-lf-verify/src/DA/Daml/LF/Verify/Solve.hs
Original file line number Diff line number Diff line change
Expand Up @@ -168,19 +168,21 @@ filterCondUpd tem f (Conditional b x (Just y)) =
constructConstr :: Env 'Solving
-- ^ The generator environment to convert.
-> TypeConName
-- ^ The template name to be verified.
-- ^ The template name of the choice to be verified.
-> ChoiceName
-- ^ The choice name to be verified.
-> TypeConName
-- ^ The template name of the field to be verified.
-> FieldName
-- ^ The field name to be verified.
-> ConstraintSet
constructConstr env tem ch f =
case lookupChoInHMap (_envschs env) tem ch of
constructConstr env chtem ch ftem f =
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can we come up with slightly clearer variable names, e.g. choiceName templateName (or tpl which we use in other places so it’s clear enough) and field or fieldName?

case lookupChoInHMap (_envschs env) chtem ch of
Just (self, this, arg, updSubst) ->
Gertjan423 marked this conversation as resolved.
Show resolved Hide resolved
let upds = _ussUpdate $ updSubst (EVar self) (EVar this) (EVar arg)
vars = concatMap skol2var (_envsskol env)
(cres, arcs) = foldl
(\(cs,as) upd -> let (cs',as') = filterCondUpd tem f upd in (cs ++ cs',as ++ as'))
(\(cs,as) upd -> let (cs',as') = filterCondUpd ftem f upd in (cs ++ cs',as ++ as'))
([],[]) upds
in ConstraintSet vars cres arcs
Nothing -> error "Choice not found"
Gertjan423 marked this conversation as resolved.
Show resolved Hide resolved
Expand Down