From 70507424b8c90d611dc9329369c191e4eaf5f0c3 Mon Sep 17 00:00:00 2001 From: Ana Pantilie Date: Mon, 18 Nov 2024 16:30:27 +0200 Subject: [PATCH 1/3] Add pairing session --- nix/agda.nix | 2 +- plutus-executables/executables/uplc/Main.hs | 44 +++++++++++++++++---- plutus-executables/plutus-executables.cabal | 6 ++- 3 files changed, 41 insertions(+), 11 deletions(-) diff --git a/nix/agda.nix b/nix/agda.nix index 9c13969464f..a8599cf41a1 100644 --- a/nix/agda.nix +++ b/nix/agda.nix @@ -124,7 +124,7 @@ rec { agda-project = pkgs.haskell-nix.hackage-project { name = "Agda"; - version = "2.7.0"; + version = "2.7.0.1"; compiler-nix-name = "ghc96"; cabalProjectLocal = "extra-packages: ieee754, filemanip"; modules = [ agda-project-module-patch-default ]; diff --git a/plutus-executables/executables/uplc/Main.hs b/plutus-executables/executables/uplc/Main.hs index fbb24673d01..21e8d7a36c8 100644 --- a/plutus-executables/executables/uplc/Main.hs +++ b/plutus-executables/executables/uplc/Main.hs @@ -1,5 +1,6 @@ -- editorconfig-checker-disable +{-# LANGUAGE TemplateHaskell #-} {-# OPTIONS_GHC -Wno-orphans #-} module Main (main) where @@ -19,6 +20,7 @@ import PlutusPrelude import Untyped qualified as AgdaFFI +import Data.FileEmbed qualified as FileEmbed import UntypedPlutusCore.Evaluation.Machine.SteppableCek.DebugDriver qualified as D import UntypedPlutusCore.Evaluation.Machine.SteppableCek.Internal qualified as D @@ -36,6 +38,8 @@ import Criterion.Types (Config (..)) import Data.ByteString.Lazy as BSL (readFile) import Data.Foldable import Data.List.Split (splitOn) +import Data.Maybe (fromJust) +import Data.Strict.Maybe qualified as Maybe.Strict import Data.Text qualified as T import Flat (unflat) import Options.Applicative @@ -45,6 +49,14 @@ import System.FilePath (()) import System.IO (hPrint, stderr) import Text.Read (readMaybe) +-- import Data.ByteString qualified as BS +-- import Data.ByteString.Lazy qualified as BSL +-- import Data.ByteString.Char8 qualified as BSL8 + +import Data.ByteString qualified as BS +import Data.ByteString.Char8 qualified as BS8 +import Data.ByteString.Lazy qualified as BSL + import Control.Monad.ST (RealWorld) import System.Console.Haskeline qualified as Repl @@ -52,7 +64,10 @@ import Agda.Interaction.Base (ComputeMode (DefaultCompute)) import Agda.Interaction.FindFile qualified as HAgda.File import Agda.Interaction.Imports qualified as HAgda.Imp import Agda.Interaction.Options (CommandLineOptions (optIncludePaths), defaultOptions) +import Agda.Interaction.Options qualified as HAgda.Options import Agda.Syntax.Parser qualified as HAgda.Parser +import Agda.TypeChecking.Serialise qualified as HAgda.Serialise +import Agda.Utils.Trie qualified as HAgda.Trie import Agda.Compiler.Backend (crInterface, iInsideScope, setCommandLineOptions, setScope) import Agda.Interaction.BasicOps (evalInCurrent) @@ -61,6 +76,7 @@ import Agda.Syntax.Translation.ConcreteToAbstract (ToAbstract (toAbstract)) import Agda.TypeChecking.Pretty (PrettyTCM (..)) import Agda.Utils.FileName qualified as HAgda.File import AgdaUnparse (agdaUnparse) +import Debug.Trace (traceShowM) import System.Environment (getEnv) uplcHelpText :: String @@ -318,19 +334,31 @@ runAgda certName rawTrace = do Left err -> error $ show err stdlibPath <- getEnv "AGDA_STDLIB_SRC" metatheoryPath <- getEnv "PLUTUS_METHATHEORY_SRC" - inputFile <- HAgda.File.absolute (metatheoryPath "Certifier.agda") + -- inputFile <- HAgda.File.absolute ("/home/ana/Workspace/IOG/plutus/Certifier.agdai") + -- ifaceFile <- HAgda.Imp.mkInterfaceFile "/home/ana/Workspace/IOG/plutus/Certifier.agdai" + -- let ifaceFile = HAgda.File.InterfaceFile "/home/ana/Workspace/IOG/plutus/Certifier.agdai" + -- let embeddedInterfaceFile :: BS.ByteString + let embeddedInterfaceFile = BS8.fromStrict $(FileEmbed.embedFile "/home/ana/Workspace/IOG/plutus/Certifier.agdai") runTCMPrettyErrors $ do let opts = defaultOptions - { optIncludePaths = - [ metatheoryPath - , stdlibPath - ] + { HAgda.Options.optTraceImports = 42 + , HAgda.Options.optPragmaOptions = HAgda.Options.defaultPragmaOptions + { HAgda.Options._optVerbose = Maybe.Strict.Just (HAgda.Trie.singleton ["import.iface"] 7) + } } + -- { optIncludePaths = + -- -- [ metatheoryPath + -- -- , stdlibPath + -- -- ] + -- -- } setCommandLineOptions opts - result <- HAgda.Imp.typeCheckMain HAgda.Imp.TypeCheck =<< HAgda.Imp.parseSource (HAgda.File.SourceFile inputFile) - let interface = crInterface result - insideScope = iInsideScope interface + -- result <- HAgda.Imp.typeCheckMain HAgda.Imp.TypeCheck =<< HAgda.Imp.parseSource (HAgda.File.SourceFile inputFile) + -- let interface = crInterface result + -- interface <- HAgda.Imp.readInterface ifaceFile + interface <- HAgda.Serialise.decodeInterface embeddedInterfaceFile + -- traceShowM interface + let insideScope = iInsideScope (fromJust interface) setScope insideScope internalisedTrace <- toAbstract parsedTrace decisionProcedureResult <- evalInCurrent DefaultCompute internalisedTrace diff --git a/plutus-executables/plutus-executables.cabal b/plutus-executables/plutus-executables.cabal index 9f606005956..03cf873a01c 100644 --- a/plutus-executables/plutus-executables.cabal +++ b/plutus-executables/plutus-executables.cabal @@ -103,11 +103,12 @@ executable uplc main-is: uplc/Main.hs hs-source-dirs: executables build-depends: - , Agda ==2.7.0 - , base >=4.9 && <5 + , Agda ==2.7.0.1 + , base >=4.9 && <5 , bytestring , criterion , deepseq + , file-embed , filepath , flat ^>=0.6 , haskeline @@ -119,6 +120,7 @@ executable uplc , plutus-metatheory , prettyprinter , split + , strict , text -- build-tool-depends: Agda:agda From d20499b80cb11278e4b5311ce2c03e4ae7bb99d0 Mon Sep 17 00:00:00 2001 From: Ana Pantilie Date: Tue, 19 Nov 2024 18:52:27 +0200 Subject: [PATCH 2/3] temp --- plutus-executables/executables/uplc/Main.hs | 133 +++++++++++++++++--- plutus-executables/plutus-executables.cabal | 6 +- plutus-metatheory/src/Main.lagda.md | 1 + 3 files changed, 118 insertions(+), 22 deletions(-) diff --git a/plutus-executables/executables/uplc/Main.hs b/plutus-executables/executables/uplc/Main.hs index 21e8d7a36c8..162eb9f8085 100644 --- a/plutus-executables/executables/uplc/Main.hs +++ b/plutus-executables/executables/uplc/Main.hs @@ -5,6 +5,7 @@ module Main (main) where +import Control.Exception qualified as E import PlutusCore qualified as PLC import PlutusCore.Annotation (SrcSpan) import PlutusCore.Data (Data) @@ -21,6 +22,7 @@ import PlutusPrelude import Untyped qualified as AgdaFFI import Data.FileEmbed qualified as FileEmbed +import Debug.Trace (traceM) import UntypedPlutusCore.Evaluation.Machine.SteppableCek.DebugDriver qualified as D import UntypedPlutusCore.Evaluation.Machine.SteppableCek.Internal qualified as D @@ -30,11 +32,12 @@ import UntypedPlutusCore.Evaluation.Machine.Cek qualified as Cek import UntypedPlutusCore.Transform.Simplifier import Control.DeepSeq (force) -import Control.Monad.Except (runExcept) +import Control.Monad.Except (catchError, runExcept, throwError) import Control.Monad.IO.Class (liftIO) import Criterion (benchmarkWith, whnf) import Criterion.Main (defaultConfig) import Criterion.Types (Config (..)) +import Data.ByteString.Lazy (ByteString) import Data.ByteString.Lazy as BSL (readFile) import Data.Foldable import Data.List.Split (splitOn) @@ -69,16 +72,31 @@ import Agda.Syntax.Parser qualified as HAgda.Parser import Agda.TypeChecking.Serialise qualified as HAgda.Serialise import Agda.Utils.Trie qualified as HAgda.Trie -import Agda.Compiler.Backend (crInterface, iInsideScope, setCommandLineOptions, setScope) +import Agda.Benchmarking (Phase (Deserialization), billToPure) +import Agda.Compiler.Backend (Interface, TCErr (..), TCM, crInterface, iInsideScope, iScope, + setCommandLineOptions, setScope) import Agda.Interaction.BasicOps (evalInCurrent) import Agda.Main (runTCMPrettyErrors) +import Agda.Syntax.Scope.Base (publicModules) import Agda.Syntax.Translation.ConcreteToAbstract (ToAbstract (toAbstract)) import Agda.TypeChecking.Pretty (PrettyTCM (..)) +import Agda.TypeChecking.Serialise.Base +import Agda.TypeChecking.Serialise.Base (runGetState) +import Agda.TypeChecking.Serialise.Instances () import Agda.Utils.FileName qualified as HAgda.File +import Agda.Utils.IO.Binary (readBinaryFile') +import Agda.Utils.Null qualified as Agda.Null import AgdaUnparse (agdaUnparse) +import Codec.Compression.Zlib.Internal qualified as Z +import Data.Binary qualified as B +import Data.Binary.Get qualified as B +import Data.Binary.Put qualified as B +import Data.ByteString.Builder (byteString, toLazyByteString) +import Data.Word import Debug.Trace (traceShowM) import System.Environment (getEnv) + uplcHelpText :: String uplcHelpText = helpText "Untyped Plutus Core" @@ -152,7 +170,7 @@ benchmarkOpts = ( long "time-limit" <> short 'T' <> metavar "TIME LIMIT" - <> value 5.0 + <> Options.Applicative.value 5.0 <> showDefault <> help "Time limit (in seconds) for benchmarking.") @@ -334,37 +352,112 @@ runAgda certName rawTrace = do Left err -> error $ show err stdlibPath <- getEnv "AGDA_STDLIB_SRC" metatheoryPath <- getEnv "PLUTUS_METHATHEORY_SRC" - -- inputFile <- HAgda.File.absolute ("/home/ana/Workspace/IOG/plutus/Certifier.agdai") - -- ifaceFile <- HAgda.Imp.mkInterfaceFile "/home/ana/Workspace/IOG/plutus/Certifier.agdai" - -- let ifaceFile = HAgda.File.InterfaceFile "/home/ana/Workspace/IOG/plutus/Certifier.agdai" + inputFile <- HAgda.File.absolute ("/home/ana/Workspace/IOG/plutus/plutus-metatheory/_build/2.7.0.1/agda/src/Certifier.agdai") + Just ifaceFile <- HAgda.File.mkInterfaceFile inputFile + -- let ifaceFile = HAgda.File.InterfaceFile "/home/ana/Workspace/IOG/plutus/plutus-metatheory/_build/2.7.0.1/agda/src/Certifier.agdai" -- let embeddedInterfaceFile :: BS.ByteString - let embeddedInterfaceFile = BS8.fromStrict $(FileEmbed.embedFile "/home/ana/Workspace/IOG/plutus/Certifier.agdai") + let embeddedInterfaceFile = BS8.fromStrict $(FileEmbed.embedFile "/home/ana/Workspace/IOG/plutus/plutus-metatheory/_build/2.7.0.1/agda/src/Certifier.agdai") runTCMPrettyErrors $ do let opts = + -- defaultOptions + -- { HAgda.Options.optTraceImports = 42 + -- , HAgda.Options.optPragmaOptions = HAgda.Options.defaultPragmaOptions + -- { HAgda.Options._optVerbose = Maybe.Strict.Just (HAgda.Trie.singleton [] 0) + -- } + -- } defaultOptions - { HAgda.Options.optTraceImports = 42 - , HAgda.Options.optPragmaOptions = HAgda.Options.defaultPragmaOptions - { HAgda.Options._optVerbose = Maybe.Strict.Just (HAgda.Trie.singleton ["import.iface"] 7) - } + { optIncludePaths = + [ metatheoryPath + , stdlibPath + ] } - -- { optIncludePaths = - -- -- [ metatheoryPath - -- -- , stdlibPath - -- -- ] - -- -- } + -- traceShowM opts setCommandLineOptions opts - -- result <- HAgda.Imp.typeCheckMain HAgda.Imp.TypeCheck =<< HAgda.Imp.parseSource (HAgda.File.SourceFile inputFile) + -- aaaa <- HAgda.Imp.parseSource (HAgda.File.SourceFile inputFile) + -- traceM "asasdads" + -- result <- HAgda.Imp.typeCheckMain HAgda.Imp.TypeCheck aaaa -- let interface = crInterface result - -- interface <- HAgda.Imp.readInterface ifaceFile - interface <- HAgda.Serialise.decodeInterface embeddedInterfaceFile + Just interface <- readInterface ifaceFile + -- interface <- HAgda.Serialise.decodeInterface embeddedInterfaceFile -- traceShowM interface - let insideScope = iInsideScope (fromJust interface) + let insideScope = iInsideScope interface + -- let insideScope = iInsideScope (fromJust interface) setScope insideScope internalisedTrace <- toAbstract parsedTrace decisionProcedureResult <- evalInCurrent DefaultCompute internalisedTrace final <- prettyTCM decisionProcedureResult liftIO $ writeFile (certName ++ ".agda") (show final) +readInterface :: HAgda.File.InterfaceFile -> TCM (Maybe Agda.Compiler.Backend.Interface) +readInterface file = do + let ifp = HAgda.File.filePath $ HAgda.File.intFilePath file + -- Decode the interface file + (s, close) <- liftIO $ readBinaryFile' ifp + do mi <- liftIO . E.evaluate =<< decodeInterface s + + -- Close the file. Note + -- ⑴ that evaluate ensures that i is evaluated to WHNF (before + -- the next IO operation is executed), and + -- ⑵ that decode returns Nothing if an error is encountered, + -- so it is safe to close the file here. + liftIO close + + res <- return $ constructIScope <$> mi + return res + -- Catch exceptions and close + `catchError` \e -> liftIO close >> handler e + -- Catch exceptions + `catchError` handler + where + handler = \case + IOException _ _ e -> do + -- alwaysReportSLn "" 0 $ "IO exception: " ++ show e + return Nothing -- Work-around for file locking bug. + -- TODO: What does this refer to? Please + -- document. + e -> throwError e + +constructIScope :: Interface -> Interface +constructIScope i = billToPure [ Deserialization ] $ + i{ iScope = publicModules $ iInsideScope i } + +currentInterfaceVersion :: B.Word64 +currentInterfaceVersion = 20240629 * 10 + 0 + +decodeInterface :: ByteString -> TCM (Maybe Interface) +decodeInterface s = do + + -- Note that runGetState and the decompression code below can raise + -- errors if the input is malformed. The decoder is (intended to be) + -- strict enough to ensure that all such errors can be caught by the + -- handler here or the one in decode. + + s <- liftIO $ + E.handle (\(E.ErrorCall s) -> return (Left s)) $ + E.evaluate $ + let (ver, s', _) = runGetState B.get (BSL.drop 16 s) 0 in + if ver /= currentInterfaceVersion + then Left "Wrong interface version." + else Right $ + toLazyByteString $ + Z.foldDecompressStreamWithInput + (\s -> (byteString s <>)) + (\s -> if Agda.Null.null s + then mempty + else error "Garbage at end.") + (\err -> error (show err)) + (Z.decompressST Z.gzipFormat Z.defaultDecompressParams) + s' + + case s of + Right s -> do + traceM "hello" + HAgda.Serialise.decode s + Left err -> do + -- reportSLn "import.iface" 5 $ + -- "Error when decoding interface file: " ++ err + return Nothing + ---------------- Script application ---------------- -- | Apply one script to a list of others and output the result. All of the diff --git a/plutus-executables/plutus-executables.cabal b/plutus-executables/plutus-executables.cabal index 03cf873a01c..9ca95c67a9f 100644 --- a/plutus-executables/plutus-executables.cabal +++ b/plutus-executables/plutus-executables.cabal @@ -104,8 +104,9 @@ executable uplc hs-source-dirs: executables build-depends: , Agda ==2.7.0.1 - , base >=4.9 && <5 - , bytestring + , base >=4.9 && <5 + , binary >=0.8.6.0 && <0.9 + , bytestring >=0.10.8.2 && <0.13 , criterion , deepseq , file-embed @@ -122,6 +123,7 @@ executable uplc , split , strict , text + , zlib >=0.6 && <0.8 -- build-tool-depends: Agda:agda diff --git a/plutus-metatheory/src/Main.lagda.md b/plutus-metatheory/src/Main.lagda.md index c091fe80ed1..1ebe41d768c 100644 --- a/plutus-metatheory/src/Main.lagda.md +++ b/plutus-metatheory/src/Main.lagda.md @@ -6,6 +6,7 @@ layout: page module Main where import VerifiedCompilation +import Certifier open import Agda.Builtin.IO using (IO) import IO.Primitive.Core as IO using (return;_>>=_) open import Agda.Builtin.Unit using (⊤;tt) From a3c067fa674175191860f3c1295288e0c156d214 Mon Sep 17 00:00:00 2001 From: Ana Pantilie Date: Wed, 20 Nov 2024 19:25:42 +0200 Subject: [PATCH 3/3] Temp --- plutus-executables/executables/uplc/Main.hs | 14 ++++++++------ 1 file changed, 8 insertions(+), 6 deletions(-) diff --git a/plutus-executables/executables/uplc/Main.hs b/plutus-executables/executables/uplc/Main.hs index 162eb9f8085..bb0376958b3 100644 --- a/plutus-executables/executables/uplc/Main.hs +++ b/plutus-executables/executables/uplc/Main.hs @@ -352,11 +352,13 @@ runAgda certName rawTrace = do Left err -> error $ show err stdlibPath <- getEnv "AGDA_STDLIB_SRC" metatheoryPath <- getEnv "PLUTUS_METHATHEORY_SRC" - inputFile <- HAgda.File.absolute ("/home/ana/Workspace/IOG/plutus/plutus-metatheory/_build/2.7.0.1/agda/src/Certifier.agdai") + -- let ifacePath = "/home/ana/Workspace/IOG/plutus/plutus-metatheory/_build/2.7.0.1/agda/src" + inputFile <- HAgda.File.absolute ("/home/ana/Workspace/IOG/plutus/agda-interfaces/src/Certifier.agdai") + interfaceDir <- HAgda.File.absolute ("/home/ana/Workspace/IOG/plutus/agda-interfaces/src") Just ifaceFile <- HAgda.File.mkInterfaceFile inputFile -- let ifaceFile = HAgda.File.InterfaceFile "/home/ana/Workspace/IOG/plutus/plutus-metatheory/_build/2.7.0.1/agda/src/Certifier.agdai" -- let embeddedInterfaceFile :: BS.ByteString - let embeddedInterfaceFile = BS8.fromStrict $(FileEmbed.embedFile "/home/ana/Workspace/IOG/plutus/plutus-metatheory/_build/2.7.0.1/agda/src/Certifier.agdai") + -- let embeddedInterfaceFile = BS8.fromStrict $(FileEmbed.embedFile "/home/ana/Workspace/IOG/plutus/plutus-metatheory/_build/2.7.0.1/agda/src/Certifier.agdai") runTCMPrettyErrors $ do let opts = -- defaultOptions @@ -366,10 +368,10 @@ runAgda certName rawTrace = do -- } -- } defaultOptions - { optIncludePaths = - [ metatheoryPath - , stdlibPath - ] + { HAgda.Options.optAbsoluteIncludePaths = [interfaceDir] + -- [ metatheoryPath "_build/2.7.0.1/agda/src" + -- , stdlibPath "../_build/2.7.0.1/agda/src" + -- ] } -- traceShowM opts setCommandLineOptions opts