forked from aziz/SublimeHyperClick
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathhyper_click_annotator.py
162 lines (138 loc) · 5.37 KB
/
hyper_click_annotator.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
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
import sublime_plugin
import sublime
import re
import webbrowser
from .hyper_click.path_resolver import HyperClickPathResolver
class HyperClickAnnotator(sublime_plugin.EventListener):
def __init__(self):
self.current_line = (-1, -1)
def is_valid_line(self, line_content, view):
settings = sublime.load_settings('HyperClick.sublime-settings')
scopes = settings.get('scopes', {})
for selector in scopes:
if view.match_selector(view.sel()[0].b, selector):
for regex_str in scopes[selector]['regexes']:
pattern = re.compile(regex_str)
matched = pattern.match(line_content)
if matched:
return matched
return False
def on_navigate(self, url):
if url.startswith('http://') or url.startswith('https://'):
webbrowser.open_new_tab(url)
else:
self.window.open_file(url)
def annotate(self, point, view):
self.window = view.window()
if not self.window:
return
settings = sublime.load_settings('HyperClick.sublime-settings')
if not settings.get('annotations_enabled'):
return
self.roots = view.window().folders()
self.syntax = view.settings().get('syntax')
line_range = view.line(point)
if view.line(line_range.b) == self.current_line:
return
line_content = view.substr(line_range).strip()
matched = self.is_valid_line(line_content, view)
if matched:
CSS = sublime.load_resource("Packages/HyperClick/html/ui.css")
HTML = sublime.load_resource("Packages/HyperClick/html/ui.html")
destination_str = matched.group(1)
file_path = HyperClickPathResolver(
view,
destination_str,
self.roots,
settings
)
region = sublime.Region(line_range.b, line_range.b)
self.current_line = view.line(line_range.b)
view.erase_phantoms('hyper_click')
resolved_path = file_path.resolve()
if resolved_path:
content = """
<span class="label label-success"><a href="{link}">{content}</a></span>
""".format(
link=resolved_path,
content=settings.get('annotation_found_text', '➜')
)
view.add_phantom(
'hyper_click',
region,
HTML.format(css=CSS, content=content),
sublime.LAYOUT_INLINE, self.on_navigate
)
else:
content = """
<span class="label label-error">{content}</span>
""".format(content=settings.get('annotation_not_found_text', '✘'))
view.add_phantom(
'hyper_click',
region,
HTML.format(css=CSS, content=content),
sublime.LAYOUT_INLINE, self.on_navigate
)
else:
self.current_line = (-1, -1)
view.erase_phantoms('hyper_click')
def on_selection_modified_async(self, view):
if view.is_dirty():
view.erase_phantoms('hyper_click')
return
if len(view.sel()) != 1:
view.erase_phantoms('hyper_click')
return
point = view.sel()[0].b
self.annotate(point, view)
def on_activated_async(self, view):
self.on_selection_modified_async(view)
def on_deactivated_async(self, view):
view.erase_phantoms('hyper_click')
def on_query_context(self, view, key, operator, operand, match_all):
if key == 'hyper_click_jump_line':
cursor = view.sel()[0].b
line_range = view.line(cursor)
line_content = view.substr(line_range).strip()
return bool(self.is_valid_line(line_content, view))
return None
def on_hover(self, view, point, hover_zone):
self.annotate(point, view)
def plugin_loaded():
window = sublime.active_window()
if not window:
return
view = window.active_view()
if not view:
return
settings = sublime.load_settings('HyperClick.sublime-settings')
project_settings = view.settings().get('HyperClick', {})
old_keys = [
'supported_syntaxes',
'import_line_regex',
'valid_extensions',
'default_filenames',
'vendor_dirs',
'aliases',
'lookup_paths'
]
msg = ''
for key in old_keys:
if settings.has(key):
msg += key + '\n'
if project_settings.get(key, False):
msg += key + ' (in project)\n'
if msg != '':
panel = window.create_output_panel('HyperClickSettings', True)
panel.set_read_only(False)
panel.run_command('append', {
'characters': 'Old HyperClick settings detected:\n'
})
panel.run_command('append', {
'characters': msg
})
panel.run_command('append', {
'characters': '\nPlease refer to the HyperClick README on how to upgrade\nhttps://github.com/aziz/SublimeHyperClick/blob/master/README.md#upgrading-settings-for-20'
})
panel.set_read_only(True)
window.run_command("show_panel", {"panel": 'output.HyperClickSettings'})