Main: Group static members and add some docs

This commit is contained in:
Rémi Verschelde 2018-09-20 11:45:05 +02:00
parent 4fca3fe180
commit eb4af940dd
2 changed files with 111 additions and 62 deletions

View File

@ -77,63 +77,95 @@
#include "editor/project_manager.h" #include "editor/project_manager.h"
#endif #endif
static ProjectSettings *globals = NULL; /* Static members */
// Singletons
// Initialized in setup()
static Engine *engine = NULL; static Engine *engine = NULL;
static ProjectSettings *globals = NULL;
static InputMap *input_map = NULL; static InputMap *input_map = NULL;
static bool _start_success = false; static TranslationServer *translation_server = NULL;
static ScriptDebugger *script_debugger = NULL;
AudioServer *audio_server = NULL;
ARVRServer *arvr_server = NULL;
PhysicsServer *physics_server = NULL;
Physics2DServer *physics_2d_server = NULL;
static MessageQueue *message_queue = NULL;
static Performance *performance = NULL; static Performance *performance = NULL;
static PackedData *packed_data = NULL; static PackedData *packed_data = NULL;
#ifdef MINIZIP_ENABLED #ifdef MINIZIP_ENABLED
static ZipArchive *zip_packed_data = NULL; static ZipArchive *zip_packed_data = NULL;
#endif #endif
static FileAccessNetworkClient *file_access_network_client = NULL; static FileAccessNetworkClient *file_access_network_client = NULL;
static TranslationServer *translation_server = NULL; static ScriptDebugger *script_debugger = NULL;
static MessageQueue *message_queue = NULL;
// Initialized in setup2()
static AudioServer *audio_server = NULL;
static ARVRServer *arvr_server = NULL;
static PhysicsServer *physics_server = NULL;
static Physics2DServer *physics_2d_server = NULL;
// We error out if setup2() doesn't turn this true
static bool _start_success = false;
// Drivers
static int video_driver_idx = -1;
static int audio_driver_idx = -1;
// Engine config/tools
static bool editor = false;
static bool project_manager = false;
static String locale;
static bool show_help = false;
static bool auto_build_solutions = false;
static bool auto_quit = false;
static OS::ProcessID allow_focus_steal_pid = 0;
// Display
static OS::VideoMode video_mode; static OS::VideoMode video_mode;
static int init_screen = -1;
static bool init_fullscreen = false;
static bool init_maximized = false; static bool init_maximized = false;
static bool init_windowed = false; static bool init_windowed = false;
static bool init_fullscreen = false;
static bool init_always_on_top = false; static bool init_always_on_top = false;
static bool init_use_custom_pos = false; static bool init_use_custom_pos = false;
static Vector2 init_custom_pos;
static bool force_lowdpi = false;
static bool use_vsync = true;
// Debug
static bool use_debug_profiler = false;
#ifdef DEBUG_ENABLED #ifdef DEBUG_ENABLED
static bool debug_collisions = false; static bool debug_collisions = false;
static bool debug_navigation = false; static bool debug_navigation = false;
#endif #endif
static int frame_delay = 0; static int frame_delay = 0;
static Vector2 init_custom_pos;
static int video_driver_idx = -1;
static int audio_driver_idx = -1;
static String locale;
static bool use_debug_profiler = false;
static bool force_lowdpi = false;
static int init_screen = -1;
static bool use_vsync = true;
static bool editor = false;
static bool show_help = false;
static bool disable_render_loop = false; static bool disable_render_loop = false;
static int fixed_fps = -1; static int fixed_fps = -1;
static bool auto_build_solutions = false;
static bool auto_quit = false;
static bool print_fps = false; static bool print_fps = false;
static OS::ProcessID allow_focus_steal_pid = 0; /* Helper methods */
static bool project_manager = false;
// Used by Mono module, should likely be registered in Engine singleton instead
// FIXME: This is also not 100% accurate, `project_manager` is only true when it was requested,
// but not if e.g. we fail to load and project and fallback to the manager.
bool Main::is_project_manager() { bool Main::is_project_manager() {
return project_manager; return project_manager;
} }
void initialize_physics() { static String unescape_cmdline(const String &p_str) {
return p_str.replace("%20", " ");
}
static String get_full_version_string() {
String hash = String(VERSION_HASH);
if (hash.length() != 0)
hash = "." + hash.left(7);
return String(VERSION_FULL_BUILD) + hash;
}
// FIXME: Could maybe be moved to PhysicsServerManager and Physics2DServerManager directly
// to have less code in main.cpp.
void initialize_physics() {
/// 3D Physics Server /// 3D Physics Server
physics_server = PhysicsServerManager::new_server(ProjectSettings::get_singleton()->get(PhysicsServerManager::setting_property_name)); physics_server = PhysicsServerManager::new_server(ProjectSettings::get_singleton()->get(PhysicsServerManager::setting_property_name));
if (!physics_server) { if (!physics_server) {
@ -161,19 +193,6 @@ void finalize_physics() {
memdelete(physics_2d_server); memdelete(physics_2d_server);
} }
static String unescape_cmdline(const String &p_str) {
return p_str.replace("%20", " ");
}
static String get_full_version_string() {
String hash = String(VERSION_HASH);
if (hash.length() != 0)
hash = "." + hash.left(7);
return String(VERSION_FULL_BUILD) + hash;
}
//#define DEBUG_INIT //#define DEBUG_INIT
#ifdef DEBUG_INIT #ifdef DEBUG_INIT
#define MAIN_PRINT(m_txt) print_line(m_txt) #define MAIN_PRINT(m_txt) print_line(m_txt)
@ -278,6 +297,32 @@ void Main::print_help(const char *p_binary) {
#endif #endif
} }
/* Engine initialization
*
* Consists of several methods that are called by each platform's specific main(argc, argv).
* To fully understand engine init, one should therefore start from the platform's main and
* see how it calls into the Main class' methods.
*
* The initialization is typically done in 3 steps (with the setup2 step triggered either
* automatically by setup, or manually in the platform's main).
*
* - setup(execpath, argc, argv, p_second_phase) is the main entry point for all platforms,
* responsible for the initialization of all low level singletons and core types, and parsing
* command line arguments to configure things accordingly.
* If p_second_phase is true, it will chain into setup2() (default behaviour). This is
* disabled on some platforms (Android, iOS, UWP) which trigger the second step in their
* own time.
*
* - setup2(p_main_tid_override) registers high level servers and singletons, displays the
* boot splash, then registers higher level types (scene, editor, etc.).
*
* - start() is the last step and that's where command line tools can run, or the main loop
* can be created eventually and the project settings put into action. That's also where
* the editor node is created, if relevant.
* start() does it own argument parsing for a subset of the command line arguments described
* in help, it's a bit messy and should be globalized with the setup() parsing somehow.
*/
Error Main::setup(const char *execpath, int argc, char *argv[], bool p_second_phase) { Error Main::setup(const char *execpath, int argc, char *argv[], bool p_second_phase) {
RID_OwnerBase::init_rid(); RID_OwnerBase::init_rid();
@ -1003,15 +1048,6 @@ error:
if (file_access_network_client) if (file_access_network_client)
memdelete(file_access_network_client); memdelete(file_access_network_client);
// Note 1: *zip_packed_data live into *packed_data
// Note 2: PackedData::~PackedData destroy this.
/*
#ifdef MINIZIP_ENABLED
if (zip_packed_data)
memdelete( zip_packed_data );
#endif
*/
unregister_core_driver_types(); unregister_core_driver_types();
unregister_core_types(); unregister_core_types();
@ -1210,7 +1246,6 @@ Error Main::setup2(Thread::ID p_main_tid_override) {
} }
// everything the main loop needs to know about frame timings // everything the main loop needs to know about frame timings
static MainTimerSync main_timer_sync; static MainTimerSync main_timer_sync;
bool Main::start() { bool Main::start() {
@ -1713,13 +1748,23 @@ bool Main::start() {
return true; return true;
} }
/* Main iteration
*
* This is the iteration of the engine's game loop, advancing the state of physics,
* rendering and audio.
* It's called directly by the platform's OS::run method, where the loop is created
* and monitored.
*
* The OS implementation can impact its draw step with the Main::force_redraw() method.
*/
uint64_t Main::last_ticks = 0; uint64_t Main::last_ticks = 0;
uint64_t Main::target_ticks = 0; uint64_t Main::target_ticks = 0;
uint32_t Main::frames = 0; uint32_t Main::frames = 0;
uint32_t Main::frame = 0; uint32_t Main::frame = 0;
bool Main::force_redraw_requested = false; bool Main::force_redraw_requested = false;
//for performance metrics // For performance metrics
static uint64_t physics_process_max = 0; static uint64_t physics_process_max = 0;
static uint64_t idle_process_max = 0; static uint64_t idle_process_max = 0;
@ -1743,11 +1788,6 @@ bool Main::iteration() {
Engine::get_singleton()->_frame_step = step; Engine::get_singleton()->_frame_step = step;
/*
if (time_accum+step < frame_slice)
return false;
*/
uint64_t physics_process_ticks = 0; uint64_t physics_process_ticks = 0;
uint64_t idle_process_ticks = 0; uint64_t idle_process_ticks = 0;
@ -1891,9 +1931,15 @@ bool Main::iteration() {
} }
void Main::force_redraw() { void Main::force_redraw() {
force_redraw_requested = true; force_redraw_requested = true;
}; }
/* Engine deinitialization
*
* Responsible for freeing all the memory allocated by previous setup steps,
* so that the engine closes cleanly without leaking memory or crashing.
* The order matters as some of those steps are linked with each other.
*/
void Main::cleanup() { void Main::cleanup() {

View File

@ -49,13 +49,16 @@ class Main {
static bool force_redraw_requested; static bool force_redraw_requested;
public: public:
static bool is_project_manager();
static Error setup(const char *execpath, int argc, char *argv[], bool p_second_phase = true); static Error setup(const char *execpath, int argc, char *argv[], bool p_second_phase = true);
static Error setup2(Thread::ID p_main_tid_override = 0); static Error setup2(Thread::ID p_main_tid_override = 0);
static bool start(); static bool start();
static bool iteration(); static bool iteration();
static void cleanup();
static void force_redraw(); static void force_redraw();
static bool is_project_manager();
static void cleanup();
}; };
#endif #endif // MAIN_H