diff options
author | chriseth <c@ethdev.com> | 2015-10-07 18:09:07 +0800 |
---|---|---|
committer | chriseth <c@ethdev.com> | 2015-10-07 18:31:38 +0800 |
commit | f3913d699620d5c47b6a9f3d0c222ddcc10df44a (patch) | |
tree | 35d0f9300ed130c805fec651d5e177a8162457d8 | |
parent | d35a4b849da427629334665cc1bb931a259adac9 (diff) | |
download | dexon-solidity-f3913d699620d5c47b6a9f3d0c222ddcc10df44a.tar dexon-solidity-f3913d699620d5c47b6a9f3d0c222ddcc10df44a.tar.gz dexon-solidity-f3913d699620d5c47b6a9f3d0c222ddcc10df44a.tar.bz2 dexon-solidity-f3913d699620d5c47b6a9f3d0c222ddcc10df44a.tar.lz dexon-solidity-f3913d699620d5c47b6a9f3d0c222ddcc10df44a.tar.xz dexon-solidity-f3913d699620d5c47b6a9f3d0c222ddcc10df44a.tar.zst dexon-solidity-f3913d699620d5c47b6a9f3d0c222ddcc10df44a.zip |
Fix boost error.
-rw-r--r-- | libsolidity/InterfaceHandler.cpp | 23 |
1 files changed, 12 insertions, 11 deletions
diff --git a/libsolidity/InterfaceHandler.cpp b/libsolidity/InterfaceHandler.cpp index d23d8264..be15ae58 100644 --- a/libsolidity/InterfaceHandler.cpp +++ b/libsolidity/InterfaceHandler.cpp @@ -1,8 +1,6 @@ #include <libsolidity/InterfaceHandler.h> -#include <boost/range/adaptor/transformed.hpp> #include <boost/range/irange.hpp> -#include <boost/algorithm/string/join.hpp> #include <libsolidity/AST.h> #include <libsolidity/CompilerStack.h> using namespace std; @@ -111,15 +109,16 @@ string InterfaceHandler::abiInterface(ContractDefinition const& _contractDef) string InterfaceHandler::ABISolidityInterface(ContractDefinition const& _contractDef) { - using namespace boost::adaptors; - using namespace boost::algorithm; string ret = (_contractDef.isLibrary() ? "library " : "contract ") + _contractDef.name() + "{"; auto populateParameters = [](vector<string> const& _paramNames, vector<string> const& _paramTypes) { - return "(" + join(boost::irange<size_t>(0, _paramNames.size()) | transformed([&](size_t _i) { - return _paramTypes[_i] + " " + _paramNames[_i]; - }), ",") + ")"; + string ret = "("; + for (size_t i = 0; i < _paramNames.size(); ++i) + ret += _paramTypes[i] + " " + _paramNames[i] + ","; + if (ret.size() != 1) + ret.pop_back(); + return ret + ")"; }; // If this is a library, include all its enum and struct types. Should be more intelligent // in the future and check what is actually used (it might even use types from other libraries @@ -135,10 +134,12 @@ string InterfaceHandler::ABISolidityInterface(ContractDefinition const& _contrac } for (auto const& enu: _contractDef.definedEnums()) { - ret += "enum " + enu->name() + "{" + - join(enu->members() | transformed([](ASTPointer<EnumValue> const& _value) { - return _value->name(); - }), ",") + "}"; + ret += "enum " + enu->name() + "{"; + for (ASTPointer<EnumValue> const& val: enu->members()) + ret += val->name() + ","; + if (ret.back() == ',') + ret.pop_back(); + ret += "}"; } } if (_contractDef.constructor()) |