mirror of
https://github.com/hrydgard/ppsspp.git
synced 2024-12-02 18:46:52 +00:00
5d028cb004
This removes the option to use system SDL, which seems like a trap. Also simplifies the macbundle.sh script accordingly. Buildfix Buildfix fix Moar buildfix
51 lines
1.0 KiB
C++
51 lines
1.0 KiB
C++
#include "ppsspp_config.h"
|
|
#if PPSSPP_PLATFORM(MAC)
|
|
#include "SDL2/SDL.h"
|
|
#include "SDL2/SDL_syswm.h"
|
|
#else
|
|
#include "SDL.h"
|
|
#include "SDL_syswm.h"
|
|
#endif
|
|
|
|
#include "Common/GraphicsContext.h"
|
|
#include "Common/GPU/Vulkan/VulkanContext.h"
|
|
#include "Common/GPU/Vulkan/VulkanDebug.h"
|
|
|
|
#include "Common/GPU/thin3d.h"
|
|
|
|
class VulkanRenderManager;
|
|
|
|
class SDLVulkanGraphicsContext : public GraphicsContext {
|
|
public:
|
|
SDLVulkanGraphicsContext() {}
|
|
~SDLVulkanGraphicsContext() {
|
|
delete draw_;
|
|
}
|
|
|
|
bool Init(SDL_Window *&window, int x, int y, int w, int h, int mode, std::string *error_message);
|
|
|
|
void Shutdown() override;
|
|
|
|
void SwapBuffers() override {
|
|
// We don't do it this way.
|
|
}
|
|
|
|
void Resize() override;
|
|
|
|
void Poll() override;
|
|
|
|
void SwapInterval(int interval) override {
|
|
}
|
|
void *GetAPIContext() override {
|
|
return vulkan_;
|
|
}
|
|
|
|
Draw::DrawContext *GetDrawContext() override {
|
|
return draw_;
|
|
}
|
|
private:
|
|
Draw::DrawContext *draw_ = nullptr;
|
|
VulkanContext *vulkan_ = nullptr;
|
|
VulkanRenderManager *renderManager_ = nullptr;
|
|
};
|