File: CSSParserTokenRange.h

package info (click to toggle)
chromium-browser 57.0.2987.98-1~deb8u1
  • links: PTS, VCS
  • area: main
  • in suites: jessie
  • size: 2,637,852 kB
  • ctags: 2,544,394
  • sloc: cpp: 12,815,961; ansic: 3,676,222; python: 1,147,112; asm: 526,608; java: 523,212; xml: 286,794; perl: 92,654; sh: 86,408; objc: 73,271; makefile: 27,698; cs: 18,487; yacc: 13,031; tcl: 12,957; pascal: 4,875; ml: 4,716; lex: 3,904; sql: 3,862; ruby: 1,982; lisp: 1,508; php: 1,368; exp: 404; awk: 325; csh: 117; jsp: 39; sed: 37
file content (79 lines) | stat: -rw-r--r-- 2,235 bytes parent folder | download
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
// Copyright 2014 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#ifndef CSSParserTokenRange_h
#define CSSParserTokenRange_h

#include "core/CoreExport.h"
#include "core/css/parser/CSSParserToken.h"
#include "wtf/Allocator.h"
#include "wtf/Vector.h"

namespace blink {

CORE_EXPORT extern const CSSParserToken& staticEOFToken;

// A CSSParserTokenRange is an iterator over a subrange of a vector of
// CSSParserTokens. Accessing outside of the range will return an endless stream
// of EOF tokens. This class refers to half-open intervals [first, last).
class CORE_EXPORT CSSParserTokenRange {
  DISALLOW_NEW();

 public:
  template <size_t inlineBuffer>
  CSSParserTokenRange(const Vector<CSSParserToken, inlineBuffer>& vector)
      : m_first(vector.begin()), m_last(vector.end()) {}

  // This should be called on a range with tokens returned by that range.
  CSSParserTokenRange makeSubRange(const CSSParserToken* first,
                                   const CSSParserToken* last) const;

  bool atEnd() const { return m_first == m_last; }
  const CSSParserToken* end() const { return m_last; }

  const CSSParserToken& peek(unsigned offset = 0) const {
    if (m_first + offset >= m_last)
      return staticEOFToken;
    return *(m_first + offset);
  }

  const CSSParserToken& consume() {
    if (m_first == m_last)
      return staticEOFToken;
    return *m_first++;
  }

  const CSSParserToken& consumeIncludingWhitespace() {
    const CSSParserToken& result = consume();
    consumeWhitespace();
    return result;
  }

  // The returned range doesn't include the brackets
  CSSParserTokenRange consumeBlock();

  void consumeComponentValue();

  void consumeWhitespace() {
    while (peek().type() == WhitespaceToken)
      ++m_first;
  }

  String serialize() const;

  const CSSParserToken* begin() const { return m_first; }

  static void initStaticEOFToken();

 private:
  CSSParserTokenRange(const CSSParserToken* first, const CSSParserToken* last)
      : m_first(first), m_last(last) {}

  const CSSParserToken* m_first;
  const CSSParserToken* m_last;
};

}  // namespace blink

#endif  // CSSParserTokenRange_h