mirror of
https://github.com/chylex/IntelliJ-AceJump.git
synced 2025-09-16 07:24:50 +02:00
Compare commits
8 Commits
43dfec940e
...
vim
Author | SHA1 | Date | |
---|---|---|---|
568128f474
|
|||
018d29007c
|
|||
cb814e0999
|
|||
1fc06e8120
|
|||
841f2fd125
|
|||
6c8f19e311
|
|||
ce4f3b5f03
|
|||
46f42c88eb
|
@@ -8,7 +8,7 @@ plugins {
|
||||
}
|
||||
|
||||
group = "org.acejump"
|
||||
version = "chylex-23"
|
||||
version = "chylex-26"
|
||||
|
||||
repositories {
|
||||
mavenCentral()
|
||||
@@ -18,7 +18,7 @@ intellij {
|
||||
version.set("2024.2")
|
||||
updateSinceUntilBuild.set(false)
|
||||
|
||||
plugins.add("IdeaVIM:chylex-40")
|
||||
plugins.add("IdeaVIM:chylex-41")
|
||||
plugins.add("com.intellij.classic.ui:242.20224.159")
|
||||
|
||||
pluginsRepositories {
|
||||
|
@@ -16,7 +16,7 @@ import com.maddyhome.idea.vim.group.visual.vimSetSelection
|
||||
import com.maddyhome.idea.vim.helper.inVisualMode
|
||||
import com.maddyhome.idea.vim.helper.vimSelectionStart
|
||||
import com.maddyhome.idea.vim.newapi.vim
|
||||
import com.maddyhome.idea.vim.state.mode.Mode
|
||||
import com.maddyhome.idea.vim.state.mode.Mode.OP_PENDING
|
||||
import com.maddyhome.idea.vim.state.mode.SelectionType
|
||||
import org.acejump.boundaries.StandardBoundaries.AFTER_CARET
|
||||
import org.acejump.boundaries.StandardBoundaries.BEFORE_CARET
|
||||
@@ -52,8 +52,8 @@ sealed class AceVimAction : DumbAwareAction() {
|
||||
}
|
||||
else {
|
||||
val vim = editor.vim
|
||||
val keyHandler = KeyHandler.getInstance()
|
||||
if (keyHandler.isOperatorPending(vim.mode, keyHandler.keyHandlerState)) {
|
||||
if (vim.mode is OP_PENDING) {
|
||||
val keyHandler = KeyHandler.getInstance()
|
||||
val key = keyHandler.keyHandlerState.commandBuilder.keys.singleOrNull()?.keyChar
|
||||
|
||||
keyHandler.fullReset(vim)
|
||||
@@ -71,10 +71,10 @@ sealed class AceVimAction : DumbAwareAction() {
|
||||
if (action != null) {
|
||||
ApplicationManager.getApplication().invokeLater {
|
||||
WriteAction.run<Nothing> {
|
||||
keyHandler.keyHandlerState.commandBuilder.pushCommandPart(action)
|
||||
keyHandler.keyHandlerState.commandBuilder.addAction(action)
|
||||
|
||||
val cmd = keyHandler.keyHandlerState.commandBuilder.buildCommand()
|
||||
val operatorArguments = OperatorArguments(vim.mode is Mode.OP_PENDING, cmd.rawCount, injector.vimState.mode)
|
||||
val operatorArguments = OperatorArguments(vim.mode is OP_PENDING, cmd.rawCount, injector.vimState.mode)
|
||||
|
||||
injector.vimState.executingCommand = cmd
|
||||
injector.actionExecutor.executeVimAction(vim, action, context, operatorArguments)
|
||||
|
@@ -18,6 +18,11 @@ sealed class EditorOffsetCache {
|
||||
*/
|
||||
abstract fun visibleArea(editor: Editor): Pair<Point, Point>
|
||||
|
||||
/**
|
||||
* Returns whether the offset is in the visible area rectangle.
|
||||
*/
|
||||
abstract fun isVisible(editor: Editor, offset: Int): Boolean
|
||||
|
||||
/**
|
||||
* Returns the editor offset at the provided pixel coordinate.
|
||||
*/
|
||||
@@ -36,6 +41,7 @@ sealed class EditorOffsetCache {
|
||||
|
||||
private class Cache : EditorOffsetCache() {
|
||||
private var visibleArea: Pair<Point, Point>? = null
|
||||
private val lineToVisibleOffsetRange = Int2ObjectOpenHashMap<IntRange>()
|
||||
private val pointToOffset = Object2IntOpenHashMap<Point>().apply { defaultReturnValue(-1) }
|
||||
private val offsetToPoint = Int2ObjectOpenHashMap<Point>()
|
||||
|
||||
@@ -43,6 +49,24 @@ sealed class EditorOffsetCache {
|
||||
return visibleArea ?: Uncached.visibleArea(editor).also { visibleArea = it }
|
||||
}
|
||||
|
||||
override fun isVisible(editor: Editor, offset: Int): Boolean {
|
||||
val visualLine = editor.offsetToVisualLine(offset, false)
|
||||
|
||||
var visibleRange = lineToVisibleOffsetRange.get(visualLine)
|
||||
if (visibleRange == null) {
|
||||
val (topLeft, bottomRight) = visibleArea(editor)
|
||||
val lineY = editor.visualLineToY(visualLine)
|
||||
|
||||
val firstVisibleOffset = xyToOffset(editor, Point(topLeft.x, lineY))
|
||||
val lastVisibleOffset = xyToOffset(editor, Point(bottomRight.x, lineY))
|
||||
|
||||
visibleRange = firstVisibleOffset..lastVisibleOffset
|
||||
lineToVisibleOffsetRange.put(visualLine, visibleRange)
|
||||
}
|
||||
|
||||
return offset in visibleRange
|
||||
}
|
||||
|
||||
override fun xyToOffset(editor: Editor, pos: Point): Int {
|
||||
val offset = pointToOffset.getInt(pos)
|
||||
|
||||
@@ -51,7 +75,6 @@ sealed class EditorOffsetCache {
|
||||
}
|
||||
|
||||
return Uncached.xyToOffset(editor, pos).also {
|
||||
@Suppress("ReplacePutWithAssignment")
|
||||
pointToOffset.put(pos, it)
|
||||
}
|
||||
}
|
||||
@@ -64,7 +87,6 @@ sealed class EditorOffsetCache {
|
||||
}
|
||||
|
||||
return Uncached.offsetToXY(editor, offset).also {
|
||||
@Suppress("ReplacePutWithAssignment")
|
||||
offsetToPoint.put(offset, it)
|
||||
}
|
||||
}
|
||||
@@ -80,6 +102,15 @@ sealed class EditorOffsetCache {
|
||||
)
|
||||
}
|
||||
|
||||
override fun isVisible(editor: Editor, offset: Int): Boolean {
|
||||
val (topLeft, bottomRight) = visibleArea(editor)
|
||||
val pos = offsetToXY(editor, offset)
|
||||
val x = pos.x
|
||||
val y = pos.y
|
||||
|
||||
return x >= topLeft.x && y >= topLeft.y && x <= bottomRight.x && y <= bottomRight.y
|
||||
}
|
||||
|
||||
override fun xyToOffset(editor: Editor, pos: Point): Int {
|
||||
return editor.logicalPositionToOffset(editor.xyToLogicalPosition(pos))
|
||||
}
|
||||
|
@@ -13,23 +13,7 @@ enum class StandardBoundaries : Boundaries {
|
||||
}
|
||||
|
||||
override fun isOffsetInside(editor: Editor, offset: Int, cache: EditorOffsetCache): Boolean {
|
||||
|
||||
// If we are not using a cache, calling getOffsetRange will cause additional 1-2 pixel coordinate -> offset lookups, which is a lot
|
||||
// more expensive than one lookup compared against the visible area.
|
||||
|
||||
// However, if we are using a cache, it's likely that the topmost and bottommost positions are already cached whereas the provided
|
||||
// offset isn't, so we save a lookup for every offset outside the range.
|
||||
|
||||
if (cache !== EditorOffsetCache.Uncached && offset !in getOffsetRange(editor, cache)) {
|
||||
return false
|
||||
}
|
||||
|
||||
val (topLeft, bottomRight) = cache.visibleArea(editor)
|
||||
val pos = cache.offsetToXY(editor, offset)
|
||||
val x = pos.x
|
||||
val y = pos.y
|
||||
|
||||
return x >= topLeft.x && y >= topLeft.y && x <= bottomRight.x && y <= bottomRight.y
|
||||
return cache.isVisible(editor, offset)
|
||||
}
|
||||
},
|
||||
|
||||
|
@@ -20,6 +20,7 @@ class AceConfig : PersistentStateComponent<AceSettings> {
|
||||
|
||||
val layout get() = settings.layout
|
||||
val minQueryLength get() = settings.minQueryLength
|
||||
val invertUppercaseMode get() = settings.invertUppercaseMode
|
||||
val editorFadeOpacity get() = settings.editorFadeOpacity
|
||||
val jumpModeColor get() = settings.jumpModeColor
|
||||
val tagForegroundColor1 get() = settings.tagForegroundColor1
|
||||
|
@@ -15,6 +15,7 @@ class AceConfigurable : Configurable {
|
||||
panel.allowedChars != settings.allowedChars ||
|
||||
panel.keyboardLayout != settings.layout ||
|
||||
panel.minQueryLengthInt != settings.minQueryLength ||
|
||||
panel.invertUppercaseMode != settings.invertUppercaseMode ||
|
||||
panel.editorFadeOpacityPercent != settings.editorFadeOpacity ||
|
||||
panel.jumpModeColor != settings.jumpModeColor ||
|
||||
panel.tagForegroundColor1 != settings.tagForegroundColor1 ||
|
||||
@@ -25,6 +26,7 @@ class AceConfigurable : Configurable {
|
||||
settings.allowedChars = panel.allowedChars
|
||||
settings.layout = panel.keyboardLayout
|
||||
settings.minQueryLength = panel.minQueryLengthInt ?: settings.minQueryLength
|
||||
settings.invertUppercaseMode = panel.invertUppercaseMode
|
||||
settings.editorFadeOpacity = panel.editorFadeOpacityPercent
|
||||
panel.jumpModeColor?.let { settings.jumpModeColor = it }
|
||||
panel.tagForegroundColor1?.let { settings.tagForegroundColor1 = it }
|
||||
|
@@ -8,6 +8,7 @@ import java.awt.Color
|
||||
data class AceSettings(
|
||||
var layout: KeyLayout = QWERTY,
|
||||
var allowedChars: String = layout.allChars,
|
||||
var invertUppercaseMode: Boolean = false,
|
||||
var minQueryLength: Int = 1,
|
||||
var editorFadeOpacity: Int = 70,
|
||||
|
||||
|
@@ -2,6 +2,7 @@ package org.acejump.config
|
||||
|
||||
import com.intellij.openapi.ui.ComboBox
|
||||
import com.intellij.ui.ColorPanel
|
||||
import com.intellij.ui.components.JBCheckBox
|
||||
import com.intellij.ui.components.JBSlider
|
||||
import com.intellij.ui.components.JBTextArea
|
||||
import com.intellij.ui.components.JBTextField
|
||||
@@ -30,6 +31,7 @@ internal class AceSettingsPanel {
|
||||
private val keyboardLayoutCombo = ComboBox<KeyLayout>()
|
||||
private val keyboardLayoutArea = JBTextArea().apply { isEditable = false }
|
||||
private val minQueryLengthField = JBTextField()
|
||||
private val invertUppercaseModeCheckBox = JBCheckBox("Invert uppercase mode")
|
||||
private val editorFadeOpacitySlider = JBSlider(0, 10).apply {
|
||||
labelTable = Hashtable((0..10).associateWith { JLabel("${it * 10}") })
|
||||
paintTrack = true
|
||||
@@ -59,6 +61,7 @@ internal class AceSettingsPanel {
|
||||
|
||||
group("Behavior") {
|
||||
row("Minimum typed characters (1-10):") { cell(minQueryLengthField).columns(COLUMNS_SHORT) }
|
||||
row { cell(invertUppercaseModeCheckBox) }
|
||||
}
|
||||
|
||||
group("Colors") {
|
||||
@@ -83,6 +86,7 @@ internal class AceSettingsPanel {
|
||||
internal var keyboardLayout by keyboardLayoutCombo
|
||||
internal var keyChars by keyboardLayoutArea
|
||||
internal var minQueryLength by minQueryLengthField
|
||||
internal var invertUppercaseMode by invertUppercaseModeCheckBox
|
||||
internal var editorFadeOpacity by editorFadeOpacitySlider
|
||||
internal var jumpModeColor by jumpModeColorWheel
|
||||
internal var tagForegroundColor1 by tagForeground1ColorWheel
|
||||
@@ -101,6 +105,7 @@ internal class AceSettingsPanel {
|
||||
allowedChars = settings.allowedChars
|
||||
keyboardLayout = settings.layout
|
||||
minQueryLength = settings.minQueryLength.toString()
|
||||
invertUppercaseMode = settings.invertUppercaseMode
|
||||
editorFadeOpacityPercent = settings.editorFadeOpacity
|
||||
jumpModeColor = settings.jumpModeColor
|
||||
tagForegroundColor1 = settings.tagForegroundColor1
|
||||
|
@@ -10,7 +10,6 @@ import com.intellij.openapi.editor.actionSystem.TypedActionHandler
|
||||
* sessions' own handlers.
|
||||
*/
|
||||
internal object EditorKeyListener : TypedActionHandler {
|
||||
private val action = TypedAction.getInstance()
|
||||
private val attached = mutableMapOf<Editor, TypedActionHandler>()
|
||||
private var originalHandler: TypedActionHandler? = null
|
||||
|
||||
@@ -20,8 +19,9 @@ internal object EditorKeyListener : TypedActionHandler {
|
||||
|
||||
fun attach(editor: Editor, callback: TypedActionHandler) {
|
||||
if (attached.isEmpty()) {
|
||||
originalHandler = action.rawHandler
|
||||
action.setupRawHandler(this)
|
||||
val typedAction = TypedAction.getInstance()
|
||||
originalHandler = typedAction.rawHandler
|
||||
typedAction.setupRawHandler(this)
|
||||
}
|
||||
|
||||
attached[editor] = callback
|
||||
@@ -31,7 +31,7 @@ internal object EditorKeyListener : TypedActionHandler {
|
||||
attached.remove(editor)
|
||||
|
||||
if (attached.isEmpty()) {
|
||||
originalHandler?.let(action::setupRawHandler)
|
||||
originalHandler?.let(TypedAction.getInstance()::setupRawHandler)
|
||||
originalHandler = null
|
||||
}
|
||||
}
|
||||
|
@@ -3,6 +3,7 @@ package org.acejump.search
|
||||
import com.intellij.openapi.editor.Editor
|
||||
import it.unimi.dsi.fastutil.ints.IntArrayList
|
||||
import org.acejump.boundaries.Boundaries
|
||||
import org.acejump.boundaries.EditorOffsetCache
|
||||
import org.acejump.clone
|
||||
import org.acejump.config.AceConfig
|
||||
import org.acejump.immutableText
|
||||
@@ -11,15 +12,16 @@ import org.acejump.matchesAt
|
||||
/**
|
||||
* Searches editor text for matches of a [SearchQuery], and updates previous results when the user [refineQuery]s a character.
|
||||
*/
|
||||
class SearchProcessor private constructor(query: SearchQuery, val boundaries: Boundaries, private val results: MutableMap<Editor, IntArrayList>) {
|
||||
internal constructor(editors: List<Editor>, query: SearchQuery, boundaries: Boundaries) : this(query, boundaries, mutableMapOf()) {
|
||||
val regex = query.toRegex()
|
||||
class SearchProcessor private constructor(query: SearchQuery, val boundaries: Boundaries, val invertUppercaseMode: Boolean, private val results: MutableMap<Editor, IntArrayList>) {
|
||||
internal constructor(editors: List<Editor>, query: SearchQuery, boundaries: Boundaries, invertUppercaseMode: Boolean) : this(query, boundaries, invertUppercaseMode, mutableMapOf()) {
|
||||
val regex = query.toRegex(invertUppercaseMode)
|
||||
|
||||
if (regex != null) {
|
||||
for (editor in editors) {
|
||||
val cache = EditorOffsetCache.new()
|
||||
val offsets = IntArrayList()
|
||||
|
||||
val offsetRange = boundaries.getOffsetRange(editor)
|
||||
val offsetRange = boundaries.getOffsetRange(editor, cache)
|
||||
var result = regex.find(editor.immutableText, offsetRange.first)
|
||||
|
||||
while (result != null) {
|
||||
@@ -29,7 +31,7 @@ class SearchProcessor private constructor(query: SearchQuery, val boundaries: Bo
|
||||
if (highlightEnd > offsetRange.last) {
|
||||
break
|
||||
}
|
||||
else if (boundaries.isOffsetInside(editor, index) && !editor.foldingModel.isOffsetCollapsed(index)) {
|
||||
else if (boundaries.isOffsetInside(editor, index, cache) && !editor.foldingModel.isOffsetCollapsed(index)) {
|
||||
offsets.add(index)
|
||||
}
|
||||
|
||||
|
@@ -21,7 +21,7 @@ internal sealed class SearchQuery {
|
||||
/**
|
||||
* Converts the query into a regular expression to find the initial matches.
|
||||
*/
|
||||
abstract fun toRegex(): Regex?
|
||||
abstract fun toRegex(invertUppercaseMode: Boolean): Regex?
|
||||
|
||||
/**
|
||||
* Searches for all occurrences of a literal text query.
|
||||
@@ -41,14 +41,14 @@ internal sealed class SearchQuery {
|
||||
return text.countMatchingCharacters(offset, rawText)
|
||||
}
|
||||
|
||||
override fun toRegex(): Regex {
|
||||
override fun toRegex(invertUppercaseMode: Boolean): Regex {
|
||||
val firstChar = rawText.first()
|
||||
val pattern = if (firstChar.isLowerCase()) {
|
||||
val pattern = if (firstChar.isLowerCase() xor invertUppercaseMode) {
|
||||
val fullPattern = Regex.escape(rawText)
|
||||
"(?i)$fullPattern"
|
||||
}
|
||||
else {
|
||||
val firstCharUppercasePattern = Regex.escape(firstChar.toString())
|
||||
val firstCharUppercasePattern = Regex.escape(firstChar.uppercase())
|
||||
val firstCharLowercasePattern = Regex.escape(firstChar.lowercase())
|
||||
val remainingPattern = if (rawText.length > 1) Regex.escape(rawText.drop(1)) else ""
|
||||
"(?:$firstCharUppercasePattern|(?<![a-zA-Z])$firstCharLowercasePattern)$remainingPattern"
|
||||
@@ -72,7 +72,7 @@ internal sealed class SearchQuery {
|
||||
return 1
|
||||
}
|
||||
|
||||
override fun toRegex(): Regex {
|
||||
override fun toRegex(invertUppercaseMode: Boolean): Regex {
|
||||
return Regex(pattern, setOf(RegexOption.MULTILINE, RegexOption.IGNORE_CASE))
|
||||
}
|
||||
}
|
||||
|
@@ -3,6 +3,7 @@ package org.acejump.search
|
||||
import com.google.common.collect.ArrayListMultimap
|
||||
import com.intellij.openapi.editor.Editor
|
||||
import it.unimi.dsi.fastutil.ints.IntList
|
||||
import it.unimi.dsi.fastutil.objects.Object2IntOpenHashMap
|
||||
import org.acejump.boundaries.EditorOffsetCache
|
||||
import org.acejump.boundaries.StandardBoundaries.VISIBLE_ON_SCREEN
|
||||
import org.acejump.input.KeyLayoutCache
|
||||
@@ -40,7 +41,7 @@ class Tagger(private val editors: List<Editor>, results: Map<Editor, IntList>) {
|
||||
.flatMap { (editor, sites) -> sites.map { site -> Tag(editor, site) } }
|
||||
.sortedWith(siteOrder(editors, caches))
|
||||
|
||||
tagMap = generateTags(tagSites).zip(tagSites).toMap()
|
||||
tagMap = generateTags(tagSites.size).zip(tagSites).toMap()
|
||||
}
|
||||
|
||||
internal fun type(char: Char): TaggingResult {
|
||||
@@ -61,13 +62,15 @@ class Tagger(private val editors: List<Editor>, results: Map<Editor, IntList>) {
|
||||
}
|
||||
|
||||
private companion object {
|
||||
private fun generateTags(tagSites: List<Tag>): List<String> {
|
||||
private fun generateTags(tagCount: Int): List<String> {
|
||||
val allowedTagsSorted = KeyLayoutCache.allowedTagsSorted
|
||||
val tags = mutableListOf<String>()
|
||||
|
||||
val containedSingleCharTags = mutableSetOf<Char>()
|
||||
val blockedSingleCharTags = mutableSetOf<Char>()
|
||||
val doubleCharTagCountsByFirstChar = Object2IntOpenHashMap<Char>()
|
||||
|
||||
for (tag in KeyLayoutCache.allowedTagsSorted) {
|
||||
for (tag in allowedTagsSorted) {
|
||||
val firstChar = tag.first()
|
||||
|
||||
if (tag.length == 1) {
|
||||
@@ -83,15 +86,41 @@ class Tagger(private val editors: List<Editor>, results: Map<Editor, IntList>) {
|
||||
}
|
||||
|
||||
blockedSingleCharTags.add(firstChar)
|
||||
doubleCharTagCountsByFirstChar.addTo(firstChar, 1)
|
||||
}
|
||||
|
||||
tags.add(tag)
|
||||
|
||||
if (tags.size >= tagSites.size) {
|
||||
return tags
|
||||
if (tags.size >= tagCount) {
|
||||
break
|
||||
}
|
||||
}
|
||||
|
||||
// In rare cases, the final tag list may contain a double character tag that is the only tag starting with its first character,
|
||||
// so we replace it with the single character tag.
|
||||
for (entry in doubleCharTagCountsByFirstChar.object2IntEntrySet()) {
|
||||
if (entry.intValue != 1) {
|
||||
continue
|
||||
}
|
||||
|
||||
tags.removeAt(tags.indexOfFirst { it.first() == entry.key })
|
||||
|
||||
val tag = entry.key.toString()
|
||||
var previousTagIndex = -1
|
||||
|
||||
// The implementation of searching where to place the single character tag is theoretically slow,
|
||||
// but getting here is so rare it doesn't matter.
|
||||
for (i in allowedTagsSorted.indexOf(tag) - 1 downTo 0) {
|
||||
previousTagIndex = tags.indexOf(allowedTagsSorted[i])
|
||||
|
||||
if (previousTagIndex != -1) {
|
||||
break
|
||||
}
|
||||
}
|
||||
|
||||
tags.add(previousTagIndex + 1, tag)
|
||||
}
|
||||
|
||||
return tags
|
||||
}
|
||||
|
||||
|
@@ -113,7 +113,7 @@ class Session(private val mainEditor: Editor, private val jumpEditors: List<Edit
|
||||
}
|
||||
|
||||
setMode(mode())
|
||||
state = SessionState.WaitForKey(actions, jumpEditors, defaultBoundary)
|
||||
state = SessionState.WaitForKey(actions, jumpEditors, defaultBoundary, AceConfig.invertUppercaseMode)
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -128,7 +128,7 @@ class Session(private val mainEditor: Editor, private val jumpEditors: List<Edit
|
||||
canvas.setMarkers(emptyList())
|
||||
}
|
||||
|
||||
val processor = SearchProcessor(jumpEditors, SearchQuery.RegularExpression(pattern.regex), defaultBoundary)
|
||||
val processor = SearchProcessor(jumpEditors, SearchQuery.RegularExpression(pattern.regex), defaultBoundary, AceConfig.invertUppercaseMode)
|
||||
textHighlighter.renderOccurrences(processor.resultsCopy, processor.query)
|
||||
|
||||
state = SessionState.SelectTag(actions, jumpEditors, processor)
|
||||
|
@@ -16,9 +16,10 @@ sealed interface SessionState {
|
||||
private val actions: SessionActions,
|
||||
private val jumpEditors: List<Editor>,
|
||||
private val defaultBoundary: Boundaries,
|
||||
private val invertUppercaseMode: Boolean,
|
||||
) : SessionState {
|
||||
override fun type(char: Char): TypeResult {
|
||||
val searchProcessor = SearchProcessor(jumpEditors, SearchQuery.Literal(char.toString()), defaultBoundary)
|
||||
val searchProcessor = SearchProcessor(jumpEditors, SearchQuery.Literal(char.toString()), defaultBoundary, invertUppercaseMode)
|
||||
|
||||
return if (searchProcessor.isQueryFinished) {
|
||||
TypeResult.ChangeState(SelectTag(actions, jumpEditors, searchProcessor))
|
||||
@@ -72,10 +73,14 @@ sealed interface SessionState {
|
||||
else -> searchProcessor.boundaries
|
||||
}
|
||||
|
||||
val newSearchProcessor = SearchProcessor(jumpEditors, query, newBoundaries)
|
||||
val newSearchProcessor = SearchProcessor(jumpEditors, query, newBoundaries, searchProcessor.invertUppercaseMode)
|
||||
return TypeResult.ChangeState(SelectTag(actions, jumpEditors, newSearchProcessor))
|
||||
}
|
||||
}
|
||||
else if (char == '\n') {
|
||||
val newSearchProcessor = SearchProcessor(jumpEditors, searchProcessor.query, searchProcessor.boundaries, !searchProcessor.invertUppercaseMode)
|
||||
return TypeResult.ChangeState(SelectTag(actions, jumpEditors, newSearchProcessor))
|
||||
}
|
||||
|
||||
return when (val result = tagger.type(AceConfig.layout.characterRemapping.getOrDefault(char, char))) {
|
||||
is TaggingResult.Nothing -> TypeResult.Nothing
|
||||
|
Reference in New Issue
Block a user