aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorchriseth <chris@ethereum.org>2017-10-17 00:16:40 +0800
committerGitHub <noreply@github.com>2017-10-17 00:16:40 +0800
commit18a72dbe4668e23aaf38404183b978fbbb1824d1 (patch)
tree85a20a6872c7b2235c555df22ed186db6a9d52ba
parentc2fab07ccdf9000023dd9373d9072d44dcdd93d7 (diff)
parent082e7b6a9ea5f4651bed0b2ab037dbba05af26eb (diff)
downloaddexon-solidity-18a72dbe4668e23aaf38404183b978fbbb1824d1.tar
dexon-solidity-18a72dbe4668e23aaf38404183b978fbbb1824d1.tar.gz
dexon-solidity-18a72dbe4668e23aaf38404183b978fbbb1824d1.tar.bz2
dexon-solidity-18a72dbe4668e23aaf38404183b978fbbb1824d1.tar.lz
dexon-solidity-18a72dbe4668e23aaf38404183b978fbbb1824d1.tar.xz
dexon-solidity-18a72dbe4668e23aaf38404183b978fbbb1824d1.tar.zst
dexon-solidity-18a72dbe4668e23aaf38404183b978fbbb1824d1.zip
Merge pull request #3086 from ethereum/allow_gas_in_view
Allow ``gas`` in view functions.
-rw-r--r--Changelog.md1
-rw-r--r--libevmasm/SemanticInformation.cpp2
-rw-r--r--test/libsolidity/ViewPureChecker.cpp7
3 files changed, 7 insertions, 3 deletions
diff --git a/Changelog.md b/Changelog.md
index d78dbbba..ac27ca7f 100644
--- a/Changelog.md
+++ b/Changelog.md
@@ -19,6 +19,7 @@ Bugfixes:
(such as ``balance``, ``transfer``, etc.)
* Type Checker: Prevent duplicate event declarations.
* Type Checker: Do not mark event parameters as shadowing state variables.
+ * Type Checker: Allow ``gas`` in view functions.
### 0.4.17 (2017-09-21)
diff --git a/libevmasm/SemanticInformation.cpp b/libevmasm/SemanticInformation.cpp
index 83cfe2c6..61a6ccda 100644
--- a/libevmasm/SemanticInformation.cpp
+++ b/libevmasm/SemanticInformation.cpp
@@ -198,6 +198,7 @@ bool SemanticInformation::invalidInPureFunctions(Instruction _instruction)
case Instruction::ORIGIN:
case Instruction::CALLER:
case Instruction::CALLVALUE:
+ case Instruction::GAS:
case Instruction::GASPRICE:
case Instruction::EXTCODESIZE:
case Instruction::EXTCODECOPY:
@@ -223,7 +224,6 @@ bool SemanticInformation::invalidInViewFunctions(Instruction _instruction)
case Instruction::SSTORE:
case Instruction::JUMP:
case Instruction::JUMPI:
- case Instruction::GAS:
case Instruction::LOG0:
case Instruction::LOG1:
case Instruction::LOG2:
diff --git a/test/libsolidity/ViewPureChecker.cpp b/test/libsolidity/ViewPureChecker.cpp
index 80241519..6353ae8a 100644
--- a/test/libsolidity/ViewPureChecker.cpp
+++ b/test/libsolidity/ViewPureChecker.cpp
@@ -349,7 +349,7 @@ BOOST_AUTO_TEST_CASE(assembly)
assembly { x := 7 }
}
function g() view public {
- assembly { for {} 1 { pop(sload(0)) } { } }
+ assembly { for {} 1 { pop(sload(0)) } { } pop(gas) }
}
function h() view public {
assembly { function g() { pop(blockhash(20)) } }
@@ -357,6 +357,9 @@ BOOST_AUTO_TEST_CASE(assembly)
function j() public {
assembly { pop(call(0, 1, 2, 3, 4, 5, 6)) }
}
+ function k() public {
+ assembly { pop(call(gas, 1, 2, 3, 4, 5, 6)) }
+ }
}
)";
CHECK_SUCCESS_NO_WARNINGS(text);
@@ -367,7 +370,7 @@ BOOST_AUTO_TEST_CASE(assembly_staticcall)
string text = R"(
contract C {
function i() view public {
- assembly { pop(staticcall(0, 1, 2, 3, 4, 5)) }
+ assembly { pop(staticcall(gas, 1, 2, 3, 4, 5)) }
}
}
)";