Merge pull request #66168 from Calinou/expose-os-restart-on-exit-3.x

Expose the "restart on exit" OS functionality (3.x)
This commit is contained in:
Rémi Verschelde 2022-10-04 16:57:43 +02:00
commit b3301d22c5
3 changed files with 54 additions and 0 deletions

View file

@ -576,6 +576,29 @@ Vector<String> _OS::get_cmdline_args() {
return cmdlinev; return cmdlinev;
} }
void _OS::set_restart_on_exit(bool p_restart, const Vector<String> &p_restart_arguments) {
List<String> args_list;
for (int i = 0; i < p_restart_arguments.size(); i++) {
args_list.push_back(p_restart_arguments[i]);
}
::OS::get_singleton()->set_restart_on_exit(p_restart, args_list);
}
bool _OS::is_restart_on_exit_set() const {
return ::OS::get_singleton()->is_restart_on_exit_set();
}
Vector<String> _OS::get_restart_on_exit_arguments() const {
List<String> args = ::OS::get_singleton()->get_restart_on_exit_arguments();
Vector<String> args_vector;
for (List<String>::Element *E = args.front(); E; E = E->next()) {
args_vector.push_back(E->get());
}
return args_vector;
}
String _OS::get_locale() const { String _OS::get_locale() const {
return OS::get_singleton()->get_locale(); return OS::get_singleton()->get_locale();
} }
@ -1405,6 +1428,10 @@ void _OS::_bind_methods() {
ClassDB::bind_method(D_METHOD("get_name"), &_OS::get_name); ClassDB::bind_method(D_METHOD("get_name"), &_OS::get_name);
ClassDB::bind_method(D_METHOD("get_cmdline_args"), &_OS::get_cmdline_args); ClassDB::bind_method(D_METHOD("get_cmdline_args"), &_OS::get_cmdline_args);
ClassDB::bind_method(D_METHOD("set_restart_on_exit", "restart", "arguments"), &_OS::set_restart_on_exit, DEFVAL(Vector<String>()));
ClassDB::bind_method(D_METHOD("is_restart_on_exit_set"), &_OS::is_restart_on_exit_set);
ClassDB::bind_method(D_METHOD("get_restart_on_exit_arguments"), &_OS::get_restart_on_exit_arguments);
ClassDB::bind_method(D_METHOD("get_datetime", "utc"), &_OS::get_datetime, DEFVAL(false)); ClassDB::bind_method(D_METHOD("get_datetime", "utc"), &_OS::get_datetime, DEFVAL(false));
ClassDB::bind_method(D_METHOD("get_date", "utc"), &_OS::get_date, DEFVAL(false)); ClassDB::bind_method(D_METHOD("get_date", "utc"), &_OS::get_date, DEFVAL(false));
ClassDB::bind_method(D_METHOD("get_time", "utc"), &_OS::get_time, DEFVAL(false)); ClassDB::bind_method(D_METHOD("get_time", "utc"), &_OS::get_time, DEFVAL(false));

View file

@ -272,6 +272,10 @@ public:
bool is_process_running(int p_pid) const; bool is_process_running(int p_pid) const;
int get_process_id() const; int get_process_id() const;
void set_restart_on_exit(bool p_restart, const Vector<String> &p_restart_arguments = Vector<String>());
bool is_restart_on_exit_set() const;
Vector<String> get_restart_on_exit_arguments() const;
bool has_environment(const String &p_var) const; bool has_environment(const String &p_var) const;
String get_environment(const String &p_var) const; String get_environment(const String &p_var) const;
bool set_environment(const String &p_var, const String &p_value) const; bool set_environment(const String &p_var, const String &p_value) const;

View file

@ -372,6 +372,12 @@
Returns the window size including decorations like window borders. Returns the window size including decorations like window borders.
</description> </description>
</method> </method>
<method name="get_restart_on_exit_arguments" qualifiers="const">
<return type="PoolStringArray" />
<description>
Returns the list of command line arguments that will be used when the project automatically restarts using [method set_restart_on_exit]. See also [method is_restart_on_exit_set].
</description>
</method>
<method name="get_scancode_string" qualifiers="const"> <method name="get_scancode_string" qualifiers="const">
<return type="String" /> <return type="String" />
<argument index="0" name="code" type="int" /> <argument index="0" name="code" type="int" />
@ -700,6 +706,12 @@
[b]Note:[/b] This method is implemented on Android, iOS, Linux, macOS and Windows. [b]Note:[/b] This method is implemented on Android, iOS, Linux, macOS and Windows.
</description> </description>
</method> </method>
<method name="is_restart_on_exit_set" qualifiers="const">
<return type="bool" />
<description>
Returns [code]true[/code] if the project will automatically restart when it exits for any reason, [code]false[/code] otherwise. See also [method set_restart_on_exit] and [method get_restart_on_exit_arguments].
</description>
</method>
<method name="is_scancode_unicode" qualifiers="const"> <method name="is_scancode_unicode" qualifiers="const">
<return type="bool" /> <return type="bool" />
<argument index="0" name="code" type="int" /> <argument index="0" name="code" type="int" />
@ -947,6 +959,17 @@
[b]Note:[/b] This method is implemented on macOS and Windows. [b]Note:[/b] This method is implemented on macOS and Windows.
</description> </description>
</method> </method>
<method name="set_restart_on_exit">
<return type="void" />
<argument index="0" name="restart" type="bool" />
<argument index="1" name="arguments" type="PoolStringArray" default="PoolStringArray( )" />
<description>
If [code]restart[/code] is [code]true[/code], restarts the project automatically when it is exited with [method SceneTree.quit] or [constant Node.NOTIFICATION_WM_QUIT_REQUEST]. Command line [code]arguments[/code] can be supplied. To restart the project with the same command line arguments as originally used to run the project, pass [method get_cmdline_args] as the value for [code]arguments[/code].
[method set_restart_on_exit] can be used to apply setting changes that require a restart. See also [method is_restart_on_exit_set] and [method get_restart_on_exit_arguments].
[b]Note:[/b] This method is only effective on desktop platforms, and only when the project isn't started from the editor. It will have no effect on mobile and Web platforms, or when the project is started from the editor.
[b]Note:[/b] If the project process crashes or is [i]killed[/i] by the user (by sending [code]SIGKILL[/code] instead of the usual [code]SIGTERM[/code]), the project won't restart automatically.
</description>
</method>
<method name="set_thread_name"> <method name="set_thread_name">
<return type="int" enum="Error" /> <return type="int" enum="Error" />
<argument index="0" name="name" type="String" /> <argument index="0" name="name" type="String" />