X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/589c1174f4dd9ccd5b7fc941e3d239888e1a8653..fcd209b6a20b41e7ddf9acf837311ac6779ea41f:/samples/ipc/server.cpp?ds=sidebyside diff --git a/samples/ipc/server.cpp b/samples/ipc/server.cpp index afe890aacf..4bd26352a2 100644 --- a/samples/ipc/server.cpp +++ b/samples/ipc/server.cpp @@ -324,25 +324,26 @@ MyConnection::OnRequest(const wxString& topic, { *size = 0; - wxString afterDate; + wxString s, + afterDate; if ( item.StartsWith("Date", &afterDate) ) { const wxDateTime now = wxDateTime::Now(); if ( afterDate.empty() ) { - m_requestData = now.Format(); + s = now.Format(); *size = wxNO_LEN; } else if ( afterDate == "+len" ) { - m_requestData = now.FormatTime() + " " + now.FormatDate(); - *size = strlen(m_requestData.mb_str()) + 1; + s = now.FormatTime() + " " + now.FormatDate(); + *size = strlen(s.mb_str()) + 1; } } else if ( item == "bytes[3]" ) { - m_requestData = "123"; + s = "123"; *size = 3; } @@ -352,7 +353,10 @@ MyConnection::OnRequest(const wxString& topic, return NULL; } - const void * const data = m_requestData.mb_str(); + // store the data pointer to which we return in a member variable to ensure + // that the pointer remains valid even after we return + m_requestData = s.mb_str(); + const void * const data = m_requestData; Log("OnRequest", topic, item, data, *size, format); return data; }