mirror of https://github.com/BOINC/boinc.git
MGR: Use the skin's application short name instead of 'BOINC' for notices from the client.
MGR: Remove potential buffer overrun.
This commit is contained in:
parent
1e106d6fd7
commit
21349c19c0
|
@ -20,11 +20,18 @@
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "stdwx.h"
|
#include "stdwx.h"
|
||||||
|
#include "diagnostics.h"
|
||||||
|
#include "util.h"
|
||||||
|
#include "mfile.h"
|
||||||
|
#include "miofile.h"
|
||||||
|
#include "parse.h"
|
||||||
|
#include "error_numbers.h"
|
||||||
|
#include "wizardex.h"
|
||||||
|
#include "error_numbers.h"
|
||||||
|
#include "browser.h"
|
||||||
#include "Events.h"
|
#include "Events.h"
|
||||||
|
|
||||||
#include "str_replace.h"
|
|
||||||
|
|
||||||
#include "BOINCGUIApp.h"
|
#include "BOINCGUIApp.h"
|
||||||
|
#include "SkinManager.h"
|
||||||
#include "MainDocument.h"
|
#include "MainDocument.h"
|
||||||
#include "NoticeListCtrl.h"
|
#include "NoticeListCtrl.h"
|
||||||
#include "BOINCInternetFSHandler.h"
|
#include "BOINCInternetFSHandler.h"
|
||||||
|
@ -478,47 +485,62 @@ void CNoticeListCtrl::OnLinkClicked( wxHtmlLinkEvent& event )
|
||||||
|
|
||||||
wxString CNoticeListCtrl::OnGetItem(size_t i) const {
|
wxString CNoticeListCtrl::OnGetItem(size_t i) const {
|
||||||
CMainDocument* pDoc = wxGetApp().GetDocument();
|
CMainDocument* pDoc = wxGetApp().GetDocument();
|
||||||
|
CSkinAdvanced* pSkinAdvanced = wxGetApp().GetSkinManager()->GetAdvanced();
|
||||||
wxString strTitle = wxEmptyString;
|
wxString strTitle = wxEmptyString;
|
||||||
wxString strDescription = wxEmptyString;
|
wxString strDescription = wxEmptyString;
|
||||||
wxString strProjectName = wxEmptyString;
|
wxString strProjectName = wxEmptyString;
|
||||||
wxString strURL = wxEmptyString;
|
wxString strURL = wxEmptyString;
|
||||||
wxString create_time = wxEmptyString;
|
wxString strCreateTime = wxEmptyString;
|
||||||
|
wxString strCategory = wxEmptyString;
|
||||||
wxString strBuffer = wxEmptyString;
|
wxString strBuffer = wxEmptyString;
|
||||||
wxString strTemp = wxEmptyString;
|
wxString strTemp = wxEmptyString;
|
||||||
wxDateTime dtBuffer;
|
wxDateTime dtBuffer;
|
||||||
char buf[1024];
|
|
||||||
|
|
||||||
wxASSERT(pDoc);
|
wxASSERT(pDoc);
|
||||||
wxASSERT(wxDynamicCast(pDoc, CMainDocument));
|
wxASSERT(wxDynamicCast(pDoc, CMainDocument));
|
||||||
|
wxASSERT(pSkinAdvanced);
|
||||||
|
wxASSERT(wxDynamicCast(pSkinAdvanced, CSkinAdvanced));
|
||||||
|
|
||||||
if (pDoc->IsConnected()) {
|
if (pDoc->IsConnected()) {
|
||||||
NOTICE* np = pDoc->notice((unsigned int)i);
|
NOTICE* np = pDoc->notice((unsigned int)i);
|
||||||
|
|
||||||
|
strCategory = wxString(np->category, wxConvUTF8);
|
||||||
|
|
||||||
|
strProjectName = wxString(np->project_name, wxConvUTF8);
|
||||||
|
|
||||||
strURL = wxString(np->link, wxConvUTF8);
|
strURL = wxString(np->link, wxConvUTF8);
|
||||||
|
|
||||||
if (!strcmp(np->category, "client")) {
|
strTitle = wxString(np->title, wxConvUTF8);
|
||||||
if (strlen(np->project_name)) {
|
|
||||||
sprintf(buf, "%s: %s", np->project_name, "_(\"Notice from BOINC\")");
|
// Fix-up title
|
||||||
|
if (strCategory == wxT("client")) {
|
||||||
|
strBuffer.Printf(
|
||||||
|
wxT("_(\"Notice from %s\")"),
|
||||||
|
pSkinAdvanced->GetApplicationShortName()
|
||||||
|
);
|
||||||
|
if (strProjectName.size()) {
|
||||||
|
strTemp.Printf(wxT("%s: %s"), strProjectName.c_str(), strBuffer.c_str());
|
||||||
} else {
|
} else {
|
||||||
safe_strcpy(buf, "_(\"Notice from BOINC\")");
|
strTemp.Printf(wxT("%s"), strBuffer.c_str());
|
||||||
}
|
}
|
||||||
} else if (!strcmp(np->category, "scheduler")) {
|
} else if (strCategory == wxT("scheduler")) {
|
||||||
sprintf(buf, "%s: %s", np->project_name, "_(\"Notice from server\")");
|
strTemp.Printf(wxT("%s: %s"), strProjectName.c_str(), wxT("_(\"Notice from server\")"));
|
||||||
} else {
|
} else {
|
||||||
if (strlen(np->project_name)) {
|
if (strProjectName.size()) {
|
||||||
sprintf(buf, "%s: %s", np->project_name, np->title);
|
strTemp.Printf(wxT("%s: %s"), strProjectName.c_str(), strTitle.c_str());
|
||||||
} else {
|
} else {
|
||||||
safe_strcpy(buf, np->title);
|
strTemp = strTitle;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
strTitle = wxString(buf, wxConvUTF8);
|
|
||||||
|
strTitle = strTemp;
|
||||||
pDoc->LocalizeNoticeText(strTitle, true);
|
pDoc->LocalizeNoticeText(strTitle, true);
|
||||||
|
|
||||||
strDescription = wxString(np->description.c_str(), wxConvUTF8);
|
strDescription = wxString(np->description.c_str(), wxConvUTF8);
|
||||||
pDoc->LocalizeNoticeText(strDescription, true);
|
pDoc->LocalizeNoticeText(strDescription, true);
|
||||||
|
|
||||||
dtBuffer.Set((time_t)np->create_time);
|
dtBuffer.Set((time_t)np->create_time);
|
||||||
create_time = dtBuffer.Format();
|
strCreateTime = dtBuffer.Format();
|
||||||
|
|
||||||
strBuffer = wxT("<table border=0 cellpadding=5><tr><td>");
|
strBuffer = wxT("<table border=0 cellpadding=5><tr><td>");
|
||||||
|
|
||||||
|
@ -534,7 +556,7 @@ wxString CNoticeListCtrl::OnGetItem(size_t i) const {
|
||||||
|
|
||||||
strBuffer += wxT("<br><font size=-2 color=#8f8f8f>");
|
strBuffer += wxT("<br><font size=-2 color=#8f8f8f>");
|
||||||
|
|
||||||
strBuffer += create_time;
|
strBuffer += strCreateTime;
|
||||||
|
|
||||||
if (!strURL.IsEmpty()) {
|
if (!strURL.IsEmpty()) {
|
||||||
strTemp.Printf(
|
strTemp.Printf(
|
||||||
|
|
Loading…
Reference in New Issue