From 7ec64c38eae734613449b642f17e552a7cd832c8 Mon Sep 17 00:00:00 2001 From: dxo Date: Wed, 27 Sep 2023 16:14:11 +0200 Subject: [PATCH] Solidity: rm duplicated code & stop inserting license & version headers - removes duplicated code for compiling contracts with solc - stops silently inserting license and version headers into the input source (fixes: https://github.com/ethereum/act/pull/161) --- src/EVM/Solidity.hs | 104 +++++++------------------------------------- test/test.hs | 6 +-- 2 files changed, 16 insertions(+), 94 deletions(-) diff --git a/src/EVM/Solidity.hs b/src/EVM/Solidity.hs index 77ab8ecdd..eb85b2158 100644 --- a/src/EVM/Solidity.hs +++ b/src/EVM/Solidity.hs @@ -1,13 +1,10 @@ {-# LANGUAGE DataKinds #-} {-# LANGUAGE DeriveAnyClass #-} {-# LANGUAGE DerivingStrategies #-} -{-# LANGUAGE QuasiQuotes #-} module EVM.Solidity ( solidity , solcRuntime - , solidity' - , yul' , yul , yulRuntime , JumpType (..) @@ -72,11 +69,10 @@ import Data.List.NonEmpty qualified as NonEmpty import Data.Maybe import Data.Semigroup import Data.Sequence (Seq) -import Data.String.Here qualified as Here import Data.Text (pack, intercalate) import Data.Text qualified as T import Data.Text.Encoding (encodeUtf8, decodeUtf8) -import Data.Text.IO (readFile, writeFile) +import Data.Text.IO (readFile) import Data.Vector (Vector) import Data.Vector qualified as Vector import Data.Word (Word8) @@ -84,8 +80,6 @@ import Options.Generic import Prelude hiding (readFile, writeFile) import System.FilePattern.Directory import System.FilePath.Posix -import System.IO hiding (readFile, writeFile) -import System.IO.Temp import System.Process import Text.Read (readMaybe) import Witch (unsafeInto) @@ -358,40 +352,40 @@ readSolc pt root fp = yul :: Text -> Text -> IO (Maybe ByteString) yul contractName src = do - (json, path) <- yul' src - let f = (json ^?! key "contracts") ^?! key (Key.fromText path) + json <- solc Yul src + let f = (json ^?! key "contracts") ^?! key (Key.fromText "hevm.sol") c = f ^?! key (Key.fromText $ if T.null contractName then "object" else contractName) bytecode = c ^?! key "evm" ^?! key "bytecode" ^?! key "object" % _String pure $ (toCode contractName) <$> (Just bytecode) yulRuntime :: Text -> Text -> IO (Maybe ByteString) yulRuntime contractName src = do - (json, path) <- yul' src - let f = (json ^?! key "contracts") ^?! key (Key.fromText path) + json <- solc Yul src + let f = (json ^?! key "contracts") ^?! key (Key.fromText "hevm.sol") c = f ^?! key (Key.fromText $ if T.null contractName then "object" else contractName) bytecode = c ^?! key "evm" ^?! key "deployedBytecode" ^?! key "object" % _String pure $ (toCode contractName) <$> (Just bytecode) solidity :: Text -> Text -> IO (Maybe ByteString) solidity contract src = do - (json, path) <- solidity' src + json <- solc Solidity src let (Contracts sol, _, _) = fromJust $ readStdJSON json - pure $ Map.lookup (path <> ":" <> contract) sol <&> (.creationCode) + pure $ Map.lookup ("hevm.sol:" <> contract) sol <&> (.creationCode) solcRuntime :: Text -> Text -> IO (Maybe ByteString) solcRuntime contract src = do - (json, path) <- solidity' src + json <- solc Solidity src case readStdJSON json of - Just (Contracts sol, _, _) -> pure $ Map.lookup (path <> ":" <> contract) sol <&> (.runtimeCode) + Just (Contracts sol, _, _) -> pure $ Map.lookup ("hevm.sol:" <> contract) sol <&> (.runtimeCode) Nothing -> internalError $ "unable to parse solidity output:\n" <> (T.unpack json) functionAbi :: Text -> IO Method functionAbi f = do - (json, path) <- solidity' ("contract ABI { function " <> f <> " public {}}") + json <- solc Solidity ("contract ABI { function " <> f <> " public {}}") let (Contracts sol, _, _) = fromMaybe (internalError . T.unpack $ "unable to parse solc output:\n" <> json) (readStdJSON json) - case Map.toList $ (fromJust (Map.lookup (path <> ":ABI") sol)).abiMap of + case Map.toList $ (fromJust (Map.lookup "hevm.sol:ABI" sol)).abiMap of [(_,b)] -> pure b _ -> internalError "unexpected abi format" @@ -661,80 +655,12 @@ toCode contractName t = case BS16.decodeBase16 (encodeUtf8 t) of then error $ T.unpack ("Error toCode: unlinked libraries detected in bytecode, in " <> contractName) else error $ T.unpack ("Error toCode:" <> e <> ", in " <> contractName) -solidity' :: Text -> IO (Text, Text) -solidity' src = withSystemTempFile "hevm.sol" $ \path handle -> do - hClose handle - writeFile path ("//SPDX-License-Identifier: UNLICENSED\n" <> "pragma solidity ^0.8.6;\n" <> src) - writeFile (path <> ".json") - [Here.i| - { - "language": "Solidity", - "sources": { - ${path}: { - "urls": [ - ${path} - ] - } - }, - "settings": { - "outputSelection": { - "*": { - "*": [ - "metadata", - "evm.bytecode", - "evm.deployedBytecode", - "abi", - "storageLayout", - "evm.bytecode.sourceMap", - "evm.bytecode.linkReferences", - "evm.bytecode.generatedSources", - "evm.deployedBytecode.sourceMap", - "evm.deployedBytecode.linkReferences", - "evm.deployedBytecode.generatedSources" - ], - "": [ - "ast" - ] - } - } - } - } - |] - x <- pack <$> - readProcess - "solc" - ["--allow-paths", path, "--standard-json", (path <> ".json")] - "" - pure (x, pack path) - -yul' :: Text -> IO (Text, Text) -yul' src = withSystemTempFile "hevm.yul" $ \path handle -> do - hClose handle - writeFile path src - writeFile (path <> ".json") - [Here.i| - { - "language": "Yul", - "sources": { ${path}: { "urls": [ ${path} ] } }, - "settings": { "outputSelection": { "*": { "*": ["*"], "": [ "*" ] } } } - } - |] - x <- pack <$> - readProcess - "solc" - ["--allow-paths", path, "--standard-json", (path <> ".json")] - "" - pure (x, pack path) - solc :: Language -> Text -> IO Text solc lang src = - withSystemTempFile "hevm.sol" $ \path handle -> do - hClose handle - writeFile path (stdjson lang src) - T.pack <$> readProcess - "solc" - ["--standard-json", path] - "" + T.pack <$> readProcess + "solc" + ["--standard-json"] + (T.unpack $ stdjson lang src) data Language = Solidity | Yul deriving (Show) diff --git a/test/test.hs b/test/test.hs index e6c2cd279..b74a2a24b 100644 --- a/test/test.hs +++ b/test/test.hs @@ -45,7 +45,6 @@ import Witch (unsafeInto, into) import Optics.Core hiding (pre, re, elements) import Optics.State -import Optics.Operators.Unsafe import EVM hiding (choose) import EVM.ABI @@ -683,10 +682,7 @@ tests = testGroup "hevm" } |] - (json, path') <- solidity' srccode - let (Contracts solc', _, _) = fromJust $ readStdJSON json - initCode = (solc' ^?! ix (path' <> ":A")).creationCode - -- add constructor arguments + Just initCode <- solidity "A" srccode assertEqual "constructor args screwed up metadata stripping" (stripBytecodeMetadata (initCode <> encodeAbiValue (AbiUInt 256 1))) (stripBytecodeMetadata initCode) ]