From ca7f058cdb4d53a8f0d1fb6d254fe08a6514579d Mon Sep 17 00:00:00 2001 From: r0qs Date: Tue, 17 Dec 2024 15:35:13 +0100 Subject: [PATCH 1/2] StandardCompiler: Fix inconsistency in optimizeStackAllocation default behavior --- libsolidity/interface/StandardCompiler.cpp | 9 +++++++-- solc/CommandLineParser.cpp | 2 -- 2 files changed, 7 insertions(+), 4 deletions(-) diff --git a/libsolidity/interface/StandardCompiler.cpp b/libsolidity/interface/StandardCompiler.cpp index 9357310c07e4..73091b17d741 100644 --- a/libsolidity/interface/StandardCompiler.cpp +++ b/libsolidity/interface/StandardCompiler.cpp @@ -548,12 +548,14 @@ std::variant parseOptimizerSettings(Json const& _jsonIn OptimiserSettings settings = OptimiserSettings::minimal(); + bool optimizerEnabled = false; if (_jsonInput.contains("enabled")) { if (!_jsonInput["enabled"].is_boolean()) return formatFatalError(Error::Type::JSONError, "The \"enabled\" setting must be a Boolean."); - if (_jsonInput["enabled"].get()) + optimizerEnabled = _jsonInput["enabled"].get(); + if (optimizerEnabled) settings = OptimiserSettings::standard(); } @@ -588,7 +590,10 @@ std::variant parseOptimizerSettings(Json const& _jsonIn return *error; if (auto error = checkOptimizerDetail(details, "simpleCounterForLoopUncheckedIncrement", settings.simpleCounterForLoopUncheckedIncrement)) return *error; - settings.optimizeStackAllocation = settings.runYulOptimiser; + + if (optimizerEnabled || settings.runYulOptimiser) + settings.optimizeStackAllocation = true; + if (details.contains("yulDetails")) { if (!settings.runYulOptimiser) diff --git a/solc/CommandLineParser.cpp b/solc/CommandLineParser.cpp index 5929144049a2..eec695c27d00 100644 --- a/solc/CommandLineParser.cpp +++ b/solc/CommandLineParser.cpp @@ -271,8 +271,6 @@ OptimiserSettings CommandLineOptions::optimiserSettings() const settings.runYulOptimiser = optimizer.optimizeYul; if (optimizer.optimizeYul) - // NOTE: Standard JSON disables optimizeStackAllocation by default when yul optimizer is disabled. - // --optimize --no-optimize-yul on the CLI does not have that effect. settings.optimizeStackAllocation = true; if (optimizer.expectedExecutionsPerDeployment.has_value()) From 015724891b1cc92f691dd21b6d3372bbcfb57c46 Mon Sep 17 00:00:00 2001 From: r0qs Date: Wed, 18 Dec 2024 17:41:28 +0100 Subject: [PATCH 2/2] CompilerStack: Fix incorrect assertion of Stack Allocation optimizer settings when generating metadata --- libsolidity/interface/CompilerStack.cpp | 3 +-- .../args | 1 + .../input.sol | 3 +++ .../output | 4 ++++ .../args | 1 + .../input.sol | 3 +++ .../output | 4 ++++ .../in.sol | 6 ++++++ .../input.json | 20 +++++++++++++++++++ .../output.json | 14 +++++++++++++ .../standard_metadata_optimizer_no_yul/in.sol | 6 ++++++ .../input.json | 17 ++++++++++++++++ .../output.json | 14 +++++++++++++ .../in.sol | 6 ++++++ .../input.json | 20 +++++++++++++++++++ .../output.json | 14 +++++++++++++ .../output.json | 2 +- .../output.json | 2 +- .../output | 2 +- .../output | 2 +- 20 files changed, 138 insertions(+), 6 deletions(-) create mode 100644 test/cmdlineTests/optimizer_enabled_yul_optimizer_disabled/args create mode 100644 test/cmdlineTests/optimizer_enabled_yul_optimizer_disabled/input.sol create mode 100644 test/cmdlineTests/optimizer_enabled_yul_optimizer_disabled/output create mode 100644 test/cmdlineTests/optimizer_enabled_yul_optimizer_disabled_empty_sequence/args create mode 100644 test/cmdlineTests/optimizer_enabled_yul_optimizer_disabled_empty_sequence/input.sol create mode 100644 test/cmdlineTests/optimizer_enabled_yul_optimizer_disabled_empty_sequence/output create mode 100644 test/cmdlineTests/standard_metadata_no_optimizer_no_yul_empty_sequence/in.sol create mode 100644 test/cmdlineTests/standard_metadata_no_optimizer_no_yul_empty_sequence/input.json create mode 100644 test/cmdlineTests/standard_metadata_no_optimizer_no_yul_empty_sequence/output.json create mode 100644 test/cmdlineTests/standard_metadata_optimizer_no_yul/in.sol create mode 100644 test/cmdlineTests/standard_metadata_optimizer_no_yul/input.json create mode 100644 test/cmdlineTests/standard_metadata_optimizer_no_yul/output.json create mode 100644 test/cmdlineTests/standard_metadata_optimizer_no_yul_empty_sequence/in.sol create mode 100644 test/cmdlineTests/standard_metadata_optimizer_no_yul_empty_sequence/input.json create mode 100644 test/cmdlineTests/standard_metadata_optimizer_no_yul_empty_sequence/output.json diff --git a/libsolidity/interface/CompilerStack.cpp b/libsolidity/interface/CompilerStack.cpp index 9649b79c842a..79b144e171aa 100644 --- a/libsolidity/interface/CompilerStack.cpp +++ b/libsolidity/interface/CompilerStack.cpp @@ -1736,13 +1736,12 @@ std::string CompilerStack::createMetadata(Contract const& _contract, bool _forIR } else if (OptimiserSuite::isEmptyOptimizerSequence(m_optimiserSettings.yulOptimiserSteps + ":" + m_optimiserSettings.yulOptimiserCleanupSteps)) { - solAssert(m_optimiserSettings.optimizeStackAllocation == false); details["yulDetails"] = Json::object(); + details["yulDetails"]["stackAllocation"] = m_optimiserSettings.optimizeStackAllocation; details["yulDetails"]["optimizerSteps"] = ":"; } else { - solAssert(m_optimiserSettings.optimizeStackAllocation == false); solAssert(m_optimiserSettings.yulOptimiserSteps == OptimiserSettings::DefaultYulOptimiserSteps); solAssert(m_optimiserSettings.yulOptimiserCleanupSteps == OptimiserSettings::DefaultYulOptimiserCleanupSteps); } diff --git a/test/cmdlineTests/optimizer_enabled_yul_optimizer_disabled/args b/test/cmdlineTests/optimizer_enabled_yul_optimizer_disabled/args new file mode 100644 index 000000000000..d738796768bb --- /dev/null +++ b/test/cmdlineTests/optimizer_enabled_yul_optimizer_disabled/args @@ -0,0 +1 @@ +--metadata --optimize --no-optimize-yul diff --git a/test/cmdlineTests/optimizer_enabled_yul_optimizer_disabled/input.sol b/test/cmdlineTests/optimizer_enabled_yul_optimizer_disabled/input.sol new file mode 100644 index 000000000000..37cd85bffa5d --- /dev/null +++ b/test/cmdlineTests/optimizer_enabled_yul_optimizer_disabled/input.sol @@ -0,0 +1,3 @@ +// SPDX-License-Identifier: GPL-3.0 +pragma solidity >=0.0; +contract C { } \ No newline at end of file diff --git a/test/cmdlineTests/optimizer_enabled_yul_optimizer_disabled/output b/test/cmdlineTests/optimizer_enabled_yul_optimizer_disabled/output new file mode 100644 index 000000000000..9e97fabe553c --- /dev/null +++ b/test/cmdlineTests/optimizer_enabled_yul_optimizer_disabled/output @@ -0,0 +1,4 @@ + +======= optimizer_enabled_yul_optimizer_disabled/input.sol:C ======= +Metadata: +{"compiler":{"version": ""},"language":"Solidity","output":{"abi":[],"devdoc":{"kind":"dev","methods":{},"version":1},"userdoc":{"kind":"user","methods":{},"version":1}},"settings":{"compilationTarget":{"optimizer_enabled_yul_optimizer_disabled/input.sol":"C"},"evmVersion":"cancun","libraries":{},"metadata":{"bytecodeHash":"ipfs"},"optimizer":{"details":{"constantOptimizer":true,"cse":true,"deduplicate":true,"inliner":true,"jumpdestRemover":true,"orderLiterals":true,"peephole":true,"simpleCounterForLoopUncheckedIncrement":true,"yul":false},"runs":200},"remappings":[]},"sources":{"optimizer_enabled_yul_optimizer_disabled/input.sol":{"keccak256":"0xc2db3500808896ce1e69de2fe20cecab7ae2ffbb47cdf6ba8321296d95f49fc5","license":"GPL-3.0","urls":["bzz-raw://fde21393c068cd9f2d2b10ba4782db54f6f1c9a725074b17fa742531076be8a4","dweb:/ipfs/QmeTD6mR7YrWNyRowKRS7xs6cJNeMF3T49GAHzGM1bquyM"]}},"version":1} diff --git a/test/cmdlineTests/optimizer_enabled_yul_optimizer_disabled_empty_sequence/args b/test/cmdlineTests/optimizer_enabled_yul_optimizer_disabled_empty_sequence/args new file mode 100644 index 000000000000..9d4234625124 --- /dev/null +++ b/test/cmdlineTests/optimizer_enabled_yul_optimizer_disabled_empty_sequence/args @@ -0,0 +1 @@ +--metadata --optimize --no-optimize-yul --yul-optimizations : diff --git a/test/cmdlineTests/optimizer_enabled_yul_optimizer_disabled_empty_sequence/input.sol b/test/cmdlineTests/optimizer_enabled_yul_optimizer_disabled_empty_sequence/input.sol new file mode 100644 index 000000000000..37cd85bffa5d --- /dev/null +++ b/test/cmdlineTests/optimizer_enabled_yul_optimizer_disabled_empty_sequence/input.sol @@ -0,0 +1,3 @@ +// SPDX-License-Identifier: GPL-3.0 +pragma solidity >=0.0; +contract C { } \ No newline at end of file diff --git a/test/cmdlineTests/optimizer_enabled_yul_optimizer_disabled_empty_sequence/output b/test/cmdlineTests/optimizer_enabled_yul_optimizer_disabled_empty_sequence/output new file mode 100644 index 000000000000..e90a8520f5de --- /dev/null +++ b/test/cmdlineTests/optimizer_enabled_yul_optimizer_disabled_empty_sequence/output @@ -0,0 +1,4 @@ + +======= optimizer_enabled_yul_optimizer_disabled_empty_sequence/input.sol:C ======= +Metadata: +{"compiler":{"version": ""},"language":"Solidity","output":{"abi":[],"devdoc":{"kind":"dev","methods":{},"version":1},"userdoc":{"kind":"user","methods":{},"version":1}},"settings":{"compilationTarget":{"optimizer_enabled_yul_optimizer_disabled_empty_sequence/input.sol":"C"},"evmVersion":"cancun","libraries":{},"metadata":{"bytecodeHash":"ipfs"},"optimizer":{"details":{"constantOptimizer":true,"cse":true,"deduplicate":true,"inliner":true,"jumpdestRemover":true,"orderLiterals":true,"peephole":true,"simpleCounterForLoopUncheckedIncrement":true,"yul":false,"yulDetails":{"optimizerSteps":":","stackAllocation":true}},"runs":200},"remappings":[]},"sources":{"optimizer_enabled_yul_optimizer_disabled_empty_sequence/input.sol":{"keccak256":"0xc2db3500808896ce1e69de2fe20cecab7ae2ffbb47cdf6ba8321296d95f49fc5","license":"GPL-3.0","urls":["bzz-raw://fde21393c068cd9f2d2b10ba4782db54f6f1c9a725074b17fa742531076be8a4","dweb:/ipfs/QmeTD6mR7YrWNyRowKRS7xs6cJNeMF3T49GAHzGM1bquyM"]}},"version":1} diff --git a/test/cmdlineTests/standard_metadata_no_optimizer_no_yul_empty_sequence/in.sol b/test/cmdlineTests/standard_metadata_no_optimizer_no_yul_empty_sequence/in.sol new file mode 100644 index 000000000000..9e5350072a2c --- /dev/null +++ b/test/cmdlineTests/standard_metadata_no_optimizer_no_yul_empty_sequence/in.sol @@ -0,0 +1,6 @@ +// SPDX-License-Identifier: GPL-3.0 +pragma solidity >=0.0; + +contract C { + function f() public pure {} +} diff --git a/test/cmdlineTests/standard_metadata_no_optimizer_no_yul_empty_sequence/input.json b/test/cmdlineTests/standard_metadata_no_optimizer_no_yul_empty_sequence/input.json new file mode 100644 index 000000000000..6e6d3238cdf0 --- /dev/null +++ b/test/cmdlineTests/standard_metadata_no_optimizer_no_yul_empty_sequence/input.json @@ -0,0 +1,20 @@ +{ + "language": "Solidity", + "sources": { + "A": {"urls": ["standard_metadata_no_optimizer_no_yul_empty_sequence/in.sol"]} + }, + "settings": { + "optimizer": { + "enabled": false, + "details": { + "yul": false, + "yulDetails": { + "optimizerSteps": ":" + } + } + }, + "outputSelection": { + "*": {"*": ["metadata"]} + } + } +} diff --git a/test/cmdlineTests/standard_metadata_no_optimizer_no_yul_empty_sequence/output.json b/test/cmdlineTests/standard_metadata_no_optimizer_no_yul_empty_sequence/output.json new file mode 100644 index 000000000000..31c4f9374edf --- /dev/null +++ b/test/cmdlineTests/standard_metadata_no_optimizer_no_yul_empty_sequence/output.json @@ -0,0 +1,14 @@ +{ + "contracts": { + "A": { + "C": { + "metadata": "{\"compiler\":{\"version\":\"\"},\"language\":\"Solidity\",\"output\":{\"abi\":[{\"inputs\":[],\"name\":\"f\",\"outputs\":[],\"stateMutability\":\"pure\",\"type\":\"function\"}],\"devdoc\":{\"kind\":\"dev\",\"methods\":{},\"version\":1},\"userdoc\":{\"kind\":\"user\",\"methods\":{},\"version\":1}},\"settings\":{\"compilationTarget\":{\"A\":\"C\"},\"evmVersion\":\"cancun\",\"libraries\":{},\"metadata\":{\"bytecodeHash\":\"ipfs\"},\"optimizer\":{\"details\":{\"constantOptimizer\":false,\"cse\":false,\"deduplicate\":false,\"inliner\":false,\"jumpdestRemover\":true,\"orderLiterals\":false,\"peephole\":true,\"simpleCounterForLoopUncheckedIncrement\":true,\"yul\":false,\"yulDetails\":{\"optimizerSteps\":\":\",\"stackAllocation\":false}},\"runs\":200},\"remappings\":[]},\"sources\":{\"A\":{\"keccak256\":\"0xadb715fb333a8148b6c34d75ffa489e541cf67b9539db523c0948564d2a8cbf1\",\"license\":\"GPL-3.0\",\"urls\":[\"bzz-raw://226f3b9be90a1b9329f7d01771fdf38e941b8e64a977945ad40300e921d99051\",\"dweb:/ipfs/QmdB5oEAJrLUJFVPEv5nGQzKRU1MnrqEgEGKupdpDVDzgN\"]}},\"version\":1}" + } + } + }, + "sources": { + "A": { + "id": 0 + } + } +} diff --git a/test/cmdlineTests/standard_metadata_optimizer_no_yul/in.sol b/test/cmdlineTests/standard_metadata_optimizer_no_yul/in.sol new file mode 100644 index 000000000000..9e5350072a2c --- /dev/null +++ b/test/cmdlineTests/standard_metadata_optimizer_no_yul/in.sol @@ -0,0 +1,6 @@ +// SPDX-License-Identifier: GPL-3.0 +pragma solidity >=0.0; + +contract C { + function f() public pure {} +} diff --git a/test/cmdlineTests/standard_metadata_optimizer_no_yul/input.json b/test/cmdlineTests/standard_metadata_optimizer_no_yul/input.json new file mode 100644 index 000000000000..9572eed45251 --- /dev/null +++ b/test/cmdlineTests/standard_metadata_optimizer_no_yul/input.json @@ -0,0 +1,17 @@ +{ + "language": "Solidity", + "sources": { + "A": {"urls": ["standard_metadata_optimizer_no_yul/in.sol"]} + }, + "settings": { + "optimizer": { + "enabled": true, + "details": { + "yul": false + } + }, + "outputSelection": { + "*": {"*": ["metadata"]} + } + } +} diff --git a/test/cmdlineTests/standard_metadata_optimizer_no_yul/output.json b/test/cmdlineTests/standard_metadata_optimizer_no_yul/output.json new file mode 100644 index 000000000000..b0429916bd46 --- /dev/null +++ b/test/cmdlineTests/standard_metadata_optimizer_no_yul/output.json @@ -0,0 +1,14 @@ +{ + "contracts": { + "A": { + "C": { + "metadata": "{\"compiler\":{\"version\":\"\"},\"language\":\"Solidity\",\"output\":{\"abi\":[{\"inputs\":[],\"name\":\"f\",\"outputs\":[],\"stateMutability\":\"pure\",\"type\":\"function\"}],\"devdoc\":{\"kind\":\"dev\",\"methods\":{},\"version\":1},\"userdoc\":{\"kind\":\"user\",\"methods\":{},\"version\":1}},\"settings\":{\"compilationTarget\":{\"A\":\"C\"},\"evmVersion\":\"cancun\",\"libraries\":{},\"metadata\":{\"bytecodeHash\":\"ipfs\"},\"optimizer\":{\"details\":{\"constantOptimizer\":true,\"cse\":true,\"deduplicate\":true,\"inliner\":true,\"jumpdestRemover\":true,\"orderLiterals\":true,\"peephole\":true,\"simpleCounterForLoopUncheckedIncrement\":true,\"yul\":false},\"runs\":200},\"remappings\":[]},\"sources\":{\"A\":{\"keccak256\":\"0xadb715fb333a8148b6c34d75ffa489e541cf67b9539db523c0948564d2a8cbf1\",\"license\":\"GPL-3.0\",\"urls\":[\"bzz-raw://226f3b9be90a1b9329f7d01771fdf38e941b8e64a977945ad40300e921d99051\",\"dweb:/ipfs/QmdB5oEAJrLUJFVPEv5nGQzKRU1MnrqEgEGKupdpDVDzgN\"]}},\"version\":1}" + } + } + }, + "sources": { + "A": { + "id": 0 + } + } +} diff --git a/test/cmdlineTests/standard_metadata_optimizer_no_yul_empty_sequence/in.sol b/test/cmdlineTests/standard_metadata_optimizer_no_yul_empty_sequence/in.sol new file mode 100644 index 000000000000..9e5350072a2c --- /dev/null +++ b/test/cmdlineTests/standard_metadata_optimizer_no_yul_empty_sequence/in.sol @@ -0,0 +1,6 @@ +// SPDX-License-Identifier: GPL-3.0 +pragma solidity >=0.0; + +contract C { + function f() public pure {} +} diff --git a/test/cmdlineTests/standard_metadata_optimizer_no_yul_empty_sequence/input.json b/test/cmdlineTests/standard_metadata_optimizer_no_yul_empty_sequence/input.json new file mode 100644 index 000000000000..84ca0b289539 --- /dev/null +++ b/test/cmdlineTests/standard_metadata_optimizer_no_yul_empty_sequence/input.json @@ -0,0 +1,20 @@ +{ + "language": "Solidity", + "sources": { + "A": {"urls": ["standard_metadata_optimizer_no_yul_empty_sequence/in.sol"]} + }, + "settings": { + "optimizer": { + "enabled": true, + "details": { + "yul": false, + "yulDetails": { + "optimizerSteps": ":" + } + } + }, + "outputSelection": { + "*": {"*": ["metadata"]} + } + } +} diff --git a/test/cmdlineTests/standard_metadata_optimizer_no_yul_empty_sequence/output.json b/test/cmdlineTests/standard_metadata_optimizer_no_yul_empty_sequence/output.json new file mode 100644 index 000000000000..da50b3dfb8a1 --- /dev/null +++ b/test/cmdlineTests/standard_metadata_optimizer_no_yul_empty_sequence/output.json @@ -0,0 +1,14 @@ +{ + "contracts": { + "A": { + "C": { + "metadata": "{\"compiler\":{\"version\":\"\"},\"language\":\"Solidity\",\"output\":{\"abi\":[{\"inputs\":[],\"name\":\"f\",\"outputs\":[],\"stateMutability\":\"pure\",\"type\":\"function\"}],\"devdoc\":{\"kind\":\"dev\",\"methods\":{},\"version\":1},\"userdoc\":{\"kind\":\"user\",\"methods\":{},\"version\":1}},\"settings\":{\"compilationTarget\":{\"A\":\"C\"},\"evmVersion\":\"cancun\",\"libraries\":{},\"metadata\":{\"bytecodeHash\":\"ipfs\"},\"optimizer\":{\"details\":{\"constantOptimizer\":true,\"cse\":true,\"deduplicate\":true,\"inliner\":true,\"jumpdestRemover\":true,\"orderLiterals\":true,\"peephole\":true,\"simpleCounterForLoopUncheckedIncrement\":true,\"yul\":false,\"yulDetails\":{\"optimizerSteps\":\":\",\"stackAllocation\":true}},\"runs\":200},\"remappings\":[]},\"sources\":{\"A\":{\"keccak256\":\"0xadb715fb333a8148b6c34d75ffa489e541cf67b9539db523c0948564d2a8cbf1\",\"license\":\"GPL-3.0\",\"urls\":[\"bzz-raw://226f3b9be90a1b9329f7d01771fdf38e941b8e64a977945ad40300e921d99051\",\"dweb:/ipfs/QmdB5oEAJrLUJFVPEv5nGQzKRU1MnrqEgEGKupdpDVDzgN\"]}},\"version\":1}" + } + } + }, + "sources": { + "A": { + "id": 0 + } + } +} diff --git a/test/cmdlineTests/standard_optimizer_yulDetails_optimiserSteps_empty_sequence_metadata/output.json b/test/cmdlineTests/standard_optimizer_yulDetails_optimiserSteps_empty_sequence_metadata/output.json index c461a1485bda..6672ab6e12c6 100644 --- a/test/cmdlineTests/standard_optimizer_yulDetails_optimiserSteps_empty_sequence_metadata/output.json +++ b/test/cmdlineTests/standard_optimizer_yulDetails_optimiserSteps_empty_sequence_metadata/output.json @@ -2,7 +2,7 @@ "contracts": { "A": { "C": { - "metadata": "{\"compiler\":{\"version\":\"\"},\"language\":\"Solidity\",\"output\":{\"abi\":[],\"devdoc\":{\"kind\":\"dev\",\"methods\":{},\"version\":1},\"userdoc\":{\"kind\":\"user\",\"methods\":{},\"version\":1}},\"settings\":{\"compilationTarget\":{\"A\":\"C\"},\"evmVersion\":\"cancun\",\"libraries\":{},\"metadata\":{\"bytecodeHash\":\"ipfs\"},\"optimizer\":{\"details\":{\"constantOptimizer\":false,\"cse\":false,\"deduplicate\":false,\"inliner\":false,\"jumpdestRemover\":true,\"orderLiterals\":false,\"peephole\":true,\"simpleCounterForLoopUncheckedIncrement\":true,\"yul\":false,\"yulDetails\":{\"optimizerSteps\":\":\"}},\"runs\":200},\"remappings\":[]},\"sources\":{\"A\":{\"keccak256\":\"0xb284c39999cb85b80be315a6e9e322adf67a783c66e91ba4439168694580a66d\",\"license\":\"GPL-3.0\",\"urls\":[\"bzz-raw://098cee915fad095b8a996813768bd7d5e8c9e40c405e8c43d0572bb7bbc17334\",\"dweb:/ipfs/QmZmUzvSryrrD7pJ9S32iQnEWn4QBL4J1NdbQqL2Xc3yTr\"]}},\"version\":1}" + "metadata": "{\"compiler\":{\"version\":\"\"},\"language\":\"Solidity\",\"output\":{\"abi\":[],\"devdoc\":{\"kind\":\"dev\",\"methods\":{},\"version\":1},\"userdoc\":{\"kind\":\"user\",\"methods\":{},\"version\":1}},\"settings\":{\"compilationTarget\":{\"A\":\"C\"},\"evmVersion\":\"cancun\",\"libraries\":{},\"metadata\":{\"bytecodeHash\":\"ipfs\"},\"optimizer\":{\"details\":{\"constantOptimizer\":false,\"cse\":false,\"deduplicate\":false,\"inliner\":false,\"jumpdestRemover\":true,\"orderLiterals\":false,\"peephole\":true,\"simpleCounterForLoopUncheckedIncrement\":true,\"yul\":false,\"yulDetails\":{\"optimizerSteps\":\":\",\"stackAllocation\":false}},\"runs\":200},\"remappings\":[]},\"sources\":{\"A\":{\"keccak256\":\"0xb284c39999cb85b80be315a6e9e322adf67a783c66e91ba4439168694580a66d\",\"license\":\"GPL-3.0\",\"urls\":[\"bzz-raw://098cee915fad095b8a996813768bd7d5e8c9e40c405e8c43d0572bb7bbc17334\",\"dweb:/ipfs/QmZmUzvSryrrD7pJ9S32iQnEWn4QBL4J1NdbQqL2Xc3yTr\"]}},\"version\":1}" } } }, diff --git a/test/cmdlineTests/standard_optimizer_yulDetails_optimiserSteps_empty_sequence_whitespaces_metadata/output.json b/test/cmdlineTests/standard_optimizer_yulDetails_optimiserSteps_empty_sequence_whitespaces_metadata/output.json index c461a1485bda..6672ab6e12c6 100644 --- a/test/cmdlineTests/standard_optimizer_yulDetails_optimiserSteps_empty_sequence_whitespaces_metadata/output.json +++ b/test/cmdlineTests/standard_optimizer_yulDetails_optimiserSteps_empty_sequence_whitespaces_metadata/output.json @@ -2,7 +2,7 @@ "contracts": { "A": { "C": { - "metadata": "{\"compiler\":{\"version\":\"\"},\"language\":\"Solidity\",\"output\":{\"abi\":[],\"devdoc\":{\"kind\":\"dev\",\"methods\":{},\"version\":1},\"userdoc\":{\"kind\":\"user\",\"methods\":{},\"version\":1}},\"settings\":{\"compilationTarget\":{\"A\":\"C\"},\"evmVersion\":\"cancun\",\"libraries\":{},\"metadata\":{\"bytecodeHash\":\"ipfs\"},\"optimizer\":{\"details\":{\"constantOptimizer\":false,\"cse\":false,\"deduplicate\":false,\"inliner\":false,\"jumpdestRemover\":true,\"orderLiterals\":false,\"peephole\":true,\"simpleCounterForLoopUncheckedIncrement\":true,\"yul\":false,\"yulDetails\":{\"optimizerSteps\":\":\"}},\"runs\":200},\"remappings\":[]},\"sources\":{\"A\":{\"keccak256\":\"0xb284c39999cb85b80be315a6e9e322adf67a783c66e91ba4439168694580a66d\",\"license\":\"GPL-3.0\",\"urls\":[\"bzz-raw://098cee915fad095b8a996813768bd7d5e8c9e40c405e8c43d0572bb7bbc17334\",\"dweb:/ipfs/QmZmUzvSryrrD7pJ9S32iQnEWn4QBL4J1NdbQqL2Xc3yTr\"]}},\"version\":1}" + "metadata": "{\"compiler\":{\"version\":\"\"},\"language\":\"Solidity\",\"output\":{\"abi\":[],\"devdoc\":{\"kind\":\"dev\",\"methods\":{},\"version\":1},\"userdoc\":{\"kind\":\"user\",\"methods\":{},\"version\":1}},\"settings\":{\"compilationTarget\":{\"A\":\"C\"},\"evmVersion\":\"cancun\",\"libraries\":{},\"metadata\":{\"bytecodeHash\":\"ipfs\"},\"optimizer\":{\"details\":{\"constantOptimizer\":false,\"cse\":false,\"deduplicate\":false,\"inliner\":false,\"jumpdestRemover\":true,\"orderLiterals\":false,\"peephole\":true,\"simpleCounterForLoopUncheckedIncrement\":true,\"yul\":false,\"yulDetails\":{\"optimizerSteps\":\":\",\"stackAllocation\":false}},\"runs\":200},\"remappings\":[]},\"sources\":{\"A\":{\"keccak256\":\"0xb284c39999cb85b80be315a6e9e322adf67a783c66e91ba4439168694580a66d\",\"license\":\"GPL-3.0\",\"urls\":[\"bzz-raw://098cee915fad095b8a996813768bd7d5e8c9e40c405e8c43d0572bb7bbc17334\",\"dweb:/ipfs/QmZmUzvSryrrD7pJ9S32iQnEWn4QBL4J1NdbQqL2Xc3yTr\"]}},\"version\":1}" } } }, diff --git a/test/cmdlineTests/yul_optimizer_disabled_sequence_empty/output b/test/cmdlineTests/yul_optimizer_disabled_sequence_empty/output index 7b948303ee43..c9e5d1fed5ef 100644 --- a/test/cmdlineTests/yul_optimizer_disabled_sequence_empty/output +++ b/test/cmdlineTests/yul_optimizer_disabled_sequence_empty/output @@ -1,4 +1,4 @@ ======= yul_optimizer_disabled_sequence_empty/input.sol:C ======= Metadata: -{"compiler":{"version": ""},"language":"Solidity","output":{"abi":[],"devdoc":{"kind":"dev","methods":{},"version":1},"userdoc":{"kind":"user","methods":{},"version":1}},"settings":{"compilationTarget":{"yul_optimizer_disabled_sequence_empty/input.sol":"C"},"evmVersion":"cancun","libraries":{},"metadata":{"bytecodeHash":"ipfs"},"optimizer":{"details":{"constantOptimizer":false,"cse":false,"deduplicate":false,"inliner":false,"jumpdestRemover":true,"orderLiterals":false,"peephole":true,"simpleCounterForLoopUncheckedIncrement":true,"yul":false,"yulDetails":{"optimizerSteps":":"}},"runs":200},"remappings":[]},"sources":{"yul_optimizer_disabled_sequence_empty/input.sol":{"keccak256":"0xc2db3500808896ce1e69de2fe20cecab7ae2ffbb47cdf6ba8321296d95f49fc5","license":"GPL-3.0","urls":["bzz-raw://fde21393c068cd9f2d2b10ba4782db54f6f1c9a725074b17fa742531076be8a4","dweb:/ipfs/QmeTD6mR7YrWNyRowKRS7xs6cJNeMF3T49GAHzGM1bquyM"]}},"version":1} +{"compiler":{"version": ""},"language":"Solidity","output":{"abi":[],"devdoc":{"kind":"dev","methods":{},"version":1},"userdoc":{"kind":"user","methods":{},"version":1}},"settings":{"compilationTarget":{"yul_optimizer_disabled_sequence_empty/input.sol":"C"},"evmVersion":"cancun","libraries":{},"metadata":{"bytecodeHash":"ipfs"},"optimizer":{"details":{"constantOptimizer":false,"cse":false,"deduplicate":false,"inliner":false,"jumpdestRemover":true,"orderLiterals":false,"peephole":true,"simpleCounterForLoopUncheckedIncrement":true,"yul":false,"yulDetails":{"optimizerSteps":":","stackAllocation":false}},"runs":200},"remappings":[]},"sources":{"yul_optimizer_disabled_sequence_empty/input.sol":{"keccak256":"0xc2db3500808896ce1e69de2fe20cecab7ae2ffbb47cdf6ba8321296d95f49fc5","license":"GPL-3.0","urls":["bzz-raw://fde21393c068cd9f2d2b10ba4782db54f6f1c9a725074b17fa742531076be8a4","dweb:/ipfs/QmeTD6mR7YrWNyRowKRS7xs6cJNeMF3T49GAHzGM1bquyM"]}},"version":1} diff --git a/test/cmdlineTests/yul_optimizer_steps_without_optimize_empty_sequence/output b/test/cmdlineTests/yul_optimizer_steps_without_optimize_empty_sequence/output index 6873abe60e47..50911f28e5f7 100644 --- a/test/cmdlineTests/yul_optimizer_steps_without_optimize_empty_sequence/output +++ b/test/cmdlineTests/yul_optimizer_steps_without_optimize_empty_sequence/output @@ -130,4 +130,4 @@ object "C_28" { } Metadata: -{"compiler":{"version": ""},"language":"Solidity","output":{"abi":[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[],"name":"foo","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"pure","type":"function"}],"devdoc":{"kind":"dev","methods":{},"version":1},"userdoc":{"kind":"user","methods":{},"version":1}},"settings":{"compilationTarget":{"yul_optimizer_steps_without_optimize_empty_sequence/input.sol":"C"},"evmVersion":"cancun","libraries":{},"metadata":{"bytecodeHash":"ipfs"},"optimizer":{"details":{"constantOptimizer":false,"cse":false,"deduplicate":false,"inliner":false,"jumpdestRemover":true,"orderLiterals":false,"peephole":true,"simpleCounterForLoopUncheckedIncrement":true,"yul":false,"yulDetails":{"optimizerSteps":":"}},"runs":200},"remappings":[]},"sources":{"yul_optimizer_steps_without_optimize_empty_sequence/input.sol":{"keccak256":"0x3fc910e345ce1ee62bfa6b0f66931ee632c08265b25b6139cfbbfe4d2f8d5dd8","license":"GPL-3.0","urls":["bzz-raw://e557e9ad2c2e420a669c06ae456b0b790d77d2d6d492cd8540e6b244388a5140","dweb:/ipfs/QmaNiZmC2Mo3YxGiehs1n3dVTjZwD7FguX7EUtpeshMVuR"]}},"version":1} +{"compiler":{"version": ""},"language":"Solidity","output":{"abi":[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[],"name":"foo","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"pure","type":"function"}],"devdoc":{"kind":"dev","methods":{},"version":1},"userdoc":{"kind":"user","methods":{},"version":1}},"settings":{"compilationTarget":{"yul_optimizer_steps_without_optimize_empty_sequence/input.sol":"C"},"evmVersion":"cancun","libraries":{},"metadata":{"bytecodeHash":"ipfs"},"optimizer":{"details":{"constantOptimizer":false,"cse":false,"deduplicate":false,"inliner":false,"jumpdestRemover":true,"orderLiterals":false,"peephole":true,"simpleCounterForLoopUncheckedIncrement":true,"yul":false,"yulDetails":{"optimizerSteps":":","stackAllocation":false}},"runs":200},"remappings":[]},"sources":{"yul_optimizer_steps_without_optimize_empty_sequence/input.sol":{"keccak256":"0x3fc910e345ce1ee62bfa6b0f66931ee632c08265b25b6139cfbbfe4d2f8d5dd8","license":"GPL-3.0","urls":["bzz-raw://e557e9ad2c2e420a669c06ae456b0b790d77d2d6d492cd8540e6b244388a5140","dweb:/ipfs/QmaNiZmC2Mo3YxGiehs1n3dVTjZwD7FguX7EUtpeshMVuR"]}},"version":1}