From 76ad4daededb483dfcb656d2a6f9bc7468d6ede6 Mon Sep 17 00:00:00 2001 From: arkpar Date: Tue, 14 Jul 2015 13:13:32 +0200 Subject: [PATCH 1/2] Allow 0x prefix for address entry in AZ --- alethzero/MainWin.cpp | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/alethzero/MainWin.cpp b/alethzero/MainWin.cpp index 60c07fd8d..6b0fc7989 100644 --- a/alethzero/MainWin.cpp +++ b/alethzero/MainWin.cpp @@ -638,18 +638,22 @@ pair Main::fromString(std::string const& _n) const if (_n == "(Create Contract)") return make_pair(Address(), bytes()); + std::string n = _n; + if (n.find_first_of("0x") == 0) + n.erase(0, 2); + auto g_newNameReg = getNameReg(); if (g_newNameReg) { - Address a = abiOut
(ethereum()->call(g_newNameReg, abiIn("addr(bytes32)", ::toString32(_n))).output); + Address a = abiOut
(ethereum()->call(g_newNameReg, abiIn("addr(bytes32)", ::toString32(n))).output); if (a) return make_pair(a, bytes()); } - if (_n.size() == 40) + if (n.size() == 40) { try { - return make_pair(Address(fromHex(_n, WhenError::Throw)), bytes()); + return make_pair(Address(fromHex(n, WhenError::Throw)), bytes()); } catch (BadHexCharacter& _e) { @@ -665,7 +669,7 @@ pair Main::fromString(std::string const& _n) const } else try { - return ICAP::decoded(_n).address([&](Address const& a, bytes const& b) -> bytes + return ICAP::decoded(n).address([&](Address const& a, bytes const& b) -> bytes { return ethereum()->call(a, b).output; }, g_newNameReg); From 231b70866666dc4372baf9c88d3d05e14b555f39 Mon Sep 17 00:00:00 2001 From: arkpar Date: Tue, 14 Jul 2015 14:30:30 +0200 Subject: [PATCH 2/2] find instead of find_firt_of --- alethzero/MainWin.cpp | 2 +- test/TestHelper.cpp | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/alethzero/MainWin.cpp b/alethzero/MainWin.cpp index 6b0fc7989..dd3d5bbd3 100644 --- a/alethzero/MainWin.cpp +++ b/alethzero/MainWin.cpp @@ -639,7 +639,7 @@ pair Main::fromString(std::string const& _n) const return make_pair(Address(), bytes()); std::string n = _n; - if (n.find_first_of("0x") == 0) + if (n.find("0x") == 0) n.erase(0, 2); auto g_newNameReg = getNameReg(); diff --git a/test/TestHelper.cpp b/test/TestHelper.cpp index 9a1b16935..2ed1ed4d0 100644 --- a/test/TestHelper.cpp +++ b/test/TestHelper.cpp @@ -479,7 +479,7 @@ bytes importCode(json_spirit::mObject& _o) { bytes code; if (_o["code"].type() == json_spirit::str_type) - if (_o["code"].get_str().find_first_of("0x") != 0) + if (_o["code"].get_str().find("0x") != 0) code = compileLLL(_o["code"].get_str(), false); else code = fromHex(_o["code"].get_str().substr(2));