2014-02-10 09:10:30 +08:00
|
|
|
/**************************************************************************/
|
|
|
|
/* main.h */
|
|
|
|
/**************************************************************************/
|
|
|
|
/* This file is part of: */
|
|
|
|
/* GODOT ENGINE */
|
|
|
|
/* https://godotengine.org */
|
|
|
|
/**************************************************************************/
|
|
|
|
/* Copyright (c) 2014-present Godot Engine contributors (see AUTHORS.md). */
|
|
|
|
/* Copyright (c) 2007-2014 Juan Linietsky, Ariel Manzur. */
|
|
|
|
/* */
|
|
|
|
/* Permission is hereby granted, free of charge, to any person obtaining */
|
|
|
|
/* a copy of this software and associated documentation files (the */
|
|
|
|
/* "Software"), to deal in the Software without restriction, including */
|
|
|
|
/* without limitation the rights to use, copy, modify, merge, publish, */
|
|
|
|
/* distribute, sublicense, and/or sell copies of the Software, and to */
|
|
|
|
/* permit persons to whom the Software is furnished to do so, subject to */
|
|
|
|
/* the following conditions: */
|
|
|
|
/* */
|
|
|
|
/* The above copyright notice and this permission notice shall be */
|
|
|
|
/* included in all copies or substantial portions of the Software. */
|
|
|
|
/* */
|
|
|
|
/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
|
|
|
|
/* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
|
|
|
|
/* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. */
|
|
|
|
/* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
|
|
|
|
/* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
|
|
|
|
/* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
|
|
|
|
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
|
|
|
|
/**************************************************************************/
|
2018-01-05 07:50:27 +08:00
|
|
|
|
2014-02-10 09:10:30 +08:00
|
|
|
#ifndef MAIN_H
|
|
|
|
#define MAIN_H
|
|
|
|
|
2020-11-08 06:33:38 +08:00
|
|
|
#include "core/error/error_list.h"
|
2017-08-22 23:21:41 +08:00
|
|
|
#include "core/os/thread.h"
|
2018-09-12 00:13:45 +08:00
|
|
|
#include "core/typedefs.h"
|
2014-02-10 09:10:30 +08:00
|
|
|
|
2022-08-14 03:52:03 +08:00
|
|
|
template <typename T>
|
|
|
|
class Vector;
|
|
|
|
|
2014-02-10 09:10:30 +08:00
|
|
|
class Main {
|
2020-02-16 04:37:48 +08:00
|
|
|
enum CLIOptionAvailability {
|
|
|
|
CLI_OPTION_AVAILABILITY_EDITOR,
|
|
|
|
CLI_OPTION_AVAILABILITY_TEMPLATE_DEBUG,
|
|
|
|
CLI_OPTION_AVAILABILITY_TEMPLATE_RELEASE,
|
|
|
|
CLI_OPTION_AVAILABILITY_HIDDEN,
|
|
|
|
};
|
|
|
|
|
2022-03-12 09:04:14 +08:00
|
|
|
static void print_header(bool p_rich);
|
2020-02-16 04:37:48 +08:00
|
|
|
static void print_help_copyright(const char *p_notice);
|
|
|
|
static void print_help_title(const char *p_title);
|
|
|
|
static void print_help_option(const char *p_option, const char *p_description, CLIOptionAvailability p_availability = CLI_OPTION_AVAILABILITY_TEMPLATE_RELEASE);
|
|
|
|
static String format_help_option(const char *p_option);
|
2014-02-10 09:10:30 +08:00
|
|
|
static void print_help(const char *p_binary);
|
|
|
|
static uint64_t last_ticks;
|
2022-04-12 06:23:22 +08:00
|
|
|
static uint32_t hide_print_fps_attempts;
|
2018-05-28 19:47:09 +08:00
|
|
|
static uint32_t frames;
|
2014-02-10 09:10:30 +08:00
|
|
|
static uint32_t frame;
|
|
|
|
static bool force_redraw_requested;
|
2019-01-25 00:09:05 +08:00
|
|
|
static int iterating;
|
2020-09-21 07:35:20 +08:00
|
|
|
static bool agile_input_event_flushing;
|
2014-02-10 09:10:30 +08:00
|
|
|
|
2017-03-05 23:44:50 +08:00
|
|
|
public:
|
Main: Fixup bogus fallback to project manager with more bolognese
WARNING: Hacks everywhere!
The logic in `main.cpp` is due a full rewrite as it's extremely hacky,
splitting argument parsing over several functions, with a mess of global state
and assumptions about what combinations of arguments or lack thereof should
mean in terms of what we want to read: game, editor, project manager, or
command line tools such as `--doctool`, `--export` or `--script`.
Until this is fully rewritten, this patch hacks things some more to ensure
that we don't fall back to the project manager in cases where it's not
warranted, and especially not *too late*, as it can mean that we haven't
properly initialized stuff like `EditorPaths` needed by the PM (which in turn
impacts what kind of path will be used for logs and the shader cache, etc...
the rabbit hole goes deep).
Fixes #41435.
Fixes #49392.
Fixes #49658.
Fixes https://github.com/godotengine/godot/issues/38202#issuecomment-773158477.
2021-06-17 01:08:29 +08:00
|
|
|
static bool is_cmdline_tool();
|
2022-08-14 03:52:03 +08:00
|
|
|
#ifdef TOOLS_ENABLED
|
|
|
|
enum CLIScope {
|
|
|
|
CLI_SCOPE_TOOL, // Editor and project manager.
|
|
|
|
CLI_SCOPE_PROJECT,
|
|
|
|
};
|
|
|
|
static const Vector<String> &get_forwardable_cli_arguments(CLIScope p_scope);
|
|
|
|
#endif
|
|
|
|
|
2020-07-21 00:35:34 +08:00
|
|
|
static int test_entrypoint(int argc, char *argv[], bool &tests_need_run);
|
2014-02-10 09:10:30 +08:00
|
|
|
static Error setup(const char *execpath, int argc, char *argv[], bool p_second_phase = true);
|
2024-07-03 17:37:14 +08:00
|
|
|
static Error setup2(bool p_show_boot_logo = true); // The thread calling setup2() will effectively become the main thread.
|
2021-12-14 09:44:12 +08:00
|
|
|
static String get_rendering_driver_name();
|
2024-07-03 17:37:14 +08:00
|
|
|
static void setup_boot_logo();
|
2020-08-03 02:30:56 +08:00
|
|
|
#ifdef TESTS_ENABLED
|
|
|
|
static Error test_setup();
|
|
|
|
static void test_cleanup();
|
|
|
|
#endif
|
2024-03-07 01:50:35 +08:00
|
|
|
static int start();
|
2018-09-20 17:45:05 +08:00
|
|
|
|
2014-02-10 09:10:30 +08:00
|
|
|
static bool iteration();
|
|
|
|
static void force_redraw();
|
2018-09-20 17:45:05 +08:00
|
|
|
|
2019-01-23 00:17:39 +08:00
|
|
|
static bool is_iterating();
|
|
|
|
|
2021-02-22 18:06:33 +08:00
|
|
|
static void cleanup(bool p_force = false);
|
2014-02-10 09:10:30 +08:00
|
|
|
};
|
|
|
|
|
2022-11-01 22:29:38 +08:00
|
|
|
// Test main override is for the testing behavior.
|
2020-07-21 00:35:34 +08:00
|
|
|
#define TEST_MAIN_OVERRIDE \
|
|
|
|
bool run_test = false; \
|
|
|
|
int return_code = Main::test_entrypoint(argc, argv, run_test); \
|
|
|
|
if (run_test) { \
|
|
|
|
return return_code; \
|
|
|
|
}
|
|
|
|
|
|
|
|
#define TEST_MAIN_PARAM_OVERRIDE(argc, argv) \
|
|
|
|
bool run_test = false; \
|
|
|
|
int return_code = Main::test_entrypoint(argc, argv, run_test); \
|
|
|
|
if (run_test) { \
|
|
|
|
return return_code; \
|
|
|
|
}
|
|
|
|
|
2018-09-20 17:45:05 +08:00
|
|
|
#endif // MAIN_H
|