Conditionally compile different drivers
This commit is contained in:
@@ -41,9 +41,15 @@ endif ()
|
||||
|
||||
if (WIN32)
|
||||
add_compile_definitions(
|
||||
_CRT_SECURE_NO_WARNINGS
|
||||
NOVA_WINDOWS
|
||||
NOMINMAX
|
||||
WIN32_LEAN_AND_MEAN
|
||||
_CRT_SECURE_NO_WARNINGS
|
||||
_CRT_NONSTDC_NO_WARNINGS
|
||||
)
|
||||
else ()
|
||||
add_compile_definitions(
|
||||
NOVA_LINUX
|
||||
)
|
||||
endif ()
|
||||
|
||||
|
||||
@@ -1,9 +1,55 @@
|
||||
# Copyright (c) 2025, Jayden Grubb <contact@jaydengrubb.com>
|
||||
# SPDX-License-Identifier: BSD-3-Clause
|
||||
|
||||
find_package(Vulkan REQUIRED)
|
||||
include(FetchContent)
|
||||
|
||||
set(NOVA_VULKAN ON CACHE BOOL "Enable Vulkan support")
|
||||
set(NOVA_WAYLAND ON CACHE BOOL "Enable Wayland support")
|
||||
set(NOVA_X11 ON CACHE BOOL "Enable X11 support")
|
||||
|
||||
set(ENGINE_SRC
|
||||
core/debug.cpp
|
||||
platform/system.cpp
|
||||
render/renderer.cpp
|
||||
render/render_device.cpp
|
||||
)
|
||||
|
||||
if (WIN32)
|
||||
set(ENGINE_SRC
|
||||
${ENGINE_SRC}
|
||||
drivers/windows/system_driver.cpp
|
||||
)
|
||||
set(NOVA_WAYLAND OFF)
|
||||
set(NOVA_X11 OFF)
|
||||
else ()
|
||||
set(ENGINE_SRC
|
||||
${ENGINE_SRC}
|
||||
drivers/linux/system_driver.cpp
|
||||
)
|
||||
endif ()
|
||||
|
||||
if (NOVA_VULKAN)
|
||||
find_package(Vulkan REQUIRED)
|
||||
set(ENGINE_SRC
|
||||
${ENGINE_SRC}
|
||||
drivers/vulkan/render_driver.cpp
|
||||
)
|
||||
endif ()
|
||||
if (NOVA_WAYLAND)
|
||||
set(ENGINE_SRC
|
||||
${ENGINE_SRC}
|
||||
drivers/linux/wayland/system_driver.cpp
|
||||
)
|
||||
endif ()
|
||||
if (NOVA_X11)
|
||||
set(ENGINE_SRC
|
||||
${ENGINE_SRC}
|
||||
drivers/linux/x11/system_driver.cpp
|
||||
)
|
||||
endif ()
|
||||
|
||||
list(TRANSFORM ENGINE_SRC PREPEND ${CMAKE_CURRENT_SOURCE_DIR}/src/)
|
||||
|
||||
FetchContent_Declare(
|
||||
spdlog
|
||||
GIT_REPOSITORY https://github.com/gabime/spdlog.git
|
||||
@@ -20,23 +66,9 @@ FetchContent_Declare(
|
||||
)
|
||||
FetchContent_MakeAvailable(SDL3)
|
||||
|
||||
set(ENGINE_SRC
|
||||
core/debug.cpp
|
||||
drivers/vulkan/render_driver.cpp
|
||||
drivers/windows/system_driver.cpp
|
||||
drivers/linux/system_driver.cpp
|
||||
drivers/linux/wayland/system_driver.cpp
|
||||
drivers/linux/x11/system_driver.cpp
|
||||
platform/system.cpp
|
||||
render/renderer.cpp
|
||||
render/render_device.cpp
|
||||
)
|
||||
|
||||
list(TRANSFORM ENGINE_SRC PREPEND ${CMAKE_CURRENT_SOURCE_DIR}/src/)
|
||||
|
||||
set(ENGINE_INCLUDES_PRIVATE
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/src
|
||||
${Vulkan_INCLUDE_DIRS}
|
||||
$<$<BOOL:${NOVA_VULKAN}>:${Vulkan_INCLUDE_DIRS}>
|
||||
${SDL3_INCLUDE_DIRS}
|
||||
)
|
||||
set(ENGINE_INCLUDES_PUBLIC
|
||||
@@ -44,12 +76,17 @@ set(ENGINE_INCLUDES_PUBLIC
|
||||
${spdlog_INCLUDE_DIRS}
|
||||
)
|
||||
set(ENGINE_LIBS_PRIVATE
|
||||
Vulkan::Vulkan
|
||||
$<$<BOOL:${NOVA_VULKAN}>:Vulkan::Vulkan>
|
||||
SDL3::SDL3
|
||||
)
|
||||
set(ENGINE_LIBS_PUBLIC
|
||||
spdlog::spdlog
|
||||
)
|
||||
set(ENGINE_DEFS
|
||||
$<$<BOOL:${NOVA_VULKAN}>:NOVA_VULKAN>
|
||||
$<$<BOOL:${NOVA_WAYLAND}>:NOVA_WAYLAND>
|
||||
$<$<BOOL:${NOVA_X11}>:NOVA_X11>
|
||||
)
|
||||
|
||||
if (NOVA_ENGINE_SHARED)
|
||||
add_library(nova SHARED ${ENGINE_SRC})
|
||||
@@ -63,6 +100,7 @@ if (NOVA_ENGINE_SHARED)
|
||||
)
|
||||
target_compile_definitions(nova PRIVATE
|
||||
NOVA_DLL_EXPORT
|
||||
${ENGINE_DEFS}
|
||||
)
|
||||
endif ()
|
||||
if (NOVA_ENGINE_STATIC)
|
||||
@@ -75,4 +113,7 @@ if (NOVA_ENGINE_STATIC)
|
||||
PUBLIC ${ENGINE_LIBS_PUBLIC}
|
||||
PRIVATE ${ENGINE_LIBS_PRIVATE}
|
||||
)
|
||||
target_compile_definitions(nova_static PRIVATE
|
||||
${ENGINE_DEFS}
|
||||
)
|
||||
endif ()
|
||||
|
||||
@@ -7,7 +7,7 @@
|
||||
#pragma once
|
||||
|
||||
#ifndef NOVA_API
|
||||
#ifdef WIN32
|
||||
#ifdef NOVA_WINDOWS
|
||||
#ifdef NOVA_DLL_EXPORT
|
||||
#define NOVA_API __declspec(dllexport)
|
||||
#elif NOVA_DLL_IMPORT
|
||||
@@ -15,7 +15,7 @@
|
||||
#else
|
||||
#define NOVA_API
|
||||
#endif
|
||||
#else
|
||||
#elif NOVA_LINUX
|
||||
#ifdef NOVA_DLL_EXPORT
|
||||
#define NOVA_API __attribute__((visibility("default")))
|
||||
#else
|
||||
|
||||
@@ -4,10 +4,17 @@
|
||||
* SPDX-License-Identifier: BSD-3-Clause
|
||||
*/
|
||||
|
||||
#include "drivers/linux/system_driver.h"
|
||||
#ifdef NOVA_WAYLAND
|
||||
#include "drivers/linux/wayland/system_driver.h"
|
||||
#endif
|
||||
#ifdef NOVA_X11
|
||||
#include "drivers/linux/x11/system_driver.h"
|
||||
#endif
|
||||
|
||||
#include <nova/core/debug.h>
|
||||
|
||||
#include "drivers/linux/system_driver.h"
|
||||
|
||||
using namespace Nova;
|
||||
|
||||
LinuxSystemDriver::LinuxSystemDriver() {
|
||||
@@ -17,3 +24,21 @@ LinuxSystemDriver::LinuxSystemDriver() {
|
||||
LinuxSystemDriver::~LinuxSystemDriver() {
|
||||
NOVA_AUTO_TRACE();
|
||||
}
|
||||
|
||||
std::unique_ptr<SystemDriver> LinuxSystemDriver::get_default_driver() {
|
||||
NOVA_AUTO_TRACE();
|
||||
|
||||
#ifdef NOVA_WAYLAND
|
||||
if (std::getenv("WAYLAND_DISPLAY")) {
|
||||
return std::make_unique<WaylandSystemDriver>();
|
||||
}
|
||||
#endif
|
||||
#ifdef NOVA_X11
|
||||
if (std::getenv("DISPLAY")) {
|
||||
return std::make_unique<X11SystemDriver>();
|
||||
}
|
||||
#endif
|
||||
|
||||
NOVA_WARN("Unsupported display server");
|
||||
return std::make_unique<LinuxSystemDriver>();
|
||||
}
|
||||
|
||||
@@ -8,10 +8,14 @@
|
||||
|
||||
#include <nova/platform/system_driver.h>
|
||||
|
||||
#include <memory>
|
||||
|
||||
namespace Nova {
|
||||
class LinuxSystemDriver : public SystemDriver {
|
||||
public:
|
||||
LinuxSystemDriver();
|
||||
~LinuxSystemDriver() override;
|
||||
|
||||
static std::unique_ptr<SystemDriver> get_default_driver();
|
||||
};
|
||||
} // namespace Nova
|
||||
|
||||
@@ -4,12 +4,17 @@
|
||||
* SPDX-License-Identifier: BSD-3-Clause
|
||||
*/
|
||||
|
||||
#ifdef NOVA_WINDOWS
|
||||
#include "drivers/windows/system_driver.h"
|
||||
#endif
|
||||
#ifdef NOVA_LINUX
|
||||
#include "drivers/linux/system_driver.h"
|
||||
#endif
|
||||
|
||||
#include <nova/core/debug.h>
|
||||
#include <nova/platform/system.h>
|
||||
|
||||
#include "drivers/linux/wayland/system_driver.h"
|
||||
#include "drivers/linux/x11/system_driver.h"
|
||||
#include "drivers/windows/system_driver.h"
|
||||
#include <memory>
|
||||
|
||||
using namespace Nova;
|
||||
|
||||
@@ -19,17 +24,12 @@ void System::init() {
|
||||
NOVA_AUTO_TRACE();
|
||||
NOVA_ASSERT(!s_driver);
|
||||
|
||||
#ifdef WIN32
|
||||
#ifdef NOVA_WINDOWS
|
||||
s_driver = std::make_unique<WindowsSystemDriver>();
|
||||
#elif NOVA_LINUX
|
||||
s_driver = LinuxSystemDriver::get_default_driver();
|
||||
#else
|
||||
if (std::getenv("WAYLAND_DISPLAY")) {
|
||||
s_driver = std::make_unique<WaylandSystemDriver>();
|
||||
} else if (std::getenv("DISPLAY")) {
|
||||
s_driver = std::make_unique<X11SystemDriver>();
|
||||
} else {
|
||||
NOVA_ERROR("Unsupported windowing system");
|
||||
s_driver = std::make_unique<LinuxSystemDriver>();
|
||||
}
|
||||
throw std::runtime_error("Unsupported platform");
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
@@ -4,13 +4,15 @@
|
||||
* SPDX-License-Identifier: BSD-3-Clause
|
||||
*/
|
||||
|
||||
#ifdef NOVA_VULKAN
|
||||
#include "drivers/vulkan/render_driver.h"
|
||||
#endif
|
||||
|
||||
#include <nova/core/debug.h>
|
||||
#include <nova/render/renderer.h>
|
||||
|
||||
#include <memory>
|
||||
|
||||
#include "drivers/vulkan/render_driver.h"
|
||||
|
||||
using namespace Nova;
|
||||
|
||||
static std::unique_ptr<RenderDriver> s_driver;
|
||||
@@ -18,13 +20,15 @@ static std::unique_ptr<RenderDriver> s_driver;
|
||||
void Renderer::init(const RenderAPI api) {
|
||||
NOVA_AUTO_TRACE();
|
||||
NOVA_ASSERT(!s_driver);
|
||||
|
||||
switch (api) {
|
||||
#ifdef NOVA_VULKAN
|
||||
case RenderAPI::VULKAN:
|
||||
s_driver = std::make_unique<VulkanRenderDriver>();
|
||||
break;
|
||||
#endif
|
||||
default:
|
||||
NOVA_ERROR("Unsupported render API");
|
||||
break;
|
||||
throw std::runtime_error("Unsupported render API");
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user