diff options
Diffstat (limited to 'src/yuzu')
| -rw-r--r-- | src/yuzu/CMakeLists.txt | 4 | ||||
| -rw-r--r-- | src/yuzu/bootmanager.cpp | 17 | ||||
| -rw-r--r-- | src/yuzu/configuration/configure_service.cpp | 6 | ||||
| -rw-r--r-- | src/yuzu/yuzu.rc | 2 | 
4 files changed, 25 insertions, 4 deletions
| diff --git a/src/yuzu/CMakeLists.txt b/src/yuzu/CMakeLists.txt index 8b9404718..75c27e39e 100644 --- a/src/yuzu/CMakeLists.txt +++ b/src/yuzu/CMakeLists.txt @@ -208,6 +208,10 @@ if (MSVC)      copy_yuzu_unicorn_deps(yuzu)  endif() +if (NOT APPLE) +    target_compile_definitions(yuzu PRIVATE HAS_OPENGL) +endif() +  if (ENABLE_VULKAN)      target_include_directories(yuzu PRIVATE ../../externals/Vulkan-Headers/include)      target_compile_definitions(yuzu PRIVATE HAS_VULKAN) diff --git a/src/yuzu/bootmanager.cpp b/src/yuzu/bootmanager.cpp index 1f5e43043..696da2137 100644 --- a/src/yuzu/bootmanager.cpp +++ b/src/yuzu/bootmanager.cpp @@ -8,13 +8,16 @@  #include <QHBoxLayout>  #include <QKeyEvent>  #include <QMessageBox> -#include <QOffscreenSurface> -#include <QOpenGLContext>  #include <QPainter>  #include <QScreen>  #include <QStringList>  #include <QWindow> +#ifdef HAS_OPENGL +#include <QOffscreenSurface> +#include <QOpenGLContext> +#endif +  #if !defined(WIN32) && HAS_VULKAN  #include <qpa/qplatformnativeinterface.h>  #endif @@ -98,6 +101,7 @@ void EmuThread::run() {  #endif  } +#ifdef HAS_OPENGL  class OpenGLSharedContext : public Core::Frontend::GraphicsContext {  public:      /// Create the original context that should be shared from @@ -183,6 +187,7 @@ private:      std::unique_ptr<QOffscreenSurface> offscreen_surface{};      QSurface* surface;  }; +#endif  class DummyContext : public Core::Frontend::GraphicsContext {}; @@ -473,6 +478,7 @@ void GRenderWindow::resizeEvent(QResizeEvent* event) {  }  std::unique_ptr<Core::Frontend::GraphicsContext> GRenderWindow::CreateSharedContext() const { +#ifdef HAS_OPENGL      if (Settings::values.renderer_backend == Settings::RendererBackend::OpenGL) {          auto c = static_cast<OpenGLSharedContext*>(main_context.get());          // Bind the shared contexts to the main surface in case the backend wants to take over @@ -480,6 +486,7 @@ std::unique_ptr<Core::Frontend::GraphicsContext> GRenderWindow::CreateSharedCont          return std::make_unique<OpenGLSharedContext>(c->GetShareContext(),                                                       child_widget->windowHandle());      } +#endif      return std::make_unique<DummyContext>();  } @@ -560,6 +567,7 @@ void GRenderWindow::OnMinimalClientAreaChangeRequest(std::pair<u32, u32> minimal  }  bool GRenderWindow::InitializeOpenGL() { +#ifdef HAS_OPENGL      // TODO: One of these flags might be interesting: WA_OpaquePaintEvent, WA_NoBackground,      // WA_DontShowOnScreen, WA_DeleteOnClose      auto child = new OpenGLRenderWidget(this); @@ -571,6 +579,11 @@ bool GRenderWindow::InitializeOpenGL() {          std::make_unique<OpenGLSharedContext>(context->GetShareContext(), child->windowHandle()));      return true; +#else +    QMessageBox::warning(this, tr("OpenGL not available!"), +                         tr("yuzu has not been compiled with OpenGL support.")); +    return false; +#endif  }  bool GRenderWindow::InitializeVulkan() { diff --git a/src/yuzu/configuration/configure_service.cpp b/src/yuzu/configuration/configure_service.cpp index 06566e981..0de7a4f0b 100644 --- a/src/yuzu/configuration/configure_service.cpp +++ b/src/yuzu/configuration/configure_service.cpp @@ -68,6 +68,7 @@ void ConfigureService::SetConfiguration() {  }  std::pair<QString, QString> ConfigureService::BCATDownloadEvents() { +#ifdef YUZU_ENABLE_BOXCAT      std::optional<std::string> global;      std::map<std::string, Service::BCAT::EventStatus> map;      const auto res = Service::BCAT::Boxcat::GetStatus(global, map); @@ -105,7 +106,10 @@ std::pair<QString, QString> ConfigureService::BCATDownloadEvents() {                     .arg(QString::fromStdString(key))                     .arg(FormatEventStatusString(value));      } -    return {QStringLiteral("Current Boxcat Events"), std::move(out)}; +    return {tr("Current Boxcat Events"), std::move(out)}; +#else +    return {tr("Current Boxcat Events"), tr("There are currently no events on boxcat.")}; +#endif  }  void ConfigureService::OnBCATImplChanged() { diff --git a/src/yuzu/yuzu.rc b/src/yuzu/yuzu.rc index 1b253653f..4a3645a71 100644 --- a/src/yuzu/yuzu.rc +++ b/src/yuzu/yuzu.rc @@ -16,4 +16,4 @@ IDI_ICON1               ICON                    "../../dist/yuzu.ico"  // RT_MANIFEST  // -1                       RT_MANIFEST             "../../dist/yuzu.manifest" +0                       RT_MANIFEST             "../../dist/yuzu.manifest" | 
