2023-01-05 12:25:55 +00:00
|
|
|
/**************************************************************************/
|
|
|
|
/* os_windows.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-04 23:50:27 +00:00
|
|
|
|
2014-02-10 01:10:30 +00:00
|
|
|
#ifndef OS_WINDOWS_H
|
|
|
|
#define OS_WINDOWS_H
|
2019-02-12 13:23:35 +00:00
|
|
|
|
2020-11-07 22:33:38 +00:00
|
|
|
#include "core/config/project_settings.h"
|
2020-04-28 13:19:37 +00:00
|
|
|
#include "core/input/input.h"
|
2018-09-11 16:13:45 +00:00
|
|
|
#include "core/os/os.h"
|
2019-02-12 14:43:54 +00:00
|
|
|
#include "crash_handler_windows.h"
|
2019-02-12 13:23:35 +00:00
|
|
|
#include "drivers/unix/ip_unix.h"
|
2017-08-27 17:01:34 +00:00
|
|
|
#include "drivers/wasapi/audio_driver_wasapi.h"
|
2019-02-12 13:23:35 +00:00
|
|
|
#include "drivers/winmidi/midi_driver_winmidi.h"
|
2019-02-12 14:43:54 +00:00
|
|
|
#include "key_mapping_windows.h"
|
2017-01-16 18:19:45 +00:00
|
|
|
#include "servers/audio_server.h"
|
2022-10-03 09:43:20 +00:00
|
|
|
|
2016-10-17 15:40:45 +00:00
|
|
|
#ifdef XAUDIO2_ENABLED
|
|
|
|
#include "drivers/xaudio2/audio_driver_xaudio2.h"
|
|
|
|
#endif
|
2014-02-10 01:10:30 +00:00
|
|
|
|
2019-06-22 16:34:26 +00:00
|
|
|
#if defined(VULKAN_ENABLED)
|
|
|
|
#include "drivers/vulkan/rendering_device_vulkan.h"
|
|
|
|
#include "platform/windows/vulkan_context_win.h"
|
|
|
|
#endif
|
|
|
|
|
2017-03-05 15:44:50 +00:00
|
|
|
#include <io.h>
|
2021-09-23 06:56:12 +00:00
|
|
|
#include <shellapi.h>
|
2014-02-10 01:10:30 +00:00
|
|
|
#include <stdio.h>
|
2022-10-03 09:43:20 +00:00
|
|
|
|
2021-09-23 06:56:12 +00:00
|
|
|
#define WIN32_LEAN_AND_MEAN
|
2022-11-21 13:04:01 +00:00
|
|
|
#include <dwrite.h>
|
|
|
|
#include <dwrite_2.h>
|
2017-03-05 15:44:50 +00:00
|
|
|
#include <windows.h>
|
|
|
|
#include <windowsx.h>
|
2017-01-16 18:19:45 +00:00
|
|
|
|
2022-05-08 23:25:49 +00:00
|
|
|
#ifdef DEBUG_ENABLED
|
|
|
|
// forward error messages to OutputDebugString
|
|
|
|
#define WINDOWS_DEBUG_OUTPUT_ENABLED
|
|
|
|
#endif
|
|
|
|
|
2022-10-14 10:18:25 +00:00
|
|
|
#ifndef ENABLE_VIRTUAL_TERMINAL_PROCESSING
|
|
|
|
#define ENABLE_VIRTUAL_TERMINAL_PROCESSING 0x4
|
|
|
|
#endif
|
|
|
|
|
2022-07-08 12:38:30 +00:00
|
|
|
template <class T>
|
|
|
|
class ComAutoreleaseRef {
|
|
|
|
public:
|
|
|
|
T *reference = nullptr;
|
|
|
|
|
|
|
|
_FORCE_INLINE_ T *operator->() { return reference; }
|
|
|
|
_FORCE_INLINE_ const T *operator->() const { return reference; }
|
|
|
|
_FORCE_INLINE_ T *operator*() { return reference; }
|
|
|
|
_FORCE_INLINE_ const T *operator*() const { return reference; }
|
|
|
|
_FORCE_INLINE_ bool is_valid() const { return reference != nullptr; }
|
|
|
|
_FORCE_INLINE_ bool is_null() const { return reference == nullptr; }
|
|
|
|
ComAutoreleaseRef() {}
|
2022-11-21 13:04:01 +00:00
|
|
|
ComAutoreleaseRef(T *p_ref) {
|
|
|
|
reference = p_ref;
|
|
|
|
}
|
2022-07-08 12:38:30 +00:00
|
|
|
~ComAutoreleaseRef() {
|
|
|
|
if (reference != nullptr) {
|
|
|
|
reference->Release();
|
|
|
|
reference = nullptr;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2017-01-08 22:52:38 +00:00
|
|
|
class JoypadWindows;
|
2014-02-10 01:10:30 +00:00
|
|
|
|
2022-10-11 09:52:41 +00:00
|
|
|
class OS_Windows : public OS {
|
|
|
|
uint64_t ticks_start = 0;
|
|
|
|
uint64_t ticks_per_second = 0;
|
2014-02-10 01:10:30 +00:00
|
|
|
|
2020-03-09 15:56:48 +00:00
|
|
|
HINSTANCE hInstance;
|
2022-04-04 13:06:57 +00:00
|
|
|
MainLoop *main_loop = nullptr;
|
2014-02-10 01:10:30 +00:00
|
|
|
|
2017-08-27 17:01:34 +00:00
|
|
|
#ifdef WASAPI_ENABLED
|
|
|
|
AudioDriverWASAPI driver_wasapi;
|
|
|
|
#endif
|
2016-10-17 15:40:45 +00:00
|
|
|
#ifdef XAUDIO2_ENABLED
|
|
|
|
AudioDriverXAudio2 driver_xaudio2;
|
|
|
|
#endif
|
2018-07-14 12:11:28 +00:00
|
|
|
#ifdef WINMIDI_ENABLED
|
|
|
|
MIDIDriverWinMidi driver_midi;
|
|
|
|
#endif
|
2014-02-10 01:10:30 +00:00
|
|
|
|
2017-09-08 01:01:49 +00:00
|
|
|
CrashHandler crash_handler;
|
|
|
|
|
2022-05-08 23:25:49 +00:00
|
|
|
#ifdef WINDOWS_DEBUG_OUTPUT_ENABLED
|
|
|
|
ErrorHandlerList error_handlers;
|
|
|
|
#endif
|
|
|
|
|
2020-03-09 15:56:48 +00:00
|
|
|
HWND main_window;
|
2018-11-09 19:30:08 +00:00
|
|
|
|
2022-11-21 13:04:01 +00:00
|
|
|
IDWriteFactory *dwrite_factory = nullptr;
|
|
|
|
IDWriteFactory2 *dwrite_factory2 = nullptr;
|
|
|
|
IDWriteFontCollection *font_collection = nullptr;
|
|
|
|
IDWriteFontFallback *system_font_fallback = nullptr;
|
|
|
|
|
|
|
|
bool dwrite_init = false;
|
|
|
|
bool dwrite2_init = false;
|
|
|
|
|
|
|
|
String _get_default_fontname(const String &p_font_name) const;
|
|
|
|
DWRITE_FONT_WEIGHT _weight_to_dw(int p_weight) const;
|
|
|
|
DWRITE_FONT_STRETCH _stretch_to_dw(int p_stretch) const;
|
|
|
|
|
2018-09-13 01:38:39 +00:00
|
|
|
// functions used by main to initialize/deinitialize the OS
|
2016-03-08 23:00:52 +00:00
|
|
|
protected:
|
2020-12-17 17:15:59 +00:00
|
|
|
virtual void initialize() override;
|
2016-03-08 23:00:52 +00:00
|
|
|
|
2020-12-17 17:15:59 +00:00
|
|
|
virtual void set_main_loop(MainLoop *p_main_loop) override;
|
|
|
|
virtual void delete_main_loop() override;
|
2016-03-08 23:00:52 +00:00
|
|
|
|
2020-12-17 17:15:59 +00:00
|
|
|
virtual void finalize() override;
|
|
|
|
virtual void finalize_core() override;
|
2022-12-29 20:06:11 +00:00
|
|
|
virtual String get_stdin_string() override;
|
2016-03-08 23:00:52 +00:00
|
|
|
|
2020-05-19 13:34:15 +00:00
|
|
|
String _quote_command_line_argument(const String &p_text) const;
|
|
|
|
|
2014-02-10 01:10:30 +00:00
|
|
|
struct ProcessInfo {
|
|
|
|
STARTUPINFO si;
|
|
|
|
PROCESS_INFORMATION pi;
|
|
|
|
};
|
2022-10-11 09:52:41 +00:00
|
|
|
HashMap<ProcessID, ProcessInfo> *process_map = nullptr;
|
2014-02-10 01:10:30 +00:00
|
|
|
|
|
|
|
public:
|
2021-07-22 16:23:48 +00:00
|
|
|
virtual void alert(const String &p_alert, const String &p_title = "ALERT!") override;
|
|
|
|
|
2022-02-07 16:33:55 +00:00
|
|
|
virtual Error get_entropy(uint8_t *r_buffer, int p_bytes) override;
|
|
|
|
|
2022-04-28 22:51:04 +00:00
|
|
|
virtual Error open_dynamic_library(const String p_path, void *&p_library_handle, bool p_also_set_library_path = false, String *r_resolved_path = nullptr) override;
|
2020-12-17 17:15:59 +00:00
|
|
|
virtual Error close_dynamic_library(void *p_library_handle) override;
|
|
|
|
virtual Error get_dynamic_library_symbol_handle(void *p_library_handle, const String p_name, void *&p_symbol_handle, bool p_optional = false) override;
|
2017-03-08 01:50:13 +00:00
|
|
|
|
2020-12-17 17:15:59 +00:00
|
|
|
virtual MainLoop *get_main_loop() const override;
|
2014-02-10 01:10:30 +00:00
|
|
|
|
2020-12-17 17:15:59 +00:00
|
|
|
virtual String get_name() const override;
|
2022-09-16 09:14:14 +00:00
|
|
|
virtual String get_distribution_name() const override;
|
|
|
|
virtual String get_version() const override;
|
2016-03-08 23:00:52 +00:00
|
|
|
|
2022-10-11 10:39:41 +00:00
|
|
|
virtual Vector<String> get_video_adapter_driver_info() const override;
|
|
|
|
|
2020-12-17 17:15:59 +00:00
|
|
|
virtual void initialize_joypads() override {}
|
2020-03-09 15:56:48 +00:00
|
|
|
|
2022-09-08 05:36:10 +00:00
|
|
|
virtual DateTime get_datetime(bool p_utc) const override;
|
2020-12-17 17:15:59 +00:00
|
|
|
virtual TimeZoneInfo get_time_zone_info() const override;
|
|
|
|
virtual double get_unix_time() const override;
|
2014-02-10 01:10:30 +00:00
|
|
|
|
2020-12-17 17:15:59 +00:00
|
|
|
virtual Error set_cwd(const String &p_cwd) override;
|
2014-02-10 01:10:30 +00:00
|
|
|
|
2020-12-17 17:15:59 +00:00
|
|
|
virtual void delay_usec(uint32_t p_usec) const override;
|
|
|
|
virtual uint64_t get_ticks_usec() const override;
|
2014-02-10 01:10:30 +00:00
|
|
|
|
2021-12-16 13:00:55 +00:00
|
|
|
virtual Error execute(const String &p_path, const List<String> &p_arguments, String *r_pipe = nullptr, int *r_exitcode = nullptr, bool read_stderr = false, Mutex *p_pipe_mutex = nullptr, bool p_open_console = false) override;
|
|
|
|
virtual Error create_process(const String &p_path, const List<String> &p_arguments, ProcessID *r_child_id = nullptr, bool p_open_console = false) override;
|
2020-12-17 17:15:59 +00:00
|
|
|
virtual Error kill(const ProcessID &p_pid) override;
|
|
|
|
virtual int get_process_id() const override;
|
2021-08-13 03:36:23 +00:00
|
|
|
virtual bool is_process_running(const ProcessID &p_pid) const override;
|
2016-03-08 23:00:52 +00:00
|
|
|
|
2020-12-17 17:15:59 +00:00
|
|
|
virtual bool has_environment(const String &p_var) const override;
|
|
|
|
virtual String get_environment(const String &p_var) const override;
|
|
|
|
virtual bool set_environment(const String &p_var, const String &p_value) const override;
|
2014-02-10 01:10:30 +00:00
|
|
|
|
2022-07-08 12:38:30 +00:00
|
|
|
virtual Vector<String> get_system_fonts() const override;
|
2022-11-21 13:04:01 +00:00
|
|
|
virtual String get_system_font_path(const String &p_font_name, int p_weight = 400, int p_stretch = 100, bool p_italic = false) const override;
|
|
|
|
virtual Vector<String> get_system_font_path_for_text(const String &p_font_name, const String &p_text, const String &p_locale = String(), const String &p_script = String(), int p_weight = 400, int p_stretch = 100, bool p_italic = false) const override;
|
2022-07-08 12:38:30 +00:00
|
|
|
|
2020-12-17 17:15:59 +00:00
|
|
|
virtual String get_executable_path() const override;
|
2014-02-10 01:10:30 +00:00
|
|
|
|
2020-12-17 17:15:59 +00:00
|
|
|
virtual String get_locale() const override;
|
2018-01-29 15:46:30 +00:00
|
|
|
|
2020-12-27 00:50:21 +00:00
|
|
|
virtual String get_processor_name() const override;
|
2018-01-29 15:46:30 +00:00
|
|
|
|
2021-12-20 09:28:54 +00:00
|
|
|
virtual uint64_t get_embedded_pck_offset() const override;
|
|
|
|
|
2020-12-17 17:15:59 +00:00
|
|
|
virtual String get_config_path() const override;
|
|
|
|
virtual String get_data_path() const override;
|
|
|
|
virtual String get_cache_path() const override;
|
|
|
|
virtual String get_godot_dir_name() const override;
|
Add initial support for the XDG Base Directory spec
Spec version 0.7 from https://standards.freedesktop.org/basedir-spec/basedir-spec-0.7.html
(latest as of this commit).
Three virtual methods are added to OS for the various XDG paths we will use:
- OS::get_data_path gives XDG_DATA_HOME, or if missing:
~/.local/share on X11, ~/Library/Application Support/ on macOS and %APPDATA% on Windows
- OS::get_config_path gives XDG_CONFIG_HOME, or if missing:
~/.config on X11, ~/Library/Application Support/ on macOS and %APPDATA% on Windows
- OS::get_cache_path gives XDG_CACHE_HOME, or if missing:
~/.cache on X11, ~/Library/Caches on macOS and %APPDATA% on Windows
So for Windows there are no changes, for Linux we follow the full split spec
and for macOS stuff will move from ~/.godot to ~/Library/Application Support/Godot.
Support for system-wide installation of templates on Unix was removed for now,
as it's a bit hackish and I don't think anyone uses it.
user:// will still be OS::get_data_path() + "/godot/app_userdata/$name" by
default, but when using the application/config/use_shared_user_dir option
it will now use XDG_DATA_HOME/$name, e.g. ~/.local/share/MyGame.
For now everything still goes in EditorSettings::get_settings_dir(), but
this will be changed in a later commit to make use of the new splitting
where relevant.
Part of #3513.
2017-11-17 16:11:41 +00:00
|
|
|
|
2021-07-11 01:39:31 +00:00
|
|
|
virtual String get_system_dir(SystemDir p_dir, bool p_shared_storage = true) const override;
|
2020-12-17 17:15:59 +00:00
|
|
|
virtual String get_user_data_dir() const override;
|
2014-12-02 17:02:41 +00:00
|
|
|
|
2020-12-17 17:15:59 +00:00
|
|
|
virtual String get_unique_id() const override;
|
2018-01-20 13:40:52 +00:00
|
|
|
|
2020-12-17 17:15:59 +00:00
|
|
|
virtual Error shell_open(String p_uri) override;
|
2014-04-18 14:43:54 +00:00
|
|
|
|
2014-02-10 01:10:30 +00:00
|
|
|
void run();
|
|
|
|
|
2020-12-17 17:15:59 +00:00
|
|
|
virtual bool _check_internal_feature_support(const String &p_feature) override;
|
2017-02-08 23:07:35 +00:00
|
|
|
|
2020-12-18 09:38:09 +00:00
|
|
|
virtual void disable_crash_handler() override;
|
|
|
|
virtual bool is_disable_crash_handler() const override;
|
2020-12-17 17:15:59 +00:00
|
|
|
virtual void initialize_debugging() override;
|
2017-09-08 01:01:49 +00:00
|
|
|
|
2020-12-17 17:15:59 +00:00
|
|
|
virtual Error move_to_trash(const String &p_path) override;
|
2017-09-25 13:15:11 +00:00
|
|
|
|
2020-03-09 15:56:48 +00:00
|
|
|
void set_main_window(HWND p_main_window) { main_window = p_main_window; }
|
2019-03-03 20:12:19 +00:00
|
|
|
|
2020-03-09 15:56:48 +00:00
|
|
|
HINSTANCE get_hinstance() { return hInstance; }
|
2016-03-08 23:00:52 +00:00
|
|
|
OS_Windows(HINSTANCE _hInstance);
|
2014-02-10 01:10:30 +00:00
|
|
|
~OS_Windows();
|
|
|
|
};
|
|
|
|
|
2022-07-23 21:41:51 +00:00
|
|
|
#endif // OS_WINDOWS_H
|