[*] basic in-house cpp linting (#4039)

- add `#pragma once` to remainder files
- "correcter" defines (ANDROID), see https://groups.google.com/g/android-ndk/c/cf9_f1SLXls
- extra miscelly fixups

Signed-off-by: lizzie <lizzie@eden-emu.dev>

Reviewed-on: https://git.eden-emu.dev/eden-emu/eden/pulls/4039
Reviewed-by: MaranBr <maranbr@eden-emu.dev>
Reviewed-by: crueter <crueter@eden-emu.dev>
This commit is contained in:
lizzie 2026-06-04 05:49:07 +02:00 committed by crueter
parent 978d9d935d
commit 89199f4d27
No known key found for this signature in database
GPG Key ID: 425ACD2D4830EBC6
53 changed files with 176 additions and 153 deletions

View File

@ -306,7 +306,7 @@ if (YUZU_ROOM)
add_compile_definitions(YUZU_ROOM) add_compile_definitions(YUZU_ROOM)
endif() endif()
if ((ANDROID OR APPLE OR UNIX) AND (NOT PLATFORM_LINUX OR ANDROID) AND NOT WIN32) if (UNIX AND NOT (PLATFORM_LINUX OR WIN32))
if(CXX_APPLE OR CXX_CLANG) if(CXX_APPLE OR CXX_CLANG)
# libc++ has stop_token and jthread as experimental # libc++ has stop_token and jthread as experimental
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fexperimental-library") set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fexperimental-library")
@ -524,6 +524,8 @@ elseif (WIN32)
# PSAPI is the Process Status API # PSAPI is the Process Status API
set(PLATFORM_LIBRARIES ${PLATFORM_LIBRARIES} psapi imm32 version crypt32 rpcrt4 gdi32 wldap32 mswsock) set(PLATFORM_LIBRARIES ${PLATFORM_LIBRARIES} psapi imm32 version crypt32 rpcrt4 gdi32 wldap32 mswsock)
endif() endif()
elseif (PLATFORM_MANAGARM)
set(PLATFORM_LIBRARIES iconv intl)
elseif (PLATFORM_HAIKU) elseif (PLATFORM_HAIKU)
# Haiku is so special :) # Haiku is so special :)
set(PLATFORM_LIBRARIES bsd /boot/system/lib/libnetwork.so) set(PLATFORM_LIBRARIES bsd /boot/system/lib/libnetwork.so)

View File

@ -303,7 +303,7 @@ namespace {
} }
[[nodiscard]] s64 GetHostCNTFRQ() noexcept { [[nodiscard]] s64 GetHostCNTFRQ() noexcept {
u64 cntfrq_el0 = 0; u64 cntfrq_el0 = 0;
#ifdef ANDROID #ifdef __ANDROID__
std::string_view board{""}; std::string_view board{""};
char buffer[PROP_VALUE_MAX]; char buffer[PROP_VALUE_MAX];
int len{__system_property_get("ro.product.board", buffer)}; int len{__system_property_get("ro.product.board", buffer)};

View File

@ -1,3 +1,6 @@
// SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project
// SPDX-License-Identifier: GPL-3.0-or-later
// SPDX-FileCopyrightText: 2013 Dolphin Emulator Project // SPDX-FileCopyrightText: 2013 Dolphin Emulator Project
// SPDX-FileCopyrightText: 2014 Citra Emulator Project // SPDX-FileCopyrightText: 2014 Citra Emulator Project
// SPDX-License-Identifier: GPL-2.0-or-later // SPDX-License-Identifier: GPL-2.0-or-later
@ -30,7 +33,7 @@ std::string NativeErrorToString(int e) {
return ret; return ret;
#else #else
char err_str[255]; char err_str[255];
#if defined(ANDROID) || \ #if defined(__ANDROID__) || \
(defined(__GLIBC__) && (_GNU_SOURCE || (_POSIX_C_SOURCE < 200112L && _XOPEN_SOURCE < 600))) (defined(__GLIBC__) && (_GNU_SOURCE || (_POSIX_C_SOURCE < 200112L && _XOPEN_SOURCE < 600)))
// Thread safe (GNU-specific) // Thread safe (GNU-specific)
const char* str = strerror_r(e, err_str, sizeof(err_str)); const char* str = strerror_r(e, err_str, sizeof(err_str));

View File

@ -9,7 +9,7 @@
#include "common/assert.h" #include "common/assert.h"
#include "common/fs/file.h" #include "common/fs/file.h"
#include "common/fs/fs.h" #include "common/fs/fs.h"
#ifdef ANDROID #ifdef __ANDROID__
#include "common/fs/fs_android.h" #include "common/fs/fs_android.h"
#endif #endif
#include "common/logging.h" #include "common/logging.h"
@ -259,7 +259,7 @@ void IOFile::Open(const fs::path& path, FileAccessMode mode, FileType type, File
} else { } else {
_wfopen_s(&file, path.c_str(), AccessModeToWStr(mode, type)); _wfopen_s(&file, path.c_str(), AccessModeToWStr(mode, type));
} }
#elif ANDROID #elif __ANDROID__
if (Android::IsContentUri(path)) { if (Android::IsContentUri(path)) {
ASSERT_MSG(mode == FileAccessMode::Read, "Content URI file access is for read-only!"); ASSERT_MSG(mode == FileAccessMode::Read, "Content URI file access is for read-only!");
const auto fd = Android::OpenContentUri(path, Android::OpenMode::Read); const auto fd = Android::OpenContentUri(path, Android::OpenMode::Read);
@ -396,7 +396,7 @@ u64 IOFile::GetSize() const {
// Flush any unwritten buffered data into the file prior to retrieving the file size. // Flush any unwritten buffered data into the file prior to retrieving the file size.
std::fflush(file); std::fflush(file);
#if ANDROID #ifdef __ANDROID__
u64 file_size = 0; u64 file_size = 0;
if (Android::IsContentUri(file_path)) { if (Android::IsContentUri(file_path)) {
file_size = Android::GetSize(file_path); file_size = Android::GetSize(file_path);

View File

@ -6,7 +6,7 @@
#include "common/fs/file.h" #include "common/fs/file.h"
#include "common/fs/fs.h" #include "common/fs/fs.h"
#ifdef ANDROID #ifdef __ANDROID__
#include "common/fs/fs_android.h" #include "common/fs/fs_android.h"
#endif #endif
#include "common/fs/path_util.h" #include "common/fs/path_util.h"
@ -532,7 +532,7 @@ void IterateDirEntriesRecursively(const std::filesystem::path& path,
bool Exists(const fs::path& path) { bool Exists(const fs::path& path) {
std::error_code ec; std::error_code ec;
#ifdef ANDROID #ifdef __ANDROID__
if (Android::IsContentUri(path)) { if (Android::IsContentUri(path)) {
return Android::Exists(path); return Android::Exists(path);
} else { } else {
@ -545,7 +545,7 @@ bool Exists(const fs::path& path) {
bool IsFile(const fs::path& path) { bool IsFile(const fs::path& path) {
std::error_code ec; std::error_code ec;
#ifdef ANDROID #ifdef __ANDROID__
if (Android::IsContentUri(path)) { if (Android::IsContentUri(path)) {
return !Android::IsDirectory(path); return !Android::IsDirectory(path);
} else { } else {
@ -558,7 +558,7 @@ bool IsFile(const fs::path& path) {
bool IsDir(const fs::path& path) { bool IsDir(const fs::path& path) {
std::error_code ec; std::error_code ec;
#ifdef ANDROID #ifdef __ANDROID__
if (Android::IsContentUri(path)) { if (Android::IsContentUri(path)) {
return Android::IsDirectory(path); return Android::IsDirectory(path);
} else { } else {
@ -611,7 +611,7 @@ fs::file_type GetEntryType(const fs::path& path) {
} }
u64 GetSize(const fs::path& path) { u64 GetSize(const fs::path& path) {
#ifdef ANDROID #ifdef __ANDROID__
if (Android::IsContentUri(path)) { if (Android::IsContentUri(path)) {
return Android::GetSize(path); return Android::GetSize(path);
} }

View File

@ -11,7 +11,7 @@
#include "common/assert.h" #include "common/assert.h"
#include "common/fs/fs.h" #include "common/fs/fs.h"
#ifdef ANDROID #ifdef __ANDROID__
#include "common/fs/fs_android.h" #include "common/fs/fs_android.h"
#endif #endif
#include "common/fs/fs_paths.h" #include "common/fs/fs_paths.h"
@ -126,7 +126,7 @@ public:
LEGACY_PATH(Yuzu, YUZU) LEGACY_PATH(Yuzu, YUZU)
LEGACY_PATH(Suyu, SUYU) LEGACY_PATH(Suyu, SUYU)
#undef LEGACY_PATH #undef LEGACY_PATH
#elif ANDROID #elif __ANDROID__
ASSERT(!eden_path.empty()); ASSERT(!eden_path.empty());
eden_path_cache = eden_path / CACHE_DIR; eden_path_cache = eden_path / CACHE_DIR;
eden_path_config = eden_path / CONFIG_DIR; eden_path_config = eden_path / CONFIG_DIR;
@ -447,11 +447,11 @@ std::vector<std::string> SplitPathComponentsCopy(std::string_view filename) {
std::string SanitizePath(std::string_view path_, DirectorySeparator directory_separator) { std::string SanitizePath(std::string_view path_, DirectorySeparator directory_separator) {
std::string path(path_); std::string path(path_);
#ifdef ANDROID #ifdef __ANDROID__
if (Android::IsContentUri(path)) { if (Android::IsContentUri(path)) {
return path; return path;
} }
#endif // ANDROID #endif // __ANDROID__
char type1 = directory_separator == DirectorySeparator::BackwardSlash ? '/' : '\\'; char type1 = directory_separator == DirectorySeparator::BackwardSlash ? '/' : '\\';
char type2 = directory_separator == DirectorySeparator::BackwardSlash ? '\\' : '/'; char type2 = directory_separator == DirectorySeparator::BackwardSlash ? '\\' : '/';
@ -482,7 +482,7 @@ std::string GetParentPath(std::string_view path) {
return std::string(path); return std::string(path);
} }
#ifdef ANDROID #ifdef __ANDROID__
if (path[0] != '/') { if (path[0] != '/') {
std::string path_string{path}; std::string path_string{path};
return FS::Android::GetParentDirectory(path_string); return FS::Android::GetParentDirectory(path_string);

View File

@ -320,7 +320,7 @@ struct DebuggerBackend final : public Backend {
void Flush() noexcept override {} void Flush() noexcept override {}
}; };
#endif #endif
#ifdef ANDROID #ifdef __ANDROID__
/// @brief Backend that writes to the Android logcat /// @brief Backend that writes to the Android logcat
struct LogcatBackend : public Backend { struct LogcatBackend : public Backend {
explicit LogcatBackend() noexcept = default; explicit LogcatBackend() noexcept = default;
@ -359,7 +359,7 @@ struct Impl {
#ifdef _WIN32 #ifdef _WIN32
lambda(static_cast<Backend&>(debugger_backend)); lambda(static_cast<Backend&>(debugger_backend));
#endif #endif
#ifdef ANDROID #ifdef __ANDROID__
lambda(static_cast<Backend&>(lc_backend)); lambda(static_cast<Backend&>(lc_backend));
#endif #endif
} }
@ -372,7 +372,7 @@ struct Impl {
#ifdef _WIN32 #ifdef _WIN32
DebuggerBackend debugger_backend{}; DebuggerBackend debugger_backend{};
#endif #endif
#ifdef ANDROID #ifdef __ANDROID__
LogcatBackend lc_backend{}; LogcatBackend lc_backend{};
#endif #endif
std::chrono::steady_clock::time_point time_origin{std::chrono::steady_clock::now()}; std::chrono::steady_clock::time_point time_origin{std::chrono::steady_clock::now()};

View File

@ -359,7 +359,7 @@ struct Values {
true, true,
true}; true};
SwitchableSetting<int, true> fsr_sharpening_slider{linkage, SwitchableSetting<int, true> fsr_sharpening_slider{linkage,
#ifdef ANDROID #ifdef __ANDROID__
0, 0,
#else #else
25, 25,
@ -417,7 +417,7 @@ struct Values {
linkage, 0, "bg_blue", Category::Renderer, Specialization::Default, true, true}; linkage, 0, "bg_blue", Category::Renderer, Specialization::Default, true, true};
SwitchableSetting<GpuAccuracy, true> gpu_accuracy{linkage, SwitchableSetting<GpuAccuracy, true> gpu_accuracy{linkage,
#ifdef ANDROID #ifdef __ANDROID__
GpuAccuracy::Low, GpuAccuracy::Low,
#else #else
GpuAccuracy::Medium, GpuAccuracy::Medium,
@ -447,7 +447,7 @@ struct Values {
"nvdec_emulation", Category::RendererAdvanced}; "nvdec_emulation", Category::RendererAdvanced};
SwitchableSetting<AnisotropyMode, true> max_anisotropy{linkage, SwitchableSetting<AnisotropyMode, true> max_anisotropy{linkage,
#ifdef ANDROID #ifdef __ANDROID__
AnisotropyMode::Default, AnisotropyMode::Default,
#else #else
AnisotropyMode::Automatic, AnisotropyMode::Automatic,
@ -500,7 +500,7 @@ struct Values {
Category::RendererAdvanced}; Category::RendererAdvanced};
SwitchableSetting<bool> use_reactive_flushing{linkage, SwitchableSetting<bool> use_reactive_flushing{linkage,
#ifdef ANDROID #ifdef __ANDROID__
false, false,
#else #else
true, true,
@ -519,7 +519,7 @@ struct Values {
true, true,
true}; true};
#ifdef ANDROID #ifdef __ANDROID__
SwitchableSetting<bool> use_optimized_vertex_buffers{linkage, SwitchableSetting<bool> use_optimized_vertex_buffers{linkage,
false, false,
"use_optimized_vertex_buffers", "use_optimized_vertex_buffers",
@ -553,7 +553,7 @@ struct Values {
true, true,
true}; true};
SwitchableSetting<bool> async_presentation{linkage, SwitchableSetting<bool> async_presentation{linkage,
#ifdef ANDROID #ifdef __ANDROID__
false, false,
#else #else
false, false,
@ -599,7 +599,7 @@ struct Values {
Category::RendererHacks}; Category::RendererHacks};
SwitchableSetting<ExtendedDynamicState> dyna_state{linkage, SwitchableSetting<ExtendedDynamicState> dyna_state{linkage,
#if defined(ANDROID) #if defined(__ANDROID__)
ExtendedDynamicState::Disabled, ExtendedDynamicState::Disabled,
#elif defined(__APPLE__) #elif defined(__APPLE__)
ExtendedDynamicState::Disabled, ExtendedDynamicState::Disabled,
@ -618,7 +618,7 @@ struct Values {
Specialization::Scalar}; Specialization::Scalar};
SwitchableSetting<bool> vertex_input_dynamic_state{linkage, SwitchableSetting<bool> vertex_input_dynamic_state{linkage,
#if defined (ANDROID) #ifdef __ANDROID__
false, false,
#else #else
true, true,
@ -634,7 +634,7 @@ struct Values {
linkage, false, "disable_shader_loop_safety_checks", Category::RendererDebug}; linkage, false, "disable_shader_loop_safety_checks", Category::RendererDebug};
Setting<bool> enable_renderdoc_hotkey{linkage, false, "renderdoc_hotkey", Setting<bool> enable_renderdoc_hotkey{linkage, false, "renderdoc_hotkey",
Category::RendererDebug}; Category::RendererDebug};
#if defined(ANDROID) && defined(ARCHITECTURE_arm64) #if defined(__ANDROID__) && defined(ARCHITECTURE_arm64)
// Debug override for automatic BCn patching detection // Debug override for automatic BCn patching detection
Setting<bool> patch_old_qcom_drivers{linkage, false, "patch_old_qcom_drivers", Setting<bool> patch_old_qcom_drivers{linkage, false, "patch_old_qcom_drivers",
Category::RendererDebug}; Category::RendererDebug};
@ -679,7 +679,7 @@ struct Values {
Setting<s32> current_user{linkage, 0, "current_user", Category::System}; Setting<s32> current_user{linkage, 0, "current_user", Category::System};
SwitchableSetting<ConsoleMode> use_docked_mode{linkage, SwitchableSetting<ConsoleMode> use_docked_mode{linkage,
#ifdef ANDROID #ifdef __ANDROID__
ConsoleMode::Handheld, ConsoleMode::Handheld,
#else #else
ConsoleMode::Docked, ConsoleMode::Docked,

View File

@ -1,4 +1,4 @@
// SPDX-FileCopyrightText: Copyright 2025 Eden Emulator Project // SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project
// SPDX-License-Identifier: GPL-3.0-or-later // SPDX-License-Identifier: GPL-3.0-or-later
// SPDX-FileCopyrightText: 2013 Dolphin Emulator Project // SPDX-FileCopyrightText: 2013 Dolphin Emulator Project
@ -18,7 +18,7 @@
#include <windows.h> #include <windows.h>
#endif #endif
#ifdef ANDROID #ifdef __ANDROID__
#include <common/fs/fs_android.h> #include <common/fs/fs_android.h>
#endif #endif
@ -45,7 +45,7 @@ bool SplitPath(const std::string& full_path, std::string* _pPath, std::string* _
if (full_path.empty()) if (full_path.empty())
return false; return false;
#ifdef ANDROID #ifdef __ANDROID__
if (full_path[0] != '/') { if (full_path[0] != '/') {
*_pPath = Common::FS::Android::GetParentDirectory(full_path); *_pPath = Common::FS::Android::GetParentDirectory(full_path);
*_pFilename = Common::FS::Android::GetFilename(full_path); *_pFilename = Common::FS::Android::GetFilename(full_path);

View File

@ -1,4 +1,4 @@
// SPDX-FileCopyrightText: Copyright 2025 Eden Emulator Project // SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project
// SPDX-License-Identifier: GPL-3.0-or-later // SPDX-License-Identifier: GPL-3.0-or-later
// SPDX-FileCopyrightText: 2012 PPSSPP Project // SPDX-FileCopyrightText: 2012 PPSSPP Project
@ -10,12 +10,10 @@
#pragma once #pragma once
#if defined(_MSC_VER)
#include <cstdlib> #include <cstdlib>
#endif
#include <bit>
#include <cstring> #include <cstring>
#include <type_traits> #include <type_traits>
#include <bit>
#include "common/common_types.h" #include "common/common_types.h"
namespace Common { namespace Common {

View File

@ -9,7 +9,7 @@
#include <boost/asio.hpp> #include <boost/asio.hpp>
#include <boost/version.hpp> #include <boost/version.hpp>
#if BOOST_VERSION > 108400 && (!defined(_WINDOWS) && !defined(ANDROID)) || defined(YUZU_BOOST_v1) #if BOOST_VERSION > 108400 && (!defined(_WINDOWS) && !defined(__ANDROID__)) || defined(YUZU_BOOST_v1)
#define USE_BOOST_v1 #define USE_BOOST_v1
#endif #endif

View File

@ -23,7 +23,7 @@
#define stat _stat64 #define stat _stat64
#endif #endif
#ifdef ANDROID #ifdef __ANDROID__
#include "common/fs/fs_android.h" #include "common/fs/fs_android.h"
#endif #endif
@ -288,7 +288,7 @@ RealVfsFile::~RealVfsFile() {
} }
std::string RealVfsFile::GetName() const { std::string RealVfsFile::GetName() const {
#ifdef ANDROID #ifdef __ANDROID__
if (path[0] != '/') { if (path[0] != '/') {
return FS::Android::GetFilename(path); return FS::Android::GetFilename(path);
} }

View File

@ -31,7 +31,7 @@ RenderdocAPI::RenderdocAPI() {
#elif defined(__HAIKU__) #elif defined(__HAIKU__)
// no rtld on haiku // no rtld on haiku
#else #else
#ifdef ANDROID #ifdef __ANDROID__
static constexpr const char RENDERDOC_LIB[] = "libVkLayer_GLES_RenderDoc.so"; static constexpr const char RENDERDOC_LIB[] = "libVkLayer_GLES_RenderDoc.so";
#else #else
static constexpr const char RENDERDOC_LIB[] = "librenderdoc.so"; static constexpr const char RENDERDOC_LIB[] = "librenderdoc.so";

View File

@ -75,7 +75,7 @@ ArgCallback DevirtualizeItanium(mcl::class_type<decltype(mfp)>* this_) {
template<auto mfp> template<auto mfp>
ArgCallback Devirtualize(mcl::class_type<decltype(mfp)>* this_) { ArgCallback Devirtualize(mcl::class_type<decltype(mfp)>* this_) {
#if defined(__APPLE__) || defined(linux) || defined(__linux) || defined(__linux__) #if defined(__APPLE__) || defined(__linux__)
return DevirtualizeItanium<mfp>(this_); return DevirtualizeItanium<mfp>(this_);
#elif defined(__MINGW64__) #elif defined(__MINGW64__)
return DevirtualizeItanium<mfp>(this_); return DevirtualizeItanium<mfp>(this_);

View File

@ -1009,7 +1009,7 @@ std::string Config::AdjustOutputString(const std::string& string) {
// Windows requires that two forward slashes are used at the start of a path for unmapped // Windows requires that two forward slashes are used at the start of a path for unmapped
// network drives so we have to watch for that here // network drives so we have to watch for that here
#ifndef ANDROID #ifndef __ANDROID__
if (string.substr(0, 2) == "//") { if (string.substr(0, 2) == "//") {
boost::replace_all(adjusted_string, "//", "/"); boost::replace_all(adjusted_string, "//", "/");
adjusted_string.insert(0, "/"); adjusted_string.insert(0, "/");

View File

@ -1,8 +1,7 @@
// SPDX-FileCopyrightText: Copyright 2025 Eden Emulator Project // SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project
// SPDX-License-Identifier: GPL-3.0-or-later // SPDX-License-Identifier: GPL-3.0-or-later
#ifndef DATA_MANAGER_H #pragma once
#define DATA_MANAGER_H
#include "common/common_types.h" #include "common/common_types.h"
#include <string> #include <string>
@ -21,5 +20,3 @@ std::string ReadableBytesSize(u64 size) noexcept;
u64 DataDirSize(DataDir dir); u64 DataDirSize(DataDir dir);
}; // namespace FrontendCommon::DataManager }; // namespace FrontendCommon::DataManager
#endif // DATA_MANAGER_H

View File

@ -13,7 +13,7 @@
#include "core/crypto/key_manager.h" #include "core/crypto/key_manager.h"
#include "frontend_common/content_manager.h" #include "frontend_common/content_manager.h"
#ifdef ANDROID #ifdef __ANDROID__
#include <jni.h> #include <jni.h>
#include <common/android/id_cache.h> #include <common/android/id_cache.h>
#include <common/android/android_common.h> #include <common/android/android_common.h>
@ -25,7 +25,7 @@ FirmwareManager::InstallKeys(std::string location, std::string extension) {
const auto keys_dir = Common::FS::GetEdenPath(Common::FS::EdenPath::KeysDir); const auto keys_dir = Common::FS::GetEdenPath(Common::FS::EdenPath::KeysDir);
#ifdef ANDROID #ifdef __ANDROID__
JNIEnv *env = Common::Android::GetEnvForThread(); JNIEnv *env = Common::Android::GetEnvForThread();
jstring jsrc = Common::Android::ToJString(env, location); jstring jsrc = Common::Android::ToJString(env, location);

View File

@ -1,8 +1,7 @@
// SPDX-FileCopyrightText: Copyright 2025 Eden Emulator Project // SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project
// SPDX-License-Identifier: GPL-3.0-or-later // SPDX-License-Identifier: GPL-3.0-or-later
#ifndef FIRMWARE_MANAGER_H #pragma once
#define FIRMWARE_MANAGER_H
#include "common/common_types.h" #include "common/common_types.h"
#include "core/core.h" #include "core/core.h"
@ -107,5 +106,3 @@ inline std::pair<Service::Set::FirmwareVersionFormat, Result> GetFirmwareVersion
// TODO(crueter): GET AS STRING // TODO(crueter): GET AS STRING
} }
#endif

View File

@ -5,6 +5,7 @@
#include <filesystem> #include <filesystem>
#include <optional> #include <optional>
#include <vector>
#include "common/common_types.h" #include "common/common_types.h"
namespace FrontendCommon { namespace FrontendCommon {

View File

@ -179,7 +179,7 @@ void EmulatedController::LoadDevices() {
if (npad_id_type == NpadIdType::Player1 || npad_id_type == NpadIdType::Handheld) { if (npad_id_type == NpadIdType::Player1 || npad_id_type == NpadIdType::Handheld) {
camera_params[1] = Common::ParamPackage{"engine:camera,camera:1"}; camera_params[1] = Common::ParamPackage{"engine:camera,camera:1"};
nfc_params[0] = Common::ParamPackage{"engine:virtual_amiibo,nfc:1"}; nfc_params[0] = Common::ParamPackage{"engine:virtual_amiibo,nfc:1"};
#ifndef ANDROID #ifndef __ANDROID__
ring_params[1] = Common::ParamPackage{"engine:joycon,axis_x:100,axis_y:101"}; ring_params[1] = Common::ParamPackage{"engine:joycon,axis_x:100,axis_y:101"};
#else #else
android_params = Common::ParamPackage{"engine:android,port:100"}; android_params = Common::ParamPackage{"engine:android,port:100"};

View File

@ -30,7 +30,7 @@
#include "input_common/drivers/sdl_driver.h" #include "input_common/drivers/sdl_driver.h"
#endif #endif
#ifdef ANDROID #ifdef __ANDROID__
#include "input_common/drivers/android.h" #include "input_common/drivers/android.h"
#endif #endif
@ -85,7 +85,7 @@ struct InputSubsystem::Impl {
RegisterEngine("cemuhookudp", udp_client); RegisterEngine("cemuhookudp", udp_client);
RegisterEngine("tas", tas_input); RegisterEngine("tas", tas_input);
RegisterEngine("camera", camera); RegisterEngine("camera", camera);
#ifdef ANDROID #ifdef __ANDROID__
RegisterEngine("android", android); RegisterEngine("android", android);
#endif #endif
RegisterEngine("virtual_amiibo", virtual_amiibo); RegisterEngine("virtual_amiibo", virtual_amiibo);
@ -119,7 +119,7 @@ struct InputSubsystem::Impl {
UnregisterEngine(udp_client); UnregisterEngine(udp_client);
UnregisterEngine(tas_input); UnregisterEngine(tas_input);
UnregisterEngine(camera); UnregisterEngine(camera);
#ifdef ANDROID #ifdef __ANDROID__
UnregisterEngine(android); UnregisterEngine(android);
#endif #endif
UnregisterEngine(virtual_amiibo); UnregisterEngine(virtual_amiibo);
@ -138,13 +138,13 @@ struct InputSubsystem::Impl {
Common::ParamPackage{{"display", "Any"}, {"engine", "any"}}, Common::ParamPackage{{"display", "Any"}, {"engine", "any"}},
}; };
#ifndef ANDROID #ifndef __ANDROID__
auto keyboard_devices = keyboard->GetInputDevices(); auto keyboard_devices = keyboard->GetInputDevices();
devices.insert(devices.end(), keyboard_devices.begin(), keyboard_devices.end()); devices.insert(devices.end(), keyboard_devices.begin(), keyboard_devices.end());
auto mouse_devices = mouse->GetInputDevices(); auto mouse_devices = mouse->GetInputDevices();
devices.insert(devices.end(), mouse_devices.begin(), mouse_devices.end()); devices.insert(devices.end(), mouse_devices.begin(), mouse_devices.end());
#endif #endif
#ifdef ANDROID #ifdef __ANDROID__
auto android_devices = android->GetInputDevices(); auto android_devices = android->GetInputDevices();
devices.insert(devices.end(), android_devices.begin(), android_devices.end()); devices.insert(devices.end(), android_devices.begin(), android_devices.end());
#endif #endif
@ -176,7 +176,7 @@ struct InputSubsystem::Impl {
if (engine == mouse->GetEngineName()) { if (engine == mouse->GetEngineName()) {
return mouse; return mouse;
} }
#ifdef ANDROID #ifdef __ANDROID__
if (engine == android->GetEngineName()) { if (engine == android->GetEngineName()) {
return android; return android;
} }
@ -261,7 +261,7 @@ struct InputSubsystem::Impl {
if (engine == mouse->GetEngineName()) { if (engine == mouse->GetEngineName()) {
return true; return true;
} }
#ifdef ANDROID #ifdef __ANDROID__
if (engine == android->GetEngineName()) { if (engine == android->GetEngineName()) {
return true; return true;
} }
@ -294,7 +294,7 @@ struct InputSubsystem::Impl {
void BeginConfiguration() { void BeginConfiguration() {
keyboard->BeginConfiguration(); keyboard->BeginConfiguration();
mouse->BeginConfiguration(); mouse->BeginConfiguration();
#ifdef ANDROID #ifdef __ANDROID__
android->BeginConfiguration(); android->BeginConfiguration();
#endif #endif
#ifdef ENABLE_LIBUSB #ifdef ENABLE_LIBUSB
@ -310,7 +310,7 @@ struct InputSubsystem::Impl {
void EndConfiguration() { void EndConfiguration() {
keyboard->EndConfiguration(); keyboard->EndConfiguration();
mouse->EndConfiguration(); mouse->EndConfiguration();
#ifdef ANDROID #ifdef __ANDROID__
android->EndConfiguration(); android->EndConfiguration();
#endif #endif
#ifdef ENABLE_LIBUSB #ifdef ENABLE_LIBUSB
@ -355,7 +355,7 @@ struct InputSubsystem::Impl {
std::shared_ptr<Joycons> joycon; std::shared_ptr<Joycons> joycon;
#endif #endif
#ifdef ANDROID #ifdef __ANDROID__
std::shared_ptr<Android> android; std::shared_ptr<Android> android;
#endif #endif
}; };
@ -412,7 +412,7 @@ const Camera* InputSubsystem::GetCamera() const {
return impl->camera.get(); return impl->camera.get();
} }
#ifdef ANDROID #ifdef __ANDROID__
Android* InputSubsystem::GetAndroid() { Android* InputSubsystem::GetAndroid() {
return impl->android.get(); return impl->android.get();
} }

View File

@ -1,8 +1,7 @@
// SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project // SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project
// SPDX-License-Identifier: GPL-3.0-or-later // SPDX-License-Identifier: GPL-3.0-or-later
#ifndef FRONTEND_H #pragma once
#define FRONTEND_H
#include <QGuiApplication> #include <QGuiApplication>
#include "qt_common/qt_common.h" #include "qt_common/qt_common.h"
@ -114,4 +113,3 @@ const QString GetTextInput(const QString& title = QString(), const QString& capt
const QString& defaultText = QString()); const QString& defaultText = QString());
} // namespace QtCommon::Frontend } // namespace QtCommon::Frontend
#endif // FRONTEND_H

View File

@ -1,8 +1,7 @@
// SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project // SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project
// SPDX-License-Identifier: GPL-3.0-or-later // SPDX-License-Identifier: GPL-3.0-or-later
#ifndef QT_COMMON_H #pragma once
#define QT_COMMON_H
#include <memory> #include <memory>
#include <QWindow> #include <QWindow>
@ -62,4 +61,3 @@ const QString tr(const std::string& str);
std::filesystem::path GetEdenCommand(); std::filesystem::path GetEdenCommand();
} // namespace QtCommon } // namespace QtCommon
#endif

View File

@ -1,9 +1,7 @@
// SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project // SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project
// SPDX-License-Identifier: GPL-3.0-or-later // SPDX-License-Identifier: GPL-3.0-or-later
#ifndef QT_APPLET_UTIL_H #pragma once
#define QT_APPLET_UTIL_H
// TODO // TODO
namespace QtCommon::Applets {} namespace QtCommon::Applets {}
#endif // QT_APPLET_UTIL_H

View File

@ -1,8 +1,7 @@
// SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project // SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project
// SPDX-License-Identifier: GPL-3.0-or-later // SPDX-License-Identifier: GPL-3.0-or-later
#ifndef QT_CONTENT_UTIL_H #pragma once
#define QT_CONTENT_UTIL_H
#include <QObject> #include <QObject>
#include "common/common_types.h" #include "common/common_types.h"
@ -63,4 +62,3 @@ void configureFilesystemProvider(const std::string& filepath);
// Profiles // // Profiles //
void FixProfiles(); void FixProfiles();
} // namespace QtCommon::Content } // namespace QtCommon::Content
#endif // QT_CONTENT_UTIL_H

View File

@ -1,12 +1,12 @@
// SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project // SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project
// SPDX-License-Identifier: GPL-3.0-or-later // SPDX-License-Identifier: GPL-3.0-or-later
#pragma once
#include <filesystem> #include <filesystem>
#include <optional> #include <optional>
#include "common/common_types.h" #include "common/common_types.h"
#pragma once
namespace QtCommon::FS { namespace QtCommon::FS {
void LinkRyujinx(std::filesystem::path& from, std::filesystem::path& to); void LinkRyujinx(std::filesystem::path& from, std::filesystem::path& to);

View File

@ -1,8 +1,7 @@
// SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project // SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project
// SPDX-License-Identifier: GPL-3.0-or-later // SPDX-License-Identifier: GPL-3.0-or-later
#ifndef QT_GAME_UTIL_H #pragma once
#define QT_GAME_UTIL_H
#include <QObject> #include <QObject>
#include <QStandardPaths> #include <QStandardPaths>
@ -78,5 +77,3 @@ void CreateHomeMenuShortcut(ShortcutTarget target);
[[nodiscard]] bool SaveIconToFile(const std::filesystem::path& icon_path, const QImage& image); [[nodiscard]] bool SaveIconToFile(const std::filesystem::path& icon_path, const QImage& image);
} // namespace QtCommon::Game } // namespace QtCommon::Game
#endif // QT_GAME_UTIL_H

View File

@ -1,8 +1,7 @@
// SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project // SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project
// SPDX-License-Identifier: GPL-3.0-or-later // SPDX-License-Identifier: GPL-3.0-or-later
#ifndef QT_META_H #pragma once
#define QT_META_H
#include <QObject> #include <QObject>
@ -12,4 +11,3 @@ namespace QtCommon::Meta {
void RegisterMetaTypes(); void RegisterMetaTypes();
} // namespace QtCommon::Meta } // namespace QtCommon::Meta
#endif // QT_META_H

View File

@ -1,8 +1,7 @@
// SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project // SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project
// SPDX-License-Identifier: GPL-3.0-or-later // SPDX-License-Identifier: GPL-3.0-or-later
#ifndef QT_PATH_UTIL_H #pragma once
#define QT_PATH_UTIL_H
#include <QObject> #include <QObject>
#include "common/common_types.h" #include "common/common_types.h"
@ -10,5 +9,3 @@
namespace QtCommon::Path { namespace QtCommon::Path {
bool OpenShaderCache(u64 program_id, QObject* parent); bool OpenShaderCache(u64 program_id, QObject* parent);
} }
#endif // QT_PATH_UTIL_H

View File

@ -1,16 +1,11 @@
// SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project // SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project
// SPDX-License-Identifier: GPL-3.0-or-later // SPDX-License-Identifier: GPL-3.0-or-later
#ifndef QT_ROM_UTIL_H #pragma once
#define QT_ROM_UTIL_H
#include <cstddef> #include <cstddef>
#include "qt_common/qt_common.h" #include "qt_common/qt_common.h"
namespace QtCommon::ROM { namespace QtCommon::ROM {
bool RomFSRawCopy(size_t total_size, size_t& read_size, QtProgressCallback callback, const FileSys::VirtualDir& src, const FileSys::VirtualDir& dest, bool full);
bool RomFSRawCopy(size_t total_size, size_t& read_size, QtProgressCallback callback,
const FileSys::VirtualDir& src, const FileSys::VirtualDir& dest, bool full);
} }
#endif // QT_ROM_UTIL_H

View File

@ -151,7 +151,7 @@ Id EmitConvertU32U64(EmitContext& ctx, Id value) {
} }
Id EmitConvertF16F32(EmitContext& ctx, Id value) { Id EmitConvertF16F32(EmitContext& ctx, Id value) {
#ifdef ANDROID #ifdef __ANDROID__
return ctx.OpFConvert(ctx.F16[1], value); return ctx.OpFConvert(ctx.F16[1], value);
#else #else
const auto result = ctx.OpFConvert(ctx.F16[1], value); const auto result = ctx.OpFConvert(ctx.F16[1], value);

View File

@ -506,7 +506,7 @@ Id EmitImageSampleExplicitLod(EmitContext& ctx, IR::Inst* inst, const IR::Value&
Id result = Emit(&EmitContext::OpImageSparseSampleExplicitLod, Id result = Emit(&EmitContext::OpImageSparseSampleExplicitLod,
&EmitContext::OpImageSampleExplicitLod, ctx, inst, ctx.F32[4], &EmitContext::OpImageSampleExplicitLod, ctx, inst, ctx.F32[4],
Texture(ctx, info, index), coords, operands.Mask(), operands.Span()); Texture(ctx, info, index), coords, operands.Mask(), operands.Span());
#ifdef ANDROID #ifdef __ANDROID__
if (Settings::values.fix_bloom_effects.GetValue()) { if (Settings::values.fix_bloom_effects.GetValue()) {
result = ctx.OpVectorTimesScalar(ctx.F32[4], result, ctx.Const(0.98f)); result = ctx.OpVectorTimesScalar(ctx.F32[4], result, ctx.Const(0.98f));
} }

View File

@ -801,7 +801,7 @@ void BufferCache<P>::UpdateVertexBufferSlot(u32 index, const Binding& binding) {
template <class P> template <class P>
void BufferCache<P>::BindHostVertexBuffers() { void BufferCache<P>::BindHostVertexBuffers() {
#ifdef ANDROID #ifdef __ANDROID__
const bool use_optimized_vertex_buffers = Settings::values.use_optimized_vertex_buffers.GetValue(); const bool use_optimized_vertex_buffers = Settings::values.use_optimized_vertex_buffers.GetValue();
#else #else
constexpr bool use_optimized_vertex_buffers = true; constexpr bool use_optimized_vertex_buffers = true;

View File

@ -1,7 +1,7 @@
// SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project // SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project
// SPDX-License-Identifier: GPL-3.0-or-later // SPDX-License-Identifier: GPL-3.0-or-later
#ifdef ANDROID #ifdef __ANDROID__
#include "video_core/gpu_logging/freedreno_debug.h" #include "video_core/gpu_logging/freedreno_debug.h"
#include "common/logging.h" #include "common/logging.h"
@ -49,4 +49,4 @@ std::string FreedrenoDebugger::GetBreadcrumbs() {
} // namespace GPU::Logging::Freedreno } // namespace GPU::Logging::Freedreno
#endif // ANDROID #endif // __ANDROID__

View File

@ -3,7 +3,7 @@
#pragma once #pragma once
#ifdef ANDROID #ifdef __ANDROID__
#include <string> #include <string>
@ -29,4 +29,4 @@ private:
} // namespace GPU::Logging::Freedreno } // namespace GPU::Logging::Freedreno
#endif // ANDROID #endif // __ANDROID__

View File

@ -28,7 +28,7 @@ namespace {
constexpr AVPixelFormat PreferredGpuFormat = AV_PIX_FMT_NV12; constexpr AVPixelFormat PreferredGpuFormat = AV_PIX_FMT_NV12;
constexpr AVPixelFormat PreferredCpuFormat = AV_PIX_FMT_YUV420P; constexpr AVPixelFormat PreferredCpuFormat = AV_PIX_FMT_YUV420P;
constexpr std::array PreferredGpuDecoders = { constexpr std::array PreferredGpuDecoders = {
#if defined (_WIN32) #if defined(_WIN32)
AV_HWDEVICE_TYPE_CUDA, AV_HWDEVICE_TYPE_CUDA,
AV_HWDEVICE_TYPE_D3D11VA, AV_HWDEVICE_TYPE_D3D11VA,
AV_HWDEVICE_TYPE_DXVA2, AV_HWDEVICE_TYPE_DXVA2,
@ -39,7 +39,7 @@ constexpr std::array PreferredGpuDecoders = {
AV_HWDEVICE_TYPE_DRM, AV_HWDEVICE_TYPE_DRM,
#elif defined(__APPLE__) #elif defined(__APPLE__)
AV_HWDEVICE_TYPE_VIDEOTOOLBOX, AV_HWDEVICE_TYPE_VIDEOTOOLBOX,
#elif defined(ANDROID) #elif defined(__ANDROID__)
AV_HWDEVICE_TYPE_MEDIACODEC, AV_HWDEVICE_TYPE_MEDIACODEC,
#elif defined(__unix__) #elif defined(__unix__)
AV_HWDEVICE_TYPE_CUDA, AV_HWDEVICE_TYPE_CUDA,

View File

@ -45,7 +45,7 @@
#include "video_core/vulkan_common/vulkan_wrapper.h" #include "video_core/vulkan_common/vulkan_wrapper.h"
#include "video_core/gpu_logging/gpu_logging.h" #include "video_core/gpu_logging/gpu_logging.h"
#ifdef ANDROID #ifdef __ANDROID__
#include "../../android/app/src/main/jni/android_settings.h" #include "../../android/app/src/main/jni/android_settings.h"
#endif #endif
@ -328,7 +328,7 @@ Shader::RuntimeInfo MakeRuntimeInfo(std::span<const Shader::IR::Program> program
size_t GetTotalPipelineWorkers() { size_t GetTotalPipelineWorkers() {
const size_t max_core_threads = const size_t max_core_threads =
std::max<size_t>(static_cast<size_t>(std::thread::hardware_concurrency()), 2ULL) - 1ULL; std::max<size_t>(static_cast<size_t>(std::thread::hardware_concurrency()), 2ULL) - 1ULL;
#ifdef ANDROID #ifdef __ANDROID__
const int configured = AndroidSettings::values.pipeline_worker_count.GetValue(); const int configured = AndroidSettings::values.pipeline_worker_count.GetValue();
const int clamped = std::clamp(configured, 4, 8); const int clamped = std::clamp(configured, 4, 8);
const size_t desired = static_cast<size_t>(clamped); const size_t desired = static_cast<size_t>(clamped);

View File

@ -309,7 +309,7 @@ void PresentManager::CopyToSwapchain(Frame* frame) {
try { try {
// Recreate surface and swapchain if needed. // Recreate surface and swapchain if needed.
if (requires_recreation) { if (requires_recreation) {
#ifdef ANDROID #ifdef __ANDROID__
surface = CreateSurface(instance, render_window.GetWindowInfo()); surface = CreateSurface(instance, render_window.GetWindowInfo());
#endif #endif
RecreateSwapchain(frame); RecreateSwapchain(frame);

View File

@ -928,13 +928,13 @@ void RasterizerVulkan::LoadDiskResources(u64 title_id, std::stop_token stop_load
} }
void RasterizerVulkan::FlushWork() { void RasterizerVulkan::FlushWork() {
#ifdef ANDROID #ifdef __ANDROID__
static constexpr u32 DRAWS_TO_DISPATCH = 512; static constexpr u32 DRAWS_TO_DISPATCH = 512;
static constexpr u32 CHECK_MASK = 3; static constexpr u32 CHECK_MASK = 3;
#else #else
static constexpr u32 DRAWS_TO_DISPATCH = 4096; static constexpr u32 DRAWS_TO_DISPATCH = 4096;
static constexpr u32 CHECK_MASK = 7; static constexpr u32 CHECK_MASK = 7;
#endif // ANDROID #endif // __ANDROID__
static_assert(DRAWS_TO_DISPATCH % (CHECK_MASK + 1) == 0); static_assert(DRAWS_TO_DISPATCH % (CHECK_MASK + 1) == 0);
if ((++draw_counter & CHECK_MASK) != CHECK_MASK) { if ((++draw_counter & CHECK_MASK) != CHECK_MASK) {

View File

@ -288,7 +288,7 @@ void Swapchain::CreateSwapchain(const VkSurfaceCapabilitiesKHR& capabilities) {
.imageSharingMode = VK_SHARING_MODE_EXCLUSIVE, .imageSharingMode = VK_SHARING_MODE_EXCLUSIVE,
.queueFamilyIndexCount = 0, .queueFamilyIndexCount = 0,
.pQueueFamilyIndices = nullptr, .pQueueFamilyIndices = nullptr,
#ifdef ANDROID #ifdef __ANDROID__
// On Android, do not allow surface rotation to deviate from the frontend. // On Android, do not allow surface rotation to deviate from the frontend.
.preTransform = VK_SURFACE_TRANSFORM_IDENTITY_BIT_KHR, .preTransform = VK_SURFACE_TRANSFORM_IDENTITY_BIT_KHR,
#else #else
@ -313,7 +313,7 @@ void Swapchain::CreateSwapchain(const VkSurfaceCapabilitiesKHR& capabilities) {
swapchain_ci.imageFormat, // Base format MUST be first swapchain_ci.imageFormat, // Base format MUST be first
VK_FORMAT_B8G8R8A8_UNORM, VK_FORMAT_B8G8R8A8_UNORM,
VK_FORMAT_B8G8R8A8_SRGB, VK_FORMAT_B8G8R8A8_SRGB,
#ifdef ANDROID #ifdef __ANDROID__
VK_FORMAT_R8G8B8A8_UNORM, // Android may use RGBA VK_FORMAT_R8G8B8A8_UNORM, // Android may use RGBA
VK_FORMAT_R8G8B8A8_SRGB, VK_FORMAT_R8G8B8A8_SRGB,
#endif #endif
@ -338,7 +338,7 @@ void Swapchain::CreateSwapchain(const VkSurfaceCapabilitiesKHR& capabilities) {
images = swapchain.GetImages(); images = swapchain.GetImages();
image_count = static_cast<u32>(images.size()); image_count = static_cast<u32>(images.size());
#ifdef ANDROID #ifdef __ANDROID__
// Android is already ordered the same as Switch. // Android is already ordered the same as Switch.
image_view_format = VK_FORMAT_R8G8B8A8_UNORM; image_view_format = VK_FORMAT_R8G8B8A8_UNORM;
#else #else

View File

@ -1,10 +1,10 @@
// SPDX-FileCopyrightText: Copyright 2025 Eden Emulator Project // SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project
// SPDX-License-Identifier: GPL-3.0-or-later // SPDX-License-Identifier: GPL-3.0-or-later
// SPDX-FileCopyrightText: Copyright 2022 yuzu Emulator Project // SPDX-FileCopyrightText: Copyright 2022 yuzu Emulator Project
// SPDX-License-Identifier: GPL-2.0-or-later // SPDX-License-Identifier: GPL-2.0-or-later
#if defined(ANDROID) && defined(ARCHITECTURE_arm64) #if defined(__ANDROID__) && defined(ARCHITECTURE_arm64)
#include <adrenotools/driver.h> #include <adrenotools/driver.h>
#endif #endif
@ -20,7 +20,7 @@ namespace Vulkan {
using namespace Common::Literals; using namespace Common::Literals;
TurboMode::TurboMode(const vk::Instance& instance, const vk::InstanceDispatch& dld) TurboMode::TurboMode(const vk::Instance& instance, const vk::InstanceDispatch& dld)
#ifndef ANDROID #ifndef __ANDROID__
: m_device{CreateDevice(instance, dld, VK_NULL_HANDLE)}, m_allocator{m_device} : m_device{CreateDevice(instance, dld, VK_NULL_HANDLE)}, m_allocator{m_device}
#endif #endif
{ {
@ -40,7 +40,7 @@ void TurboMode::QueueSubmitted() {
} }
void TurboMode::Run(std::stop_token stop_token) { void TurboMode::Run(std::stop_token stop_token) {
#ifndef ANDROID #ifndef __ANDROID__
auto& dld = m_device.GetLogical(); auto& dld = m_device.GetLogical();
// Allocate buffer. 2MiB should be sufficient. // Allocate buffer. 2MiB should be sufficient.
@ -154,7 +154,7 @@ void TurboMode::Run(std::stop_token stop_token) {
#endif #endif
while (!stop_token.stop_requested()) { while (!stop_token.stop_requested()) {
#ifdef ANDROID #ifdef __ANDROID__
#ifdef ARCHITECTURE_arm64 #ifdef ARCHITECTURE_arm64
adrenotools_set_turbo(true); adrenotools_set_turbo(true);
#endif #endif
@ -232,7 +232,7 @@ void TurboMode::Run(std::stop_token stop_token) {
std::chrono::milliseconds{100}; std::chrono::milliseconds{100};
}); });
} }
#if defined(ANDROID) && defined(ARCHITECTURE_arm64) #if defined(__ANDROID__) && defined(ARCHITECTURE_arm64)
adrenotools_set_turbo(false); adrenotools_set_turbo(false);
#endif #endif
} }

View File

@ -1,3 +1,6 @@
// SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project
// SPDX-License-Identifier: GPL-3.0-or-later
// SPDX-FileCopyrightText: Copyright 2022 yuzu Emulator Project // SPDX-FileCopyrightText: Copyright 2022 yuzu Emulator Project
// SPDX-License-Identifier: GPL-2.0-or-later // SPDX-License-Identifier: GPL-2.0-or-later
@ -23,7 +26,7 @@ public:
private: private:
void Run(std::stop_token stop_token); void Run(std::stop_token stop_token);
#ifndef ANDROID #ifndef __ANDROID__
Device m_device; Device m_device;
MemoryAllocator m_allocator; MemoryAllocator m_allocator;
#endif #endif

View File

@ -1,3 +1,6 @@
// SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project
// SPDX-License-Identifier: GPL-3.0-or-later
// SPDX-FileCopyrightText: 2013 Jorge Jimenez (jorge@iryoku.com) // SPDX-FileCopyrightText: 2013 Jorge Jimenez (jorge@iryoku.com)
// SPDX-FileCopyrightText: 2013 Jose I. Echevarria (joseignacioechevarria@gmail.com) // SPDX-FileCopyrightText: 2013 Jose I. Echevarria (joseignacioechevarria@gmail.com)
// SPDX-FileCopyrightText: 2013 Belen Masia (bmasia@unizar.es) // SPDX-FileCopyrightText: 2013 Belen Masia (bmasia@unizar.es)
@ -5,8 +8,7 @@
// SPDX-FileCopyrightText: 2013 Diego Gutierrez (diegog@unizar.es) // SPDX-FileCopyrightText: 2013 Diego Gutierrez (diegog@unizar.es)
// SPDX-License-Identifier: MIT // SPDX-License-Identifier: MIT
#ifndef AREATEX_H #pragma once
#define AREATEX_H
#define AREATEX_WIDTH 160 #define AREATEX_WIDTH 160
#define AREATEX_HEIGHT 560 #define AREATEX_HEIGHT 560
@ -11219,5 +11221,3 @@ static const unsigned char areaTexBytes[] = {
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}; 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
#endif

View File

@ -1,3 +1,6 @@
// SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project
// SPDX-License-Identifier: GPL-3.0-or-later
// SPDX-FileCopyrightText: 2013 Jorge Jimenez (jorge@iryoku.com) // SPDX-FileCopyrightText: 2013 Jorge Jimenez (jorge@iryoku.com)
// SPDX-FileCopyrightText: 2013 Jose I. Echevarria (joseignacioechevarria@gmail.com) // SPDX-FileCopyrightText: 2013 Jose I. Echevarria (joseignacioechevarria@gmail.com)
// SPDX-FileCopyrightText: 2013 Belen Masia (bmasia@unizar.es) // SPDX-FileCopyrightText: 2013 Belen Masia (bmasia@unizar.es)
@ -5,8 +8,7 @@
// SPDX-FileCopyrightText: 2013 Diego Gutierrez (diegog@unizar.es) // SPDX-FileCopyrightText: 2013 Diego Gutierrez (diegog@unizar.es)
// SPDX-License-Identifier: MIT // SPDX-License-Identifier: MIT
#ifndef SEARCHTEX_H #pragma once
#define SEARCHTEX_H
#define SEARCHTEX_WIDTH 64 #define SEARCHTEX_WIDTH 64
#define SEARCHTEX_HEIGHT 16 #define SEARCHTEX_HEIGHT 16
@ -84,5 +86,3 @@ static const unsigned char searchTexBytes[] = {
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
}; };
#endif

View File

@ -27,7 +27,7 @@ VkBool32 DebugUtilCallback(VkDebugUtilsMessageSeverityFlagBitsEXT severity,
[[maybe_unused]] void* user_data) { [[maybe_unused]] void* user_data) {
// Skip logging known false-positive validation errors // Skip logging known false-positive validation errors
switch (static_cast<u32>(data->messageIdNumber)) { switch (static_cast<u32>(data->messageIdNumber)) {
#ifdef ANDROID #ifdef __ANDROID__
case 0xbf9cf353u: // VUID-vkCmdBindVertexBuffers2-pBuffers-04111 case 0xbf9cf353u: // VUID-vkCmdBindVertexBuffers2-pBuffers-04111
// The below are due to incorrect reporting of extendedDynamicState // The below are due to incorrect reporting of extendedDynamicState
case 0x1093bebbu: // VUID-vkCmdSetCullMode-None-03384 case 0x1093bebbu: // VUID-vkCmdSetCullMode-None-03384

View File

@ -26,7 +26,7 @@
#include "video_core/vulkan_common/vulkan_wrapper.h" #include "video_core/vulkan_common/vulkan_wrapper.h"
#include "video_core/gpu_logging/gpu_logging.h" #include "video_core/gpu_logging/gpu_logging.h"
#if defined(ANDROID) && defined(ARCHITECTURE_arm64) #if defined(__ANDROID__) && defined(ARCHITECTURE_arm64)
#include <adrenotools/bcenabler.h> #include <adrenotools/bcenabler.h>
#include <android/api-level.h> #include <android/api-level.h>
#endif #endif
@ -294,7 +294,7 @@ ankerl::unordered_dense::map<VkFormat, VkFormatProperties> GetFormatProperties(v
return format_properties; return format_properties;
} }
#if defined(ANDROID) && defined(ARCHITECTURE_arm64) #if defined(__ANDROID__) && defined(ARCHITECTURE_arm64)
void OverrideBcnFormats(ankerl::unordered_dense::map<VkFormat, VkFormatProperties>& format_properties) { void OverrideBcnFormats(ankerl::unordered_dense::map<VkFormat, VkFormatProperties>& format_properties) {
// These properties are extracted from Adreno driver 512.687.0 // These properties are extracted from Adreno driver 512.687.0
constexpr VkFormatFeatureFlags tiling_features{VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT | constexpr VkFormatFeatureFlags tiling_features{VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT |
@ -504,7 +504,7 @@ Device::Device(VkInstance instance_, vk::PhysicalDevice physical_, VkSurfaceKHR
features.shader_atomic_int64.shaderSharedInt64Atomics = false; features.shader_atomic_int64.shaderSharedInt64Atomics = false;
features.features.shaderInt64 = false; features.features.shaderInt64 = false;
#if defined(ANDROID) && defined(ARCHITECTURE_arm64) #if defined(__ANDROID__) && defined(ARCHITECTURE_arm64)
// BCn patching only safe on Android 9+ (API 28+). Older versions crash on driver load. // BCn patching only safe on Android 9+ (API 28+). Older versions crash on driver load.
const auto major = (properties.properties.driverVersion >> 24) << 2; const auto major = (properties.properties.driverVersion >> 24) << 2;
const auto minor = (properties.properties.driverVersion >> 12) & 0xFFFU; const auto minor = (properties.properties.driverVersion >> 12) & 0xFFFU;

View File

@ -16,7 +16,7 @@ namespace Vulkan {
std::shared_ptr<Common::DynamicLibrary> OpenLibrary( std::shared_ptr<Common::DynamicLibrary> OpenLibrary(
[[maybe_unused]] Core::Frontend::GraphicsContext* context) { [[maybe_unused]] Core::Frontend::GraphicsContext* context) {
LOG_DEBUG(Render_Vulkan, "Looking for a Vulkan library"); LOG_DEBUG(Render_Vulkan, "Looking for a Vulkan library");
#if defined(ANDROID) && defined(ARCHITECTURE_arm64) #if defined(__ANDROID__) && defined(ARCHITECTURE_arm64)
// Android manages its Vulkan driver from the frontend. // Android manages its Vulkan driver from the frontend.
return context->GetDriverLibrary(); return context->GetDriverLibrary();
#else #else

View File

@ -453,7 +453,7 @@ public:
return handle != Type{}; return handle != Type{};
} }
#ifndef ANDROID #ifndef __ANDROID__
/** /**
* Releases ownership of the managed handle. * Releases ownership of the managed handle.
* The caller is responsible for managing the lifetime of the returned handle. * The caller is responsible for managing the lifetime of the returned handle.
@ -535,7 +535,7 @@ public:
return handle != Type{}; return handle != Type{};
} }
#ifndef ANDROID #ifndef __ANDROID__
/** /**
* Releases ownership of the managed handle. * Releases ownership of the managed handle.
* The caller is responsible for managing the lifetime of the returned handle. * The caller is responsible for managing the lifetime of the returned handle.

View File

@ -1,8 +1,7 @@
// SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project // SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project
// SPDX-License-Identifier: GPL-3.0-or-later // SPDX-License-Identifier: GPL-3.0-or-later
#ifndef DATA_DIALOG_H #pragma once
#define DATA_DIALOG_H
#include <QDialog> #include <QDialog>
#include "frontend_common/data_manager.h" #include "frontend_common/data_manager.h"
@ -47,5 +46,3 @@ private:
std::optional<std::string> selectProfile(); std::optional<std::string> selectProfile();
}; };
#endif // DATA_DIALOG_H

View File

@ -1,8 +1,7 @@
// SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project // SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project
// SPDX-License-Identifier: GPL-3.0-or-later // SPDX-License-Identifier: GPL-3.0-or-later
#ifndef MIGRATION_DIALOG_H #pragma once
#define MIGRATION_DIALOG_H
#include <QHBoxLayout> #include <QHBoxLayout>
#include <QMessageBox> #include <QMessageBox>
@ -29,5 +28,3 @@ private:
QAbstractButton* m_clickedButton; QAbstractButton* m_clickedButton;
}; };
#endif // MIGRATION_DIALOG_H

View File

@ -1,8 +1,7 @@
// SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project // SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project
// SPDX-License-Identifier: GPL-3.0-or-later // SPDX-License-Identifier: GPL-3.0-or-later
#ifndef MIGRATION_WORKER_H #pragma once
#define MIGRATION_WORKER_H
#include <QObject> #include <QObject>
#include "common/fs/path_util.h" #include "common/fs/path_util.h"
@ -73,5 +72,3 @@ private:
MigrationStrategy strategy; MigrationStrategy strategy;
QString success_text = tr("Data was migrated successfully."); QString success_text = tr("Data was migrated successfully.");
}; };
#endif // MIGRATION_WORKER_H

View File

@ -1,8 +1,7 @@
// SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project // SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project
// SPDX-License-Identifier: GPL-3.0-or-later // SPDX-License-Identifier: GPL-3.0-or-later
#ifndef RYUJINX_DIALOG_H #pragma once
#define RYUJINX_DIALOG_H
#include <filesystem> #include <filesystem>
#include <QDialog> #include <QDialog>
@ -28,5 +27,3 @@ private:
std::filesystem::path m_eden; std::filesystem::path m_eden;
std::filesystem::path m_ryu; std::filesystem::path m_ryu;
}; };
#endif // RYUJINX_DIALOG_H

55
tools/cpp-lint.sh Executable file
View File

@ -0,0 +1,55 @@
#!/bin/sh -ex
# SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project
# SPDX-License-Identifier: GPL-3.0-or-later
# tools/../
ROOTDIR=$(CDPATH='' cd -- "$(dirname -- "$0")/../" && pwd)
BUILD_DIR="$ROOTDIR"/build
SRC_DIR="$ROOTDIR"/src
die() {
echo "-- $*" >&2
exit 1
}
usage() {
cat <<EOF
Usage: $0 [command]
Dumb script that serves as a ad-hoc cpp-linter
Commands:
once Check for #pragma once prescence in header files
osdef Finds OS defines that are not recommended to use.
inchk Check includes being valid/toolchain not being stupid
EOF
}
while :; do
case "$1" in
once)
find "$SRC_DIR" -type f -name "*.h" -exec grep -L "#pragma once" {} +
break
;;
osdef)
# not recommended macros
PATTERN="ANDROID\|_WIN64\|__linux\|__unix\|APPLE\|__APPLE"
strings=("ANDROID" "_WIN64" "__linux" "__unix" "APPLE" "__APPLE" "linux" "unix")
for item in "${strings[@]}"; do
PATTERN="$PATTERN\|ifdef $item\|($item)"
done
# if statements for macros that shouldn't be if
strings=("_WIN32" "_AIX" "__managarm__" "__unix__" "__linux__" "__FreeBSD__" "__NetBSD__" \
"__OpenBSD__" "__DragonFly__" "__redox__" "__HAIKU__" "__OHOS__" "__FIREOS__")
for item in "${strings[@]}"; do
PATTERN="$PATTERN\|if $item"
done
find "$SRC_DIR" -type f -name "*.h" -exec grep -nw "$PATTERN" {} + || echo
break
;;
*) usage ;;
esac
shift
done