Fix wxStyledTextCtrl compilation in non-Unicode build.
The value returned by wx2stc() in non-Unicode build is a simple "char*" and we can't call length() method on it, add a helper wx2stclen() function to get the length from the original wxString itself in this case. Closes #14013. git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@71428 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
		@@ -23,6 +23,15 @@ extern wxString stc2wx(const char* str);
 | 
				
			|||||||
extern wxString stc2wx(const char* str, size_t len);
 | 
					extern wxString stc2wx(const char* str, size_t len);
 | 
				
			||||||
extern const wxWX2MBbuf wx2stc(const wxString& str);
 | 
					extern const wxWX2MBbuf wx2stc(const wxString& str);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// This function takes both wxString and wxCharBuffer because it uses either
 | 
				
			||||||
 | 
					// one or the other of them depending on the build mode. In Unicode it uses the
 | 
				
			||||||
 | 
					// length of the already converted buffer to avoid doing the conversion again
 | 
				
			||||||
 | 
					// just to compute the length.
 | 
				
			||||||
 | 
					inline size_t wx2stclen(const wxString& WXUNUSED(str), const wxCharBuffer& buf)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    return buf.length() - 1;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#else // not UNICODE
 | 
					#else // not UNICODE
 | 
				
			||||||
 | 
					
 | 
				
			||||||
inline wxString stc2wx(const char* str) {
 | 
					inline wxString stc2wx(const char* str) {
 | 
				
			||||||
@@ -35,6 +44,12 @@ inline const wxWX2MBbuf wx2stc(const wxString& str) {
 | 
				
			|||||||
    return str.mbc_str();
 | 
					    return str.mbc_str();
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// As explained above, the buffer argument is only used in Unicode build.
 | 
				
			||||||
 | 
					inline size_t wx2stclen(const wxString& str, const char* WXUNUSED(buf))
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    return str.length();
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#endif // UNICODE
 | 
					#endif // UNICODE
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#endif // _WX_STC_PRIVATE_H_
 | 
					#endif // _WX_STC_PRIVATE_H_
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -259,7 +259,7 @@ void wxStyledTextCtrl::SetHScrollBar(wxScrollBar* bar)  {
 | 
				
			|||||||
// Add text to the document at current position.
 | 
					// Add text to the document at current position.
 | 
				
			||||||
void wxStyledTextCtrl::AddText(const wxString& text) {
 | 
					void wxStyledTextCtrl::AddText(const wxString& text) {
 | 
				
			||||||
                    wxWX2MBbuf buf = (wxWX2MBbuf)wx2stc(text);
 | 
					                    wxWX2MBbuf buf = (wxWX2MBbuf)wx2stc(text);
 | 
				
			||||||
                    SendMsg(2001, buf.length()-1, (sptr_t)(const char*)buf);
 | 
					                    SendMsg(2001, wx2stclen(text, buf), (sptr_t)(const char*)buf);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// Add array of cells to document.
 | 
					// Add array of cells to document.
 | 
				
			||||||
@@ -1709,7 +1709,7 @@ int wxStyledTextCtrl::GetTargetEnd() const
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
     int wxStyledTextCtrl::ReplaceTarget(const wxString& text) {
 | 
					     int wxStyledTextCtrl::ReplaceTarget(const wxString& text) {
 | 
				
			||||||
         wxWX2MBbuf buf = (wxWX2MBbuf)wx2stc(text);
 | 
					         wxWX2MBbuf buf = (wxWX2MBbuf)wx2stc(text);
 | 
				
			||||||
         return SendMsg(2194, buf.length()-1, (sptr_t)(const char*)buf);
 | 
					         return SendMsg(2194, wx2stclen(text, buf), (sptr_t)(const char*)buf);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// Replace the target text with the argument text after \d processing.
 | 
					// Replace the target text with the argument text after \d processing.
 | 
				
			||||||
@@ -1721,7 +1721,7 @@ int wxStyledTextCtrl::GetTargetEnd() const
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
     int wxStyledTextCtrl::ReplaceTargetRE(const wxString& text) {
 | 
					     int wxStyledTextCtrl::ReplaceTargetRE(const wxString& text) {
 | 
				
			||||||
         wxWX2MBbuf buf = (wxWX2MBbuf)wx2stc(text);
 | 
					         wxWX2MBbuf buf = (wxWX2MBbuf)wx2stc(text);
 | 
				
			||||||
         return SendMsg(2195, buf.length()-1, (sptr_t)(const char*)buf);
 | 
					         return SendMsg(2195, wx2stclen(text, buf), (sptr_t)(const char*)buf);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// Search for a counted string in the target and set the target to the found
 | 
					// Search for a counted string in the target and set the target to the found
 | 
				
			||||||
@@ -1730,7 +1730,7 @@ int wxStyledTextCtrl::GetTargetEnd() const
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
     int wxStyledTextCtrl::SearchInTarget(const wxString& text) {
 | 
					     int wxStyledTextCtrl::SearchInTarget(const wxString& text) {
 | 
				
			||||||
         wxWX2MBbuf buf = (wxWX2MBbuf)wx2stc(text);
 | 
					         wxWX2MBbuf buf = (wxWX2MBbuf)wx2stc(text);
 | 
				
			||||||
         return SendMsg(2197, buf.length()-1, (sptr_t)(const char*)buf);
 | 
					         return SendMsg(2197, wx2stclen(text, buf), (sptr_t)(const char*)buf);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// Set the search flags used by SearchInTarget.
 | 
					// Set the search flags used by SearchInTarget.
 | 
				
			||||||
@@ -2086,7 +2086,7 @@ bool wxStyledTextCtrl::GetUseVerticalScrollBar() const
 | 
				
			|||||||
// Append a string to the end of the document without changing the selection.
 | 
					// Append a string to the end of the document without changing the selection.
 | 
				
			||||||
void wxStyledTextCtrl::AppendText(const wxString& text) {
 | 
					void wxStyledTextCtrl::AppendText(const wxString& text) {
 | 
				
			||||||
                    wxWX2MBbuf buf = (wxWX2MBbuf)wx2stc(text);
 | 
					                    wxWX2MBbuf buf = (wxWX2MBbuf)wx2stc(text);
 | 
				
			||||||
                    SendMsg(2282, buf.length()-1, (sptr_t)(const char*)buf);
 | 
					                    SendMsg(2282, wx2stclen(text, buf), (sptr_t)(const char*)buf);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// Is drawing done in two phases with backgrounds drawn before foregrounds?
 | 
					// Is drawing done in two phases with backgrounds drawn before foregrounds?
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user