-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
0 parents
commit c127b86
Showing
3 changed files
with
298 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
au BufRead,BufNewFile *.s setlocal ft=mips |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,44 @@ | ||
" Vim indent file | ||
" Language: MIPS | ||
" Maintainer: Shoaib Meenai <[email protected]> | ||
|
||
if exists("b:did_indent") | ||
finish | ||
endif | ||
let b:did_indent = 1 | ||
|
||
setlocal indentexpr=GetMipsIndent() | ||
setlocal indentkeys=!^F,o,O,<:>,0#,=,*<Return> | ||
setlocal tabstop=8 softtabstop=8 shiftwidth=8 noexpandtab | ||
|
||
if exists("*GetMipsIndent") | ||
finish | ||
endif | ||
|
||
let s:label_rx = '^[^#"]*:' | ||
let s:equate_rx = '^[^#]*=' | ||
let s:starts_with_comment_rx = '^\s*#' | ||
let s:starts_with_directive_rx = '^\s*\.' | ||
|
||
function GetMipsIndent() | ||
let line_number = v:lnum | ||
let line_contents = getline(line_number) | ||
|
||
if line_contents =~ s:label_rx || line_contents =~ s:equate_rx | ||
return 0 | ||
endif | ||
|
||
if line_contents =~ s:starts_with_comment_rx | ||
" if this returns -1, we'll just keep the current indent, which will | ||
" have gotten set to &shiftwidth when inserting the line | ||
return indent(nextnonblank(line_number + 1)) | ||
endif | ||
|
||
if line_contents =~ s:starts_with_directive_rx | ||
" if you manually indent assembler directives, prevent them from being | ||
" reindented | ||
return -1 | ||
endif | ||
|
||
return &shiftwidth | ||
endfunction |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,253 @@ | ||
" Vim syntax file | ||
" Language: MIPS | ||
" Maintainer: Alex Brick <[email protected]> | ||
" Last Change: 2007 Oct 18 | ||
|
||
if version < 600 | ||
syntax clear | ||
elseif exists("b:current_syntax") | ||
finish | ||
endif | ||
|
||
setlocal iskeyword+=- | ||
syntax case match | ||
|
||
syntax match mipsComment /#.*/ | ||
syntax match mipsNumber /\<[-]\?\d\+\>/ " Decimal numbers | ||
syntax match mipsNumber /\<-\?0\(x\|X\)[0-9a-fA-F]\+\>/ " Hex numbers | ||
syntax region mipsString start=/"/ skip=/\\"/ end=/"/ | ||
syntax match mipsLabelColon /:/ contained | ||
syntax match mipsLabel /\w\+:/ contains=mipsLabelColon | ||
|
||
" Registers | ||
syntax match mipsRegister "\$zero" | ||
syntax match mipsRegister "\$v0" | ||
syntax match mipsRegister "\$v1" | ||
syntax match mipsRegister "\$a0" | ||
syntax match mipsRegister "\$a1" | ||
syntax match mipsRegister "\$a2" | ||
syntax match mipsRegister "\$a3" | ||
syntax match mipsRegister "\$t0" | ||
syntax match mipsRegister "\$t1" | ||
syntax match mipsRegister "\$t2" | ||
syntax match mipsRegister "\$t3" | ||
syntax match mipsRegister "\$t4" | ||
syntax match mipsRegister "\$t5" | ||
syntax match mipsRegister "\$t6" | ||
syntax match mipsRegister "\$t7" | ||
syntax match mipsRegister "\$t8" | ||
syntax match mipsRegister "\$t9" | ||
syntax match mipsRegister "\$s0" | ||
syntax match mipsRegister "\$s1" | ||
syntax match mipsRegister "\$s2" | ||
syntax match mipsRegister "\$s3" | ||
syntax match mipsRegister "\$s4" | ||
syntax match mipsRegister "\$s5" | ||
syntax match mipsRegister "\$s6" | ||
syntax match mipsRegister "\$s7" | ||
syntax match mipsRegister "\$s8" | ||
syntax match mipsRegister "\$k0" | ||
syntax match mipsRegister "\$k1" | ||
syntax match mipsRegister "\$gp" | ||
syntax match mipsRegister "\$sp" | ||
syntax match mipsRegister "\$fp" | ||
syntax match mipsRegister "\$ra" | ||
syntax match mipsRegister "\$at" | ||
|
||
let i = 0 | ||
while i < 32 | ||
" This is for the regular registers | ||
execute 'syntax match mipsRegister "\$' . i . '\(\d\+\)\@!"' | ||
" And this is for the FP registers | ||
execute 'syntax match mipsRegister "\$f' . i . '\(\d\+\)\@!"' | ||
let i = i + 1 | ||
endwhile | ||
|
||
" Directives | ||
syntax match mipsDirective "\.2byte" | ||
syntax match mipsDirective "\.4byte" | ||
syntax match mipsDirective "\.8byte" | ||
syntax match mipsDirective "\.aent" | ||
syntax match mipsDirective "\.align" | ||
syntax match mipsDirective "\.ascii" | ||
syntax match mipsDirective "\.asciiz" | ||
syntax match mipsDirective "\.byte" | ||
syntax match mipsDirective "\.comm" | ||
syntax match mipsDirective "\.cpadd" | ||
syntax match mipsDirective "\.cpload" | ||
syntax match mipsDirective "\.cplocal" | ||
syntax match mipsDirective "\.cprestore" | ||
syntax match mipsDirective "\.cpreturn" | ||
syntax match mipsDirective "\.cpsetup" | ||
syntax match mipsDirective "\.data" | ||
syntax match mipsDirective "\.double" | ||
syntax match mipsDirective "\.dword" | ||
syntax match mipsDirective "\.dynsym" | ||
syntax match mipsDirective "\.end" | ||
syntax match mipsDirective "\.endr" | ||
syntax match mipsDirective "\.ent" | ||
syntax match mipsDirective "\.extern" | ||
syntax match mipsDirective "\.file" | ||
syntax match mipsDirective "\.float" | ||
syntax match mipsDirective "\.fmask" | ||
syntax match mipsDirective "\.frame" | ||
syntax match mipsDirective "\.globl" | ||
syntax match mipsDirective "\.gpvalue" | ||
syntax match mipsDirective "\.gpword" | ||
syntax match mipsDirective "\.half" | ||
syntax match mipsDirective "\.kdata" | ||
syntax match mipsDirective "\.ktext" | ||
syntax match mipsDirective "\.lab" | ||
syntax match mipsDirective "\.lcomm" | ||
syntax match mipsDirective "\.loc" | ||
syntax match mipsDirective "\.mask" | ||
syntax match mipsDirective "\.nada" | ||
syntax match mipsDirective "\.nop" | ||
syntax match mipsDirective "\.option" | ||
syntax match mipsDirective "\.origin" | ||
syntax match mipsDirective "\.repeat" | ||
syntax match mipsDirective "\.rdata" | ||
syntax match mipsDirective "\.sdata" | ||
syntax match mipsDirective "\.section" | ||
syntax match mipsDirective "\.set" | ||
syntax match mipsDirective "\.size" | ||
syntax match mipsDirective "\.space" | ||
syntax match mipsDirective "\.struct" | ||
syntax match mipsDirective "\.text" | ||
syntax match mipsDirective "\.type" | ||
syntax match mipsDirective "\.verstamp" | ||
syntax match mipsDirective "\.weakext" | ||
syntax match mipsDirective "\.word" | ||
|
||
" Arithmetic and Logical Instructions | ||
syntax keyword mipsInstruction abs | ||
syntax keyword mipsInstruction add addu addi addiu | ||
syntax keyword mipsInstruction and andi | ||
syntax keyword mipsInstruction clo clz | ||
syntax keyword mipsInstruction div divu | ||
syntax keyword mipsInstruction mult multu mul mulo mulou madd maddu msub msubu | ||
syntax keyword mipsInstruction neg negu | ||
syntax keyword mipsInstruction nor | ||
syntax keyword mipsInstruction not | ||
syntax keyword mipsInstruction or ori | ||
syntax keyword mipsInstruction rem remu | ||
syntax keyword mipsInstruction sll sllv sra srav srl srlv | ||
syntax keyword mipsInstruction rol ror | ||
syntax keyword mipsInstruction sub subu | ||
syntax keyword mipsInstruction xor xori | ||
|
||
" Constant-Manipulating Instructions | ||
syntax keyword mipsInstruction lui li | ||
syntax keyword mipsInstruction slt sltu slti sltiu | ||
syntax keyword mipsInstruction seq | ||
syntax keyword mipsInstruction sge sgeu | ||
syntax keyword mipsInstruction sgt sgtu | ||
syntax keyword mipsInstruction sle sleu | ||
syntax keyword mipsInstruction sne | ||
|
||
" Branch Instructions | ||
syntax keyword mipsInstruction b | ||
syntax keyword mipsInstruction bc1f bc1t | ||
syntax keyword mipsInstruction beq beqz | ||
syntax keyword mipsInstruction bgez bgezal bgtz | ||
syntax keyword mipsInstruction blez bltzal bltz | ||
syntax keyword mipsInstruction bne bnez | ||
syntax keyword mipsInstruction bge bgeu | ||
syntax keyword mipsInstruction bgt bgtu | ||
syntax keyword mipsInstruction ble bleu | ||
syntax keyword mipsInstruction blt bltu | ||
|
||
" Jump Instructions | ||
syntax keyword mipsInstruction j jal jalr jr | ||
|
||
" Trap Instructions | ||
syntax keyword mipsInstruction teq teqi | ||
syntax keyword mipsInstruction tne tnei | ||
syntax keyword mipsInstruction tge tgeu tgei tgeiu | ||
syntax keyword mipsInstruction tlt tltu tlti tltiu | ||
|
||
" Load Instructions | ||
syntax keyword mipsInstruction la | ||
syntax keyword mipsInstruction lb lbu lh lhu | ||
syntax keyword mipsInstruction lw lwc1 lwl lwr | ||
syntax keyword mipsInstruction ld | ||
syntax keyword mipsInstruction ulh ulhu ulw | ||
syntax keyword mipsInstruction ll | ||
|
||
" Store Instructions | ||
syntax keyword mipsInstruction sb sh sw swc1 sdc1 swl swr sd ush usw sc | ||
|
||
" Data Movement Instructions | ||
syntax keyword mipsInstruction move | ||
syntax keyword mipsInstruction mfhi mflo | ||
syntax keyword mipsInstruction mthi mtlo | ||
syntax keyword mipsInstruction mfc0 mfc1 | ||
syntax match mipsInstruction "mfc1\.d" | ||
syntax keyword mipsInstruction mtc0 mtc1 | ||
syntax keyword mipsInstruction movn movz movf movt | ||
|
||
" Floating-Point Instructions | ||
syntax match mipsInstruction "abs\.d" | ||
syntax match mipsInstruction "abs\.s" | ||
syntax match mipsInstruction "add\.d" | ||
syntax match mipsInstruction "add\.s" | ||
syntax match mipsInstruction "ceil\.w\.d" | ||
syntax match mipsInstruction "ceil\.w\.s" | ||
syntax match mipsInstruction "c\.eq\.d" | ||
syntax match mipsInstruction "c\.eq\.s" | ||
syntax match mipsInstruction "c\.le\.d" | ||
syntax match mipsInstruction "c\.le\.s" | ||
syntax match mipsInstruction "c\.lt\.d" | ||
syntax match mipsInstruction "c\.lt\.s" | ||
syntax match mipsInstruction "cvt\.d\.s" | ||
syntax match mipsInstruction "cvt\.d\.w" | ||
syntax match mipsInstruction "cvt\.s\.d" | ||
syntax match mipsInstruction "cvt\.s\.w" | ||
syntax match mipsInstruction "cvt\.w\.d" | ||
syntax match mipsInstruction "cvt\.w\.s" | ||
syntax match mipsInstruction "div\.d" | ||
syntax match mipsInstruction "div\.s" | ||
syntax match mipsInstruction "floor\.w\.d" | ||
syntax match mipsInstruction "floor\.w\.s" | ||
syntax match mipsInstruction "l\.d" | ||
syntax match mipsInstruction "l\.s" | ||
syntax match mipsInstruction "mov\.d" | ||
syntax match mipsInstruction "mov\.s" | ||
syntax match mipsInstruction "movf\.d" | ||
syntax match mipsInstruction "movf\.s" | ||
syntax match mipsInstruction "movt\.d" | ||
syntax match mipsInstruction "movt\.s" | ||
syntax match mipsInstruction "movn\.d" | ||
syntax match mipsInstruction "movn\.s" | ||
syntax match mipsInstruction "movz\.d" | ||
syntax match mipsInstruction "movz\.s" | ||
syntax match mipsInstruction "mul\.d" | ||
syntax match mipsInstruction "mul\.s" | ||
syntax match mipsInstruction "neg\.d" | ||
syntax match mipsInstruction "neg\.s" | ||
syntax match mipsInstruction "round\.w\.d" | ||
syntax match mipsInstruction "round\.w\.s" | ||
syntax match mipsInstruction "sqrt\.d" | ||
syntax match mipsInstruction "sqrt\.s" | ||
syntax match mipsInstruction "s\.d" | ||
syntax match mipsInstruction "s\.s" | ||
syntax match mipsInstruction "sub\.d" | ||
syntax match mipsInstruction "sub\.s" | ||
syntax match mipsInstruction "trunc\.w\.d" | ||
syntax match mipsInstruction "trunc\.w\.s" | ||
|
||
" Exception and Interrupt Instructions | ||
syntax keyword mipsInstruction eret | ||
syntax keyword mipsInstruction syscall | ||
syntax keyword mipsInstruction break | ||
syntax keyword mipsInstruction nop | ||
|
||
hi def link mipsComment Comment | ||
hi def link mipsNumber Number | ||
hi def link mipsString String | ||
hi def link mipsLabel Label | ||
hi def link mipsRegister Identifier | ||
hi def link mipsDirective Type | ||
hi def link mipsInstruction Statement | ||
|
||
let b:current_syntax = "mips" |