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:
parent
25245bea10
commit
3319fc1c45
@ -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.
|
@ -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>
|
||||||
""")
|
""")
|
||||||
|
@ -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);
|
|
||||||
}
|
}
|
||||||
};
|
}
|
||||||
}
|
|
||||||
}
|
}
|
@ -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"
|
||||||
|
@ -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);
|
|
||||||
}
|
|
||||||
}
|
|
@ -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)
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -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()
|
||||||
|
|
||||||
}
|
|
@ -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"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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>
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user