mirror of
https://github.com/wakatime/sublime-wakatime.git
synced 2023-08-10 21:13:02 +03:00
improve C# and php dependency detection
This commit is contained in:
parent
c50100e675
commit
3cecd0de5d
@ -10,9 +10,16 @@
|
|||||||
"""
|
"""
|
||||||
|
|
||||||
from . import TokenParser
|
from . import TokenParser
|
||||||
|
from ..compat import u
|
||||||
|
|
||||||
|
|
||||||
class CSharpParser(TokenParser):
|
class CSharpParser(TokenParser):
|
||||||
|
exclude = [
|
||||||
|
r'^system$',
|
||||||
|
r'^microsoft$',
|
||||||
|
]
|
||||||
|
state = None
|
||||||
|
buffer = u('')
|
||||||
|
|
||||||
def parse(self):
|
def parse(self):
|
||||||
for index, token, content in self.tokens:
|
for index, token, content in self.tokens:
|
||||||
@ -20,14 +27,38 @@ class CSharpParser(TokenParser):
|
|||||||
return self.dependencies
|
return self.dependencies
|
||||||
|
|
||||||
def _process_token(self, token, content):
|
def _process_token(self, token, content):
|
||||||
if self.partial(token) == 'Namespace':
|
if self.partial(token) == 'Keyword':
|
||||||
|
self._process_keyword(token, content)
|
||||||
|
if self.partial(token) == 'Namespace' or self.partial(token) == 'Name':
|
||||||
self._process_namespace(token, content)
|
self._process_namespace(token, content)
|
||||||
|
elif self.partial(token) == 'Punctuation':
|
||||||
|
self._process_punctuation(token, content)
|
||||||
else:
|
else:
|
||||||
self._process_other(token, content)
|
self._process_other(token, content)
|
||||||
|
|
||||||
|
def _process_keyword(self, token, content):
|
||||||
|
if content == 'using':
|
||||||
|
self.state = 'import'
|
||||||
|
self.buffer = u('')
|
||||||
|
|
||||||
def _process_namespace(self, token, content):
|
def _process_namespace(self, token, content):
|
||||||
if content != 'import' and content != 'package' and content != 'namespace':
|
if self.state == 'import':
|
||||||
self.append(content, truncate=True)
|
if u(content) != u('import') and u(content) != u('package') and u(content) != u('namespace') and u(content) != u('static'):
|
||||||
|
if u(content) == u(';'): # pragma: nocover
|
||||||
|
self._process_punctuation(token, content)
|
||||||
|
else:
|
||||||
|
self.buffer += u(content)
|
||||||
|
|
||||||
|
def _process_punctuation(self, token, content):
|
||||||
|
if self.state == 'import':
|
||||||
|
if u(content) == u(';'):
|
||||||
|
self.append(self.buffer, truncate=True)
|
||||||
|
self.buffer = u('')
|
||||||
|
self.state = None
|
||||||
|
elif u(content) == u('='):
|
||||||
|
self.buffer = u('')
|
||||||
|
else:
|
||||||
|
self.buffer += u(content)
|
||||||
|
|
||||||
def _process_other(self, token, content):
|
def _process_other(self, token, content):
|
||||||
pass
|
pass
|
||||||
|
@ -61,10 +61,10 @@ class PhpParser(TokenParser):
|
|||||||
|
|
||||||
def _process_literal_string(self, token, content):
|
def _process_literal_string(self, token, content):
|
||||||
if self.state == 'include':
|
if self.state == 'include':
|
||||||
if content != '"':
|
if content != '"' and content != "'":
|
||||||
content = content.strip()
|
content = content.strip()
|
||||||
if u(token) == 'Token.Literal.String.Double':
|
if u(token) == 'Token.Literal.String.Double':
|
||||||
content = u('"{0}"').format(content)
|
content = u("'{0}'").format(content)
|
||||||
self.append(content)
|
self.append(content)
|
||||||
self.state = None
|
self.state = None
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user