forked from eden-emu/eden
		
	Logging: Don't lock the queue for the duration of the write
This commit is contained in:
		
							parent
							
								
									ca04901b0f
								
							
						
					
					
						commit
						ada0d38ca9
					
				
					 1 changed files with 5 additions and 3 deletions
				
			
		|  | @ -83,8 +83,10 @@ private: | |||
|                 } | ||||
|             }; | ||||
|             while (true) { | ||||
|                 std::unique_lock<std::mutex> lock(message_mutex); | ||||
|                 message_cv.wait(lock, [&] { return !running || message_queue.Pop(entry); }); | ||||
|                 { | ||||
|                     std::unique_lock<std::mutex> lock(message_mutex); | ||||
|                     message_cv.wait(lock, [&] { return !running || message_queue.Pop(entry); }); | ||||
|                 } | ||||
|                 if (!running) { | ||||
|                     break; | ||||
|                 } | ||||
|  | @ -282,4 +284,4 @@ void FmtLogMessageImpl(Class log_class, Level log_level, const char* filename, | |||
| 
 | ||||
|     Impl::Instance().PushEntry(std::move(entry)); | ||||
| } | ||||
| } // namespace Log
 | ||||
| } // namespace Log
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 James Rowe
						James Rowe