File: CSSParserTokenRange.h

package info (click to toggle)
chromium-browser 41.0.2272.118-1
  • links: PTS, VCS
  • area: main
  • in suites: jessie-kfreebsd
  • size: 2,189,132 kB
  • sloc: cpp: 9,691,462; ansic: 3,341,451; python: 712,689; asm: 518,779; xml: 208,926; java: 169,820; sh: 119,353; perl: 68,907; makefile: 28,311; yacc: 13,305; objc: 11,385; tcl: 3,186; cs: 2,225; sql: 2,217; lex: 2,215; lisp: 1,349; pascal: 1,256; awk: 407; ruby: 155; sed: 53; php: 14; exp: 11
file content (81 lines) | stat: -rw-r--r-- 2,233 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
80
81
// 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/css/parser/CSSParserToken.h"
#include "wtf/Vector.h"

namespace blink {

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 CSSParserTokenRange {
public:
    CSSParserTokenRange(const Vector<CSSParserToken>& 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);

    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& consumeIncludingComments()
    {
        const CSSParserToken& result = consume();
        while (peek().type() == CommentToken)
            ++m_first;
        return result;
    }

    const CSSParserToken& consumeIncludingWhitespaceAndComments()
    {
        const CSSParserToken& result = consume();
        consumeWhitespaceAndComments();
        return result;
    }

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

    void consumeComponentValue();
    void consumeWhitespaceAndComments();

    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

#endif // CSSParserTokenRange_h