-
-
Notifications
You must be signed in to change notification settings - Fork 366
/
Copy pathcommands.py
115 lines (92 loc) · 3.53 KB
/
commands.py
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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
import sublime
import sublime_plugin
import os
from threading import Thread
from . import sublimelint
from .lint import persist
from .lint.edit import Edit
def error_command(f):
def run(self, edit, **kwargs):
vid = self.view.id()
if vid in persist.errors and persist.errors[vid]:
f(self, self.view, persist.errors[vid], **kwargs)
return run
def select_line(view, line):
sel = view.sel()
point = view.text_point(line, 0)
sel.clear()
sel.add(view.line(point))
class sublimelint_next_error(sublime_plugin.TextCommand):
@error_command
def run(self, view, errors, direction=1):
self.view.run_command('single_selection')
sel = view.sel()
if len(sel) == 0:
sel.add((0, 0))
line = view.rowcol(sel[0].a)[0]
errors = list(errors)
if line in errors: errors.remove(line)
errors = sorted(errors + [line])
i = errors.index(line) + direction
if i >= len(errors):
i -= len(errors)
select_line(view, errors[i])
view.show_at_center(sel[0])
class sublimelint_all_errors(sublime_plugin.TextCommand):
@error_command
def run(self, view, errors):
options = []
option_to_line = []
for lineno, messages in sorted(errors.items()):
line = view.substr(
view.full_line(view.text_point(lineno, 0))
)
while messages:
option_to_line.append(lineno)
options.append(
[("%i| %s" % (lineno + 1, line.strip()))] +
[m for m in messages[:2]]
)
messages = messages[2:]
def center_line(i):
if i != -1:
select_line(view, option_to_line[i])
view.show_at_center(view.sel()[0])
view.window().show_quick_panel(options, center_line, sublime.MONOSPACE_FONT)
class sublimelint_report(sublime_plugin.WindowCommand):
def run(self, on='files'):
output = self.window.new_file()
output.set_name('SublimeLint')
output.set_scratch(True)
if on == 'files' or on == 'both':
for view in self.window.views():
self.report(output, view)
if on == 'folders' or on == 'both':
for folder in self.window.folders():
self.folder(output, folder)
def folder(self, output, folder):
for root, dirs, files in os.walk(folder):
for name in files:
path = os.path.join(root, name)
# heuristic to speed things up a bit:
# ignore files over 256KB
if os.stat(path).st_size < 256 * 1024:
# TODO: not implemented
pass
def report(self, output, view):
def finish_lint(view, linters):
if not linters:
return
with Edit(output) as edit:
if not any(l.errors for l in linters):
return
filename = os.path.basename(linters[0].filename or 'untitled')
out = '\n{}:\n'.format(filename)
for linter in linters:
if linter.errors:
for line, errors in sorted(linter.errors.items()):
for error in errors:
out += ' {}: {}\n'.format(line, error)
edit.insert(output.size(), out)
args = (view.id(), finish_lint)
Thread(target=sublimelint.SublimeLint.lint, args=args).start()