From 780471d2cb6b49496243e31483e3769bf993514d Mon Sep 17 00:00:00 2001 From: kdekaluga Date: Sat, 14 May 2016 14:28:49 +0300 Subject: [PATCH 1/4] Update avr-asm.tmLanguage Added missing registers (X, Y, Z, PC, ZERO), missing instructions (adiw, icall), #-directives Labels after jump command (e.g. rjmp, brcs, etc.) are now colored. --- avr-asm.tmLanguage | 43 +++++++++++++++++++++++++++++++++++++------ 1 file changed, 37 insertions(+), 6 deletions(-) diff --git a/avr-asm.tmLanguage b/avr-asm.tmLanguage index 8dd92a4..bbda7dd 100644 --- a/avr-asm.tmLanguage +++ b/avr-asm.tmLanguage @@ -11,6 +11,23 @@ AVR ASM patterns + + match + (rjmp|rcall|brbs|brbc|breq|brne|brcs|brcc|brsh|brlo|brmi|brpl|brge|brlt|brhs|brhc|brts|brtc|brvs|brvc|brie|brid)\s+(\w+) + captures + + 1 + + name + keyword.operator.asm + + 2 + + name + entity.name.function + + + comment General purpose register set @@ -20,10 +37,8 @@ storage.type.asm - comment - General purpose register set (16-bit pointers) match - (?i)\b(xl|xh|yl|yh|zl|zh)\b + (?i)\b(X|Y|Z|XL|XH|YL|YH|ZL|ZH|PC|ZERO)\b name storage.type.asm @@ -31,7 +46,7 @@ comment Arithmetic and logic instruction mnemonics match - (?i)\b(add|adc|sub|subi|sbc|sbci|sbiw|and|andi|or|ori|eor|com|neg|sbr|cbr|inc|dec|tst|clr|ser)\b + (?i)\b(add|adc|adiw|sub|subi|sbc|sbci|sbiw|and|andi|or|ori|eor|com|neg|sbr|cbr|inc|dec|tst|clr|ser)\b name keyword.operator.asm @@ -39,7 +54,7 @@ comment Branch instruction mnemonics match - (?i)\b(rjmp|ijmp|rcall|ret|reti|cpse|cp|cpc|cpi|sbrc|sbrs|sbic|sbis|brbs|brbc|breq|brne|brcs|brcc|brsh|brlo|brmi|brpl|brge|brlt|brhs|brhc|brts|brtc|brvs|brvc|brie|brid)\b + (?i)\b(rjmp|ijmp|rcall|icall|ret|reti|cpse|cp|cpc|cpi|sbrc|sbrs|sbic|sbis|brbs|brbc|breq|brne|brcs|brcc|brsh|brlo|brmi|brpl|brge|brlt|brhs|brhc|brts|brtc|brvs|brvc|brie|brid)\b name keyword.operator.asm @@ -75,6 +90,22 @@ name constant.character.asm + + comment + AVR ASM 1.0 directives + match + (?i)\#(define|undef|ifdef|ifndef|if|elif|else|endif|error|warning|message|include|pragma) + name + constant.character.asm + + + comment + AVR ASM 1.0 directives + match + (?i)(low|high|byte2|byte3|byte4|lwrd|hwrd|page|exp2|log2) + name + constant.character.asm + comment Comment line @@ -137,7 +168,7 @@ comment Dec number constant match - \b(0|[1-9]\d+)\b + \-?\b(\d+)\b name constant.numeric.asm From ce26e4d684d6cd46ee0c83b3453a9d8579fdb925 Mon Sep 17 00:00:00 2001 From: PRESFIL Date: Mon, 25 Jul 2016 20:26:42 +0300 Subject: [PATCH 2/4] Missed commands and directives Added: Commands: adiw, mul, muls, mulsu, fmul, fmuls, mfulsu, eijmp, jmp, icall, eicall, call, elpm, espm. Added: Directives: elseif, word, warning. Fixed: Conflicts[]: --- avr-asm.JSON-tmLanguage | 35 +++++++++-------------------------- 1 file changed, 9 insertions(+), 26 deletions(-) diff --git a/avr-asm.JSON-tmLanguage b/avr-asm.JSON-tmLanguage index fdd63d5..23a6ad3 100644 --- a/avr-asm.JSON-tmLanguage +++ b/avr-asm.JSON-tmLanguage @@ -2,106 +2,89 @@ "name": "AVR ASM", "scopeName": "source.asm", "fileTypes": ["asm", "inc"], - "patterns": [ - + "patterns": + [ { - "match": "(?i)\\br(0|1|2|3|4|5|6|7|8|9|10|11|12|13|14|15|16|17|18|19|20|21|22|23|24|25|26|27|28|29|30|31)\\b", + "match": "(?i)\\bR(0|1|2|3|4|5|6|7|8|9|10|11|12|13|14|15|16|17|18|19|20|21|22|23|24|25|26|27|28|29|30|31)\\b", "name": "storage.type.asm", "comment": "General perpose register set" }, - { - "match": "(?i)\\b(xl|xh|yl|yh|zl|zh)\\b", + "match": "(?i)\\b(XL|XH|YL|YH|ZL|ZH)\\b", "name": "storage.type.asm", "comment": "General perpose register set (16-bit pointers)" }, - { - "match": "(?i)\\b(add|adc|sub|subi|sbc|sbci|sbiw|and|andi|or|ori|eor|com|neg|sbr|cbr|inc|dec|tst|clr|ser)\\b", + "match": "(?i)\\b(add|adc|sub|subi|sbc|sbci|sbiw|and|andi|or|ori|eor|com|neg|sbr|cbr|inc|dec|tst|clr|ser|adiw|mul|muls|mulsu|fmul|fmuls|fmulsu)\\b", "name": "keyword.operator.asm", "comment": "Arithmetic and logic instruction mnemonics" }, - { - "match": "(?i)\\b(rjmp|ijmp|rcall|ret|reti|cpse|cp|cpc|cpi|sbrc|sbrs|sbic|sbis|brbs|brbc|breq|brne|brcs|brcc|brsh|brlo|brmi|brpl|brge|brlt|brhs|brhc|brts|brtc|brvs|brvc|brie|brid)\\b", + "match": "(?i)\\b(rjmp|ijmp|eijmp|jmp|rcall|icall|eicall|call|ret|reti|cpse|cp|cpc|cpi|sbrc|sbrs|sbic|sbis|brbs|brbc|breq|brne|brcs|brcc|brsh|brlo|brmi|brpl|brge|brlt|brhs|brhc|brts|brtc|brvs|brvc|brie|brid)\\b", "name": "keyword.operator.asm", "comment": "Branch instruction mnemonics" }, - { "match": "(?i)\\b(sbi|cbi|lsl|lsr|rol|ror|asr|swap|bset|bclr|bst|bld|sec|clc|sen|cln|sez|clz|sei|cli|ses|cls|sev|clv|set|clt|seh|clh)\\b", "name": "keyword.operator.asm", "comment": "Bit and bit-test instruction mnemonics" }, - { - "match": "(?i)\\b(mov|movw|ldi|ld|ldd|lds|st|std|sts|lpm|spm|in|out|push|pop)\\b", + "match": "(?i)\\b(mov|movw|ldi|ld|ldd|lds|st|std|sts|lpm|elpm|spm|espm|in|out|push|pop)\\b", "name": "keyword.operator.asm", "comment": "Data transfer instruction mnemonics" }, - { "match": "(?i)\\b(nop|sleep|wdr|break)\\b", "name": "keyword.coperator.asm", "comment": "MCU control instruction mnemonics" }, - { - "match": "(?i)(^|\\s)\\.(byte|cseg|csegsize|db|dd|def|device|dq|dseg|dw|elif|else|endif|endm|endmacro|equ|error|eseg|exit|if|ifdef|ifndef|include|list|listmac|macro|message|nolist|org|set|undef)", + "match": "(?i)(^|\\s)\\.(byte|csegsize|cseg|db|dd|def|device|dq|dseg|dw|elseif|elif|else|endif|endmacro|endm|equ|error|eseg|exit|if|ifdef|ifndef|include|list|listmac|macro|message|nolist|org|set|undef|word|warning)", "name": "constant.character.asm", "comment": "AVR ASM 1.0 directives" }, - { "match": "(\/\/|;)(\\s|\\S)*", "name": "comment.line.asm", "comment": "Comment line" }, - { "begin": "(\/\\*)", "end": "(\\*\/)", "name": "comment.block.asm", "comment": "C-style comment block (AVR ASM 2.0 only)" }, - { "match": "(^|\\s)\"[\\w\\s\\W]*\"($|\\s)", "name": "string.asm", "comment": "Single-line string" }, - { "match": "(^|\\s)\\'[\\w\\s\\W]*\\'($|\\s)", "name": "string.asm", "comment": "Single-line string" }, - { "match": "(?i)\\b(0x(\\d|[A-F])+)\\b", "name": "constant.numeric.asm", "comment": "Hex number constant" }, - { "match": "\\b(0[0-7]+)\\b", "name": "constant.numeric.asm", "comment": "Oct number constant" }, - { "match": "\\b(0b(0|1)+)\\b", "name": "constant.numeric.asm", "comment": "Bin number constant" }, - { "match": "\\b(0|[1-9]\\d+)\\b", "name": "constant.numeric.asm", "comment": "Dec number constant" } - ], - "uuid": "97b6acae-cfc1-4c14-b572-c51987e1e023" -} \ No newline at end of file +} From 5b70bb2e1be66ff1c5423021b249e4f92d12ddfa Mon Sep 17 00:00:00 2001 From: PRESFIL Date: Mon, 25 Jul 2016 20:47:26 +0300 Subject: [PATCH 3/4] Highlighting Conflict Fixes Fixed: Conflicts[]: - 1. Between ".cseg" and ".csegsize" - 2. Between ".endm" and ".endmacro" - 3. Between ".elif"/".else" and ".elseif" - 4. Between ".if" and ".ifdef"/".ifndef" - 5. Between ".list" and ".listmac" --- avr-asm.JSON-tmLanguage | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/avr-asm.JSON-tmLanguage b/avr-asm.JSON-tmLanguage index 23a6ad3..b74fe9b 100644 --- a/avr-asm.JSON-tmLanguage +++ b/avr-asm.JSON-tmLanguage @@ -40,7 +40,7 @@ "comment": "MCU control instruction mnemonics" }, { - "match": "(?i)(^|\\s)\\.(byte|csegsize|cseg|db|dd|def|device|dq|dseg|dw|elseif|elif|else|endif|endmacro|endm|equ|error|eseg|exit|if|ifdef|ifndef|include|list|listmac|macro|message|nolist|org|set|undef|word|warning)", + "match": "(?i)(^|\\s)\\.(byte|csegsize|cseg|db|dd|def|device|dq|dseg|dw|elseif|elif|else|endif|endmacro|endm|equ|error|eseg|exit|ifdef|ifndef|if|include|listmac|list|macro|message|nolist|org|set|undef|word|warning)", "name": "constant.character.asm", "comment": "AVR ASM 1.0 directives" }, From 8bbb46307b8c6bc47230ae796b3d59305e798026 Mon Sep 17 00:00:00 2001 From: PRESFIL Date: Mon, 25 Jul 2016 21:07:28 +0300 Subject: [PATCH 4/4] Copy mnemonics and other fixes from avr-asm.JSON-tmLanguage into avr-asm.tmLanguage --- avr-asm.tmLanguage | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/avr-asm.tmLanguage b/avr-asm.tmLanguage index bbda7dd..3ecf76b 100644 --- a/avr-asm.tmLanguage +++ b/avr-asm.tmLanguage @@ -13,7 +13,7 @@ match - (rjmp|rcall|brbs|brbc|breq|brne|brcs|brcc|brsh|brlo|brmi|brpl|brge|brlt|brhs|brhc|brts|brtc|brvs|brvc|brie|brid)\s+(\w+) + (rjmp|ijmp|eijmp|jmp|rcall|icall|eicall|call|ret|reti|cpse|cp|cpc|cpi|sbrc|sbrs|sbic|sbis|brbs|brbc|breq|brne|brcs|brcc|brsh|brlo|brmi|brpl|brge|brlt|brhs|brhc|brts|brtc|brvs|brvc|brie|brid)\s+(\w+) captures 1 @@ -32,7 +32,7 @@ comment General purpose register set match - (?i)\br(0|1|2|3|4|5|6|7|8|9|10|11|12|13|14|15|16|17|18|19|20|21|22|23|24|25|26|27|28|29|30|31)\b + (?i)\bR(0|1|2|3|4|5|6|7|8|9|10|11|12|13|14|15|16|17|18|19|20|21|22|23|24|25|26|27|28|29|30|31)\b name storage.type.asm @@ -46,7 +46,7 @@ comment Arithmetic and logic instruction mnemonics match - (?i)\b(add|adc|adiw|sub|subi|sbc|sbci|sbiw|and|andi|or|ori|eor|com|neg|sbr|cbr|inc|dec|tst|clr|ser)\b + (?i)\b(add|adc|sub|subi|sbc|sbci|sbiw|and|andi|or|ori|eor|com|neg|sbr|cbr|inc|dec|tst|clr|ser|adiw|mul|muls|mulsu|fmul|fmuls|fmulsu)\b name keyword.operator.asm @@ -54,7 +54,7 @@ comment Branch instruction mnemonics match - (?i)\b(rjmp|ijmp|rcall|icall|ret|reti|cpse|cp|cpc|cpi|sbrc|sbrs|sbic|sbis|brbs|brbc|breq|brne|brcs|brcc|brsh|brlo|brmi|brpl|brge|brlt|brhs|brhc|brts|brtc|brvs|brvc|brie|brid)\b + (?i)\b(rjmp|ijmp|eijmp|jmp|rcall|icall|eicall|call|ret|reti|cpse|cp|cpc|cpi|sbrc|sbrs|sbic|sbis|brbs|brbc|breq|brne|brcs|brcc|brsh|brlo|brmi|brpl|brge|brlt|brhs|brhc|brts|brtc|brvs|brvc|brie|brid)\b name keyword.operator.asm @@ -70,7 +70,7 @@ comment Data transfer instruction mnemonics match - (?i)\b(mov|movw|ldi|ld|ldd|lds|st|std|sts|lpm|spm|in|out|push|pop)\b + (?i)\b(mov|movw|ldi|ld|ldd|lds|st|std|sts|lpm|elpm|spm|espm|in|out|push|pop)\b name keyword.operator.asm @@ -86,7 +86,7 @@ comment AVR ASM 1.0 directives match - (?i)(^|\s)\.(byte|cseg|csegsize|db|dd|def|device|dq|dseg|dw|elif|else|endif|endm|endmacro|equ|error|eseg|exit|if|ifdef|ifndef|include|list|listmac|macro|message|nolist|org|set|undef) + (?i)(^|\s)\.(byte|csegsize|cseg|db|dd|def|device|dq|dseg|dw|elseif|elif|else|endif|endmacro|endm|equ|error|eseg|exit|ifdef|ifndef|if|include|listmac|list|macro|message|nolist|org|set|undef|word|warning) name constant.character.asm