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