From 5c2f1e5111017c9429a6cc30d3685297b71fb7c8 Mon Sep 17 00:00:00 2001 From: sebthom Date: Wed, 21 Feb 2024 23:07:18 +0100 Subject: [PATCH] fix: OnEnterRules broken for indentOutdent #718 --- ...LanguageConfigurationAutoEditStrategy.java | 38 +++++++++++++------ 1 file changed, 26 insertions(+), 12 deletions(-) diff --git a/org.eclipse.tm4e.languageconfiguration/src/main/java/org/eclipse/tm4e/languageconfiguration/internal/LanguageConfigurationAutoEditStrategy.java b/org.eclipse.tm4e.languageconfiguration/src/main/java/org/eclipse/tm4e/languageconfiguration/internal/LanguageConfigurationAutoEditStrategy.java index 643d7547a..c096bc990 100644 --- a/org.eclipse.tm4e.languageconfiguration/src/main/java/org/eclipse/tm4e/languageconfiguration/internal/LanguageConfigurationAutoEditStrategy.java +++ b/org.eclipse.tm4e.languageconfiguration/src/main/java/org/eclipse/tm4e/languageconfiguration/internal/LanguageConfigurationAutoEditStrategy.java @@ -221,26 +221,40 @@ private static void onEnter(final CursorConfiguration cursorCfg, final IDocument if (enterAction != null) { command.shiftsCaret = false; final String newLine = command.text; - command.text = switch (enterAction.indentAction) { - case None // Nothing special - -> newLine + cursorCfg.normalizeIndentation(enterAction.indentation + enterAction.appendText); - case Indent // Indent once - -> newLine + cursorCfg.normalizeIndentation(enterAction.indentation + enterAction.appendText); - case IndentOutdent -> { + switch (enterAction.indentAction) { + case None: { + // Nothing special + final String increasedIndent = cursorCfg + .normalizeIndentation(enterAction.indentation + enterAction.appendText); + command.text = newLine + increasedIndent; + command.caretOffset = command.offset + command.text.length(); + break; + } + case Indent: { + // Indent once + final String increasedIndent = cursorCfg + .normalizeIndentation(enterAction.indentation + enterAction.appendText); + command.text = newLine + increasedIndent; + command.caretOffset = command.offset + command.text.length(); + break; + } + case IndentOutdent: { // Ultra special final String normalIndent = cursorCfg.normalizeIndentation(enterAction.indentation); final String increasedIndent = cursorCfg .normalizeIndentation(enterAction.indentation + enterAction.appendText); - yield newLine + increasedIndent + newLine + normalIndent; + command.text = newLine + increasedIndent + newLine + normalIndent; + command.caretOffset = command.offset + (newLine + increasedIndent).length(); + break; } - case Outdent -> { + case Outdent: final String indentation = getIndentationFromWhitespace(enterAction.indentation, cursorCfg); final String outdentedText = cursorCfg .outdentString(cursorCfg.normalizeIndentation(indentation + enterAction.appendText)); - yield newLine + outdentedText; - } - }; - command.caretOffset = command.offset + command.text.length(); + command.text = newLine + outdentedText; + command.caretOffset = command.offset + command.text.length(); + break; + } return; } }