- MGR: Fix the application name for both views.

NOTE: the data type 'char' should NOT be used within the various
        views. This is the classic example of how direct data access
        messes things up in projects with many developers. Use wxString
        with the PrintF method instead.

    clientgui/
        ViewWork.cpp
        ViewWorkGrid.cpp

svn path=/trunk/boinc/; revision=15574
This commit is contained in:
Rom Walton 2008-07-09 03:46:34 +00:00
parent cbde755a32
commit 0fd57fa3f6
3 changed files with 39 additions and 18 deletions

View File

@ -5588,3 +5588,14 @@ Eric K 8 July 2008
client/ client/
cs_platforms.C cs_platforms.C
Rom 8 July 2008
- MGR: Fix the application name for both views.
NOTE: the data type 'char' should NOT be used within the various
views. This is the classic example of how direct data access
messes things up in projects with many developers. Use wxString
with the PrintF method instead.
clientgui/
ViewWork.cpp
ViewWorkGrid.cpp

View File

@ -735,7 +735,8 @@ void CViewWork::GetDocApplicationName(wxInt32 item, wxString& strBuffer) const {
CMainDocument* pDoc = wxGetApp().GetDocument(); CMainDocument* pDoc = wxGetApp().GetDocument();
RESULT* result = wxGetApp().GetDocument()->result(item); RESULT* result = wxGetApp().GetDocument()->result(item);
RESULT* state_result = NULL; RESULT* state_result = NULL;
wxString strLocalBuffer; wxString strAppBuffer = wxEmptyString;
wxString strClassBuffer = wxEmptyString;
wxASSERT(pDoc); wxASSERT(pDoc);
wxASSERT(wxDynamicCast(pDoc, CMainDocument)); wxASSERT(wxDynamicCast(pDoc, CMainDocument));
@ -750,23 +751,27 @@ void CViewWork::GetDocApplicationName(wxInt32 item, wxString& strBuffer) const {
wxString strLocale = wxString(setlocale(LC_NUMERIC, NULL), wxConvUTF8); wxString strLocale = wxString(setlocale(LC_NUMERIC, NULL), wxConvUTF8);
setlocale(LC_NUMERIC, "C"); setlocale(LC_NUMERIC, "C");
if (state_result->wup->app->user_friendly_name.size()) { if (state_result->wup->app->user_friendly_name.size()) {
strLocalBuffer = HtmlEntityDecode(wxString(state_result->app->user_friendly_name.c_str(), wxConvUTF8)); strAppBuffer = HtmlEntityDecode(wxString(state_result->app->user_friendly_name.c_str(), wxConvUTF8));
} else { } else {
strLocalBuffer = HtmlEntityDecode(wxString(state_result->wup->avp->app_name.c_str(), wxConvUTF8)); strAppBuffer = HtmlEntityDecode(wxString(state_result->wup->avp->app_name.c_str(), wxConvUTF8));
} }
char buf[256];
if (state_result->wup->avp->plan_class.size()) { if (state_result->wup->avp->plan_class.size()) {
sprintf(buf, " (%s)", state_result->wup->avp->plan_class.c_str()); strClassBuffer.Printf(
} else { wxT(" (%s)"),
strcpy(buf, ""); wxString(state_result->wup->avp->plan_class.c_str(), wxConvUTF8)
);
} }
strBuffer.Printf( strBuffer.Printf(
wxT(" %s %.2f%s"), wxT(" %s %.2f%s"),
strLocalBuffer.c_str(), strAppBuffer.c_str(),
state_result->wup->avp->version_num/100.0, state_result->wup->avp->version_num/100.0,
buf strClassBuffer.c_str()
); );
setlocale(LC_NUMERIC, (const char*)strLocale.mb_str()); setlocale(LC_NUMERIC, (const char*)strLocale.mb_str());
} }
} }

View File

@ -599,7 +599,8 @@ wxInt32 CViewWorkGrid::FormatApplicationName(wxInt32 item, wxString& strBuffer)
CMainDocument* pDoc = wxGetApp().GetDocument(); CMainDocument* pDoc = wxGetApp().GetDocument();
RESULT* result = wxGetApp().GetDocument()->result(item); RESULT* result = wxGetApp().GetDocument()->result(item);
RESULT* state_result = NULL; RESULT* state_result = NULL;
wxString strLocalBuffer; wxString strAppBuffer = wxEmptyString;
wxString strClassBuffer = wxEmptyString;
wxASSERT(pDoc); wxASSERT(pDoc);
wxASSERT(wxDynamicCast(pDoc, CMainDocument)); wxASSERT(wxDynamicCast(pDoc, CMainDocument));
@ -614,23 +615,27 @@ wxInt32 CViewWorkGrid::FormatApplicationName(wxInt32 item, wxString& strBuffer)
wxString strLocale = wxString(setlocale(LC_NUMERIC, NULL), wxConvUTF8); wxString strLocale = wxString(setlocale(LC_NUMERIC, NULL), wxConvUTF8);
setlocale(LC_NUMERIC, "C"); setlocale(LC_NUMERIC, "C");
if (state_result->wup->app->user_friendly_name.size()) { if (state_result->wup->app->user_friendly_name.size()) {
strLocalBuffer = HtmlEntityDecode(wxString(state_result->app->user_friendly_name.c_str(), wxConvUTF8)); strAppBuffer = HtmlEntityDecode(wxString(state_result->app->user_friendly_name.c_str(), wxConvUTF8));
} else { } else {
strLocalBuffer = HtmlEntityDecode(wxString(state_result->wup->avp->app_name.c_str(), wxConvUTF8)); strAppBuffer = HtmlEntityDecode(wxString(state_result->wup->avp->app_name.c_str(), wxConvUTF8));
} }
char buf[256];
if (state_result->wup->avp->plan_class.size()) { if (state_result->wup->avp->plan_class.size()) {
sprintf(buf, " (%s)", state_result->wup->avp->plan_class.c_str()); strClassBuffer.Printf(
} else { wxT(" (%s)"),
strcpy(buf, ""); wxString(state_result->wup->avp->plan_class.c_str(), wxConvUTF8)
);
} }
strBuffer.Printf( strBuffer.Printf(
wxT(" %s %.2f%s"), wxT(" %s %.2f%s"),
strLocalBuffer.c_str(), strAppBuffer.c_str(),
state_result->wup->avp->version_num/100.0, state_result->wup->avp->version_num/100.0,
buf strClassBuffer.c_str()
); );
setlocale(LC_NUMERIC, (const char*)strLocale.mb_str()); setlocale(LC_NUMERIC, (const char*)strLocale.mb_str());
} }
return 0; return 0;