Add linter option

This commit is contained in:
Zachary Yedidia 2016-05-05 11:31:53 -04:00
parent 3cbb23bfbe
commit 31567c9e15
5 changed files with 91 additions and 28 deletions

View file

@ -218,7 +218,6 @@ func main() {
L.SetGlobal("OS", luar.New(L, runtime.GOOS)) L.SetGlobal("OS", luar.New(L, runtime.GOOS))
L.SetGlobal("view", luar.New(L, view)) L.SetGlobal("view", luar.New(L, view))
L.SetGlobal("settings", luar.New(L, &settings))
L.SetGlobal("messenger", luar.New(L, messenger)) L.SetGlobal("messenger", luar.New(L, messenger))
L.SetGlobal("GetOption", luar.New(L, GetOption)) L.SetGlobal("GetOption", luar.New(L, GetOption))
L.SetGlobal("AddOption", luar.New(L, AddOption)) L.SetGlobal("AddOption", luar.New(L, AddOption))

File diff suppressed because one or more lines are too long

View file

@ -406,6 +406,13 @@ func (v *View) ClearGutterMessages(section string) {
v.messages[section] = []GutterMessage{} v.messages[section] = []GutterMessage{}
} }
// ClearAllGutterMessages clears all the gutter messages
func (v *View) ClearAllGutterMessages() {
for k := range v.messages {
v.messages[k] = []GutterMessage{}
}
}
// DisplayView renders the view to the screen // DisplayView renders the view to the screen
func (v *View) DisplayView() { func (v *View) DisplayView() {
// The character number of the character in the top left of the screen // The character number of the character in the top left of the screen

View file

@ -13,9 +13,6 @@ function go_onSave()
go_gofmt() go_gofmt()
end end
linter_lint("go build", "go build -o /dev/null 2>&1", "%f:%l: %m")
linter_lint("go lint", "golint " .. view.Buf.Path, "%f:%l:%d+: %m")
view:ReOpen() view:ReOpen()
end end
end end

View file

@ -1,25 +1,33 @@
if GetOption("linter") == nil then
AddOption("linter", true)
end
function linter_onSave() function linter_onSave()
local ft = view.Buf.Filetype if GetOption("linter") then
local file = view.Buf.Path local ft = view.Buf.Filetype
local devnull = "/dev/null" local file = view.Buf.Path
if OS == "windows" then local devnull = "/dev/null"
devnull = "NUL" if OS == "windows" then
end devnull = "NUL"
if ft == "Go" then end
linter_lint("gobuild", "go build -o " .. devnull, "%f:%l: %m") if ft == "Go" then
linter_lint("golint", "golint " .. view.Buf.Path, "%f:%l:%d+: %m") linter_lint("gobuild", "go build -o " .. devnull, "%f:%l: %m")
elseif ft == "Lua" then linter_lint("golint", "golint " .. view.Buf.Path, "%f:%l:%d+: %m")
linter_lint("luacheck", "luacheck --no-color " .. file, "%f:%l:%d+: %m") elseif ft == "Lua" then
elseif ft == "Python" then linter_lint("luacheck", "luacheck --no-color " .. file, "%f:%l:%d+: %m")
linter_lint("pyflakes", "pyflakes " .. file, "%f:%l: %m") elseif ft == "Python" then
elseif ft == "C" then linter_lint("pyflakes", "pyflakes " .. file, "%f:%l: %m")
linter_lint("gcc", "gcc -fsyntax-only -Wall -Wextra " .. file, "%f:%l:%d+:.+: %m") elseif ft == "C" then
elseif ft == "D" then linter_lint("gcc", "gcc -fsyntax-only -Wall -Wextra " .. file, "%f:%l:%d+:.+: %m")
linter_lint("dmd", "dmd -color=off -o- -w -wi -c " .. file, "%f%(%l%):.+: %m") elseif ft == "D" then
elseif ft == "Java" then linter_lint("dmd", "dmd -color=off -o- -w -wi -c " .. file, "%f%(%l%):.+: %m")
linter_lint("javac", "javac " .. file, "%f:%l: error: %m") elseif ft == "Java" then
elseif ft == "JavaScript" then linter_lint("javac", "javac " .. file, "%f:%l: error: %m")
linter_lint("jshint", "jshint " .. file, "%f: line %l,.+, %m") elseif ft == "JavaScript" then
linter_lint("jshint", "jshint " .. file, "%f: line %l,.+, %m")
end
else
view:ClearAllGutterMessages()
end end
end end