forked from eden-emu/eden
		
	logging/settings: Increase maximum log size to 100 MB and add extended logging option
The extended logging option is automatically disabled on boot but can be enabled afterwards, allowing the log file to go up to 1 GB during that session. This commit also fixes a few errors that are present in the general debug menu.
This commit is contained in:
		
							parent
							
								
									bb752df736
								
							
						
					
					
						commit
						43ce33b6cc
					
				
					 5 changed files with 54 additions and 11 deletions
				
			
		|  | @ -23,6 +23,7 @@ | |||
| #include "common/logging/text_formatter.h" | ||||
| #include "common/string_util.h" | ||||
| #include "common/threadsafe_queue.h" | ||||
| #include "core/settings.h" | ||||
| 
 | ||||
| namespace Log { | ||||
| 
 | ||||
|  | @ -152,10 +153,19 @@ FileBackend::FileBackend(const std::string& filename) | |||
| void FileBackend::Write(const Entry& entry) { | ||||
|     // prevent logs from going over the maximum size (in case its spamming and the user doesn't
 | ||||
|     // know)
 | ||||
|     constexpr std::size_t MAX_BYTES_WRITTEN = 50 * 1024L * 1024L; | ||||
|     if (!file.IsOpen() || bytes_written > MAX_BYTES_WRITTEN) { | ||||
|     constexpr std::size_t MAX_BYTES_WRITTEN = 100 * 1024 * 1024; | ||||
|     constexpr std::size_t MAX_BYTES_WRITTEN_EXTENDED = 1024 * 1024 * 1024; | ||||
| 
 | ||||
|     if (!file.IsOpen()) { | ||||
|         return; | ||||
|     } | ||||
| 
 | ||||
|     if (Settings::values.extended_logging && bytes_written > MAX_BYTES_WRITTEN_EXTENDED) { | ||||
|         return; | ||||
|     } else if (!Settings::values.extended_logging && bytes_written > MAX_BYTES_WRITTEN) { | ||||
|         return; | ||||
|     } | ||||
| 
 | ||||
|     bytes_written += file.WriteString(FormatLogMessage(entry).append(1, '\n')); | ||||
|     if (entry.log_level >= Level::Error) { | ||||
|         file.Flush(); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 M&M
						M&M