Coverage Report

Created: 2026-05-27 07:00

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/proc/self/cwd/external/antlr4-cpp-runtime~/runtime/src/CommonTokenStream.cpp
Line
Count
Source
1
/* Copyright (c) 2012-2017 The ANTLR Project. All rights reserved.
2
 * Use of this file is governed by the BSD 3-clause license that
3
 * can be found in the LICENSE.txt file in the project root.
4
 */
5
6
#include "Token.h"
7
8
#include "CommonTokenStream.h"
9
10
using namespace antlr4;
11
12
21.4k
CommonTokenStream::CommonTokenStream(TokenSource *tokenSource) : CommonTokenStream(tokenSource, Token::DEFAULT_CHANNEL) {
13
21.4k
}
14
15
CommonTokenStream::CommonTokenStream(TokenSource *tokenSource, size_t channel_)
16
21.4k
: BufferedTokenStream(tokenSource), channel(channel_) {
17
21.4k
}
18
19
39.4M
ssize_t CommonTokenStream::adjustSeekIndex(size_t i) {
20
39.4M
  return nextTokenOnChannel(i, channel);
21
39.4M
}
22
23
32.9M
Token* CommonTokenStream::LB(size_t k) {
24
32.9M
  if (k == 0 || k > _p) {
25
6.07k
    return nullptr;
26
6.07k
  }
27
28
32.8M
  ssize_t i = static_cast<ssize_t>(_p);
29
32.8M
  size_t n = 1;
30
  // find k good tokens looking backwards
31
65.7M
  while (n <= k) {
32
    // skip off-channel tokens
33
32.8M
    i = previousTokenOnChannel(i - 1, channel);
34
32.8M
    n++;
35
32.8M
  }
36
32.8M
  if (i < 0) {
37
1.72k
    return nullptr;
38
1.72k
  }
39
40
32.8M
  return _tokens[i].get();
41
32.8M
}
42
43
145M
Token* CommonTokenStream::LT(ssize_t k) {
44
145M
  lazyInit();
45
145M
  if (k == 0) {
46
0
    return nullptr;
47
0
  }
48
145M
  if (k < 0) {
49
32.9M
    return LB(static_cast<size_t>(-k));
50
32.9M
  }
51
112M
  size_t i = _p;
52
112M
  ssize_t n = 1; // we know tokens[p] is a good one
53
                 // find k good tokens
54
112M
  while (n < k) {
55
    // skip off-channel tokens, but make sure to not look past EOF
56
45.4k
    if (sync(i + 1)) {
57
31.8k
      i = nextTokenOnChannel(i + 1, channel);
58
31.8k
    }
59
45.4k
    n++;
60
45.4k
  }
61
62
112M
  return _tokens[i].get();
63
145M
}
64
65
0
int CommonTokenStream::getNumberOfOnChannelTokens() {
66
0
  int n = 0;
67
0
  fill();
68
0
  for (size_t i = 0; i < _tokens.size(); i++) {
69
0
    Token *t = _tokens[i].get();
70
0
    if (t->getChannel() == channel) {
71
0
      n++;
72
0
    }
73
0
    if (t->getType() == Token::EOF) {
74
0
      break;
75
0
    }
76
0
  }
77
0
  return n;
78
0
}