From 1020896fac2373a74ab87373507183be5c90be28 Mon Sep 17 00:00:00 2001 From: Zwelf Date: Mon, 19 Jun 2017 12:28:50 +0200 Subject: [PATCH] added paste to text fields --- src/game/client/lineinput.cpp | 50 +++++++++++++++++++++++++++++------ src/game/client/lineinput.h | 2 +- 2 files changed, 43 insertions(+), 9 deletions(-) diff --git a/src/game/client/lineinput.cpp b/src/game/client/lineinput.cpp index 50f9f82db..9e2a1042e 100644 --- a/src/game/client/lineinput.cpp +++ b/src/game/client/lineinput.cpp @@ -37,7 +37,7 @@ void CLineInput::Set(const char *pString) } } -bool CLineInput::CtrlStop(char c) +bool CLineInput::MoveWordStop(char c) { // jump to spaces and special ASCII characters return ((32 <= c && c <= 47) || // !"#$%&'()*+,-./ @@ -55,7 +55,8 @@ bool CLineInput::Manipulate(IInput::CEvent Event, char *pStr, int StrMaxSize, in if(CursorPos > Len) CursorPos = Len; - if(Event.m_Flags&IInput::FLAG_TEXT) + if(Event.m_Flags&IInput::FLAG_TEXT && + !(KEY_LCTRL <= Event.m_Key && Event.m_Key <= KEY_RGUI)) { // gather string stats int CharCount = 0; @@ -89,13 +90,13 @@ bool CLineInput::Manipulate(IInput::CEvent Event, char *pStr, int StrMaxSize, in if(Event.m_Flags&IInput::FLAG_PRESS) { int Key = Event.m_Key; - bool Ctrl = false; + bool MoveWord = false; #ifdef CONF_PLATFORM_MACOSX if(pInput && (pInput->KeyIsPressed(KEY_LALT) || pInput->KeyIsPressed(KEY_RALT))) #else if(pInput && (pInput->KeyIsPressed(KEY_LCTRL) || pInput->KeyIsPressed(KEY_RCTRL))) #endif - Ctrl = true; + MoveWord = true; if(Key == KEY_BACKSPACE && CursorPos > 0) { int NewCursorPos = CursorPos; @@ -103,7 +104,7 @@ bool CLineInput::Manipulate(IInput::CEvent Event, char *pStr, int StrMaxSize, in { NewCursorPos = str_utf8_rewind(pStr, NewCursorPos); NumChars -= 1; - } while(Ctrl && NewCursorPos > 0 && !CtrlStop(pStr[NewCursorPos - 1])); + } while(MoveWord && NewCursorPos > 0 && !MoveWordStop(pStr[NewCursorPos - 1])); int CharSize = CursorPos-NewCursorPos; mem_move(pStr+NewCursorPos, pStr+CursorPos, Len - NewCursorPos - CharSize + 1); // +1 == null term CursorPos = NewCursorPos; @@ -117,7 +118,7 @@ bool CLineInput::Manipulate(IInput::CEvent Event, char *pStr, int StrMaxSize, in { EndCursorPos = str_utf8_forward(pStr, EndCursorPos); NumChars -= 1; - } while(Ctrl && EndCursorPos < Len && !CtrlStop(pStr[EndCursorPos - 1])); + } while(MoveWord && EndCursorPos < Len && !MoveWordStop(pStr[EndCursorPos - 1])); int CharSize = EndCursorPos - CursorPos; mem_move(pStr + CursorPos, pStr + CursorPos + CharSize, Len - CursorPos - CharSize + 1); // +1 == null term Len -= CharSize; @@ -128,19 +129,52 @@ bool CLineInput::Manipulate(IInput::CEvent Event, char *pStr, int StrMaxSize, in do { CursorPos = str_utf8_rewind(pStr, CursorPos); - } while(Ctrl && CursorPos > 0 && !CtrlStop(pStr[CursorPos - 1])); + } while(MoveWord && CursorPos > 0 && !MoveWordStop(pStr[CursorPos - 1])); } else if(Key == KEY_RIGHT && CursorPos < Len) { do { CursorPos = str_utf8_forward(pStr, CursorPos); - } while(Ctrl && CursorPos < Len && !CtrlStop(pStr[CursorPos - 1])); + } while(MoveWord && CursorPos < Len && !MoveWordStop(pStr[CursorPos - 1])); } else if(Key == KEY_HOME) CursorPos = 0; else if(Key == KEY_END) CursorPos = Len; + else if((pInput->KeyIsPressed(KEY_LCTRL) || pInput->KeyIsPressed(KEY_RCTRL)) && Key == KEY_V) + { + // paste clipboard to cursor + const char *pClipboardText = pInput->GetClipboardText(); + + // gather string stats + int CharCount = 0; + int CharSize = 0; + while(pClipboardText[CharSize]) + { + int NewCharSize = str_utf8_forward(pClipboardText, CharSize); + if(NewCharSize != CharSize) + { + ++CharCount; + CharSize = NewCharSize; + } + } + + // add new string + if(CharCount) + { + if(Len+CharSize < StrMaxSize && CursorPos+CharSize < StrMaxSize && NumChars+CharCount < StrMaxChars) + { + mem_move(pStr + CursorPos + CharSize, pStr + CursorPos, Len-CursorPos+1); // +1 == null term + for(int i = 0; i < CharSize; i++) + pStr[CursorPos+i] = pClipboardText[i]; + CursorPos += CharSize; + Len += CharSize; + NumChars += CharCount; + Changes = true; + } + } + } } *pNumCharsPtr = NumChars; diff --git a/src/game/client/lineinput.h b/src/game/client/lineinput.h index fae3a5ef4..526b25183 100644 --- a/src/game/client/lineinput.h +++ b/src/game/client/lineinput.h @@ -19,7 +19,7 @@ class CLineInput int m_NumChars; IInput *m_pInput; public: - static bool CtrlStop(char c); + static bool MoveWordStop(char c); static bool Manipulate(IInput::CEvent e, char *pStr, int StrMaxSize, int StrMaxChars, int *pStrLenPtr, int *pCursorPosPtr, int *pNumCharsPtr, IInput *pInput); class CCallback