/* This file is part of cpp-ethereum. cpp-ethereum is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. cpp-ethereum is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with cpp-ethereum. If not, see <http://www.gnu.org/licenses/>. */ /** @file CommonJS.cpp * @authors: * Gav Wood <i@gavwood.com> * Marek Kotewicz <marek@ethdev.com> * @date 2014 */ #include "CommonJS.h" namespace dev { bytes jsToBytes(std::string const& _s) { if (_s.substr(0, 2) == "0x") // Hex return fromHex(_s.substr(2)); else if (_s.find_first_not_of("0123456789") == std::string::npos) // Decimal return toCompactBigEndian(bigint(_s)); else return bytes(); } bytes padded(bytes _b, unsigned _l) { while (_b.size() < _l) _b.insert(_b.begin(), 0); return asBytes(asString(_b).substr(_b.size() - std::max(_l, _l))); } bytes paddedRight(bytes _b, unsigned _l) { _b.resize(_l); return _b; } bytes unpadded(bytes _b) { auto p = asString(_b).find_last_not_of((char)0); _b.resize(p == std::string::npos ? 0 : (p + 1)); return _b; } bytes unpadLeft(bytes _b) { unsigned int i = 0; if (_b.size() == 0) return _b; while (i < _b.size() && _b[i] == byte(0)) i++; if (i != 0) _b.erase(_b.begin(), _b.begin() + i); return _b; } std::string fromRaw(h256 _n, unsigned* _inc) { if (_n) { std::string s((char const*)_n.data(), 32); auto l = s.find_first_of('\0'); if (!l) return ""; if (l != std::string::npos) { auto p = s.find_first_not_of('\0', l); if (!(p == std::string::npos || (_inc && p == 31))) return ""; if (_inc) *_inc = (byte)s[31]; s.resize(l); } for (auto i: s) if (i < 32) return ""; return s; } return ""; } std::string prettyU256(u256 _n, bool _abridged) { unsigned inc = 0; std::string raw; std::ostringstream s; if (!(_n >> 64)) s << " " << (uint64_t)_n << " (0x" << std::hex << (uint64_t)_n << ")"; else if (!~(_n >> 64)) s << " " << (int64_t)_n << " (0x" << std::hex << (int64_t)_n << ")"; else if ((_n >> 160) == 0) { Address a = right160(_n); std::string n; if (_abridged) n = a.abridged(); else n = toHex(a.ref()); if (n.empty()) s << "0"; else s << _n << "(0x" << n << ")"; } else if ((raw = fromRaw((h256)_n, &inc)).size()) return "\"" + raw + "\"" + (inc ? " + " + std::to_string(inc) : ""); else s << "" << (h256)_n; return s.str(); } Address fromString(std::string const& _sn) { if (_sn.size() == 40) return Address(fromHex(_sn)); else return Address(); } }