blob: 94ebca14909bd5005dde1025606968ab7b0f7f53 (
plain)
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
|
// 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 TOOLS_GN_C_INCLUDE_ITERATOR_H_
#define TOOLS_GN_C_INCLUDE_ITERATOR_H_
#include "base/basictypes.h"
#include "base/strings/string_piece.h"
class InputFile;
class LocationRange;
// Iterates through #includes in C source and header files.
//
// This only returns includes we want to check, which is user includes with
// double-quotes: #include "..."
class CIncludeIterator {
public:
// The InputFile pointed to must outlive this class.
explicit CIncludeIterator(const InputFile* input);
~CIncludeIterator();
// Fills in the string with the contents of the next include, and the
// location with where it came from, and returns true, or returns false if
// there are no more includes.
bool GetNextIncludeString(base::StringPiece* out, LocationRange* location);
// Maximum numbef of non-includes we'll tolerate before giving up. This does
// not count comments or preprocessor.
static const int kMaxNonIncludeLines;
private:
// Returns false on EOF, otherwise fills in the given line and the one-based
// line number into *line_number;
bool GetNextLine(base::StringPiece* line, int* line_number);
const InputFile* input_file_;
// This just points into input_file_.contents() for convenience.
base::StringPiece file_;
// 0-based offset into the file.
size_t offset_;
int line_number_; // One-based. Indicates the last line we read.
// Number of lines we've processed since seeing the last include (or the
// beginning of the file) with some exceptions.
int lines_since_last_include_;
DISALLOW_COPY_AND_ASSIGN(CIncludeIterator);
};
#endif // TOOLS_GN_C_INCLUDE_ITERATOR_H_
|