WriteText(value);
+ // mark the control as being not dirty - we changed its text, not the
+ // user
+ DiscardEdits();
+
// for compatibility, don't move the cursor when doing SetValue()
SetInsertionPoint(0);
}
}
-#if wxUSE_RICHEDIT && !wxUSE_UNICODE
+#if wxUSE_RICHEDIT && (!wxUSE_UNICODE || wxUSE_UNICODE_MSLU)
DWORD CALLBACK wxRichEditStreamIn(DWORD dwCookie, BYTE *buf, LONG cb, LONG *pcb)
{
extern long wxEncodingToCodepage(wxFontEncoding encoding); // from strconv.cpp
+#if wxUSE_UNICODE_MSLU
+bool wxTextCtrl::StreamIn(const wxString& value, wxFontEncoding WXUNUSED(encoding))
+{
+ const wchar_t *wpc = value.c_str();
+#else
bool wxTextCtrl::StreamIn(const wxString& value, wxFontEncoding encoding)
{
// we have to use EM_STREAMIN to force richedit control 2.0+ to show any
// finally, stream it in the control
const wchar_t *wpc = wchBuf;
+#endif // wxUSE_UNICODE_MSLU
EDITSTREAM eds;
wxZeroMemory(eds);
{
long start, end;
GetSelection(&start, &end);
- SetStyle(start, end, m_defaultStyle );
+ SetStyle(start, end, m_defaultStyle);
+ }
+
+#if wxUSE_UNICODE_MSLU
+ // RichEdit doesn't have Unicode version of EM_REPLACESEL on Win9x,
+ // but EM_STREAMIN works
+ if ( wxGetOsVersion() == wxWIN95 && GetRichVersion() > 1 )
+ {
+ done = StreamIn(valueDos, wxFONTENCODING_SYSTEM);
}
+#endif // wxUSE_UNICODE_MSLU
#if !wxUSE_UNICODE
// next check if the text we're inserting must be shown in a non
void wxTextCtrl::SetInsertionPoint(long pos)
{
SetSelection(pos, pos);
-
-#if wxUSE_RICHEDIT
- if ( !IsRich() )
-#endif
- {
- static const wxChar *nothing = _T("");
- SendMessage(GetHwnd(), EM_REPLACESEL, 0, (LPARAM)nothing);
- }
}
void wxTextCtrl::SetInsertionPointEnd()
if ( scrollCaret )
{
+#if wxUSE_RICHEDIT
+ // EM_SCROLLCARET doesn't work for me with the richedit controls
+ // unless it has focus although I don't see any mention of it in the
+ // docs - this is the only workaround I found. Of course it's not
+ // perfect as it adds the dummy focus set/kill events but it's still
+ // better than nothing
+ HWND hwndFocusOld;
+ if ( IsRich() )
+ {
+ hwndFocusOld = ::GetFocus();
+ if ( hwndFocusOld == GetHwnd() )
+ {
+ // don't change focus
+ hwndFocusOld = 0;
+ }
+
+ if ( hwndFocusOld )
+ {
+ ::SetFocus(GetHwnd());
+ }
+ }
+ else // not rich
+ {
+ hwndFocusOld = 0;
+ }
+#endif // wxUSE_RICHEDIT
+
SendMessage(hWnd, EM_SCROLLCARET, (WPARAM)0, (LPARAM)0);
+
+#if wxUSE_RICHEDIT
+ if ( hwndFocusOld )
+ {
+ ::SetFocus(hwndFocusOld);
+ }
+#endif // wxUSE_RICHEDIT
}
#else // Win16
// WPARAM is 0: selection is scrolled into view
void wxTextCtrl::Replace(long from, long to, const wxString& value)
{
// Set selection and remove it
- DoSetSelection(from, to, FALSE);
+ DoSetSelection(from, to, FALSE /* don't scroll caret into view */);
SendMessage(GetHwnd(), EM_REPLACESEL,
#ifdef __WIN32__
if ( changeSel )
{
- DoSetSelection(start, end, FALSE);
+ DoSetSelection(start, end, FALSE /* don't scroll caret into view */);
}
// initialize CHARFORMAT struct