mirror of
				https://github.com/MaskRay/ccls.git
				synced 2025-10-23 00:22:34 +00:00 
			
		
		
		
	Merge ParseFile and DoParseFile
This commit is contained in:
		
							parent
							
								
									8fef86c0f8
								
							
						
					
					
						commit
						4c1ee74b27
					
				| @ -83,7 +83,8 @@ struct ActiveThread { | |||||||
| 
 | 
 | ||||||
| enum class FileParseQuery { NeedsParse, DoesNotNeedParse, NoSuchFile }; | enum class FileParseQuery { NeedsParse, DoesNotNeedParse, NoSuchFile }; | ||||||
| 
 | 
 | ||||||
| std::vector<Index_DoIdMap> DoParseFile( | 
 | ||||||
|  | std::vector<Index_DoIdMap> ParseFile( | ||||||
|     Config* config, |     Config* config, | ||||||
|     WorkingFiles* working_files, |     WorkingFiles* working_files, | ||||||
|     FileConsumerSharedState* file_consumer_shared, |     FileConsumerSharedState* file_consumer_shared, | ||||||
| @ -92,9 +93,21 @@ std::vector<Index_DoIdMap> DoParseFile( | |||||||
|     ICacheManager* cache_manager, |     ICacheManager* cache_manager, | ||||||
|     IIndexer* indexer, |     IIndexer* indexer, | ||||||
|     bool is_interactive, |     bool is_interactive, | ||||||
|     const std::string& path, |     const Project::Entry& entry, | ||||||
|     const std::vector<std::string>& args, |     const std::string& entry_contents) { | ||||||
|     const FileContents& contents) { | 
 | ||||||
|  |   FileContents contents(entry.filename, entry_contents); | ||||||
|  | 
 | ||||||
|  |   // If the file is inferred, we may not actually be able to parse that file
 | ||||||
|  |   // directly (ie, a header file, which are not listed in the project). If this
 | ||||||
|  |   // file is inferred, then try to use the file which originally imported it.
 | ||||||
|  |   std::string path = entry.filename; | ||||||
|  |   if (entry.is_inferred) { | ||||||
|  |     IndexFile* entry_cache = cache_manager->TryLoad(entry.filename); | ||||||
|  |     if (entry_cache) | ||||||
|  |       path = entry_cache->import_file; | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|   std::vector<Index_DoIdMap> result; |   std::vector<Index_DoIdMap> result; | ||||||
| 
 | 
 | ||||||
|   // Always run this block, even if we are interactive, so we can check
 |   // Always run this block, even if we are interactive, so we can check
 | ||||||
| @ -236,7 +249,7 @@ std::vector<Index_DoIdMap> DoParseFile( | |||||||
| 
 | 
 | ||||||
|   PerformanceImportFile perf; |   PerformanceImportFile perf; | ||||||
|   std::vector<std::unique_ptr<IndexFile>> indexes = indexer->Index( |   std::vector<std::unique_ptr<IndexFile>> indexes = indexer->Index( | ||||||
|       config, file_consumer_shared, path, args, file_contents, &perf); |       config, file_consumer_shared, path, entry.args, file_contents, &perf); | ||||||
|   for (std::unique_ptr<IndexFile>& new_index : indexes) { |   for (std::unique_ptr<IndexFile>& new_index : indexes) { | ||||||
|     Timer time; |     Timer time; | ||||||
| 
 | 
 | ||||||
| @ -256,29 +269,6 @@ std::vector<Index_DoIdMap> DoParseFile( | |||||||
|   return result; |   return result; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| std::vector<Index_DoIdMap> ParseFile( |  | ||||||
|     Config* config, |  | ||||||
|     WorkingFiles* working_files, |  | ||||||
|     FileConsumerSharedState* file_consumer_shared, |  | ||||||
|     TimestampManager* timestamp_manager, |  | ||||||
|     ImportManager* import_manager, |  | ||||||
|     ICacheManager* cache_manager, |  | ||||||
|     IIndexer* indexer, |  | ||||||
|     bool is_interactive, |  | ||||||
|     const Project::Entry& entry, |  | ||||||
|     const std::string& contents) { |  | ||||||
|   FileContents file_contents(entry.filename, contents); |  | ||||||
| 
 |  | ||||||
|   // Try to determine the original import file by loading the file from cache.
 |  | ||||||
|   // This lets the user request an index on a header file, which clang will
 |  | ||||||
|   // complain about if indexed by itself.
 |  | ||||||
|   IndexFile* entry_cache = cache_manager->TryLoad(entry.filename); |  | ||||||
|   std::string tu_path = entry_cache ? entry_cache->import_file : entry.filename; |  | ||||||
|   return DoParseFile(config, working_files, file_consumer_shared, |  | ||||||
|                      timestamp_manager, import_manager, cache_manager, indexer, |  | ||||||
|                      is_interactive, tu_path, entry.args, file_contents); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| bool IndexMain_DoParse(Config* config, | bool IndexMain_DoParse(Config* config, | ||||||
|                        WorkingFiles* working_files, |                        WorkingFiles* working_files, | ||||||
|                        FileConsumerSharedState* file_consumer_shared, |                        FileConsumerSharedState* file_consumer_shared, | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user