mirror of
https://github.com/twisterarmy/twister-core.git
synced 2025-01-22 20:44:56 +00:00
Mac OS build fixes by laszlo
-- version 0.2.8 git-svn-id: https://bitcoin.svn.sourceforge.net/svnroot/bitcoin/trunk@76 1a98c847-1fd6-4fd8-948a-caf3550aa51b
This commit is contained in:
parent
966cca4bd4
commit
2d98de1b3a
8
init.cpp
8
init.cpp
@ -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__
|
||||||
|
6
main.cpp
6
main.cpp
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
4
net.cpp
4
net.cpp
@ -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
43
net.h
@ -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
23
rpc.cpp
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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
15
ui.cpp
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
14
uibase.cpp
14
uibase.cpp
@ -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 );
|
||||||
|
45
uibase.h
45
uibase.h
@ -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
|
||||||
|
@ -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&xit</property>
|
<property name="label">E&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">&Options...</property>
|
<property name="label">&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">&About...</property>
|
<property name="label">&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>
|
||||||
|
6
util.cpp
6
util.cpp
@ -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
1
util.h
@ -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);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user