| 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 |