Full support for MC68010 ISA ('movec', 'moves' and new special registers 'SFC' and 'DFC').

This commit is contained in:
Chris Hodges 2021-10-11 11:27:46 +02:00
parent 0ae17046d6
commit e0bd6981e3
10 changed files with 292 additions and 215 deletions

View File

@ -167,6 +167,7 @@ are appreciated. It really is keeping me motivated to continue development.
### V0.8 (unreleased) ### V0.8 (unreleased)
- New: Support for MC68020+ addressing modes! However, MC68020+ specific instructions have not been added yet. - New: Support for MC68020+ addressing modes! However, MC68020+ specific instructions have not been added yet.
- New: Full support for MC68010 ISA (`movec`, `moves` and new special registers `SFC` and `DFC`).
- Enhancement: Label documentation now also works for local labels and includes end-of-line comment for label, too. - Enhancement: Label documentation now also works for local labels and includes end-of-line comment for label, too.
- Enhancement: Symbol definition documentation now also includes comments in the same way as the label documentation does. - Enhancement: Symbol definition documentation now also includes comments in the same way as the label documentation does.
- New: Macro definition / invocation documentation provider that even tries to expand macros. - New: Macro definition / invocation documentation provider that even tries to expand macros.

View File

@ -61,6 +61,7 @@ patchPluginXml {
<h4>V0.8 (unreleased)</h4> <h4>V0.8 (unreleased)</h4>
<ul> <ul>
<li>New: Support for MC68020+ addressing modes! However, MC68020+ specific instructions have not been added yet. <li>New: Support for MC68020+ addressing modes! However, MC68020+ specific instructions have not been added yet.
<li>New: Full support for MC68010 ISA ('movec', 'moves' and new special registers 'SFC' and 'DFC').
<li>Enhancement: Label documentation now also works for local labels and includes end-of-line comment for label, too. <li>Enhancement: Label documentation now also works for local labels and includes end-of-line comment for label, too.
<li>Enhancement: Symbol definition documentation now also includes comments in the same way as the label documentation does. <li>Enhancement: Symbol definition documentation now also includes comments in the same way as the label documentation does.
<li>New: Macro definition / invocation documentation provider that even tries to expand macros. <li>New: Macro definition / invocation documentation provider that even tries to expand macros.

View File

@ -204,17 +204,17 @@ public class _M68kLexer implements FlexLexer {
"\1\54\1\17\1\55\1\12\4\55\1\56\1\12\2\57" + "\1\54\1\17\1\55\1\12\4\55\1\56\1\12\2\57" +
"\2\60\1\61\1\62\3\63\1\62\1\63\1\0\1\4" + "\2\60\1\61\1\62\3\63\1\62\1\63\1\0\1\4" +
"\1\64\2\65\1\66\3\0\1\10\1\67\1\70\1\71" + "\1\64\2\65\1\66\3\0\1\10\1\67\1\70\1\71" +
"\1\72\1\73\1\74\1\17\1\75\1\76\1\17\1\77" + "\1\72\1\73\1\74\2\17\1\75\1\17\1\76\1\17" +
"\1\100\2\0\1\101\4\0\1\102\1\17\1\34\1\103" + "\1\77\1\100\2\0\1\101\4\0\1\102\1\17\1\34" +
"\1\104\1\105\1\106\1\107\1\110\1\111\3\0\1\55" + "\1\103\1\104\1\105\1\106\1\107\1\110\1\111\3\0" +
"\1\0\1\55\1\0\1\55\1\0\1\55\1\60\1\62" + "\1\55\1\0\1\55\1\0\1\55\1\0\1\55\1\60" +
"\3\0\1\4\1\65\1\66\1\10\1\112\1\10\1\113" + "\1\62\3\0\1\4\1\65\1\66\1\10\1\112\1\10" +
"\1\114\1\115\1\116\1\0\1\55\3\0\1\60\1\62" + "\1\113\1\114\1\115\1\116\1\117\1\120\1\0\1\55" +
"\3\0\1\10\1\60\1\62\2\0\1\117\1\120\1\121" + "\3\0\1\60\1\62\3\0\1\10\1\60\1\62\2\0" +
"\1\0\1\122"; "\1\121\1\122\1\123\1\0\1\124";
private static int[] zzUnpackAction() { private static int[] zzUnpackAction() {
int[] result = new int[186]; int[] result = new int[190];
int offset = 0; int offset = 0;
offset = zzUnpackAction(ZZ_ACTION_PACKED_0, offset, result); offset = zzUnpackAction(ZZ_ACTION_PACKED_0, offset, result);
return result; return result;
@ -253,19 +253,19 @@ public class _M68kLexer implements FlexLexer {
"\0\u0e88\0\u0ec4\0\u0ec4\0\u0384\0\u0f00\0\u0f3c\0\u0f78\0\u0fb4" + "\0\u0e88\0\u0ec4\0\u0ec4\0\u0384\0\u0f00\0\u0f3c\0\u0f78\0\u0fb4" +
"\0\u0ff0\0\u0ff0\0\u0384\0\u102c\0\u1068\0\u0ec4\0\u10a4\0\u10e0" + "\0\u0ff0\0\u0ff0\0\u0384\0\u102c\0\u1068\0\u0ec4\0\u10a4\0\u10e0" +
"\0\u111c\0\u1158\0\u1194\0\u11d0\0\u120c\0\u1248\0\u1284\0\u12c0" + "\0\u111c\0\u1158\0\u1194\0\u11d0\0\u120c\0\u1248\0\u1284\0\u12c0" +
"\0\u0384\0\u0384\0\u0384\0\u0870\0\u0870\0\u0870\0\u12fc\0\u0870" + "\0\u0384\0\u0384\0\u0384\0\u0870\0\u0870\0\u0870\0\u12fc\0\u1338" +
"\0\u0924\0\u1338\0\u099c\0\u09d8\0\u0a14\0\u1374\0\u0384\0\u0a50" + "\0\u0870\0\u1374\0\u0924\0\u13b0\0\u099c\0\u09d8\0\u0a14\0\u13ec" +
"\0\u13b0\0\u0a8c\0\u13ec\0\u0870\0\u1428\0\u0384\0\u0384\0\u0384" + "\0\u0384\0\u0a50\0\u1428\0\u0a8c\0\u1464\0\u0870\0\u14a0\0\u0384" +
"\0\u0384\0\u0384\0\u0384\0\u0384\0\u0384\0\u1464\0\u14a0\0\u14dc" + "\0\u0384\0\u0384\0\u0384\0\u0384\0\u0384\0\u0384\0\u0384\0\u14dc" +
"\0\u1518\0\u1554\0\u1590\0\u15cc\0\u1608\0\u1644\0\u1680\0\u16bc" + "\0\u1518\0\u1554\0\u1590\0\u15cc\0\u1608\0\u1644\0\u1680\0\u16bc" +
"\0\u16f8\0\u1734\0\u1770\0\u17ac\0\u0384\0\u0384\0\u0384\0\u0384" + "\0\u16f8\0\u1734\0\u1770\0\u17ac\0\u17e8\0\u1824\0\u0384\0\u0384" +
"\0\u0384\0\u17e8\0\u0870\0\u0870\0\u0870\0\u0384\0\u1824\0\u0384" + "\0\u0384\0\u0384\0\u0384\0\u1860\0\u0870\0\u0870\0\u0870\0\u0870" +
"\0\u1860\0\u189c\0\u18d8\0\u1914\0\u1950\0\u198c\0\u19c8\0\u1a04" + "\0\u0870\0\u0384\0\u189c\0\u0384\0\u18d8\0\u1914\0\u1950\0\u198c" +
"\0\u1a40\0\u1a7c\0\u1ab8\0\u111c\0\u1af4\0\u0528\0\u0f3c\0\u1b30" + "\0\u19c8\0\u1a04\0\u1a40\0\u1a7c\0\u1ab8\0\u1af4\0\u1b30\0\u111c" +
"\0\u1b6c\0\u1ba8"; "\0\u1b6c\0\u0528\0\u0f3c\0\u1ba8\0\u1be4\0\u1c20";
private static int[] zzUnpackRowMap() { private static int[] zzUnpackRowMap() {
int[] result = new int[186]; int[] result = new int[190];
int offset = 0; int offset = 0;
offset = zzUnpackRowMap(ZZ_ROWMAP_PACKED_0, offset, result); offset = zzUnpackRowMap(ZZ_ROWMAP_PACKED_0, offset, result);
return result; return result;
@ -351,86 +351,90 @@ public class _M68kLexer implements FlexLexer {
"\2\50\23\0\3\50\10\0\1\46\1\0\1\46\30\0" + "\2\50\23\0\3\50\10\0\1\46\1\0\1\46\30\0" +
"\1\46\1\0\1\46\35\0\1\50\1\166\1\50\1\166" + "\1\46\1\0\1\46\35\0\1\50\1\166\1\50\1\166" +
"\3\50\1\0\5\50\2\0\6\50\2\0\4\50\1\0" + "\3\50\1\0\5\50\2\0\6\50\2\0\4\50\1\0" +
"\1\166\2\50\23\0\3\50\7\0\7\50\1\0\5\50" + "\1\166\1\167\1\50\23\0\3\50\7\0\7\50\1\0" +
"\2\0\6\50\2\0\4\50\1\0\3\50\23\0\3\50" + "\5\50\2\0\6\50\2\0\4\50\1\0\3\50\23\0" +
"\7\0\7\50\1\0\3\50\1\167\1\50\2\0\6\50" + "\3\50\7\0\7\50\1\0\3\50\1\170\1\50\2\0" +
"\2\0\1\50\1\167\2\50\1\0\3\50\23\0\3\50" + "\6\50\2\0\1\50\1\170\2\50\1\0\3\50\23\0" +
"\7\0\7\50\1\0\5\50\2\0\3\50\1\170\2\50" + "\3\50\7\0\7\50\1\0\5\50\2\0\3\50\1\171" +
"\2\0\4\50\1\0\3\50\23\0\1\165\2\50\7\0" + "\2\50\2\0\4\50\1\0\1\50\1\172\1\50\23\0" +
"\4\171\4\0\1\171\10\0\1\171\5\0\1\171\4\0" + "\1\165\2\50\7\0\4\173\4\0\1\173\10\0\1\173" +
"\3\171\25\0\1\171\7\0\7\50\1\0\5\50\2\0" + "\5\0\1\173\4\0\3\173\25\0\1\173\7\0\7\50" +
"\2\50\1\172\3\50\2\0\4\50\1\0\3\50\23\0" + "\1\0\5\50\2\0\2\50\1\174\3\50\2\0\4\50" +
"\3\50\43\0\1\173\40\0\1\174\1\0\1\174\30\0" + "\1\0\3\50\23\0\3\50\43\0\1\175\40\0\1\176" +
"\1\174\32\0\2\175\2\0\27\175\1\176\11\175\1\177" + "\1\0\1\176\30\0\1\176\32\0\2\177\2\0\27\177" +
"\26\175\2\200\2\0\27\200\1\201\12\200\1\177\25\200" + "\1\200\11\177\1\201\26\177\2\202\2\0\27\202\1\203" +
"\2\202\2\0\27\202\1\203\13\202\1\177\24\202\5\0" + "\12\202\1\201\25\202\2\204\2\0\27\204\1\205\13\204" +
"\7\50\1\0\5\50\2\0\2\50\1\204\3\50\2\0" + "\1\201\24\204\5\0\7\50\1\0\5\50\2\0\2\50" +
"\4\50\1\0\3\50\23\0\3\50\7\0\7\50\1\0" + "\1\206\3\50\2\0\4\50\1\0\3\50\23\0\3\50" +
"\5\50\2\0\6\50\2\0\1\205\3\50\1\0\3\50" + "\7\0\7\50\1\0\5\50\2\0\6\50\2\0\1\207" +
"\23\0\2\50\1\205\24\0\1\206\73\0\1\207\25\0" + "\3\50\1\0\3\50\23\0\2\50\1\207\24\0\1\210" +
"\1\210\1\211\44\0\1\212\26\0\1\213\44\0\1\211" + "\73\0\1\211\25\0\1\212\1\213\44\0\1\214\26\0" +
"\135\0\1\214\74\0\1\215\74\0\1\100\23\0\1\216" + "\1\215\44\0\1\213\135\0\1\216\74\0\1\217\74\0" +
"\72\0\1\217\63\0\7\123\1\0\5\123\1\0\7\123" + "\1\100\23\0\1\220\72\0\1\221\63\0\7\123\1\0" +
"\1\0\5\123\1\0\3\123\23\0\3\123\2\0\2\124" + "\5\123\1\0\7\123\1\0\5\123\1\0\3\123\23\0" +
"\3\0\25\124\1\0\17\124\1\0\21\124\2\126\2\0" + "\3\123\2\0\2\124\3\0\25\124\1\0\17\124\1\0" +
"\1\220\25\126\1\220\1\221\11\126\1\124\4\126\1\220" + "\21\124\2\126\2\0\1\222\25\126\1\222\1\223\11\126" +
"\21\126\2\127\2\0\1\222\25\127\1\222\1\223\12\127" + "\1\124\4\126\1\222\21\126\2\127\2\0\1\224\25\127" +
"\1\124\3\127\1\222\21\127\2\130\2\0\1\224\25\130" + "\1\224\1\225\12\127\1\124\3\127\1\224\21\127\2\130" +
"\1\224\1\225\13\130\1\124\2\130\1\224\21\130\2\131" + "\2\0\1\226\25\130\1\226\1\227\13\130\1\124\2\130" +
"\2\0\1\226\25\131\1\226\1\227\15\131\1\124\1\226" + "\1\226\21\130\2\131\2\0\1\230\25\131\1\230\1\231" +
"\21\131\2\132\2\0\70\132\2\0\1\134\76\0\7\136" + "\15\131\1\124\1\230\21\131\2\132\2\0\70\132\2\0" +
"\1\134\76\0\7\136\1\0\5\136\3\0\5\136\2\0" +
"\4\136\1\0\3\136\23\0\3\136\7\0\1\232\6\136" +
"\1\0\5\136\3\0\5\136\2\0\4\136\1\0\3\136" + "\1\0\5\136\3\0\5\136\2\0\4\136\1\0\3\136" +
"\23\0\3\136\7\0\1\230\6\136\1\0\5\136\3\0" + "\23\0\3\136\2\0\1\140\3\0\70\140\2\141\2\0" +
"\5\136\2\0\4\136\1\0\3\136\23\0\3\136\2\0" + "\26\141\1\0\41\141\2\0\1\143\71\0\2\141\2\0" +
"\1\140\3\0\70\140\2\141\2\0\26\141\1\0\41\141" + "\1\145\10\141\1\233\14\141\1\0\41\141\4\0\1\147" +
"\2\0\1\143\71\0\2\141\2\0\1\145\10\141\1\231" + "\10\0\1\234\2\0\1\235\1\0\1\151\2\0\1\236" +
"\14\141\1\0\41\141\4\0\1\147\10\0\1\232\2\0" + "\7\0\1\235\42\0\1\147\7\0\1\237\5\0\1\151" +
"\1\233\1\0\1\151\2\0\1\234\7\0\1\233\42\0" + "\2\0\1\236\52\0\1\151\103\0\1\240\64\0\7\153" +
"\1\147\7\0\1\235\5\0\1\151\2\0\1\234\52\0" + "\1\240\5\153\3\0\5\153\2\0\4\153\1\0\3\153" +
"\1\151\103\0\1\236\64\0\7\153\1\236\5\153\3\0" + "\23\0\3\153\16\0\1\241\57\0\1\242\3\0\70\242" +
"\5\153\2\0\4\153\1\0\3\153\23\0\3\153\16\0" + "\14\0\1\243\64\0\7\157\1\243\5\157\3\0\5\157" +
"\1\237\57\0\1\240\3\0\70\240\14\0\1\241\64\0" + "\2\0\4\157\1\0\3\157\23\0\3\157\7\0\1\30" +
"\7\157\1\241\5\157\3\0\5\157\2\0\4\157\1\0" + "\1\31\1\30\1\31\1\30\2\31\1\154\5\30\1\0" +
"\3\157\23\0\3\157\7\0\1\30\1\31\1\30\1\31" + "\1\155\1\156\1\30\1\244\3\30\2\0\4\30\1\0" +
"\1\30\2\31\1\154\5\30\1\0\1\155\1\156\1\30" + "\1\31\1\30\1\31\23\0\3\30\7\0\7\50\1\0" +
"\1\242\3\30\2\0\4\30\1\0\1\31\1\30\1\31" + "\5\50\2\0\2\50\1\245\3\50\2\0\4\50\1\0" +
"\23\0\3\30\7\0\7\50\1\0\5\50\2\0\6\50" + "\3\50\23\0\3\50\7\0\7\50\1\0\5\50\2\0" +
"\2\0\4\50\1\0\3\50\23\0\1\243\2\50\7\0" + "\6\50\2\0\4\50\1\0\3\50\23\0\1\246\2\50" +
"\7\50\1\0\5\50\2\0\3\50\1\244\2\50\2\0" + "\7\0\7\50\1\0\5\50\2\0\2\50\1\247\3\50" +
"\4\50\1\0\3\50\23\0\3\50\2\0\1\175\3\0" + "\2\0\4\50\1\0\3\50\23\0\3\50\7\0\7\50" +
"\70\175\1\200\3\0\70\200\1\202\3\0\70\202\5\0" + "\1\0\5\50\2\0\3\50\1\250\2\50\2\0\4\50" +
"\7\50\1\0\5\50\2\0\3\50\1\245\2\50\2\0" + "\1\0\3\50\23\0\3\50\2\0\1\177\3\0\70\177" +
"\4\50\1\0\3\50\23\0\3\50\21\0\1\246\75\0" + "\1\202\3\0\70\202\1\204\3\0\70\204\5\0\7\50" +
"\1\246\52\0\2\220\2\0\27\220\1\247\11\220\1\250" + "\1\0\5\50\2\0\3\50\1\251\2\50\2\0\4\50" +
"\26\220\1\126\1\124\2\0\1\220\25\126\1\220\17\126" + "\1\0\3\50\23\0\3\50\21\0\1\252\75\0\1\252" +
"\1\220\21\126\2\222\2\0\27\222\1\251\12\222\1\250" + "\52\0\2\222\2\0\27\222\1\253\11\222\1\254\26\222" +
"\25\222\1\127\1\124\2\0\1\222\25\127\1\222\17\127" + "\1\126\1\124\2\0\1\222\25\126\1\222\17\126\1\222" +
"\1\222\21\127\2\224\2\0\27\224\1\252\13\224\1\250" + "\21\126\2\224\2\0\27\224\1\255\12\224\1\254\25\224" +
"\24\224\1\130\1\124\2\0\1\224\25\130\1\224\17\130" + "\1\127\1\124\2\0\1\224\25\127\1\224\17\127\1\224" +
"\1\224\21\130\2\226\2\0\27\226\1\253\15\226\1\250" + "\21\127\2\226\2\0\27\226\1\256\13\226\1\254\24\226" +
"\22\226\1\131\1\124\2\0\1\226\25\131\1\226\17\131" + "\1\130\1\124\2\0\1\226\25\130\1\226\17\130\1\226" +
"\1\226\21\131\5\0\7\136\1\0\5\136\3\0\1\136" + "\21\130\2\230\2\0\27\230\1\257\15\230\1\254\22\230" +
"\1\254\3\136\2\0\4\136\1\0\3\136\23\0\3\136" + "\1\131\1\124\2\0\1\230\25\131\1\230\17\131\1\230" +
"\2\0\2\141\2\0\25\141\1\255\1\0\41\141\16\0" + "\21\131\5\0\7\136\1\0\5\136\3\0\1\136\1\260" +
"\1\256\72\0\1\257\63\0\1\260\73\0\1\30\1\31" + "\3\136\2\0\4\136\1\0\3\136\23\0\3\136\2\0" +
"\1\30\1\31\1\30\2\31\1\154\5\30\1\0\1\155" + "\2\141\2\0\25\141\1\261\1\0\41\141\16\0\1\262" +
"\1\156\2\30\1\261\2\30\2\0\4\30\1\0\1\31" + "\72\0\1\263\63\0\1\264\73\0\1\30\1\31\1\30" +
"\1\30\1\31\23\0\3\30\2\0\1\220\3\0\70\220" + "\1\31\1\30\2\31\1\154\5\30\1\0\1\155\1\156" +
"\1\222\3\0\70\222\1\224\3\0\70\224\1\226\3\0" + "\2\30\1\265\2\30\2\0\4\30\1\0\1\31\1\30" +
"\70\226\5\0\7\136\1\0\5\136\3\0\2\136\1\262" + "\1\31\23\0\3\30\2\0\1\222\3\0\70\222\1\224" +
"\2\136\2\0\4\136\1\0\3\136\23\0\3\136\2\0" + "\3\0\70\224\1\226\3\0\70\226\1\230\3\0\70\230" +
"\2\141\2\0\3\141\1\263\22\141\1\0\41\141\17\0" + "\5\0\7\136\1\0\5\136\3\0\2\136\1\266\2\136" +
"\1\264\75\0\1\264\100\0\1\265\52\0\1\30\1\31" + "\2\0\4\136\1\0\3\136\23\0\3\136\2\0\2\141" +
"\1\30\1\31\1\30\2\31\1\154\5\30\1\0\1\155" + "\2\0\3\141\1\267\22\141\1\0\41\141\17\0\1\270" +
"\1\156\3\30\1\266\1\30\2\0\4\30\1\0\1\31" + "\75\0\1\270\100\0\1\271\52\0\1\30\1\31\1\30" +
"\1\30\1\31\23\0\3\30\7\0\7\136\1\0\5\136" + "\1\31\1\30\2\31\1\154\5\30\1\0\1\155\1\156" +
"\3\0\3\136\1\267\1\136\2\0\4\136\1\0\3\136" + "\3\30\1\272\1\30\2\0\4\30\1\0\1\31\1\30" +
"\23\0\3\136\2\0\2\141\2\0\21\141\1\270\4\141" + "\1\31\23\0\3\30\7\0\7\136\1\0\5\136\3\0" +
"\1\0\41\141\27\0\1\271\44\0\2\270\2\0\26\270" + "\3\136\1\273\1\136\2\0\4\136\1\0\3\136\23\0" +
"\1\0\41\270\30\0\1\272\47\0\1\272\67\0"; "\3\136\2\0\2\141\2\0\21\141\1\274\4\141\1\0" +
"\41\141\27\0\1\275\44\0\2\274\2\0\26\274\1\0" +
"\41\274\30\0\1\276\47\0\1\276\67\0";
private static int[] zzUnpackTrans() { private static int[] zzUnpackTrans() {
int[] result = new int[7140]; int[] result = new int[7260];
int offset = 0; int offset = 0;
offset = zzUnpackTrans(ZZ_TRANS_PACKED_0, offset, result); offset = zzUnpackTrans(ZZ_TRANS_PACKED_0, offset, result);
return result; return result;
@ -471,14 +475,14 @@ public class _M68kLexer implements FlexLexer {
"\17\0\2\11\12\1\1\11\3\1\1\11\21\1\12\11" + "\17\0\2\11\12\1\1\11\3\1\1\11\21\1\12\11" +
"\2\1\1\11\1\1\1\11\2\1\4\11\1\1\4\11" + "\2\1\1\11\1\1\1\11\2\1\4\11\1\1\4\11" +
"\3\1\1\11\2\1\1\11\11\1\1\11\6\1\1\11" + "\3\1\1\11\2\1\1\11\11\1\1\11\6\1\1\11" +
"\3\1\1\0\5\1\3\0\1\1\3\11\11\1\2\0" + "\3\1\1\0\5\1\3\0\1\1\3\11\13\1\2\0" +
"\1\11\4\0\2\1\10\11\3\0\1\1\1\0\1\1" + "\1\11\4\0\2\1\10\11\3\0\1\1\1\0\1\1" +
"\1\0\1\1\1\0\3\1\3\0\5\11\4\1\1\11" + "\1\0\1\1\1\0\3\1\3\0\5\11\6\1\1\11" +
"\1\0\1\11\3\0\2\1\3\0\3\1\2\0\3\1" + "\1\0\1\11\3\0\2\1\3\0\3\1\2\0\3\1" +
"\1\0\1\1"; "\1\0\1\1";
private static int[] zzUnpackAttribute() { private static int[] zzUnpackAttribute() {
int[] result = new int[186]; int[] result = new int[190];
int offset = 0; int offset = 0;
offset = zzUnpackAttribute(ZZ_ATTRIBUTE_PACKED_0, offset, result); offset = zzUnpackAttribute(ZZ_ATTRIBUTE_PACKED_0, offset, result);
return result; return result;
@ -818,14 +822,14 @@ public class _M68kLexer implements FlexLexer {
return BAD_CHARACTER; return BAD_CHARACTER;
} }
// fall through // fall through
case 83: case 85:
break; break;
case 2: { case 2: {
yybegin(YYINITIAL); yybegin(YYINITIAL);
return WHITE_SPACE; return WHITE_SPACE;
} }
// fall through // fall through
case 84: case 86:
break; break;
case 3: { case 3: {
yybegin(NOSOL); yybegin(NOSOL);
@ -833,7 +837,7 @@ public class _M68kLexer implements FlexLexer {
return WHITE_SPACE; return WHITE_SPACE;
} }
// fall through // fall through
case 85: case 87:
break; break;
case 4: { case 4: {
yybegin(INSTRPART); yybegin(INSTRPART);
@ -842,7 +846,7 @@ public class _M68kLexer implements FlexLexer {
return GLOBAL_LABEL_DEF; return GLOBAL_LABEL_DEF;
} }
// fall through // fall through
case 86: case 88:
break; break;
case 5: { case 5: {
yybegin(INSTRPART); yybegin(INSTRPART);
@ -850,20 +854,20 @@ public class _M68kLexer implements FlexLexer {
return LOCAL_LABEL_DEF; return LOCAL_LABEL_DEF;
} }
// fall through // fall through
case 87: case 89:
break; break;
case 6: { case 6: {
yybegin(YYINITIAL); yybegin(YYINITIAL);
return COMMENT; return COMMENT;
} }
// fall through // fall through
case 88: case 90:
break; break;
case 7: { case 7: {
return WHITE_SPACE; return WHITE_SPACE;
} }
// fall through // fall through
case 89: case 91:
break; break;
case 8: { case 8: {
if (isAsmMnemonicWithSize(yytext())) { if (isAsmMnemonicWithSize(yytext())) {
@ -894,257 +898,257 @@ public class _M68kLexer implements FlexLexer {
return handleMacroMode(this); return handleMacroMode(this);
} }
// fall through // fall through
case 90: case 92:
break; break;
case 9: { case 9: {
return handleMacroMode(this); return handleMacroMode(this);
} }
// fall through // fall through
case 91: case 93:
break; break;
case 10: { case 10: {
yybegin(YYINITIAL); yybegin(YYINITIAL);
return EOL; return EOL;
} }
// fall through // fall through
case 92: case 94:
break; break;
case 11: { case 11: {
return COLON; return COLON;
} }
// fall through // fall through
case 93: case 95:
break; break;
case 12: { case 12: {
yybegin(WAITEOL); yybegin(WAITEOL);
return COMMENT; return COMMENT;
} }
// fall through // fall through
case 94: case 96:
break; break;
case 13: { case 13: {
startExpr(ASMOPS, ASMOPS_OP); startExpr(ASMOPS, ASMOPS_OP);
return WHITE_SPACE; return WHITE_SPACE;
} }
// fall through // fall through
case 95: case 97:
break; break;
case 14: { case 14: {
return handleEolCommentWhitespace(this); return handleEolCommentWhitespace(this);
} }
// fall through // fall through
case 96: case 98:
break; break;
case 15: { case 15: {
yybegin(exprOpState); yybegin(exprOpState);
return SYMBOL; return SYMBOL;
} }
// fall through // fall through
case 97: case 99:
break; break;
case 16: { case 16: {
yybegin(exprOpState); yybegin(exprOpState);
return DECIMAL; return DECIMAL;
} }
// fall through // fall through
case 98: case 100:
break; break;
case 17: { case 17: {
return SEPARATOR; return SEPARATOR;
} }
// fall through // fall through
case 99: case 101:
break; break;
case 18: { case 18: {
return HASH; return HASH;
} }
// fall through // fall through
case 100: case 102:
break; break;
case 19: { case 19: {
return OP_BITWISE_XOR; return OP_BITWISE_XOR;
} }
// fall through // fall through
case 101: case 103:
break; break;
case 20: { case 20: {
return ROUND_L; return ROUND_L;
} }
// fall through // fall through
case 102: case 104:
break; break;
case 21: { case 21: {
yybegin(exprOpState); yybegin(exprOpState);
return ROUND_R; return ROUND_R;
} }
// fall through // fall through
case 103: case 105:
break; break;
case 22: { case 22: {
return OP_UNARY_NOT; return OP_UNARY_NOT;
} }
// fall through // fall through
case 104: case 106:
break; break;
case 23: { case 23: {
return OP_UNARY_COMPL; return OP_UNARY_COMPL;
} }
// fall through // fall through
case 105: case 107:
break; break;
case 24: { case 24: {
return OP_PLUS; return OP_PLUS;
} }
// fall through // fall through
case 106: case 108:
break; break;
case 25: { case 25: {
return OP_MINUS; return OP_MINUS;
} }
// fall through // fall through
case 107: case 109:
break; break;
case 26: { case 26: {
yybegin(exprOpState); yybegin(exprOpState);
return CURRENT_PC_SYMBOL; return CURRENT_PC_SYMBOL;
} }
// fall through // fall through
case 108: case 110:
break; break;
case 27: { case 27: {
return SQUARE_L; return SQUARE_L;
} }
// fall through // fall through
case 109: case 111:
break; break;
case 28: { case 28: {
yybegin(exprState); yybegin(exprState);
return OP_CMP_EQ; return OP_CMP_EQ;
} }
// fall through // fall through
case 110: case 112:
break; break;
case 29: { case 29: {
yybegin(exprState); yybegin(exprState);
return OP_AR_MOD; return OP_AR_MOD;
} }
// fall through // fall through
case 111: case 113:
break; break;
case 30: { case 30: {
yybegin(exprState); yybegin(exprState);
return OP_CMP_LT; return OP_CMP_LT;
} }
// fall through // fall through
case 112: case 114:
break; break;
case 31: { case 31: {
yybegin(exprState); yybegin(exprState);
return OP_CMP_GT; return OP_CMP_GT;
} }
// fall through // fall through
case 113: case 115:
break; break;
case 32: { case 32: {
yybegin(exprState); yybegin(exprState);
return SEPARATOR; return SEPARATOR;
} }
// fall through // fall through
case 114: case 116:
break; break;
case 33: { case 33: {
yybegin(exprState); yybegin(exprState);
return OP_BITWISE_XOR; return OP_BITWISE_XOR;
} }
// fall through // fall through
case 115: case 117:
break; break;
case 34: { case 34: {
yybegin(exprState); yybegin(exprState);
return ROUND_L; return ROUND_L;
} }
// fall through // fall through
case 116: case 118:
break; break;
case 35: { case 35: {
return ROUND_R; return ROUND_R;
} }
// fall through // fall through
case 117: case 119:
break; break;
case 36: { case 36: {
yybegin(exprState); yybegin(exprState);
return OP_BITWISE_OR; return OP_BITWISE_OR;
} }
// fall through // fall through
case 118: case 120:
break; break;
case 37: { case 37: {
yybegin(exprState); yybegin(exprState);
return OP_UNARY_COMPL; return OP_UNARY_COMPL;
} }
// fall through // fall through
case 119: case 121:
break; break;
case 38: { case 38: {
yybegin(exprState); yybegin(exprState);
return OP_PLUS; return OP_PLUS;
} }
// fall through // fall through
case 120: case 122:
break; break;
case 39: { case 39: {
yybegin(exprState); yybegin(exprState);
return OP_MINUS; return OP_MINUS;
} }
// fall through // fall through
case 121: case 123:
break; break;
case 40: { case 40: {
yybegin(exprState); yybegin(exprState);
return OP_AR_MUL; return OP_AR_MUL;
} }
// fall through // fall through
case 122: case 124:
break; break;
case 41: { case 41: {
yybegin(exprState); yybegin(exprState);
return OP_BITWISE_AND; return OP_BITWISE_AND;
} }
// fall through // fall through
case 123: case 125:
break; break;
case 42: { case 42: {
yybegin(exprState); yybegin(exprState);
return OP_AR_DIV; return OP_AR_DIV;
} }
// fall through // fall through
case 124: case 126:
break; break;
case 43: { case 43: {
return SQUARE_R; return SQUARE_R;
} }
// fall through // fall through
case 125: case 127:
break; break;
case 44: { case 44: {
startExpr(EXPR, EXPR_OP); startExpr(EXPR, EXPR_OP);
return OP_ASSIGN; return OP_ASSIGN;
} }
// fall through // fall through
case 126: case 128:
break; break;
case 45: { case 45: {
return STRINGLIT; return STRINGLIT;
} }
// fall through // fall through
case 127: case 129:
break; break;
case 46: { case 46: {
return COMMENT; return COMMENT;
} }
// fall through // fall through
case 128: case 130:
break; break;
case 47: { case 47: {
yybegin(MACROLINE); yybegin(MACROLINE);
@ -1152,32 +1156,32 @@ public class _M68kLexer implements FlexLexer {
return WHITE_SPACE; return WHITE_SPACE;
} }
// fall through // fall through
case 129: case 131:
break; break;
case 48: { case 48: {
return MACRO_NAME; return MACRO_NAME;
} }
// fall through // fall through
case 130: case 132:
break; break;
case 49: { case 49: {
yybegin(MACROWAITEOL); yybegin(MACROWAITEOL);
return COMMENT; return COMMENT;
} }
// fall through // fall through
case 131: case 133:
break; break;
case 50: { case 50: {
return MACRO_LINE; return MACRO_LINE;
} }
// fall through // fall through
case 132: case 134:
break; break;
case 51: { case 51: {
return handleMacroLineEol(this); return handleMacroLineEol(this);
} }
// fall through // fall through
case 133: case 135:
break; break;
case 52: { case 52: {
yybegin(ASSIGNMENT); yybegin(ASSIGNMENT);
@ -1186,7 +1190,7 @@ public class _M68kLexer implements FlexLexer {
return SYMBOLDEF; return SYMBOLDEF;
} }
// fall through // fall through
case 134: case 136:
break; break;
case 53: { case 53: {
yybegin(INSTRPART); yybegin(INSTRPART);
@ -1195,7 +1199,7 @@ public class _M68kLexer implements FlexLexer {
return LOCAL_LABEL_DEF; return LOCAL_LABEL_DEF;
} }
// fall through // fall through
case 135: case 137:
break; break;
case 54: { case 54: {
yybegin(INSTRPART); yybegin(INSTRPART);
@ -1203,137 +1207,137 @@ public class _M68kLexer implements FlexLexer {
return GLOBAL_LABEL_DEF; return GLOBAL_LABEL_DEF;
} }
// fall through // fall through
case 136: case 138:
break; break;
case 55: { case 55: {
return OPSIZE_BS; return OPSIZE_BS;
} }
// fall through // fall through
case 137: case 139:
break; break;
case 56: { case 56: {
return OPSIZE_W; return OPSIZE_W;
} }
// fall through // fall through
case 138: case 140:
break; break;
case 57: { case 57: {
return OPSIZE_L; return OPSIZE_L;
} }
// fall through // fall through
case 139: case 141:
break; break;
case 58: { case 58: {
yybegin(exprOpState); yybegin(exprOpState);
return AREG; return AREG;
} }
// fall through // fall through
case 140: case 142:
break; break;
case 59: { case 59: {
yybegin(exprOpState); yybegin(exprOpState);
return REG_SP; return REG_SP;
} }
// fall through // fall through
case 141: case 143:
break; break;
case 60: { case 60: {
yybegin(exprOpState); yybegin(exprOpState);
return DREG; return DREG;
} }
// fall through // fall through
case 142: case 144:
break; break;
case 61: { case 61: {
yybegin(exprOpState); yybegin(exprOpState);
return REG_SR; return REG_SR;
} }
// fall through // fall through
case 143: case 145:
break; break;
case 62: { case 62: {
yybegin(exprOpState); yybegin(exprOpState);
return HEXADECIMAL; return HEXADECIMAL;
} }
// fall through // fall through
case 144: case 146:
break; break;
case 63: { case 63: {
yybegin(exprOpState); yybegin(exprOpState);
return BINARY; return BINARY;
} }
// fall through // fall through
case 145: case 147:
break; break;
case 64: { case 64: {
yybegin(exprOpState); yybegin(exprOpState);
return OCTAL; return OCTAL;
} }
// fall through // fall through
case 146: case 148:
break; break;
case 65: { case 65: {
yybegin(exprOpState); yybegin(exprOpState);
return STRINGLIT; return STRINGLIT;
} }
// fall through // fall through
case 147: case 149:
break; break;
case 66: { case 66: {
yybegin(exprOpState); yybegin(exprOpState);
return PC; return PC;
} }
// fall through // fall through
case 148: case 150:
break; break;
case 67: { case 67: {
yybegin(exprState); yybegin(exprState);
return OP_CMP_LT_EQ; return OP_CMP_LT_EQ;
} }
// fall through // fall through
case 149: case 151:
break; break;
case 68: { case 68: {
yybegin(exprState); yybegin(exprState);
return OP_AR_SHIFT_L; return OP_AR_SHIFT_L;
} }
// fall through // fall through
case 150: case 152:
break; break;
case 69: { case 69: {
yybegin(exprState); yybegin(exprState);
return OP_CMP_NOT_EQ; return OP_CMP_NOT_EQ;
} }
// fall through // fall through
case 151: case 153:
break; break;
case 70: { case 70: {
yybegin(exprState); yybegin(exprState);
return OP_CMP_GT_EQ; return OP_CMP_GT_EQ;
} }
// fall through // fall through
case 152: case 154:
break; break;
case 71: { case 71: {
yybegin(exprState); yybegin(exprState);
return OP_AR_SHIFT_R; return OP_AR_SHIFT_R;
} }
// fall through // fall through
case 153: case 155:
break; break;
case 72: { case 72: {
yybegin(exprState); yybegin(exprState);
return OP_LOGICAL_AND; return OP_LOGICAL_AND;
} }
// fall through // fall through
case 154: case 156:
break; break;
case 73: { case 73: {
yybegin(exprState); yybegin(exprState);
return OP_LOGICAL_OR; return OP_LOGICAL_OR;
} }
// fall through // fall through
case 155: case 157:
break; break;
case 74: { case 74: {
yybegin(INSTRPART); yybegin(INSTRPART);
@ -1341,63 +1345,77 @@ public class _M68kLexer implements FlexLexer {
return LOCAL_LABEL_DEF; return LOCAL_LABEL_DEF;
} }
// fall through // fall through
case 156: case 158:
break; break;
case 75: { case 75: {
yybegin(exprOpState); yybegin(exprOpState);
return REG_USP; return REG_DFC;
}
// fall through
case 157:
break;
case 76: {
yybegin(exprOpState);
return REG_CCR;
}
// fall through
case 158:
break;
case 77: {
yybegin(exprOpState);
return REG_VBR;
} }
// fall through // fall through
case 159: case 159:
break; break;
case 78: { case 76: {
startExpr(EXPR, EXPR_OP); yybegin(exprOpState);
return EQU; return REG_USP;
} }
// fall through // fall through
case 160: case 160:
break; break;
case 79: { case 77: {
yybegin(MACRODEF); yybegin(exprOpState);
return MACRO_TAG; return REG_SFC;
} }
// fall through // fall through
case 161: case 161:
break; break;
case 80: { case 78: {
return MACRO_TAG; yybegin(exprOpState);
return REG_CCR;
} }
// fall through // fall through
case 162: case 162:
break; break;
case 81: { case 79: {
yybegin(MACROTERMINATION); yybegin(exprOpState);
return MACRO_END_TAG; return REG_VBR;
} }
// fall through // fall through
case 163: case 163:
break; break;
case 80: {
startExpr(EXPR, EXPR_OP);
return EQU;
}
// fall through
case 164:
break;
case 81: {
yybegin(MACRODEF);
return MACRO_TAG;
}
// fall through
case 165:
break;
case 82: { case 82: {
return MACRO_TAG;
}
// fall through
case 166:
break;
case 83: {
yybegin(MACROTERMINATION);
return MACRO_END_TAG;
}
// fall through
case 167:
break;
case 84: {
yybegin(MACRODEF); yybegin(MACRODEF);
yypushback(pushbackAfterFirstToken(yytext())); yypushback(pushbackAfterFirstToken(yytext()));
return MACRO_NAME; return MACRO_NAME;
} }
// fall through // fall through
case 164: case 168:
break; break;
default: default:
zzScanError(ZZ_NO_MATCH); zzScanError(ZZ_NO_MATCH);

View File

@ -1664,7 +1664,7 @@ public class M68kParser implements PsiParser, LightPsiParser {
} }
/* ********************************************************** */ /* ********************************************************** */
// REG_CCR | REG_SR | REG_USP | REG_VBR // REG_CCR | REG_SR | REG_USP | REG_VBR | REG_SFC | REG_DFC
public static boolean SpecialRegister(PsiBuilder b, int l) { public static boolean SpecialRegister(PsiBuilder b, int l) {
if (!recursion_guard_(b, l, "SpecialRegister")) return false; if (!recursion_guard_(b, l, "SpecialRegister")) return false;
boolean r; boolean r;
@ -1673,6 +1673,8 @@ public class M68kParser implements PsiParser, LightPsiParser {
if (!r) r = consumeToken(b, REG_SR); if (!r) r = consumeToken(b, REG_SR);
if (!r) r = consumeToken(b, REG_USP); if (!r) r = consumeToken(b, REG_USP);
if (!r) r = consumeToken(b, REG_VBR); if (!r) r = consumeToken(b, REG_VBR);
if (!r) r = consumeToken(b, REG_SFC);
if (!r) r = consumeToken(b, REG_DFC);
exit_section_(b, l, m, r, false, null); exit_section_(b, l, m, r, false, null);
return r; return r;
} }

View File

@ -137,6 +137,8 @@ public interface M68kTypes {
IElementType OTHER_DIRECTIVE = new M68kTokenType("OTHER_DIRECTIVE"); IElementType OTHER_DIRECTIVE = new M68kTokenType("OTHER_DIRECTIVE");
IElementType PC = new M68kTokenType("PC"); IElementType PC = new M68kTokenType("PC");
IElementType REG_CCR = new M68kTokenType("REG_CCR"); IElementType REG_CCR = new M68kTokenType("REG_CCR");
IElementType REG_DFC = new M68kTokenType("REG_DFC");
IElementType REG_SFC = new M68kTokenType("REG_SFC");
IElementType REG_SP = new M68kTokenType("REG_SP"); IElementType REG_SP = new M68kTokenType("REG_SP");
IElementType REG_SR = new M68kTokenType("REG_SR"); IElementType REG_SR = new M68kTokenType("REG_SR");
IElementType REG_USP = new M68kTokenType("REG_USP"); IElementType REG_USP = new M68kTokenType("REG_USP");

View File

@ -266,6 +266,7 @@ object M68kIsa {
private val AREG_ONLY = setOf(AddressMode.ADDRESS_REGISTER_DIRECT) private val AREG_ONLY = setOf(AddressMode.ADDRESS_REGISTER_DIRECT)
private val DREG_ONLY = setOf(AddressMode.DATA_REGISTER_DIRECT) private val DREG_ONLY = setOf(AddressMode.DATA_REGISTER_DIRECT)
private val DREG_AREG = setOf(AddressMode.ADDRESS_REGISTER_DIRECT, AddressMode.DATA_REGISTER_DIRECT)
private val ADD_SUB_MODES = listOf( private val ADD_SUB_MODES = listOf(
AllowedAdrMode( AllowedAdrMode(
@ -994,6 +995,21 @@ object M68kIsa {
) )
), ),
IsaData(
"move", "Move from Status Register", id = "move from SR", isPrivileged = true,
machine = EnumSet.range(Machine.MC68010, Machine.MC68060),
modes = listOf(
AllowedAdrMode(
setOf(AddressMode.SPECIAL_REGISTER_DIRECT),
ALL_EXCEPT_AREG_IMMEDIATE_AND_PC_REL,
OP_SIZE_W,
"sr",
modInfo = RWM_SET_OP2_W,
testedCc = cc("?????")
)
)
),
*autoExpandForOtherCpus( *autoExpandForOtherCpus(
MC68020_PLUS, MC68020_PLUS,
@ -1017,6 +1033,38 @@ object M68kIsa {
) )
), ),
IsaData(
"movec", "Move Control Register", isPrivileged = true,
machine = EnumSet.range(Machine.MC68010, Machine.MC68060),
modes = listOf(
AllowedAdrMode(setOf(AddressMode.SPECIAL_REGISTER_DIRECT), DREG_AREG, OP_SIZE_L, "sfc|dfc|usp|vbr", modInfo = RWM_SET_OP2_L),
AllowedAdrMode(DREG_AREG, setOf(AddressMode.SPECIAL_REGISTER_DIRECT), OP_SIZE_L, "sfc|dfc|usp|vbr", modInfo = RWM_READ_OP1_L),
)
),
IsaData(
"moves", "Move Address Space", isPrivileged = true,
machine = EnumSet.range(Machine.MC68010, Machine.MC68060),
modes = listOf(
AllowedAdrMode(
ALL_68020_MODES_EXCEPT_IMMEDIATE_AND_PC_REL.minus(
listOf(
AddressMode.DATA_REGISTER_DIRECT,
AddressMode.ADDRESS_REGISTER_DIRECT
)
), DREG_AREG, modInfo = RWM_SET_OP2_OPSIZE
),
AllowedAdrMode(
DREG_AREG, ALL_68020_MODES_EXCEPT_IMMEDIATE_AND_PC_REL.minus(
listOf(
AddressMode.DATA_REGISTER_DIRECT,
AddressMode.ADDRESS_REGISTER_DIRECT
)
), modInfo = RWM_READ_OP1_OPSIZE
)
)
),
IsaData("reset", "Reset External Devices", machine = ALL_MACHINES, isPrivileged = true, hasOps = false, modes = NO_OPS_UNSIZED), IsaData("reset", "Reset External Devices", machine = ALL_MACHINES, isPrivileged = true, hasOps = false, modes = NO_OPS_UNSIZED),
IsaData( IsaData(
"rte", "Return from Exception", "rte", "Return from Exception",
@ -1120,10 +1168,7 @@ object M68kIsa {
private fun autoExpandForOtherCpus(machines: Set<Machine>, vararg isaDatas: IsaData): Array<out IsaData> { private fun autoExpandForOtherCpus(machines: Set<Machine>, vararg isaDatas: IsaData): Array<out IsaData> {
val allIsaData = ArrayList<IsaData>() val allIsaData = ArrayList<IsaData>()
for (isaData in isaDatas) { for (isaData in isaDatas) {
val newModes = ArrayList<AllowedAdrMode>() val newModes = isaData.modes.map { it.copy(op1 = add68020Modes(it.op1), op2 = add68020Modes(it.op2)) }
for (mode in isaData.modes) {
newModes.add(mode.copy(op1 = add68020Modes(mode.op1), op2 = add68020Modes(mode.op2)))
}
allIsaData.add(isaData.copy(machine = machines, modes = newModes)) allIsaData.add(isaData.copy(machine = machines, modes = newModes))
} }
return allIsaData.toTypedArray() return allIsaData.toTypedArray()
@ -1199,5 +1244,5 @@ object M68kIsa {
private fun isAddressModeMatching(am: AllowedAdrMode, op1: AddressMode?, op2: AddressMode?, specialReg: String?) = private fun isAddressModeMatching(am: AllowedAdrMode, op1: AddressMode?, op2: AddressMode?, specialReg: String?) =
((((op1 == null) && (am.op1 == null)) || am.op1?.contains(op1) ?: false) ((((op1 == null) && (am.op1 == null)) || am.op1?.contains(op1) ?: false)
&& (((op2 == null) && (am.op2 == null)) || am.op2?.contains(op2) ?: false) && (((op2 == null) && (am.op2 == null)) || am.op2?.contains(op2) ?: false)
&& ((specialReg == null) || (specialReg.equals(am.specialReg, true)))) && ((specialReg == null) || (am.specialReg?.split('|')?.any { it.equals(specialReg, true) } ?: false)))
} }

View File

@ -215,6 +215,8 @@ PLAIN_MACRO_LINE=[^;\r\n]+
"sr" { yybegin(exprOpState); return REG_SR; } "sr" { yybegin(exprOpState); return REG_SR; }
"usp" { yybegin(exprOpState); return REG_USP; } "usp" { yybegin(exprOpState); return REG_USP; }
"vbr" { yybegin(exprOpState); return REG_VBR; } "vbr" { yybegin(exprOpState); return REG_VBR; }
"dfc" { yybegin(exprOpState); return REG_DFC; }
"sfc" { yybegin(exprOpState); return REG_SFC; }
"#" { return HASH; } "#" { return HASH; }
"\[" { return SQUARE_L; } "\[" { return SQUARE_L; }

View File

@ -228,7 +228,7 @@ AddressRegister ::= AREG | REG_SP {
extends = Register extends = Register
} }
SpecialRegister ::= REG_CCR | REG_SR | REG_USP | REG_VBR { SpecialRegister ::= REG_CCR | REG_SR | REG_USP | REG_VBR | REG_SFC | REG_DFC {
name = "special register" name = "special register"
extends = Register extends = Register
} }

View File

@ -42,7 +42,7 @@ class M68kSyntaxHighlighter(val project: Project?) : SyntaxHighlighterBase() {
M68kTypes.AREG -> arrayOf(AREG) M68kTypes.AREG -> arrayOf(AREG)
M68kTypes.REG_SP -> arrayOf(STACK_POINTER) M68kTypes.REG_SP -> arrayOf(STACK_POINTER)
M68kTypes.DREG -> arrayOf(DREG) M68kTypes.DREG -> arrayOf(DREG)
M68kTypes.REG_USP, M68kTypes.REG_SR, M68kTypes.REG_CCR, M68kTypes.REG_VBR -> arrayOf(SPECIAL_REG) M68kTypes.REG_USP, M68kTypes.REG_SR, M68kTypes.REG_CCR, M68kTypes.REG_VBR, M68kTypes.REG_SFC, M68kTypes.REG_DFC -> arrayOf(SPECIAL_REG)
M68kTypes.COMMENT -> arrayOf(COMMENT) M68kTypes.COMMENT -> arrayOf(COMMENT)
M68kTypes.DECIMAL, M68kTypes.HEXADECIMAL, M68kTypes.OCTAL -> arrayOf(NUMBER) M68kTypes.DECIMAL, M68kTypes.HEXADECIMAL, M68kTypes.OCTAL -> arrayOf(NUMBER)
M68kTypes.STRINGLIT -> arrayOf(STRING) M68kTypes.STRINGLIT -> arrayOf(STRING)

View File

@ -13,27 +13,33 @@ internal class M68kMnemonicCompletionContributorTest : AbstractM68kTest() {
@Test @Test
internal fun completion_shows_all_move_mnemonics_after_first_letters(@MyFixture myFixture: CodeInsightTestFixture) { internal fun completion_shows_all_move_mnemonics_after_first_letters(@MyFixture myFixture: CodeInsightTestFixture) {
myFixture.configureByText("completeme.asm", """ myFixture.configureByText(
"completeme.asm", """
mo<caret> mo<caret>
""") """
)
myFixture.completeBasic() myFixture.completeBasic()
assertThat(myFixture.lookupElementStrings).containsExactlyInAnyOrder("move", "moveq", "movea", "movem", "movep") assertThat(myFixture.lookupElementStrings).containsExactlyInAnyOrder("move", "moveq", "movea", "movem", "movep", "movec", "moves")
} }
@Test @Test
internal fun completion_shows_all_mnemonics_after_label(@MyFixture myFixture: CodeInsightTestFixture) { internal fun completion_shows_all_mnemonics_after_label(@MyFixture myFixture: CodeInsightTestFixture) {
myFixture.configureByText("completeme.asm", """ myFixture.configureByText(
"completeme.asm", """
label: <caret> label: <caret>
""") """
)
myFixture.completeBasic() myFixture.completeBasic()
assertThat(myFixture.lookupElementStrings).hasSameElementsAs(M68kIsa.mnemonics) assertThat(myFixture.lookupElementStrings).hasSameElementsAs(M68kIsa.mnemonics)
} }
@Test @Test
internal fun completion_shows_all_mnemonics_after_space(@MyFixture myFixture: CodeInsightTestFixture) { internal fun completion_shows_all_mnemonics_after_space(@MyFixture myFixture: CodeInsightTestFixture) {
myFixture.configureByText("completeme.asm", """ myFixture.configureByText(
"completeme.asm", """
<caret> <caret>
""") """
)
myFixture.completeBasic() myFixture.completeBasic()
assertThat(myFixture.lookupElementStrings).hasSameElementsAs(M68kIsa.mnemonics) assertThat(myFixture.lookupElementStrings).hasSameElementsAs(M68kIsa.mnemonics)
} }