CommonJS.h 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. /*
  2. This file is part of cpp-ethereum.
  3. cpp-ethereum is free software: you can redistribute it and/or modify
  4. it under the terms of the GNU General Public License as published by
  5. the Free Software Foundation, either version 3 of the License, or
  6. (at your option) any later version.
  7. cpp-ethereum is distributed in the hope that it will be useful,
  8. but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  10. GNU General Public License for more details.
  11. You should have received a copy of the GNU General Public License
  12. along with cpp-ethereum. If not, see <http://www.gnu.org/licenses/>.
  13. */
  14. /** @file CommonJS.h
  15. * @authors:
  16. * Gav Wood <i@gavwood.com>
  17. * Marek Kotewicz <marek@ethdev.com>
  18. * @date 2014
  19. */
  20. #pragma once
  21. #include <string>
  22. #include "FixedHash.h"
  23. #include "CommonData.h"
  24. #include "CommonIO.h"
  25. namespace dev
  26. {
  27. template <unsigned S> std::string toJS(FixedHash<S> const& _h)
  28. {
  29. return "0x" + toHex(_h.ref());
  30. }
  31. template <unsigned N> std::string toJS(boost::multiprecision::number<boost::multiprecision::cpp_int_backend<N, N, boost::multiprecision::unsigned_magnitude, boost::multiprecision::unchecked, void>> const& _n)
  32. {
  33. std::string h = toHex(toCompactBigEndian(_n, 1));
  34. // remove first 0, if it is necessary;
  35. std::string res = h[0] != '0' ? h : h.substr(1);
  36. return "0x" + res;
  37. }
  38. inline std::string toJS(bytes const& _n, std::size_t _padding = 0)
  39. {
  40. bytes n = _n;
  41. n.resize(std::max<unsigned>(n.size(), _padding));
  42. return "0x" + toHex(n);
  43. }
  44. template<unsigned T> std::string toJS(SecureFixedHash<T> const& _i)
  45. {
  46. std::stringstream stream;
  47. stream << "0x" << _i.makeInsecure().hex();
  48. return stream.str();
  49. }
  50. template<typename T> std::string toJS(T const& _i)
  51. {
  52. std::stringstream stream;
  53. stream << "0x" << std::hex << _i;
  54. return stream.str();
  55. }
  56. enum class OnFailed { InterpretRaw, Empty, Throw };
  57. /// Convert string to byte array. Input parameter is hex, optionally prefixed by "0x".
  58. /// Returns empty array if invalid input.
  59. bytes jsToBytes(std::string const& _s, OnFailed _f = OnFailed::Empty);
  60. /// Add '0' on, or remove items from, the front of @a _b until it is of length @a _l.
  61. bytes padded(bytes _b, unsigned _l);
  62. /// Add '0' on, or remove items from, the back of @a _b until it is of length @a _l.
  63. bytes paddedRight(bytes _b, unsigned _l);
  64. /// Removing all trailing '0'. Returns empty array if input contains only '0' char.
  65. bytes unpadded(bytes _s);
  66. /// Remove all 0 byte on the head of @a _s.
  67. bytes unpadLeft(bytes _s);
  68. /// Convert h256 into user-readable string (by directly using std::string constructor). If it can't be interpreted as an ASCII string, empty string is returned.
  69. std::string fromRaw(h256 _n);
  70. template <unsigned N> FixedHash<N> jsToFixed(std::string const& _s)
  71. {
  72. if (_s.substr(0, 2) == "0x")
  73. // Hex
  74. return FixedHash<N>(_s.substr(2 + std::max<unsigned>(N * 2, _s.size() - 2) - N * 2));
  75. else if (_s.find_first_not_of("0123456789") == std::string::npos)
  76. // Decimal
  77. return (typename FixedHash<N>::Arith)(_s);
  78. else
  79. // Binary
  80. return FixedHash<N>(); // FAIL
  81. }
  82. template <unsigned N> boost::multiprecision::number<boost::multiprecision::cpp_int_backend<N * 8, N * 8, boost::multiprecision::unsigned_magnitude, boost::multiprecision::unchecked, void>> jsToInt(std::string const& _s)
  83. {
  84. if (_s.substr(0, 2) == "0x")
  85. // Hex
  86. return fromBigEndian<boost::multiprecision::number<boost::multiprecision::cpp_int_backend<N * 8, N * 8, boost::multiprecision::unsigned_magnitude, boost::multiprecision::unchecked, void>>>(fromHex(_s.substr(2)));
  87. else if (_s.find_first_not_of("0123456789") == std::string::npos)
  88. // Decimal
  89. return boost::multiprecision::number<boost::multiprecision::cpp_int_backend<N * 8, N * 8, boost::multiprecision::unsigned_magnitude, boost::multiprecision::unchecked, void>>(_s);
  90. else
  91. // Binary
  92. return 0; // FAIL
  93. }
  94. inline u256 jsToU256(std::string const& _s) { return jsToInt<32>(_s); }
  95. /// Convert a string representation of a number to an int
  96. /// String can be a normal decimal number, or a hex prefixed by 0x or 0X, or an octal if prefixed by 0
  97. /// Returns 0 in case of failure
  98. inline int jsToInt(std::string const& _s)
  99. {
  100. int ret = 0;
  101. DEV_IGNORE_EXCEPTIONS(ret = std::stoi(_s, nullptr, 0));
  102. return ret;
  103. }
  104. inline std::string jsToDecimal(std::string const& _s)
  105. {
  106. return toString(jsToU256(_s));
  107. }
  108. }