Fixed compatibility with older IntelliJ versions. Minimum version now 2019.3.5, though. Converted a few missing files from Java to Kotlin.

This commit is contained in:
Chris Hodges 2021-07-20 14:25:41 +02:00
parent 25245bea10
commit 3319fc1c45
9 changed files with 62 additions and 107 deletions

View File

@ -1,4 +1,4 @@
# MC68000 Assembly Language Plugin [![Build Status](https://travis-ci.com/chrisly42/mc68000-asm-plugin.svg?branch=master)](https://travis-ci.com/chrisly42/mc68000-asm-plugin) [![Coverage Status](https://coveralls.io/repos/github/chrisly42/mc68000-asm-plugin/badge.svg?branch=master)](https://coveralls.io/github/chrisly42/mc68000-asm-plugin?branch=master) # MC68000 Assembly Language Plugin [![Build Status](https://travis-ci.com/chrisly42/mc68000-asm-plugin.svg?branch=main)](https://travis-ci.com/chrisly42/mc68000-asm-plugin) [![Coverage Status](https://coveralls.io/repos/github/chrisly42/mc68000-asm-plugin/badge.svg?branch=main)](https://coveralls.io/github/chrisly42/mc68000-asm-plugin?branch=main)
_MC68000 Assembly Language Plugin_ is plugin for Jetbrains IDEs (CLion, IntelliJ, etc.). _MC68000 Assembly Language Plugin_ is plugin for Jetbrains IDEs (CLion, IntelliJ, etc.).
@ -67,4 +67,4 @@ make it work with JUnit 5. Feel free to use the code (in package ```de.platon42.
### V0.1 (20-Jun-21) ### V0.1 (20-Jun-21)
- Initial release. - Initial public release.

View File

@ -46,9 +46,9 @@ intellij {
patchPluginXml { patchPluginXml {
setChangeNotes(""" setChangeNotes("""
<h4>V0.1 (xx-Jun-21)</h4> <h4>V0.1 (20-Jun-21)</h4>
<ul> <ul>
<li>Initial. <li>Initial public release.
</ul> </ul>
<p>Full changelog available at <a href="https://github.com/chrisly42/mc68000-asm-plugin#changelog">Github project site</a>.</p> <p>Full changelog available at <a href="https://github.com/chrisly42/mc68000-asm-plugin#changelog">Github project site</a>.</p>
""") """)

View File

@ -1,36 +1,27 @@
package de.platon42.intellij.plugins.m68k; package de.platon42.intellij.plugins.m68k
import com.intellij.psi.PsiFile; import com.intellij.psi.PsiFile
import com.intellij.psi.StubBuilder; import com.intellij.psi.stubs.DefaultStubBuilder
import com.intellij.psi.stubs.DefaultStubBuilder; import com.intellij.psi.stubs.StubElement
import com.intellij.psi.stubs.StubElement; import com.intellij.psi.tree.IStubFileElementType
import com.intellij.psi.tree.IStubFileElementType; import de.platon42.intellij.plugins.m68k.psi.M68kFile
import de.platon42.intellij.plugins.m68k.psi.M68kFile; import de.platon42.intellij.plugins.m68k.stubs.M68kFileStub
import de.platon42.intellij.plugins.m68k.stubs.M68kFileStub;
import org.jetbrains.annotations.NotNull;
public class M68kFileElementType extends IStubFileElementType<M68kFileStub> { class M68kFileElementType private constructor() : IStubFileElementType<M68kFileStub>("MC68000_FILE", MC68000Language.INSTANCE) {
public static final IStubFileElementType<M68kFileStub> INSTANCE = new M68kFileElementType();
public static final int VERSION = 1;
private M68kFileElementType() { companion object {
super("MC68000_FILE", MC68000Language.Companion.getINSTANCE()); @JvmField
val INSTANCE = M68kFileElementType()
const val STUB_VERSION = 1
} }
@Override override fun getStubVersion() = STUB_VERSION
public int getStubVersion() {
return VERSION;
}
@Override override fun getBuilder() =
public StubBuilder getBuilder() { object : DefaultStubBuilder() {
return new DefaultStubBuilder() { override fun createStubForFile(file: PsiFile): StubElement<*> {
return if (file is M68kFile) M68kFileStub(file) else super.createStubForFile(file)
@Override
protected @NotNull StubElement createStubForFile(@NotNull PsiFile file) {
if (file instanceof M68kFile) return new M68kFileStub((M68kFile) file);
return super.createStubForFile(file);
} }
};
} }
} }

View File

@ -5,8 +5,7 @@ import de.platon42.intellij.plugins.m68k.M68kIcons.FILE
import org.jetbrains.annotations.NonNls import org.jetbrains.annotations.NonNls
import javax.swing.Icon import javax.swing.Icon
@Suppress("unused") class M68kFileType private constructor() : LanguageFileType(MC68000Language.INSTANCE) {
class M68kFileType private constructor() : LanguageFileType(MC68000Language.INSTANCE, false) {
@NonNls @NonNls
override fun getName(): String { override fun getName(): String {
return "MC68000 Assembler" return "MC68000 Assembler"

View File

@ -1,10 +1,6 @@
package de.platon42.intellij.plugins.m68k; package de.platon42.intellij.plugins.m68k
import com.intellij.codeInsight.editorActions.SimpleTokenSetQuoteHandler; import com.intellij.codeInsight.editorActions.SimpleTokenSetQuoteHandler
import de.platon42.intellij.plugins.m68k.psi.M68kTypes; import de.platon42.intellij.plugins.m68k.psi.M68kTypes
public class M68kStringQuoteHandler extends SimpleTokenSetQuoteHandler { class M68kStringQuoteHandler : SimpleTokenSetQuoteHandler(M68kTypes.STRINGLIT)
public M68kStringQuoteHandler() {
super(M68kTypes.STRINGLIT);
}
}

View File

@ -1,68 +1,40 @@
package de.platon42.intellij.plugins.m68k.parser; package de.platon42.intellij.plugins.m68k.parser
import com.intellij.lang.ASTNode; import com.intellij.lang.ASTNode
import com.intellij.lang.ParserDefinition; import com.intellij.lang.ParserDefinition
import com.intellij.lang.PsiParser; import com.intellij.lexer.Lexer
import com.intellij.lexer.Lexer; import com.intellij.openapi.project.Project
import com.intellij.openapi.project.Project; import com.intellij.psi.FileViewProvider
import com.intellij.psi.FileViewProvider; import com.intellij.psi.tree.TokenSet
import com.intellij.psi.PsiElement; import de.platon42.intellij.plugins.m68k.M68kFileElementType
import com.intellij.psi.PsiFile; import de.platon42.intellij.plugins.m68k.lexer.M68kLexer
import com.intellij.psi.tree.IFileElementType; import de.platon42.intellij.plugins.m68k.lexer.M68kLexerPrefs
import com.intellij.psi.tree.TokenSet; import de.platon42.intellij.plugins.m68k.psi.M68kFile
import de.platon42.intellij.plugins.m68k.M68kFileElementType; import de.platon42.intellij.plugins.m68k.psi.M68kTypes
import de.platon42.intellij.plugins.m68k.lexer.M68kLexer;
import de.platon42.intellij.plugins.m68k.lexer.M68kLexerPrefs;
import de.platon42.intellij.plugins.m68k.psi.M68kFile;
import de.platon42.intellij.plugins.m68k.psi.M68kTypes;
import org.jetbrains.annotations.NotNull;
public class M68kParserDefinition implements ParserDefinition { class M68kParserDefinition : ParserDefinition {
public static final TokenSet STRING_LITERALS = TokenSet.create(M68kTypes.STRINGLIT);
public static final TokenSet COMMENTS = TokenSet.create(M68kTypes.COMMENT);
private M68kLexerPrefs lexerPrefs = new M68kLexerPrefs(); // TODO make this configurable val lexerPrefs = M68kLexerPrefs() // TODO make this configurable
public M68kParserDefinition() { override fun createLexer(project: Project): Lexer {
}
public M68kLexerPrefs getLexerPrefs() {
return lexerPrefs;
}
@Override
public @NotNull Lexer createLexer(Project project) {
// TODO take prefs from project somehow // TODO take prefs from project somehow
return new M68kLexer(lexerPrefs); return M68kLexer(lexerPrefs)
} }
@Override override fun createParser(project: Project) = M68kParser()
public @NotNull PsiParser createParser(Project project) {
return new M68kParser();
}
@Override override fun getFileNodeType() = M68kFileElementType.INSTANCE
public @NotNull IFileElementType getFileNodeType() {
return M68kFileElementType.INSTANCE;
}
@Override override fun getCommentTokens() = COMMENTS
public @NotNull TokenSet getCommentTokens() {
return COMMENTS;
}
@Override override fun getStringLiteralElements() = STRING_LITERALS
public @NotNull TokenSet getStringLiteralElements() {
return STRING_LITERALS;
}
@Override override fun createElement(node: ASTNode) = M68kTypes.Factory.createElement(node)
public @NotNull PsiElement createElement(ASTNode node) {
return M68kTypes.Factory.createElement(node);
}
@Override override fun createFile(viewProvider: FileViewProvider) = M68kFile(viewProvider)
public @NotNull PsiFile createFile(@NotNull FileViewProvider viewProvider) {
return new M68kFile(viewProvider); companion object {
val STRING_LITERALS = TokenSet.create(M68kTypes.STRINGLIT)
val COMMENTS = TokenSet.create(M68kTypes.COMMENT)
} }
} }

View File

@ -1,7 +1,5 @@
package de.platon42.intellij.plugins.m68k.parser; package de.platon42.intellij.plugins.m68k.parser
import com.intellij.lang.parser.GeneratedParserUtilBase; import com.intellij.lang.parser.GeneratedParserUtilBase
public class M68kParserUtilBase extends GeneratedParserUtilBase { class M68kParserUtilBase : GeneratedParserUtilBase()
}

View File

@ -5,7 +5,6 @@ import com.intellij.openapi.fileTypes.SyntaxHighlighter
import com.intellij.openapi.options.colors.AttributesDescriptor import com.intellij.openapi.options.colors.AttributesDescriptor
import com.intellij.openapi.options.colors.ColorDescriptor import com.intellij.openapi.options.colors.ColorDescriptor
import com.intellij.openapi.options.colors.ColorSettingsPage import com.intellij.openapi.options.colors.ColorSettingsPage
import com.intellij.openapi.util.NlsContexts.ConfigurableName
import de.platon42.intellij.plugins.m68k.M68kIcons.FILE import de.platon42.intellij.plugins.m68k.M68kIcons.FILE
import de.platon42.intellij.plugins.m68k.syntax.M68kSyntaxHighlighter.Companion.AREG import de.platon42.intellij.plugins.m68k.syntax.M68kSyntaxHighlighter.Companion.AREG
import de.platon42.intellij.plugins.m68k.syntax.M68kSyntaxHighlighter.Companion.BAD_CHARACTER import de.platon42.intellij.plugins.m68k.syntax.M68kSyntaxHighlighter.Companion.BAD_CHARACTER
@ -90,7 +89,7 @@ hello: dc.b 'Hello World!',10,0
return ColorDescriptor.EMPTY_ARRAY return ColorDescriptor.EMPTY_ARRAY
} }
override fun getDisplayName(): @ConfigurableName String { override fun getDisplayName(): String {
return "M68k Assembly" return "M68k Assembly"
} }

View File

@ -5,11 +5,11 @@
</vendor> </vendor>
<description><![CDATA[ <description><![CDATA[
MC68000-asm-plugin is a plugin to add language support for Motorola 68000 assembly language files. MC68000 Assembly Language Plugin adds language support for Motorola 68000 (M68k) assembly language files.
<p> <p>
<a href="https://github.com/chrisly42/mc68000-asm-plugin/blob/main/README.md">Full documentation here...</a> <a href="https://github.com/chrisly42/mc68000-asm-plugin/blob/main/README.md">Full documentation here...</a>
]]></description> ]]></description>
<idea-version since-build="192.4205.45"/> <idea-version since-build="193.7288.26"/>
<depends>com.intellij.modules.lang</depends> <depends>com.intellij.modules.lang</depends>