Skip to content

Commit

Permalink
Fix #297
Browse files Browse the repository at this point in the history
  • Loading branch information
fox0430 committed Jun 1, 2019
1 parent 903e6ab commit 191f959
Show file tree
Hide file tree
Showing 3 changed files with 31 additions and 27 deletions.
13 changes: 11 additions & 2 deletions src/moepkg/editorstatus.nim
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,12 @@ import gapbuffer, editorview, ui, cursor, unicodeext, highlight, independentutil
type Mode* = enum
normal, insert, visual, visualBlock, replace, ex, filer, search, bufManager

type SelectArea* = object
startLine*: int
startColumn*: int
endLine*: int
endColumn*: int

type Registers* = object
yankedLines*: seq[seq[Rune]]
yankedStr*: seq[Rune]
Expand Down Expand Up @@ -44,6 +50,7 @@ type BufferStatus* = object
view*: EditorView
language*: SourceLanguage
cursor*: CursorPosition
selectArea*: SelectArea
isHighlight*: bool
filename*: seq[Rune]
openDir: seq[Rune]
Expand Down Expand Up @@ -266,13 +273,15 @@ proc update*(status: var EditorStatus) =
let
bufIndex = status.mainWindowInfo[i].bufferIndex
isCurrentMainWin = if i == status.currentMainWindow: true else: false
color = EditorColorPair.defaultChar
isLineNumber = status.settings.lineNumber
isCurrentLineNumber = status.settings.currentLineNumber
isCursorLine = status.settings.cursorLine
isVisualMode = if status.bufStatus[bufIndex].mode == Mode.visual or status.bufStatus[bufIndex].mode == Mode.visualBlock: true else: false
startSelectedLine = status.bufStatus[bufIndex].selectArea.startLine
endSelectedLine = status.bufStatus[bufIndex].selectArea.endLine

status.bufStatus[bufIndex].view.seekCursor(status.bufStatus[bufIndex].buffer, status.bufStatus[bufIndex].currentLine, status.bufStatus[bufIndex].currentColumn)
status.bufStatus[bufIndex].view.update(status.mainWindowInfo[i].window, isLineNumber, isCurrentLineNumber, isCursorLine, isCurrentMainWin, status.bufStatus[bufIndex].buffer, status.bufStatus[bufIndex].highlight, color, status.bufStatus[bufIndex].currentLine)
status.bufStatus[bufIndex].view.update(status.mainWindowInfo[i].window, isLineNumber, isCurrentLineNumber, isCursorLine, isCurrentMainWin, isVisualMode, status.bufStatus[bufIndex].buffer, status.bufStatus[bufIndex].highlight, status.bufStatus[bufIndex].currentLine, startSelectedLine, endSelectedLine)

status.bufStatus[bufIndex].cursor.update(status.bufStatus[bufIndex].view, status.bufStatus[bufIndex].currentLine, status.bufStatus[bufIndex].currentColumn)

Expand Down
22 changes: 11 additions & 11 deletions src/moepkg/editorview.nim
Original file line number Diff line number Diff line change
Expand Up @@ -176,9 +176,9 @@ proc write(view: EditorView, win: var Window, y, x: int, str: seq[Rune], color:
const tab = " "
win.write(y, x, ($str).replace("\t", tab), color, false)

proc writeAllLines*[T](view: var EditorView, win: var Window, lineNumber, currentLineNumber, cursorLine, currentWin: bool, buffer: T, highlight: Highlight, editorColor: EditorColorPair, currentLine: int) =
proc writeAllLines*[T](view: var EditorView, win: var Window, lineNumber, currentLineNumber, cursorLine, currentWin, isVisualMode: bool, buffer: T, highlight: Highlight, currentLine, startSelectedLine, endSelectedLine: int) =
win.erase
view.widthOfLineNum = if lineNumber: buffer.len.numberOfDigits+1 else: 0
view.widthOfLineNum = if lineNumber: buffer.len.numberOfDigits + 1 else: 0

let
start = (view.originalLine[0], view.start[0])
Expand All @@ -193,7 +193,9 @@ proc writeAllLines*[T](view: var EditorView, win: var Window, lineNumber, curren

var x = view.widthOfLineNum
if view.length[y] == 0:
view.write(win, y, x, view.lines[y], EditorColorPair.defaultChar)
if isVisualMode and (y >= startSelectedLine and endSelectedLine >= y):
view.write(win, y, x, ru" ", EditorColorPair.visualMode)
else: view.write(win, y, x, view.lines[y], EditorColorPair.defaultChar)
continue

while i < highlight.len and highlight[i].firstRow < view.originalLine[y]: inc(i)
Expand All @@ -220,19 +222,17 @@ proc writeAllLines*[T](view: var EditorView, win: var Window, lineNumber, curren
win.attroff(Attributes.underline)
else: view.write(win, y, x, str, highlight[i].color)
x += width(str)
if last == highlight[i].lastColumn - view.start[y]:
# consumed a whole segment
inc(i)
if last == highlight[i].lastColumn - view.start[y]: inc(i) # consumed a whole segment
else: break

win.refresh

proc update*[T](view: var EditorView, win: var Window, lineNumber, currentLineNumber, cursorLine, currentWin: bool, buffer: T, highlight: Highlight, editorColor: EditorColorPair, currentLine: int) =
let widthOfLineNum = buffer.len.intToStr.len+1
if lineNumber and widthOfLineNum != view.widthOfLineNum: view.resize(buffer, view.height, view.width+view.widthOfLineNum-widthOfLineNum, widthOfLineNum)
view.writeAllLines(win, lineNumber, currentLineNumber, cursorLine, currentWin, buffer, highlight, editorColor, currentLine)
proc update*[T](view: var EditorView, win: var Window, lineNumber, currentLineNumber, cursorLine, currentWin, isVisualMode: bool, buffer: T, highlight: Highlight, currentLine, startSelectedLine, endSelectedLine: int) =
let widthOfLineNum = buffer.len.intToStr.len + 1
if lineNumber and widthOfLineNum != view.widthOfLineNum: view.resize(buffer, view.height, view.width + view.widthOfLineNum - widthOfLineNum, widthOfLineNum)
view.writeAllLines(win, lineNumber, currentLineNumber, cursorLine, currentWin, isVisualMode, buffer, highlight, currentLine, startSelectedLine, endSelectedLine)
view.updated = false

proc seekCursor*[T](view: var EditorView, buffer: T, currentLine, currentColumn: int) =
while currentLine < view.originalLine[0] or (currentLine == view.originalLine[0] and view.length[0] > 0 and currentColumn < view.start[0]): view.scrollUp(buffer)
while (view.originalLine[view.height-1] != -1 and currentLine > view.originalLine[view.height-1]) or (currentLine == view.originalLine[view.height-1] and view.length[view.height-1] > 0 and currentColumn >= view.start[view.height-1]+view.length[view.height-1]): view.scrollDown(buffer)
while (view.originalLine[view.height - 1] != -1 and currentLine > view.originalLine[view.height - 1]) or (currentLine == view.originalLine[view.height - 1] and view.length[view.height - 1] > 0 and currentColumn >= view.start[view.height - 1]+view.length[view.height - 1]): view.scrollDown(buffer)
23 changes: 9 additions & 14 deletions src/moepkg/visualmode.nim
Original file line number Diff line number Diff line change
@@ -1,12 +1,6 @@
import terminal, strutils, sequtils
import editorstatus, editorview, ui, gapbuffer, normalmode, highlight, unicodeext

type SelectArea = object
startLine: int
startColumn: int
endLine: int
endColumn: int

proc initColorSegment(startLine, startColumn: int): ColorSegment =
result.firstRow = startLine
result.firstColumn = startColumn
Expand Down Expand Up @@ -187,18 +181,19 @@ proc visualBlockCommand(status: var EditorStatus, area: var SelectArea, key: Run

proc visualMode*(status: var EditorStatus) =
status.resize(terminalHeight(), terminalWidth())
let currentBuf = status.currentBuffer

var colorSegment = initColorSegment(status.bufStatus[status.currentBuffer].currentLine, status.bufStatus[status.currentBuffer].currentColumn)
var area = initSelectArea(status.bufStatus[status.currentBuffer].currentLine, status.bufStatus[status.currentBuffer].currentColumn)
status.bufStatus[currentBuf].selectArea = initSelectArea(status.bufStatus[status.currentBuffer].currentLine, status.bufStatus[status.currentBuffer].currentColumn)

while status.bufStatus[status.currentBuffer].mode == Mode.visual or status.bufStatus[status.currentBuffer].mode == Mode.visualBlock:
let isBlockMode = if status.bufStatus[status.currentBuffer].mode == Mode.visualBlock: true else: false

area.updateSelectArea(status.bufStatus[status.currentBuffer].currentLine, status.bufStatus[status.currentBuffer].currentColumn)
colorSegment.updateColorSegment(area)
status.bufStatus[currentBuf].selectArea.updateSelectArea(status.bufStatus[status.currentBuffer].currentLine, status.bufStatus[status.currentBuffer].currentColumn)
colorSegment.updateColorSegment(status.bufStatus[currentBuf].selectArea)

status.updatehighlight
if isBlockMode: status.bufStatus[status.currentBuffer].highlight.overwriteColorSegmentBlock(area, status.bufStatus[status.currentBuffer].buffer)
if isBlockMode: status.bufStatus[status.currentBuffer].highlight.overwriteColorSegmentBlock(status.bufStatus[currentBuf].selectArea, status.bufStatus[status.currentBuffer].buffer)
else: status.bufStatus[status.currentBuffer].highlight = status.bufStatus[status.currentBuffer].highlight.overwrite(colorSegment)

status.update
Expand Down Expand Up @@ -236,15 +231,15 @@ proc visualMode*(status: var EditorStatus) =
elif key == ord('g'):
if getKey(status.mainWindowInfo[status.currentMainWindow].window) == ord('g'): moveToFirstLine(status)
elif key == ord('i'):
status.bufStatus[status.currentBuffer].currentLine = area.startLine
status.bufStatus[status.currentBuffer].currentLine = status.bufStatus[currentBuf].selectArea.startLine
status.changeMode(Mode.insert)
elif key == ord('I'):
status.bufStatus[status.currentBuffer].currentLine = area.startLine
status.bufStatus[status.currentBuffer].currentLine = status.bufStatus[currentBuf].selectArea.startLine
status.bufStatus[status.currentBuffer].currentColumn = 0
status.changeMode(Mode.insert)

else:
if isBlockMode: visualBlockCommand(status, area, key)
else: visualCommand(status, area, key)
if isBlockMode: visualBlockCommand(status, status.bufStatus[currentBuf].selectArea, key)
else: visualCommand(status, status.bufStatus[currentBuf].selectArea, key)
status.updatehighlight
status.changeMode(Mode.normal)

0 comments on commit 191f959

Please sign in to comment.