mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-31 19:22:45 +00:00 
			
		
		
		
	 6e19ab2bbc
			
		
	
	
		6e19ab2bbc
		
	
	
	
	
		
			
			We have a new, improved string type coming up in AK (OOM aware, no null state), and while it's going to use UTF-8, the name UTF8String is a mouthful - so let's free up the String name by renaming the existing class. Making the old one have an annoying name will hopefully also help with quick adoption :^)
		
			
				
	
	
		
			69 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			69 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2020, Itamar S. <itamar8910@gmail.com>
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #include <AK/LexicalPath.h>
 | |
| #include <Kernel/API/InodeWatcherEvent.h>
 | |
| #include <LibCore/FileWatcher.h>
 | |
| #include <LibCore/MappedFile.h>
 | |
| #include <LibCore/Process.h>
 | |
| #include <LibCore/System.h>
 | |
| #include <LibMain/Main.h>
 | |
| #include <serenity.h>
 | |
| #include <spawn.h>
 | |
| #include <sys/stat.h>
 | |
| #include <time.h>
 | |
| #include <unistd.h>
 | |
| 
 | |
| static void wait_until_coredump_is_ready(DeprecatedString const& coredump_path)
 | |
| {
 | |
|     while (true) {
 | |
|         struct stat statbuf;
 | |
|         if (stat(coredump_path.characters(), &statbuf) < 0) {
 | |
|             perror("stat");
 | |
|             VERIFY_NOT_REACHED();
 | |
|         }
 | |
|         if (statbuf.st_mode & 0400) // Check if readable
 | |
|             break;
 | |
| 
 | |
|         usleep(10000); // sleep for 10ms
 | |
|     }
 | |
| }
 | |
| 
 | |
| static void launch_crash_reporter(DeprecatedString const& coredump_path, bool unlink_on_exit)
 | |
| {
 | |
|     auto pid = Core::Process::spawn("/bin/CrashReporter"sv,
 | |
|         unlink_on_exit
 | |
|             ? Array { "--unlink", coredump_path.characters() }.span()
 | |
|             : Array { coredump_path.characters() }.span());
 | |
|     if (pid.is_error())
 | |
|         warnln("Failed to launch CrashReporter");
 | |
| }
 | |
| 
 | |
| ErrorOr<int> serenity_main(Main::Arguments)
 | |
| {
 | |
|     TRY(Core::System::pledge("stdio rpath wpath cpath proc exec"));
 | |
| 
 | |
|     Core::BlockingFileWatcher watcher;
 | |
|     TRY(watcher.add_watch("/tmp/coredump", Core::FileWatcherEvent::Type::ChildCreated));
 | |
| 
 | |
|     while (true) {
 | |
|         auto event = watcher.wait_for_event();
 | |
|         VERIFY(event.has_value());
 | |
|         if (event.value().type != Core::FileWatcherEvent::Type::ChildCreated)
 | |
|             continue;
 | |
|         auto& coredump_path = event.value().event_path;
 | |
|         dbgln("New coredump file: {}", coredump_path);
 | |
|         wait_until_coredump_is_ready(coredump_path);
 | |
| 
 | |
|         auto file_or_error = Core::MappedFile::map(coredump_path);
 | |
|         if (file_or_error.is_error()) {
 | |
|             dbgln("Unable to map coredump {}: {}", coredump_path, file_or_error.error());
 | |
|             continue;
 | |
|         }
 | |
| 
 | |
|         launch_crash_reporter(coredump_path, true);
 | |
|     }
 | |
| }
 |