From 7326aa183463701a6f2868911c861aa65d8aca50 Mon Sep 17 00:00:00 2001 From: serr Date: Tue, 4 Feb 2025 20:15:11 +0300 Subject: [PATCH] =?UTF-8?q?=D0=BF=D0=BE=D1=84=D0=B8=D0=BA=D1=81=D0=B8?= =?UTF-8?q?=D0=BB=20=D0=B1=D0=B0=D0=B3=20=D1=81=20UP/DOWN=20=D1=81=20?= =?UTF-8?q?=D0=B1=D0=BE=D0=BB=D1=8C=D1=88=D0=BE=D0=B9=20=D1=81=D1=82=D1=80?= =?UTF-8?q?=D0=BE=D0=BA=D0=B8=20=D0=BD=D0=B0=20=D1=82=D1=83=20=D0=BA=D0=BE?= =?UTF-8?q?=D1=82=D0=BE=D1=80=D0=B0=D1=8F=20=D0=BC=D0=B5=D0=BD=D1=8C=D1=88?= =?UTF-8?q?=D0=B5?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- mvc/models.py | 38 ++++++++++++++++++-------------------- 1 file changed, 18 insertions(+), 20 deletions(-) diff --git a/mvc/models.py b/mvc/models.py index 088288e..60d7ead 100644 --- a/mvc/models.py +++ b/mvc/models.py @@ -46,19 +46,19 @@ class VimModel: self.displayBuffer[self.currentLine].insert(self.currentCol, chr(symbolCode)) self.currentCol += 1 - def MoveToLineStart(self) -> None: - """Переместить курсор в начало строки и сбросить прокрутку""" - self.currentCol = 0 - self.scrollX = 0 # Сброс горизонтальной прокрутки - - def MoveToLineEnd(self) -> None: - """Переместить курсор в конец строки с учетом прокрутки""" + def MoveToPositionWithScroll(self, position: int) -> None: + """ + Перемещает курсор в указанную позицию в текущей строке + и корректирует прокрутку, если это необходимо. + """ line_length = len(self.displayBuffer[self.currentLine]) - self.currentCol = line_length + self.currentCol = max(0, min(position, line_length)) - # Если строка длиннее экрана, корректируем прокрутку - if line_length > self.displayCols: - self.scrollX = max(0, line_length - self.displayCols + 1) + # Корректируем прокрутку, если курсор выходит за пределы видимой области + if self.currentCol < self.scrollX: + self.scrollX = self.currentCol # Прокрутка влево + elif self.currentCol >= self.scrollX + self.displayCols: + self.scrollX = self.currentCol - self.displayCols + 1 # Прокрутка вправо def EnterCommand(self): """Обработка введенной команды""" @@ -66,38 +66,36 @@ class VimModel: self.commandBuffer.clear() match cmd: case "$": - self.MoveToLineEnd() # Перемещение в конец строки + self.MoveToPositionWithScroll(len(self.displayBuffer[self.currentLine])) # Перемещение в конец строки return ReturnCode.GOOD case "^" | "0": - self.MoveToLineStart() # Перемещение в начало строки + self.MoveToPositionWithScroll(0) # Перемещение в начало строки return ReturnCode.GOOD case "q": return ReturnCode.EXIT_CODE case "i": return ReturnCode.SET_EDIT_MODE case "S": - self.MoveToLineStart() + self.MoveToPositionWithScroll(0) self.displayBuffer[self.currentLine] = [] return ReturnCode.SET_EDIT_MODE case "RIGHT": - if self.currentCol < len(self.displayBuffer[self.currentLine]): - self.currentCol += 1 + self.MoveToPositionWithScroll(self.currentCol + 1) return ReturnCode.GOOD case "LEFT": - if self.currentCol > 0: - self.currentCol -= 1 + self.MoveToPositionWithScroll(self.currentCol - 1) return ReturnCode.GOOD case "UP": if self.currentLine > 0: self.currentLine -= 1 if self.currentCol > len(self.displayBuffer[self.currentLine]): - self.currentCol = len(self.displayBuffer[self.currentLine]) + self.MoveToPositionWithScroll(len(self.displayBuffer[self.currentLine])) return ReturnCode.GOOD case "DOWN": if self.currentLine < len(self.displayBuffer) - 1: self.currentLine += 1 if self.currentCol > len(self.displayBuffer[self.currentLine]): - self.currentCol = len(self.displayBuffer[self.currentLine]) + self.MoveToPositionWithScroll(len(self.displayBuffer[self.currentLine])) return ReturnCode.GOOD def Enter(self) -> None: