Mac OS build fixes by laszlo

-- version 0.2.8
This commit is contained in:
s_nakamoto 2010-05-19 00:26:56 +00:00
parent 288424ad63
commit 240f3fbe2f
12 changed files with 109 additions and 74 deletions

View File

@ -284,6 +284,10 @@ bool CMyApp::OnInit2()
_CrtSetReportMode(_CRT_WARN, _CRTDBG_MODE_FILE); _CrtSetReportMode(_CRT_WARN, _CRTDBG_MODE_FILE);
_CrtSetReportFile(_CRT_WARN, CreateFileA("NUL", GENERIC_WRITE, 0, NULL, OPEN_EXISTING, 0, 0)); _CrtSetReportFile(_CRT_WARN, CreateFileA("NUL", GENERIC_WRITE, 0, NULL, OPEN_EXISTING, 0, 0));
#endif #endif
#if _MSC_VER >= 1400
// Disable confusing "helpful" text message on abort, ctrl-c
_set_abort_behavior(0, _WRITE_ABORT_MSG | _CALL_REPORTFAULT);
#endif
#if defined(__WXMSW__) && defined(__WXDEBUG__) && wxUSE_GUI #if defined(__WXMSW__) && defined(__WXDEBUG__) && wxUSE_GUI
// Disable malfunctioning wxWidgets debug assertion // Disable malfunctioning wxWidgets debug assertion
g_isPainting = 10000; g_isPainting = 10000;
@ -291,10 +295,12 @@ bool CMyApp::OnInit2()
#if wxUSE_GUI #if wxUSE_GUI
wxImage::AddHandler(new wxPNGHandler); wxImage::AddHandler(new wxPNGHandler);
#endif #endif
#ifdef __WXMSW__ #if defined(__WXMSW__ ) || defined(__WXMAC__)
SetAppName("Bitcoin"); SetAppName("Bitcoin");
#else #else
SetAppName("bitcoin"); SetAppName("bitcoin");
#endif
#ifndef __WXMSW__
umask(077); umask(077);
#endif #endif
#ifdef __WXMSW__ #ifdef __WXMSW__

View File

@ -1338,7 +1338,7 @@ bool CBlock::AcceptBlock()
// Don't relay old inventory during initial block download. // Don't relay old inventory during initial block download.
// Please keep this number updated to a few thousand below current block count. // Please keep this number updated to a few thousand below current block count.
if (hashBestChain == hash && nBestHeight > 40000) if (hashBestChain == hash && nBestHeight > 55000)
RelayInventory(CInv(MSG_BLOCK, hash)); RelayInventory(CInv(MSG_BLOCK, hash));
// // Add atoms to user reviews for coins created // // Add atoms to user reviews for coins created
@ -2255,9 +2255,9 @@ bool SendMessages(CNode* pto)
// Delay tx inv messages to protect privacy, // Delay tx inv messages to protect privacy,
// trickle them out to a few nodes at a time. // trickle them out to a few nodes at a time.
bool fSendTxInv = false; bool fSendTxInv = false;
if (GetTimeMillis() - pto->nLastSentTxInv > 1800 + GetRand(200)) if (GetTimeMillis() > pto->nNextSendTxInv)
{ {
pto->nLastSentTxInv = GetTimeMillis(); pto->nNextSendTxInv = GetTimeMillis() + 3000 + GetRand(2000);
fSendTxInv = true; fSendTxInv = true;
} }

View File

@ -927,9 +927,7 @@ void ThreadOpenConnections2(void* parg)
continue; continue;
// Only try the old stuff if we don't have enough connections // Only try the old stuff if we don't have enough connections
if (vNodes.size() >= 2 && nSinceLastSeen > 7 * 24 * 60 * 60) if (vNodes.size() >= 8 && nSinceLastSeen > 24 * 60 * 60)
continue;
if (vNodes.size() >= 5 && nSinceLastSeen > 24 * 60 * 60)
continue; continue;
// If multiple addresses are ready, prioritize by time since // If multiple addresses are ready, prioritize by time since

43
net.h
View File

@ -45,6 +45,7 @@ bool StopNode();
// (4) message start // (4) message start
// (12) command // (12) command
// (4) size // (4) size
// (4) checksum
// The message start string is designed to be unlikely to occur in normal data. // The message start string is designed to be unlikely to occur in normal data.
// The characters are rarely used upper ascii, not valid as UTF-8, and produce // The characters are rarely used upper ascii, not valid as UTF-8, and produce
@ -58,6 +59,7 @@ public:
char pchMessageStart[sizeof(::pchMessageStart)]; char pchMessageStart[sizeof(::pchMessageStart)];
char pchCommand[COMMAND_SIZE]; char pchCommand[COMMAND_SIZE];
unsigned int nMessageSize; unsigned int nMessageSize;
//unsigned int nChecksum;
CMessageHeader() CMessageHeader()
{ {
@ -65,6 +67,7 @@ public:
memset(pchCommand, 0, sizeof(pchCommand)); memset(pchCommand, 0, sizeof(pchCommand));
pchCommand[1] = 1; pchCommand[1] = 1;
nMessageSize = -1; nMessageSize = -1;
//nChecksum = 0;
} }
CMessageHeader(const char* pszCommand, unsigned int nMessageSizeIn) CMessageHeader(const char* pszCommand, unsigned int nMessageSizeIn)
@ -79,6 +82,8 @@ public:
READWRITE(FLATDATA(pchMessageStart)); READWRITE(FLATDATA(pchMessageStart));
READWRITE(FLATDATA(pchCommand)); READWRITE(FLATDATA(pchCommand));
READWRITE(nMessageSize); READWRITE(nMessageSize);
//if (nVersion >= 209 && GetCommand() != "version")
// READWRITE(nChecksum);
) )
string GetCommand() string GetCommand()
@ -484,7 +489,8 @@ public:
int64 nLastRecv; int64 nLastRecv;
int64 nLastSendEmpty; int64 nLastSendEmpty;
int64 nTimeConnected; int64 nTimeConnected;
unsigned int nPushPos; unsigned int nHeaderStart;
unsigned int nMessageStart;
CAddress addr; CAddress addr;
int nVersion; int nVersion;
bool fClient; bool fClient;
@ -512,7 +518,7 @@ public:
vector<CInv> vInventoryToSend; vector<CInv> vInventoryToSend;
CCriticalSection cs_inventory; CCriticalSection cs_inventory;
multimap<int64, CInv> mapAskFor; multimap<int64, CInv> mapAskFor;
int64 nLastSentTxInv; int64 nNextSendTxInv;
// publish and subscription // publish and subscription
vector<char> vfSubscribe; vector<char> vfSubscribe;
@ -528,7 +534,8 @@ public:
nLastRecv = 0; nLastRecv = 0;
nLastSendEmpty = GetTime(); nLastSendEmpty = GetTime();
nTimeConnected = GetTime(); nTimeConnected = GetTime();
nPushPos = -1; nHeaderStart = -1;
nMessageStart = -1;
addr = addrIn; addr = addrIn;
nVersion = 0; nVersion = 0;
fClient = false; // set by version message fClient = false; // set by version message
@ -542,6 +549,7 @@ public:
pindexLastGetBlocksBegin = 0; pindexLastGetBlocksBegin = 0;
hashLastGetBlocksEnd = 0; hashLastGetBlocksEnd = 0;
fGetAddr = false; fGetAddr = false;
nNextSendTxInv = 0;
vfSubscribe.assign(256, false); vfSubscribe.assign(256, false);
// Push a version message // Push a version message
@ -639,10 +647,11 @@ public:
void BeginMessage(const char* pszCommand) void BeginMessage(const char* pszCommand)
{ {
cs_vSend.Enter(); cs_vSend.Enter();
if (nPushPos != -1) if (nHeaderStart != -1)
AbortMessage(); AbortMessage();
nPushPos = vSend.size(); nHeaderStart = vSend.size();
vSend << CMessageHeader(pszCommand, 0); vSend << CMessageHeader(pszCommand, 0);
nMessageStart = vSend.size();
if (fDebug) if (fDebug)
printf("%s ", DateTimeStrFormat("%x %H:%M:%S", GetTime()).c_str()); printf("%s ", DateTimeStrFormat("%x %H:%M:%S", GetTime()).c_str());
printf("sending: %s ", pszCommand); printf("sending: %s ", pszCommand);
@ -650,10 +659,11 @@ public:
void AbortMessage() void AbortMessage()
{ {
if (nPushPos == -1) if (nHeaderStart == -1)
return; return;
vSend.resize(nPushPos); vSend.resize(nHeaderStart);
nPushPos = -1; nHeaderStart = -1;
nMessageStart = -1;
cs_vSend.Leave(); cs_vSend.Leave();
printf("(aborted)\n"); printf("(aborted)\n");
} }
@ -667,25 +677,26 @@ public:
return; return;
} }
if (nPushPos == -1) if (nHeaderStart == -1)
return; return;
// Patch in the size // Patch in the size
unsigned int nSize = vSend.size() - nPushPos - sizeof(CMessageHeader); unsigned int nSize = vSend.size() - nMessageStart;
memcpy((char*)&vSend[nPushPos] + offsetof(CMessageHeader, nMessageSize), &nSize, sizeof(nSize)); memcpy((char*)&vSend[nHeaderStart] + offsetof(CMessageHeader, nMessageSize), &nSize, sizeof(nSize));
printf("(%d bytes) ", nSize); printf("(%d bytes) ", nSize);
printf("\n"); printf("\n");
nPushPos = -1; nHeaderStart = -1;
nMessageStart = -1;
cs_vSend.Leave(); cs_vSend.Leave();
} }
void EndMessageAbortIfEmpty() void EndMessageAbortIfEmpty()
{ {
if (nPushPos == -1) if (nHeaderStart == -1)
return; return;
int nSize = vSend.size() - nPushPos - sizeof(CMessageHeader); int nSize = vSend.size() - nMessageStart;
if (nSize > 0) if (nSize > 0)
EndMessage(); EndMessage();
else else
@ -694,9 +705,9 @@ public:
const char* GetMessageCommand() const const char* GetMessageCommand() const
{ {
if (nPushPos == -1) if (nHeaderStart == -1)
return ""; return "";
return &vSend[nPushPos] + offsetof(CMessageHeader, pchCommand); return &vSend[nHeaderStart] + offsetof(CMessageHeader, pchCommand);
} }

23
rpc.cpp
View File

@ -77,6 +77,18 @@ Value getconnectioncount(const Array& params)
} }
double GetDifficulty()
{
// Floating point number that is a multiple of the minimum difficulty,
// minimum difficulty = 1.0.
if (pindexBest == NULL)
return 1.0;
int nShift = 256 - 32 - 31; // to fit in a uint
double dMinimum = (CBigNum().SetCompact(bnProofOfWorkLimit.GetCompact()) >> nShift).getuint();
double dCurrently = (CBigNum().SetCompact(pindexBest->nBits) >> nShift).getuint();
return dMinimum / dCurrently;
}
Value getdifficulty(const Array& params) Value getdifficulty(const Array& params)
{ {
if (params.size() != 0) if (params.size() != 0)
@ -84,15 +96,7 @@ Value getdifficulty(const Array& params)
"getdifficulty (no parameters)\n" "getdifficulty (no parameters)\n"
"Returns the proof-of-work difficulty as a multiple of the minimum difficulty."); "Returns the proof-of-work difficulty as a multiple of the minimum difficulty.");
if (pindexBest == NULL) return GetDifficulty();
throw runtime_error("block chain not loaded");
// Floating point number that is a multiple of the minimum difficulty,
// minimum difficulty = 1.0.
int nShift = 256 - 32 - 31; // to fit in a uint
double dMinimum = (CBigNum().SetCompact(bnProofOfWorkLimit.GetCompact()) >> nShift).getuint();
double dCurrently = (CBigNum().SetCompact(pindexBest->nBits) >> nShift).getuint();
return dMinimum / dCurrently;
} }
@ -157,6 +161,7 @@ Value getinfo(const Array& params)
obj.push_back(Pair("proxy", (fUseProxy ? addrProxy.ToStringIPPort() : string()))); obj.push_back(Pair("proxy", (fUseProxy ? addrProxy.ToStringIPPort() : string())));
obj.push_back(Pair("generate", (bool)fGenerateBitcoins)); obj.push_back(Pair("generate", (bool)fGenerateBitcoins));
obj.push_back(Pair("genproclimit", (int)(fLimitProcessors ? nLimitProcessors : -1))); obj.push_back(Pair("genproclimit", (int)(fLimitProcessors ? nLimitProcessors : -1)));
obj.push_back(Pair("difficulty", (double)GetDifficulty()));
return obj; return obj;
} }

View File

@ -19,8 +19,8 @@ class CScript;
class CDataStream; class CDataStream;
class CAutoFile; class CAutoFile;
static const int VERSION = 207; static const int VERSION = 208;
static const char* pszSubVer = ".1"; static const char* pszSubVer = ".0";

15
ui.cpp
View File

@ -256,11 +256,20 @@ CMainFrame::CMainFrame(wxWindow* parent) : CMainFrameBase(parent)
m_staticTextBalance->SetLabel(FormatMoney(GetBalance()) + " "); m_staticTextBalance->SetLabel(FormatMoney(GetBalance()) + " ");
m_listCtrl->SetFocus(); m_listCtrl->SetFocus();
ptaskbaricon = new CMyTaskBarIcon(); ptaskbaricon = new CMyTaskBarIcon();
#ifdef __WXMAC__
// Mac automatically moves wxID_EXIT, wxID_PREFERENCES and wxID_ABOUT
// to their standard places, leaving these menus empty.
GetMenuBar()->Remove(2); // remove Help menu
GetMenuBar()->Remove(0); // remove File menu
#endif
// Init column headers // Init column headers
int nDateWidth = DateTimeStr(1229413914).size() * 6 + 8; int nDateWidth = DateTimeStr(1229413914).size() * 6 + 8;
if (!strstr(DateTimeStr(1229413914).c_str(), "2008")) if (!strstr(DateTimeStr(1229413914).c_str(), "2008"))
nDateWidth += 12; nDateWidth += 12;
#ifdef __WXMAC__
nDateWidth += 2;
#endif
wxListCtrl* pplistCtrl[] = {m_listCtrlAll, m_listCtrlSentReceived, m_listCtrlSent, m_listCtrlReceived}; wxListCtrl* pplistCtrl[] = {m_listCtrlAll, m_listCtrlSentReceived, m_listCtrlSent, m_listCtrlReceived};
foreach(wxListCtrl* p, pplistCtrl) foreach(wxListCtrl* p, pplistCtrl)
{ {
@ -274,7 +283,7 @@ CMainFrame::CMainFrame(wxWindow* parent) : CMainFrameBase(parent)
} }
// Init status bar // Init status bar
int pnWidths[3] = { -100, 88, 290 }; int pnWidths[3] = { -100, 88, 300 };
#ifndef __WXMSW__ #ifndef __WXMSW__
pnWidths[1] = pnWidths[1] * 1.1 * dResize; pnWidths[1] = pnWidths[1] * 1.1 * dResize;
pnWidths[2] = pnWidths[2] * 1.1 * dResize; pnWidths[2] = pnWidths[2] * 1.1 * dResize;
@ -2157,7 +2166,7 @@ CAddressBookDialog::CAddressBookDialog(wxWindow* parent, const wxString& strInit
bool fMine = (AddressToHash160(strAddress, hash160) && mapPubKeys.count(hash160)); bool fMine = (AddressToHash160(strAddress, hash160) && mapPubKeys.count(hash160));
wxListCtrl* plistCtrl = fMine ? m_listCtrlReceiving : m_listCtrlSending; wxListCtrl* plistCtrl = fMine ? m_listCtrlReceiving : m_listCtrlSending;
int nIndex = InsertLine(plistCtrl, strName, strAddress); int nIndex = InsertLine(plistCtrl, strName, strAddress);
if (strAddress == (fMine ? strDefaultReceiving : strInitSelected)) if (strAddress == (fMine ? strDefaultReceiving : string(strInitSelected)))
plistCtrl->SetItemState(nIndex, wxLIST_STATE_SELECTED|wxLIST_STATE_FOCUSED, wxLIST_STATE_SELECTED|wxLIST_STATE_FOCUSED); plistCtrl->SetItemState(nIndex, wxLIST_STATE_SELECTED|wxLIST_STATE_FOCUSED, wxLIST_STATE_SELECTED|wxLIST_STATE_FOCUSED);
} }
} }
@ -2444,7 +2453,7 @@ void CMyTaskBarIcon::OnMenuRestore(wxCommandEvent& event)
void CMyTaskBarIcon::OnMenuOptions(wxCommandEvent& event) void CMyTaskBarIcon::OnMenuOptions(wxCommandEvent& event)
{ {
// Since it's modal, get the main window to do it // Since it's modal, get the main window to do it
wxCommandEvent event2(wxEVT_COMMAND_MENU_SELECTED, wxID_MENUOPTIONSOPTIONS); wxCommandEvent event2(wxEVT_COMMAND_MENU_SELECTED, wxID_PREFERENCES);
pframeMain->GetEventHandler()->AddPendingEvent(event2); pframeMain->GetEventHandler()->AddPendingEvent(event2);
} }

View File

@ -24,7 +24,7 @@ CMainFrameBase::CMainFrameBase( wxWindow* parent, wxWindowID id, const wxString&
m_menuFile = new wxMenu(); m_menuFile = new wxMenu();
wxMenuItem* m_menuFileExit; wxMenuItem* m_menuFileExit;
m_menuFileExit = new wxMenuItem( m_menuFile, wxID_ANY, wxString( _("E&xit") ) , wxEmptyString, wxITEM_NORMAL ); m_menuFileExit = new wxMenuItem( m_menuFile, wxID_EXIT, wxString( _("E&xit") ) , wxEmptyString, wxITEM_NORMAL );
m_menuFile->Append( m_menuFileExit ); m_menuFile->Append( m_menuFileExit );
m_menubar->Append( m_menuFile, _("&File") ); m_menubar->Append( m_menuFile, _("&File") );
@ -39,14 +39,14 @@ CMainFrameBase::CMainFrameBase( wxWindow* parent, wxWindowID id, const wxString&
m_menuOptions->Append( m_menuOptionsChangeYourAddress ); m_menuOptions->Append( m_menuOptionsChangeYourAddress );
wxMenuItem* m_menuOptionsOptions; wxMenuItem* m_menuOptionsOptions;
m_menuOptionsOptions = new wxMenuItem( m_menuOptions, wxID_MENUOPTIONSOPTIONS, wxString( _("&Options...") ) , wxEmptyString, wxITEM_NORMAL ); m_menuOptionsOptions = new wxMenuItem( m_menuOptions, wxID_PREFERENCES, wxString( _("&Options...") ) , wxEmptyString, wxITEM_NORMAL );
m_menuOptions->Append( m_menuOptionsOptions ); m_menuOptions->Append( m_menuOptionsOptions );
m_menubar->Append( m_menuOptions, _("&Settings") ); m_menubar->Append( m_menuOptions, _("&Settings") );
m_menuHelp = new wxMenu(); m_menuHelp = new wxMenu();
wxMenuItem* m_menuHelpAbout; wxMenuItem* m_menuHelpAbout;
m_menuHelpAbout = new wxMenuItem( m_menuHelp, wxID_ANY, wxString( _("&About...") ) , wxEmptyString, wxITEM_NORMAL ); m_menuHelpAbout = new wxMenuItem( m_menuHelp, wxID_ABOUT, wxString( _("&About...") ) , wxEmptyString, wxITEM_NORMAL );
m_menuHelp->Append( m_menuHelpAbout ); m_menuHelp->Append( m_menuHelpAbout );
m_menubar->Append( m_menuHelp, _("&Help") ); m_menubar->Append( m_menuHelp, _("&Help") );
@ -133,7 +133,7 @@ CMainFrameBase::CMainFrameBase( wxWindow* parent, wxWindowID id, const wxString&
wxBoxSizer* bSizer11; wxBoxSizer* bSizer11;
bSizer11 = new wxBoxSizer( wxVERTICAL ); bSizer11 = new wxBoxSizer( wxVERTICAL );
m_listCtrlAll = new wxListCtrl( m_panel9, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxLC_NO_SORT_HEADER|wxLC_REPORT|wxLC_SORT_DESCENDING|wxVSCROLL ); m_listCtrlAll = new wxListCtrl( m_panel9, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxLC_NO_SORT_HEADER|wxLC_REPORT|wxLC_SORT_DESCENDING );
bSizer11->Add( m_listCtrlAll, 1, wxEXPAND, 5 ); bSizer11->Add( m_listCtrlAll, 1, wxEXPAND, 5 );
m_panel9->SetSizer( bSizer11 ); m_panel9->SetSizer( bSizer11 );
@ -144,7 +144,7 @@ CMainFrameBase::CMainFrameBase( wxWindow* parent, wxWindowID id, const wxString&
wxBoxSizer* bSizer111; wxBoxSizer* bSizer111;
bSizer111 = new wxBoxSizer( wxVERTICAL ); bSizer111 = new wxBoxSizer( wxVERTICAL );
m_listCtrlSentReceived = new wxListCtrl( m_panel91, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxLC_NO_SORT_HEADER|wxLC_REPORT|wxLC_SORT_DESCENDING|wxVSCROLL ); m_listCtrlSentReceived = new wxListCtrl( m_panel91, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxLC_NO_SORT_HEADER|wxLC_REPORT|wxLC_SORT_DESCENDING );
bSizer111->Add( m_listCtrlSentReceived, 1, wxEXPAND, 5 ); bSizer111->Add( m_listCtrlSentReceived, 1, wxEXPAND, 5 );
m_panel91->SetSizer( bSizer111 ); m_panel91->SetSizer( bSizer111 );
@ -155,7 +155,7 @@ CMainFrameBase::CMainFrameBase( wxWindow* parent, wxWindowID id, const wxString&
wxBoxSizer* bSizer112; wxBoxSizer* bSizer112;
bSizer112 = new wxBoxSizer( wxVERTICAL ); bSizer112 = new wxBoxSizer( wxVERTICAL );
m_listCtrlSent = new wxListCtrl( m_panel92, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxLC_NO_SORT_HEADER|wxLC_REPORT|wxLC_SORT_DESCENDING|wxVSCROLL ); m_listCtrlSent = new wxListCtrl( m_panel92, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxLC_NO_SORT_HEADER|wxLC_REPORT|wxLC_SORT_DESCENDING );
bSizer112->Add( m_listCtrlSent, 1, wxEXPAND, 5 ); bSizer112->Add( m_listCtrlSent, 1, wxEXPAND, 5 );
m_panel92->SetSizer( bSizer112 ); m_panel92->SetSizer( bSizer112 );
@ -166,7 +166,7 @@ CMainFrameBase::CMainFrameBase( wxWindow* parent, wxWindowID id, const wxString&
wxBoxSizer* bSizer113; wxBoxSizer* bSizer113;
bSizer113 = new wxBoxSizer( wxVERTICAL ); bSizer113 = new wxBoxSizer( wxVERTICAL );
m_listCtrlReceived = new wxListCtrl( m_panel93, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxLC_NO_SORT_HEADER|wxLC_REPORT|wxLC_SORT_DESCENDING|wxVSCROLL ); m_listCtrlReceived = new wxListCtrl( m_panel93, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxLC_NO_SORT_HEADER|wxLC_REPORT|wxLC_SORT_DESCENDING );
bSizer113->Add( m_listCtrlReceived, 1, wxEXPAND, 5 ); bSizer113->Add( m_listCtrlReceived, 1, wxEXPAND, 5 );
m_panel93->SetSizer( bSizer113 ); m_panel93->SetSizer( bSizer113 );

View File

@ -42,29 +42,28 @@
#define wxID_MAINFRAME 1000 #define wxID_MAINFRAME 1000
#define wxID_OPTIONSGENERATEBITCOINS 1001 #define wxID_OPTIONSGENERATEBITCOINS 1001
#define wxID_MENUOPTIONSOPTIONS 1002 #define wxID_BUTTONSEND 1002
#define wxID_BUTTONSEND 1003 #define wxID_BUTTONRECEIVE 1003
#define wxID_BUTTONRECEIVE 1004 #define wxID_TEXTCTRLADDRESS 1004
#define wxID_TEXTCTRLADDRESS 1005 #define wxID_BUTTONNEW 1005
#define wxID_BUTTONNEW 1006 #define wxID_BUTTONCOPY 1006
#define wxID_BUTTONCOPY 1007 #define wxID_TRANSACTIONFEE 1007
#define wxID_TRANSACTIONFEE 1008 #define wxID_PROXYIP 1008
#define wxID_PROXYIP 1009 #define wxID_PROXYPORT 1009
#define wxID_PROXYPORT 1010 #define wxID_TEXTCTRLPAYTO 1010
#define wxID_TEXTCTRLPAYTO 1011 #define wxID_BUTTONPASTE 1011
#define wxID_BUTTONPASTE 1012 #define wxID_BUTTONADDRESSBOOK 1012
#define wxID_BUTTONADDRESSBOOK 1013 #define wxID_TEXTCTRLAMOUNT 1013
#define wxID_TEXTCTRLAMOUNT 1014 #define wxID_CHOICETRANSFERTYPE 1014
#define wxID_CHOICETRANSFERTYPE 1015 #define wxID_LISTCTRL 1015
#define wxID_LISTCTRL 1016 #define wxID_BUTTONRENAME 1016
#define wxID_BUTTONRENAME 1017 #define wxID_PANELSENDING 1017
#define wxID_PANELSENDING 1018 #define wxID_LISTCTRLSENDING 1018
#define wxID_LISTCTRLSENDING 1019 #define wxID_PANELRECEIVING 1019
#define wxID_PANELRECEIVING 1020 #define wxID_LISTCTRLRECEIVING 1020
#define wxID_LISTCTRLRECEIVING 1021 #define wxID_BUTTONDELETE 1021
#define wxID_BUTTONDELETE 1022 #define wxID_BUTTONEDIT 1022
#define wxID_BUTTONEDIT 1023 #define wxID_TEXTCTRL 1023
#define wxID_TEXTCTRL 1024
/////////////////////////////////////////////////////////////////////////////// ///////////////////////////////////////////////////////////////////////////////
/// Class CMainFrameBase /// Class CMainFrameBase

View File

@ -123,7 +123,7 @@
<property name="checked">0</property> <property name="checked">0</property>
<property name="enabled">1</property> <property name="enabled">1</property>
<property name="help"></property> <property name="help"></property>
<property name="id">wxID_ANY</property> <property name="id">wxID_EXIT</property>
<property name="kind">wxITEM_NORMAL</property> <property name="kind">wxITEM_NORMAL</property>
<property name="label">E&amp;xit</property> <property name="label">E&amp;xit</property>
<property name="name">m_menuFileExit</property> <property name="name">m_menuFileExit</property>
@ -173,7 +173,7 @@
<property name="checked">0</property> <property name="checked">0</property>
<property name="enabled">1</property> <property name="enabled">1</property>
<property name="help"></property> <property name="help"></property>
<property name="id">wxID_MENUOPTIONSOPTIONS</property> <property name="id">wxID_PREFERENCES</property>
<property name="kind">wxITEM_NORMAL</property> <property name="kind">wxITEM_NORMAL</property>
<property name="label">&amp;Options...</property> <property name="label">&amp;Options...</property>
<property name="name">m_menuOptionsOptions</property> <property name="name">m_menuOptionsOptions</property>
@ -193,7 +193,7 @@
<property name="checked">0</property> <property name="checked">0</property>
<property name="enabled">1</property> <property name="enabled">1</property>
<property name="help"></property> <property name="help"></property>
<property name="id">wxID_ANY</property> <property name="id">wxID_ABOUT</property>
<property name="kind">wxITEM_NORMAL</property> <property name="kind">wxITEM_NORMAL</property>
<property name="label">&amp;About...</property> <property name="label">&amp;About...</property>
<property name="name">m_menuHelpAbout</property> <property name="name">m_menuHelpAbout</property>
@ -924,7 +924,7 @@
<property name="tooltip"></property> <property name="tooltip"></property>
<property name="window_extra_style"></property> <property name="window_extra_style"></property>
<property name="window_name"></property> <property name="window_name"></property>
<property name="window_style">wxVSCROLL</property> <property name="window_style"></property>
<event name="OnChar"></event> <event name="OnChar"></event>
<event name="OnEnterWindow"></event> <event name="OnEnterWindow"></event>
<event name="OnEraseBackground"></event> <event name="OnEraseBackground"></event>
@ -1047,7 +1047,7 @@
<property name="tooltip"></property> <property name="tooltip"></property>
<property name="window_extra_style"></property> <property name="window_extra_style"></property>
<property name="window_name"></property> <property name="window_name"></property>
<property name="window_style">wxVSCROLL</property> <property name="window_style"></property>
<event name="OnChar"></event> <event name="OnChar"></event>
<event name="OnEnterWindow"></event> <event name="OnEnterWindow"></event>
<event name="OnEraseBackground"></event> <event name="OnEraseBackground"></event>
@ -1170,7 +1170,7 @@
<property name="tooltip"></property> <property name="tooltip"></property>
<property name="window_extra_style"></property> <property name="window_extra_style"></property>
<property name="window_name"></property> <property name="window_name"></property>
<property name="window_style">wxVSCROLL</property> <property name="window_style"></property>
<event name="OnChar"></event> <event name="OnChar"></event>
<event name="OnEnterWindow"></event> <event name="OnEnterWindow"></event>
<event name="OnEraseBackground"></event> <event name="OnEraseBackground"></event>
@ -1293,7 +1293,7 @@
<property name="tooltip"></property> <property name="tooltip"></property>
<property name="window_extra_style"></property> <property name="window_extra_style"></property>
<property name="window_name"></property> <property name="window_name"></property>
<property name="window_style">wxVSCROLL</property> <property name="window_style"></property>
<event name="OnChar"></event> <event name="OnChar"></event>
<event name="OnEnterWindow"></event> <event name="OnEnterWindow"></event>
<event name="OnEraseBackground"></event> <event name="OnEraseBackground"></event>

View File

@ -314,6 +314,12 @@ string FormatMoney(int64 n, bool fPlus)
return str; return str;
} }
bool ParseMoney(const string& str, int64& nRet)
{
return ParseMoney(str.c_str(), nRet);
}
bool ParseMoney(const char* pszIn, int64& nRet) bool ParseMoney(const char* pszIn, int64& nRet)
{ {
string strWhole; string strWhole;

1
util.h
View File

@ -133,6 +133,7 @@ void PrintException(std::exception* pex, const char* pszThread);
void LogException(std::exception* pex, const char* pszThread); void LogException(std::exception* pex, const char* pszThread);
void ParseString(const string& str, char c, vector<string>& v); void ParseString(const string& str, char c, vector<string>& v);
string FormatMoney(int64 n, bool fPlus=false); string FormatMoney(int64 n, bool fPlus=false);
bool ParseMoney(const string& str, int64& nRet);
bool ParseMoney(const char* pszIn, int64& nRet); bool ParseMoney(const char* pszIn, int64& nRet);
vector<unsigned char> ParseHex(const char* psz); vector<unsigned char> ParseHex(const char* psz);
vector<unsigned char> ParseHex(const std::string& str); vector<unsigned char> ParseHex(const std::string& str);