mirror of
				https://github.com/MaskRay/ccls.git
				synced 2025-10-25 17:42:41 +00:00 
			
		
		
		
	Be more aggressive about only indexing files once.
This should help fix perf regressions with long import times after syncing.
This commit is contained in:
		
							parent
							
								
									036c2819f1
								
							
						
					
					
						commit
						d6a8071da4
					
				| @ -896,6 +896,10 @@ std::vector<Index_DoIdMap> DoParseFile( | |||||||
|   IndexFile* previous_index = cache_loader->TryLoad(path); |   IndexFile* previous_index = cache_loader->TryLoad(path); | ||||||
|   if (previous_index) { |   if (previous_index) { | ||||||
|     // If none of the dependencies have changed, skip parsing and just load from cache.
 |     // If none of the dependencies have changed, skip parsing and just load from cache.
 | ||||||
|  | 
 | ||||||
|  |     // Checks if |path| needs to be reparsed. This will modify cached state
 | ||||||
|  |     // such that calling this function twice with the same path may return true
 | ||||||
|  |     // the first time but will return false the second.
 | ||||||
|     auto file_needs_parse = [&](const std::string& path) { |     auto file_needs_parse = [&](const std::string& path) { | ||||||
|       optional<int64_t> modification_timestamp = GetLastModificationTime(path); |       optional<int64_t> modification_timestamp = GetLastModificationTime(path); | ||||||
|       if (!modification_timestamp) |       if (!modification_timestamp) | ||||||
| @ -905,6 +909,7 @@ std::vector<Index_DoIdMap> DoParseFile( | |||||||
| 
 | 
 | ||||||
|       if (!last_cached_modification || modification_timestamp != *last_cached_modification) { |       if (!last_cached_modification || modification_timestamp != *last_cached_modification) { | ||||||
|         file_consumer_shared->Reset(path); |         file_consumer_shared->Reset(path); | ||||||
|  |         timestamp_manager->UpdateCachedModificationTime(path, *modification_timestamp); | ||||||
|         return FileParseQuery::NeedsParse; |         return FileParseQuery::NeedsParse; | ||||||
|       } |       } | ||||||
|       return FileParseQuery::DoesNotNeedParse; |       return FileParseQuery::DoesNotNeedParse; | ||||||
| @ -1284,7 +1289,9 @@ bool QueryDb_ImportMain(Config* config, QueryDatabase* db, ImportManager* import | |||||||
| 
 | 
 | ||||||
|     time.Reset(); |     time.Reset(); | ||||||
|     db->ApplyIndexUpdate(&response->update); |     db->ApplyIndexUpdate(&response->update); | ||||||
|     time.ResetAndPrint("Applying index update"); |     time.ResetAndPrint("Applying index update for " + StringJoinMap(response->update.files_def_update, [](const QueryFile::DefUpdate& value) { | ||||||
|  |       return value.path; | ||||||
|  |     })); | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   return did_work; |   return did_work; | ||||||
|  | |||||||
							
								
								
									
										14
									
								
								src/utils.h
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								src/utils.h
									
									
									
									
									
								
							| @ -32,19 +32,27 @@ std::vector<std::string> SplitString(const std::string& str, const std::string& | |||||||
| 
 | 
 | ||||||
| std::string LowerPathIfCaseInsensitive(const std::string& path); | std::string LowerPathIfCaseInsensitive(const std::string& path); | ||||||
| 
 | 
 | ||||||
| template <typename TValues> | 
 | ||||||
| std::string StringJoin(const TValues& values) { | template <typename TValues, typename TMap> | ||||||
|  | std::string StringJoinMap(const TValues& values, const TMap& map) { | ||||||
|   std::string result; |   std::string result; | ||||||
|   bool first = true; |   bool first = true; | ||||||
|   for (auto& entry : values) { |   for (auto& entry : values) { | ||||||
|     if (!first) |     if (!first) | ||||||
|       result += ", "; |       result += ", "; | ||||||
|     first = false; |     first = false; | ||||||
|     result += entry; |     result += map(entry); | ||||||
|   } |   } | ||||||
|   return result; |   return result; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | template <typename TValues> | ||||||
|  | std::string StringJoin(const TValues& values) { | ||||||
|  |   return StringJoinMap(values, [](const std::string& entry) { | ||||||
|  |     return entry; | ||||||
|  |   }); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| // Finds all files in the given folder. This is recursive.
 | // Finds all files in the given folder. This is recursive.
 | ||||||
| std::vector<std::string> GetFilesInFolder(std::string folder, bool recursive, bool add_folder_to_path); | std::vector<std::string> GetFilesInFolder(std::string folder, bool recursive, bool add_folder_to_path); | ||||||
| void GetFilesInFolder(std::string folder, bool recursive, bool add_folder_to_path, const std::function<void(const std::string&)>& handler); | void GetFilesInFolder(std::string folder, bool recursive, bool add_folder_to_path, const std::function<void(const std::string&)>& handler); | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user