Browse Source

Merge pull request #262 from caktux/parse

neth: new peer server, parseData without @, get gav from coins
cl-refactor
Gav Wood 11 years ago
parent
commit
fc33f7f3ca
  1. 3
      neth/CMakeLists.txt
  2. 45
      neth/main.cpp

3
neth/CMakeLists.txt

@ -34,14 +34,17 @@ if ("${TARGET_PLATFORM}" STREQUAL "w64")
target_link_libraries(${EXECUTABLE} cryptopp)
target_link_libraries(${EXECUTABLE} ncurses)
target_link_libraries(${EXECUTABLE} form)
target_link_libraries(${EXECUTABLE} boost_regex-mt-s)
target_link_libraries(${EXECUTABLE} boost_system-mt-s)
target_link_libraries(${EXECUTABLE} boost_filesystem-mt-s)
target_link_libraries(${EXECUTABLE} boost_thread_win32-mt-s)
set(CMAKE_SHARED_LIBRARY_LINK_CXX_FLAGS)
elseif (UNIX)
target_link_libraries(${EXECUTABLE} boost_regex)
target_link_libraries(${EXECUTABLE} ncurses)
target_link_libraries(${EXECUTABLE} form)
else ()
target_link_libraries(${EXECUTABLE} boost_regex)
target_link_libraries(${EXECUTABLE} boost_system)
target_link_libraries(${EXECUTABLE} boost_filesystem)
target_link_libraries(${EXECUTABLE} ncurses)

45
neth/main.cpp

@ -24,6 +24,7 @@
#include <chrono>
#include <fstream>
#include <iostream>
#include <boost/regex.hpp>
#include <boost/algorithm/string.hpp>
#include <boost/algorithm/string/trim_all.hpp>
#if ETH_JSONRPC
@ -133,10 +134,10 @@ string credits()
vs = vs.substr(vs.find_first_of('.') + 1)[0];
int pocnumber = stoi(vs);
string m_servers;
if (pocnumber == 4)
m_servers = "54.72.31.55";
else
if (pocnumber == 5)
m_servers = "54.72.69.180";
else
m_servers = "54.76.56.74";
ccout << "Type 'netstart 30303' to start networking" << endl;
ccout << "Type 'connect " << m_servers << " 30303' to connect" << endl;
@ -152,6 +153,7 @@ void version()
}
Address c_config = Address("661005d2720d855f1d9976f88bb10c1a3398c77f");
string pretty(h160 _a, eth::State _st)
{
string ns;
@ -969,7 +971,8 @@ int main(int argc, char** argv)
// Balance
stringstream ssb;
u256 balance = c.state().balance(us.address());
Address gavCoin("0115554959f43bf1d04cd7e3749d00fb0623ce1f");
Address coinsAddr = right160(c.stateAt(c_config, 1));
Address gavCoin = right160(c.stateAt(coinsAddr, c.stateAt(coinsAddr, 1)));
u256 totalGavCoinBalance = st.storage(gavCoin, (u160)us.address());
ssb << "Balance: " << formatBalance(balance) << " | " << totalGavCoinBalance << " GAV";
mvwprintw(consolewin, 0, x, ssb.str().c_str());
@ -1228,18 +1231,13 @@ bytes parseData(string _args)
bytes m_data;
stringstream args(_args);
string arg;
int cc = 0;
static const boost::regex r("\"([^\"]*)\"(.*)");
static const boost::regex h("(0x)?(([a-fA-F0-9])+)(.*)");
while (args >> arg)
{
int al = arg.length();
if (boost::starts_with(arg, "0x"))
{
bytes bs = fromHex(arg);
m_data += bs;
}
else if (arg[0] == '@')
if (boost::regex_match(arg, h))
{
arg = arg.substr(1, arg.length());
if (boost::starts_with(arg, "0x"))
{
cnote << "hex: " << arg;
@ -1250,16 +1248,6 @@ bytes parseData(string _args)
m_data.push_back(0);
m_data += bs;
}
else if (boost::starts_with(arg, "\"") && boost::ends_with(arg, "\""))
{
arg = arg.substr(1, arg.length() - 2);
cnote << "string: " << arg;
if (al < 32)
for (int i = 0; i < 32 - al; ++i)
m_data.push_back(0);
for (int i = 0; i < al; ++i)
m_data.push_back(arg[i]);
}
else
{
cnote << "value: " << arg;
@ -1271,10 +1259,17 @@ bytes parseData(string _args)
m_data += bs;
}
}
else
else if (boost::regex_match(arg, r))
{
arg = arg.substr(1, arg.length() - 2);
int al = arg.length();
cnote << "string: " << arg;
for (int i = 0; i < al; ++i)
m_data.push_back(arg[i]);
cc++;
if (al < 32)
for (int i = 0; i < 32 - al; ++i)
m_data.push_back(0);
}
}
return m_data;
}

Loading…
Cancel
Save