|  | @@ -32,6 +32,8 @@
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  #include "core/os/os.h"
 |  |  #include "core/os/os.h"
 | 
											
												
													
														|  |  #include "core/project_settings.h"
 |  |  #include "core/project_settings.h"
 | 
											
												
													
														|  | 
 |  | +#include "core/version.h"
 | 
											
												
													
														|  | 
 |  | +#include "core/version_hash.gen.h"
 | 
											
												
													
														|  |  #include "main/main.h"
 |  |  #include "main/main.h"
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  #ifdef DEBUG_ENABLED
 |  |  #ifdef DEBUG_ENABLED
 | 
											
										
											
												
													
														|  | @@ -61,12 +63,19 @@ static void handle_crash(int sig) {
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  	// Dump the backtrace to stderr with a message to the user
 |  |  	// Dump the backtrace to stderr with a message to the user
 | 
											
												
													
														|  | 
 |  | +	fprintf(stderr, "\n================================================================\n");
 | 
											
												
													
														|  |  	fprintf(stderr, "%s: Program crashed with signal %d\n", __FUNCTION__, sig);
 |  |  	fprintf(stderr, "%s: Program crashed with signal %d\n", __FUNCTION__, sig);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  	if (OS::get_singleton()->get_main_loop()) {
 |  |  	if (OS::get_singleton()->get_main_loop()) {
 | 
											
												
													
														|  |  		OS::get_singleton()->get_main_loop()->notification(MainLoop::NOTIFICATION_CRASH);
 |  |  		OS::get_singleton()->get_main_loop()->notification(MainLoop::NOTIFICATION_CRASH);
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | 
 |  | +	// Print the engine version just before, so that people are reminded to include the version in backtrace reports.
 | 
											
												
													
														|  | 
 |  | +	if (String(VERSION_HASH).length() != 0) {
 | 
											
												
													
														|  | 
 |  | +		fprintf(stderr, "Engine version: " VERSION_FULL_NAME " (" VERSION_HASH ")\n");
 | 
											
												
													
														|  | 
 |  | +	} else {
 | 
											
												
													
														|  | 
 |  | +		fprintf(stderr, "Engine version: " VERSION_FULL_NAME "\n");
 | 
											
												
													
														|  | 
 |  | +	}
 | 
											
												
													
														|  |  	fprintf(stderr, "Dumping the backtrace. %ls\n", msg.c_str());
 |  |  	fprintf(stderr, "Dumping the backtrace. %ls\n", msg.c_str());
 | 
											
												
													
														|  |  	char **strings = backtrace_symbols(bt_buffer, size);
 |  |  	char **strings = backtrace_symbols(bt_buffer, size);
 | 
											
												
													
														|  |  	if (strings) {
 |  |  	if (strings) {
 | 
											
										
											
												
													
														|  | @@ -115,6 +124,7 @@ static void handle_crash(int sig) {
 | 
											
												
													
														|  |  		free(strings);
 |  |  		free(strings);
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  	fprintf(stderr, "-- END OF BACKTRACE --\n");
 |  |  	fprintf(stderr, "-- END OF BACKTRACE --\n");
 | 
											
												
													
														|  | 
 |  | +	fprintf(stderr, "================================================================\n");
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  	// Abort to pass the error to the OS
 |  |  	// Abort to pass the error to the OS
 | 
											
												
													
														|  |  	abort();
 |  |  	abort();
 |