1
0
mirror of https://github.com/chylex/IntelliJ-IdeaVim.git synced 2025-04-18 16:15:47 +02:00

Compare commits

..

21 Commits

Author SHA1 Message Date
0937234558
Set plugin version to chylex-43 2025-03-19 16:08:34 +01:00
4e1d7d4228
Remove notifications about configuration options 2025-03-19 16:08:34 +01:00
b5f7393e45
Exit insert mode after refactoring 2025-03-19 16:04:14 +01:00
522fee294f
Add action to run last macro in all opened files 2025-03-19 16:04:14 +01:00
300735a6da
Stop macro execution after a failed search 2025-03-19 16:04:14 +01:00
8d4f0d838f
Revert per-caret registers 2025-03-19 16:04:14 +01:00
325a655dbf
Fix(VIM-3364): Exception with mapped Generate action 2025-03-19 16:00:18 +01:00
85da8f7b8d
Apply scrolloff after executing native IDEA actions 2025-03-19 16:00:18 +01:00
bd2e1e5888
Stay on same line after reindenting 2025-03-19 16:00:18 +01:00
34a1845cc2
Update search register when using f/t 2025-03-19 16:00:18 +01:00
d02cc5960d
Automatically add unambiguous imports after running a macro 2025-03-19 16:00:17 +01:00
285053e530
Fix(VIM-3179): Respect virtual space below editor (imperfectly) 2025-03-19 16:00:17 +01:00
f9ea683c9a
Fix(VIM-3178): Workaround to support "Jump to Source" action mapping 2025-03-19 16:00:17 +01:00
d3f736a69e
Add support for count for visual and line motion surround 2025-03-19 16:00:17 +01:00
13bfc98ddf
Fix vim-surround not working with multiple cursors
Fixes multiple cursors with vim-surround commands `cs, ds, S` (but not `ys`).
2025-03-19 16:00:17 +01:00
05fd29c0ec
Fix(VIM-696) Restore visual mode after undo/redo, and disable incompatible actions 2025-03-19 16:00:17 +01:00
c8512a2e59
Respect count with <Action> mappings 2025-03-19 13:54:57 +01:00
cc1437092f
Change matchit plugin to use HTML patterns in unrecognized files 2025-03-19 13:54:57 +01:00
6d83464cd7
Reset insert mode when switching active editor 2025-03-19 13:54:57 +01:00
d5be9cc8b6
Remove update checker 2025-03-19 03:24:39 +01:00
6026b304c2
Set custom plugin version 2025-03-19 03:24:37 +01:00
4 changed files with 23 additions and 48 deletions

View File

@ -127,7 +127,7 @@ dependencies {
// AceJump is an optional dependency. We use their SessionManager class to check if it's active
plugin("AceJump", "3.8.19")
plugin("com.intellij.classic.ui", "243.21565.122")
plugin("com.intellij.classic.ui", "242.20224.159")
bundledPlugins("org.jetbrains.plugins.terminal", "com.intellij.modules.json")
}

View File

@ -16,11 +16,11 @@
# https://data.services.jetbrains.com/products?code=IC
# Maven releases are here: https://www.jetbrains.com/intellij-repository/releases
# And snapshots: https://www.jetbrains.com/intellij-repository/snapshots
ideaVersion=2024.3
ideaVersion=2024.3.3
# Values for type: https://plugins.jetbrains.com/docs/intellij/tools-gradle-intellij-plugin.html#intellij-extension-type
ideaType=IC
instrumentPluginCode=true
version=chylex-44
version=chylex-43
javaVersion=21
remoteRobotVersion=0.11.23
antlrVersion=4.10.1

View File

@ -17,7 +17,6 @@ import com.intellij.openapi.editor.markup.HighlighterLayer
import com.intellij.openapi.editor.markup.HighlighterTargetArea
import com.intellij.openapi.editor.markup.RangeHighlighter
import com.intellij.openapi.editor.markup.TextAttributes
import com.intellij.util.application
import com.maddyhome.idea.vim.api.VimEditor
import com.maddyhome.idea.vim.api.globalOptions
import com.maddyhome.idea.vim.api.injector
@ -31,7 +30,6 @@ import com.maddyhome.idea.vim.state.mode.inVisualMode
import org.jetbrains.annotations.Contract
import java.awt.Font
import java.util.*
import javax.swing.Timer
internal fun updateSearchHighlights(
pattern: String?,
@ -86,12 +84,6 @@ internal fun addSubstitutionConfirmationHighlight(editor: Editor, start: Int, en
)
}
val removeHighlightsEditors = mutableListOf<Editor>()
val removeHighlightsTimer = Timer(400) {
removeHighlightsEditors.forEach(::removeSearchHighlights)
removeHighlightsEditors.clear()
}
/**
* Refreshes current search highlights for all visible editors
*/
@ -133,43 +125,27 @@ private fun updateSearchHighlights(
// hlsearch (+ incsearch/noincsearch)
// Make sure the range fits this editor. Note that Vim will use the same range for all windows. E.g., given
// `:1,5s/foo`, Vim will highlight all occurrences of `foo` in the first five lines of all visible windows
val isSearching = injector.commandLine.getActiveCommandLine() != null
application.invokeLater {
val vimEditor = editor.vim
val editorLastLine = vimEditor.lineCount() - 1
val searchStartLine = searchRange?.startLine ?: 0
val searchEndLine = (searchRange?.endLine ?: -1).coerceAtMost(editorLastLine)
if (searchStartLine <= editorLastLine) {
val visibleArea = editor.scrollingModel.visibleAreaOnScrollingFinished
val visibleTopLeft = visibleArea.location
val visibleBottomRight = visibleArea.location.apply { translate(visibleArea.width, visibleArea.height) }
val visibleStartOffset = editor.logicalPositionToOffset(editor.xyToLogicalPosition(visibleTopLeft))
val visibleEndOffset = editor.logicalPositionToOffset(editor.xyToLogicalPosition(visibleBottomRight))
val visibleStartLine = editor.document.getLineNumber(visibleStartOffset)
val visibleEndLine = editor.document.getLineNumber(visibleEndOffset)
removeSearchHighlights(editor)
val results =
injector.searchHelper.findAll(
vimEditor,
pattern,
searchStartLine.coerceAtLeast(visibleStartLine),
searchEndLine.coerceAtMost(visibleEndLine),
shouldIgnoreCase(pattern, shouldIgnoreSmartCase)
)
if (results.isNotEmpty()) {
if (editor === currentEditor?.ij) {
currentMatchOffset = findClosestMatch(results, initialOffset, count1, forwards)
}
highlightSearchResults(editor, pattern, results, currentMatchOffset)
if (!isSearching) {
removeHighlightsEditors.add(editor)
removeHighlightsTimer.restart()
}
val vimEditor = editor.vim
val editorLastLine = vimEditor.lineCount() - 1
val searchStartLine = searchRange?.startLine ?: 0
val searchEndLine = (searchRange?.endLine ?: -1).coerceAtMost(editorLastLine)
if (searchStartLine <= editorLastLine) {
val results =
injector.searchHelper.findAll(
vimEditor,
pattern,
searchStartLine,
searchEndLine,
shouldIgnoreCase(pattern, shouldIgnoreSmartCase)
)
if (results.isNotEmpty()) {
if (editor === currentEditor?.ij) {
currentMatchOffset = findClosestMatch(results, initialOffset, count1, forwards)
}
highlightSearchResults(editor, pattern, results, currentMatchOffset)
}
editor.vimLastSearch = pattern
}
editor.vimLastSearch = pattern
} else if (shouldAddCurrentMatchSearchHighlight(pattern, showHighlights, initialOffset)) {
// nohlsearch + incsearch. Even though search highlights are disabled, we still show a highlight (current editor
// only), because 'incsearch' is active. But we don't show a search if Visual is active (behind Command-line of
@ -203,7 +179,6 @@ private fun updateSearchHighlights(
}
}
removeHighlightsTimer.restart()
return currentEditorCurrentMatchOffset
}
@ -229,7 +204,7 @@ private fun removeSearchHighlights(editor: Editor) {
*/
@Contract("_, _, false -> false; _, null, true -> false")
private fun shouldAddAllSearchHighlights(editor: Editor, newPattern: String?, hlSearch: Boolean): Boolean {
return hlSearch && newPattern != null && newPattern != ""
return hlSearch && newPattern != null && newPattern != editor.vimLastSearch && newPattern != ""
}
private fun findClosestMatch(

View File

@ -425,7 +425,7 @@ internal object VimListenerManager {
MotionGroup.fileEditorManagerSelectionChangedCallback(event)
FileGroup.fileEditorManagerSelectionChangedCallback(event)
// VimPlugin.getSearch().fileEditorManagerSelectionChangedCallback(event)
VimPlugin.getSearch().fileEditorManagerSelectionChangedCallback(event)
IjVimRedrawService.fileEditorManagerSelectionChangedCallback(event)
VimLastSelectedEditorTracker.setLastSelectedEditor(event.newEditor)
}