From 410b618d18d712db680de8f173a671bb637ff2b0 Mon Sep 17 00:00:00 2001 From: Satoshi Nakamoto Date: Thu, 12 Aug 2010 13:20:57 +0000 Subject: [PATCH] json-spirit print reals with 8 decimal places, bitcoind help instead of bitcoind -? --- init.cpp | 4 +- json/json_spirit_value.h | 2 +- json/json_spirit_writer_template.h | 5 +- rpc.cpp | 89 +++++++++++++----------------- 4 files changed, 46 insertions(+), 54 deletions(-) diff --git a/init.cpp b/init.cpp index ee26d6c171..ccb5335d43 100644 --- a/init.cpp +++ b/init.cpp @@ -147,8 +147,8 @@ bool AppInit2(int argc, char* argv[]) _("Usage:") + "\t\t\t\t\t\t\t\t\t\t\n" + " bitcoin [options] \t " + "\n" + " bitcoin [options] [params]\t " + _("Send command to -server or bitcoind\n") + - " bitcoin [options] -? \t\t " + _("Get help for a command\n") + - " bitcoin help \t\t\t " + _("List commands\n") + + " bitcoin [options] help \t\t " + _("List commands\n") + + " bitcoin [options] help \t\t " + _("Get help for a command\n") + _("Options:\n") + " -conf= \t " + _("Specify configuration file (default: bitcoin.conf)\n") + " -gen \t " + _("Generate coins\n") + diff --git a/json/json_spirit_value.h b/json/json_spirit_value.h index 6274df1095..7e83a2a7e3 100644 --- a/json/json_spirit_value.h +++ b/json/json_spirit_value.h @@ -342,7 +342,7 @@ namespace json_spirit { std::ostringstream os; - /// satoshi: tell the types by name instead of by number + ///// Bitcoin: Tell the types by name instead of by number os << "value is type " << Value_type_name[type()] << ", expected " << Value_type_name[vtype]; throw std::runtime_error( os.str() ); diff --git a/json/json_spirit_writer_template.h b/json/json_spirit_writer_template.h index 33bd0ff867..28c49ddc64 100644 --- a/json/json_spirit_writer_template.h +++ b/json/json_spirit_writer_template.h @@ -124,8 +124,11 @@ namespace json_spirit case str_type: output( value.get_str() ); break; case bool_type: output( value.get_bool() ); break; case int_type: output_int( value ); break; - case real_type: os_ << std::showpoint << std::setprecision( 16 ) + + /// Bitcoin: Added std::fixed and changed precision from 16 to 8 + case real_type: os_ << std::showpoint << std::fixed << std::setprecision(8) << value.get_real(); break; + case null_type: os_ << "null"; break; default: assert( false ); } diff --git a/rpc.cpp b/rpc.cpp index 4c5a62f093..2a30cda0fc 100644 --- a/rpc.cpp +++ b/rpc.cpp @@ -56,10 +56,14 @@ void PrintConsole(const char* format, ...) Value help(const Array& params, bool fHelp) { - if (fHelp || params.size() != 0) + if (fHelp || params.size() > 1) throw runtime_error( - "help\n" - "List commands."); + "help [command]\n" + "List commands, or get help for a command."); + + string strCommand; + if (params.size() > 0) + strCommand = params[0].get_str(); string strRet; set setDone; @@ -70,6 +74,8 @@ Value help(const Array& params, bool fHelp) if (strMethod == "getamountreceived" || strMethod == "getallreceived") continue; + if (strCommand != "" && strMethod != strCommand) + continue; try { Array params; @@ -81,11 +87,14 @@ Value help(const Array& params, bool fHelp) { // Help text is returned in an exception string strHelp = string(e.what()); - if (strHelp.find('\n') != -1) - strHelp = strHelp.substr(0, strHelp.find('\n')); + if (strCommand == "") + if (strHelp.find('\n') != -1) + strHelp = strHelp.substr(0, strHelp.find('\n')); strRet += strHelp + "\n"; } } + if (strRet == "") + strRet = strprintf("help: unknown command: %s\n", strCommand.c_str()); strRet = strRet.substr(0,strRet.size()-1); return strRet; } @@ -1059,57 +1068,37 @@ int CommandLineRPC(int argc, char *argv[]) argv++; } - // Check that the method exists + // Method if (argc < 2) throw runtime_error("too few parameters"); string strMethod = argv[1]; - if (!mapCallTable.count(strMethod)) - throw runtime_error(strprintf("unknown command: %s", strMethod.c_str())); - Value result; - if (argc == 3 && strcmp(argv[2], "-?") == 0) - { - // Call help locally, help text is returned in an exception - try - { - map::iterator mi = mapCallTable.find(strMethod); - Array params; - (*(*mi).second)(params, true); - } - catch (std::exception& e) - { - result = e.what(); - } - } - else - { - // Parameters default to strings - Array params; - for (int i = 2; i < argc; i++) - params.push_back(argv[i]); - int n = params.size(); + // Parameters default to strings + Array params; + for (int i = 2; i < argc; i++) + params.push_back(argv[i]); + int n = params.size(); - // - // Special case non-string parameter types - // - if (strMethod == "setgenerate" && n > 0) ConvertTo(params[0]); - if (strMethod == "setgenerate" && n > 1) ConvertTo(params[1]); - if (strMethod == "sendtoaddress" && n > 1) ConvertTo(params[1]); - if (strMethod == "listtransactions" && n > 0) ConvertTo(params[0]); - if (strMethod == "listtransactions" && n > 1) ConvertTo(params[1]); - if (strMethod == "getamountreceived" && n > 1) ConvertTo(params[1]); // deprecated - if (strMethod == "getreceivedbyaddress" && n > 1) ConvertTo(params[1]); - if (strMethod == "getreceivedbylabel" && n > 1) ConvertTo(params[1]); - if (strMethod == "getallreceived" && n > 0) ConvertTo(params[0]); // deprecated - if (strMethod == "getallreceived" && n > 1) ConvertTo(params[1]); - if (strMethod == "listreceivedbyaddress" && n > 0) ConvertTo(params[0]); - if (strMethod == "listreceivedbyaddress" && n > 1) ConvertTo(params[1]); - if (strMethod == "listreceivedbylabel" && n > 0) ConvertTo(params[0]); - if (strMethod == "listreceivedbylabel" && n > 1) ConvertTo(params[1]); + // + // Special case non-string parameter types + // + if (strMethod == "setgenerate" && n > 0) ConvertTo(params[0]); + if (strMethod == "setgenerate" && n > 1) ConvertTo(params[1]); + if (strMethod == "sendtoaddress" && n > 1) ConvertTo(params[1]); + if (strMethod == "listtransactions" && n > 0) ConvertTo(params[0]); + if (strMethod == "listtransactions" && n > 1) ConvertTo(params[1]); + if (strMethod == "getamountreceived" && n > 1) ConvertTo(params[1]); // deprecated + if (strMethod == "getreceivedbyaddress" && n > 1) ConvertTo(params[1]); + if (strMethod == "getreceivedbylabel" && n > 1) ConvertTo(params[1]); + if (strMethod == "getallreceived" && n > 0) ConvertTo(params[0]); // deprecated + if (strMethod == "getallreceived" && n > 1) ConvertTo(params[1]); + if (strMethod == "listreceivedbyaddress" && n > 0) ConvertTo(params[0]); + if (strMethod == "listreceivedbyaddress" && n > 1) ConvertTo(params[1]); + if (strMethod == "listreceivedbylabel" && n > 0) ConvertTo(params[0]); + if (strMethod == "listreceivedbylabel" && n > 1) ConvertTo(params[1]); - // Execute - result = CallRPC(strMethod, params); - } + // Execute + Value result = CallRPC(strMethod, params); // Print result string strResult = (result.type() == str_type ? result.get_str() : write_string(result, true));