OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef TOOLS_GN_C_INCLUDE_ITERATOR_H_ | 5 #ifndef TOOLS_GN_C_INCLUDE_ITERATOR_H_ |
6 #define TOOLS_GN_C_INCLUDE_ITERATOR_H_ | 6 #define TOOLS_GN_C_INCLUDE_ITERATOR_H_ |
7 | 7 |
8 #include "base/basictypes.h" | 8 #include "base/basictypes.h" |
9 #include "base/strings/string_piece.h" | 9 #include "base/strings/string_piece.h" |
10 | 10 |
| 11 class InputFile; |
| 12 class LocationRange; |
| 13 |
11 // Iterates through #includes in C source and header files. | 14 // Iterates through #includes in C source and header files. |
12 // | 15 // |
13 // This only returns includes we want to check, which is user includes with | 16 // This only returns includes we want to check, which is user includes with |
14 // double-quotes: #include "..." | 17 // double-quotes: #include "..." |
15 class CIncludeIterator { | 18 class CIncludeIterator { |
16 public: | 19 public: |
17 // The buffer pointed to must outlive this class. | 20 // The InputFile pointed to must outlive this class. |
18 CIncludeIterator(const base::StringPiece& file); | 21 CIncludeIterator(const InputFile* input); |
19 ~CIncludeIterator(); | 22 ~CIncludeIterator(); |
20 | 23 |
21 // Fills in the string with the contents of the next include and returns | 24 // Fills in the string with the contents of the next include, and the |
22 // true, or returns false if there are no more includes. | 25 // location with where it came from, and returns true, or returns false if |
23 bool GetNextIncludeString(base::StringPiece* out); | 26 // there are no more includes. |
| 27 bool GetNextIncludeString(base::StringPiece* out, LocationRange* location); |
24 | 28 |
25 // Maximum numbef of non-includes we'll tolerate before giving up. This does | 29 // Maximum numbef of non-includes we'll tolerate before giving up. This does |
26 // not count comments or preprocessor. | 30 // not count comments or preprocessor. |
27 static const int kMaxNonIncludeLines; | 31 static const int kMaxNonIncludeLines; |
28 | 32 |
29 private: | 33 private: |
30 // Returns false on EOF, otherwise fills in the given line. | 34 // Returns false on EOF, otherwise fills in the given line and the one-based |
31 bool GetNextLine(base::StringPiece* line); | 35 // line number into *line_number; |
| 36 bool GetNextLine(base::StringPiece* line, int* line_number); |
32 | 37 |
| 38 const InputFile* input_file_; |
| 39 |
| 40 // This just points into input_file_.contents() for convenience. |
33 base::StringPiece file_; | 41 base::StringPiece file_; |
34 | 42 |
| 43 // 0-based offset into the file. |
35 size_t offset_; | 44 size_t offset_; |
36 | 45 |
| 46 int line_number_; // One-based. Indicates the last line we read. |
| 47 |
37 // Number of lines we've processed since seeing the last include (or the | 48 // Number of lines we've processed since seeing the last include (or the |
38 // beginning of the file) with some exceptions. | 49 // beginning of the file) with some exceptions. |
39 int lines_since_last_include_; | 50 int lines_since_last_include_; |
40 | 51 |
41 DISALLOW_COPY_AND_ASSIGN(CIncludeIterator); | 52 DISALLOW_COPY_AND_ASSIGN(CIncludeIterator); |
42 }; | 53 }; |
43 | 54 |
44 #endif // TOOLS_GN_INCLUDE_ITERATOR_H_ | 55 #endif // TOOLS_GN_INCLUDE_ITERATOR_H_ |
OLD | NEW |