forked from atom/atom
-
Notifications
You must be signed in to change notification settings - Fork 31
/
Copy pathtokenized-line.coffee
95 lines (74 loc) · 2.22 KB
/
tokenized-line.coffee
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
Token = require './token'
CommentScopeRegex = /(\b|\.)comment/
idCounter = 1
module.exports =
class TokenizedLine
constructor: (properties) ->
@id = idCounter++
return unless properties?
{@openScopes, @text, @tags, @ruleStack, @tokenIterator, @grammar, tokens} = properties
@cachedTokens = tokens
getTokenIterator: -> @tokenIterator.reset(this)
Object.defineProperty @prototype, 'tokens', get: ->
if @cachedTokens
@cachedTokens
else
iterator = @getTokenIterator()
tokens = []
while iterator.next()
tokens.push(new Token({
value: iterator.getText()
scopes: iterator.getScopes().slice()
}))
tokens
tokenAtBufferColumn: (bufferColumn) ->
@tokens[@tokenIndexAtBufferColumn(bufferColumn)]
tokenIndexAtBufferColumn: (bufferColumn) ->
column = 0
for token, index in @tokens
column += token.value.length
return index if column > bufferColumn
index - 1
tokenStartColumnForBufferColumn: (bufferColumn) ->
delta = 0
for token in @tokens
nextDelta = delta + token.bufferDelta
break if nextDelta > bufferColumn
delta = nextDelta
delta
isComment: ->
return @isCommentLine if @isCommentLine?
@isCommentLine = false
for tag in @openScopes
if @isCommentOpenTag(tag)
@isCommentLine = true
return @isCommentLine
startIndex = 0
for tag in @tags
# If we haven't encountered any comment scope when reading the first
# non-whitespace chunk of text, then we consider this as not being a
# comment line.
if tag > 0
break unless isWhitespaceOnly(@text.substr(startIndex, tag))
startIndex += tag
if @isCommentOpenTag(tag)
@isCommentLine = true
return @isCommentLine
@isCommentLine
isCommentOpenTag: (tag) ->
if tag < 0 and (tag & 1) is 1
scope = @grammar.scopeForId(tag)
if CommentScopeRegex.test(scope)
return true
false
tokenAtIndex: (index) ->
@tokens[index]
getTokenCount: ->
count = 0
count++ for tag in @tags when tag >= 0
count
isWhitespaceOnly = (text) ->
for char in text
if char isnt '\t' and char isnt ' '
return false
return true