aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorCJentzsch <jentzsch.software@gmail.com>2015-02-07 00:38:09 +0800
committerCJentzsch <jentzsch.software@gmail.com>2015-02-07 00:38:09 +0800
commit8404c8747747b8842215889139ab20b479fb792c (patch)
treef0c45fccdc9f4c6f62e32f9a48ff37da90d11aa8
parentd78e171ef44db2cfa141ca1c4b3873b2d6d84cf5 (diff)
parent5bedf7f81612767f2f60ea57a1c38c34973465ec (diff)
downloaddexon-solidity-8404c8747747b8842215889139ab20b479fb792c.tar
dexon-solidity-8404c8747747b8842215889139ab20b479fb792c.tar.gz
dexon-solidity-8404c8747747b8842215889139ab20b479fb792c.tar.bz2
dexon-solidity-8404c8747747b8842215889139ab20b479fb792c.tar.lz
dexon-solidity-8404c8747747b8842215889139ab20b479fb792c.tar.xz
dexon-solidity-8404c8747747b8842215889139ab20b479fb792c.tar.zst
dexon-solidity-8404c8747747b8842215889139ab20b479fb792c.zip
Merge remote-tracking branch 'upstream/develop' into addTests
-rw-r--r--SolidityNameAndTypeResolution.cpp22
-rw-r--r--SolidityParser.cpp13
2 files changed, 35 insertions, 0 deletions
diff --git a/SolidityNameAndTypeResolution.cpp b/SolidityNameAndTypeResolution.cpp
index 742d2ee2..05ce6ed6 100644
--- a/SolidityNameAndTypeResolution.cpp
+++ b/SolidityNameAndTypeResolution.cpp
@@ -910,6 +910,28 @@ BOOST_AUTO_TEST_CASE(disallow_declaration_of_void_type)
BOOST_CHECK_THROW(parseTextAndResolveNames(sourceCode), TypeError);
}
+BOOST_AUTO_TEST_CASE(overflow_caused_by_ether_units)
+{
+ char const* sourceCodeFine = R"(
+ contract c {
+ function c ()
+ {
+ a = 115792089237316195423570985008687907853269984665640564039458;
+ }
+ uint256 a;
+ })";
+ BOOST_CHECK_NO_THROW(parseTextAndResolveNames(sourceCodeFine));
+ char const* sourceCode = R"(
+ contract c {
+ function c ()
+ {
+ a = 115792089237316195423570985008687907853269984665640564039458 ether;
+ }
+ uint256 a;
+ })";
+ BOOST_CHECK_THROW(parseTextAndResolveNames(sourceCode), TypeError);
+}
+
BOOST_AUTO_TEST_SUITE_END()
}
diff --git a/SolidityParser.cpp b/SolidityParser.cpp
index b6837866..7af99567 100644
--- a/SolidityParser.cpp
+++ b/SolidityParser.cpp
@@ -679,6 +679,19 @@ BOOST_AUTO_TEST_CASE(literal_constants_with_ether_subdenominations)
BOOST_CHECK_NO_THROW(parseTextExplainError(text));
}
+BOOST_AUTO_TEST_CASE(literal_constants_with_ether_subdenominations_in_expressions)
+{
+ char const* text = R"(
+ contract c {
+ function c ()
+ {
+ a = 1 wei * 100 wei + 7 szabo - 3;
+ }
+ uint256 a;
+ })";
+ BOOST_CHECK_NO_THROW(parseTextExplainError(text));
+}
+
BOOST_AUTO_TEST_SUITE_END()
}