sokol: studio impl wip
This commit is contained in:
parent
9507749ff1
commit
f002911f22
108
CMakeLists.txt
108
CMakeLists.txt
|
@ -229,38 +229,32 @@ if(NOT EMSCRIPTEN)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
################################
|
################################
|
||||||
# Sokol renderer example
|
# Sokol
|
||||||
################################
|
################################
|
||||||
|
|
||||||
set(SOKOL_SRC
|
|
||||||
${EXAMPLE_DIR}/sokol/main.c
|
|
||||||
)
|
|
||||||
|
|
||||||
if(APPLE)
|
if(APPLE)
|
||||||
set(SOKOL_SRC ${SOKOL_SRC} ${EXAMPLE_DIR}/sokol/sokol.m)
|
add_library(sokol src/ext/sokol_impl.m)
|
||||||
else()
|
else()
|
||||||
set(SOKOL_SRC ${SOKOL_SRC} ${EXAMPLE_DIR}/sokol/sokol.c)
|
add_library(sokol src/ext/sokol_impl.c)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(APPLE)
|
if(APPLE)
|
||||||
set_source_files_properties(${SOKOL_SRC} PROPERTIES COMPILE_FLAGS -DSOKOL_METAL)
|
target_compile_definitions(sokol PRIVATE SOKOL_METAL)
|
||||||
elseif(WIN32)
|
elseif(WIN32)
|
||||||
set_source_files_properties(${SOKOL_SRC} PROPERTIES COMPILE_FLAGS "-DSOKOL_D3D11 -DSOKOL_D3D11_SHADER_COMPILER")
|
target_compile_definitions(sokol PRIVATE SOKOL_D3D11 SOKOL_D3D11_SHADER_COMPILER)
|
||||||
elseif(LINUX)
|
elseif(LINUX)
|
||||||
set_source_files_properties(${SOKOL_SRC} PROPERTIES COMPILE_FLAGS -DSOKOL_GLCORE33)
|
target_compile_definitions(sokol PRIVATE SOKOL_GLCORE33)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(WIN32)
|
#set_source_files_properties(${SOKOL_SRC} PROPERTIES COMPILE_FLAGS -DSOKOL_METAL)
|
||||||
add_executable(sokol-renderer WIN32 ${SOKOL_SRC})
|
# set_source_files_properties(${SOKOL_SRC} PROPERTIES COMPILE_FLAGS "-DSOKOL_D3D11 -DSOKOL_D3D11_SHADER_COMPILER")
|
||||||
else()
|
#set_source_files_properties(${SOKOL_SRC} PROPERTIES COMPILE_FLAGS -DSOKOL_GLCORE33)
|
||||||
add_executable(sokol-renderer ${SOKOL_SRC})
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(APPLE)
|
if(APPLE)
|
||||||
set_property (TARGET sokol-renderer APPEND_STRING PROPERTY
|
set_property (TARGET sokol APPEND_STRING PROPERTY
|
||||||
COMPILE_FLAGS "-fobjc-arc")
|
COMPILE_FLAGS "-fobjc-arc")
|
||||||
|
|
||||||
target_link_libraries(sokol-renderer
|
target_link_libraries(sokol
|
||||||
"-framework Cocoa"
|
"-framework Cocoa"
|
||||||
"-framework QuartzCore"
|
"-framework QuartzCore"
|
||||||
"-framework Metal"
|
"-framework Metal"
|
||||||
|
@ -268,22 +262,51 @@ if(APPLE)
|
||||||
"-framework AudioToolbox"
|
"-framework AudioToolbox"
|
||||||
)
|
)
|
||||||
elseif(WIN32)
|
elseif(WIN32)
|
||||||
target_link_libraries(sokol-renderer D3D11)
|
target_link_libraries(sokol D3D11)
|
||||||
|
|
||||||
if(MINGW)
|
if(MINGW)
|
||||||
target_link_libraries(sokol-renderer D3dcompiler_47 mingw32)
|
target_link_libraries(sokol D3dcompiler_47)
|
||||||
endif()
|
endif()
|
||||||
elseif(LINUX)
|
elseif(LINUX)
|
||||||
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -pthread")
|
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -pthread")
|
||||||
target_link_libraries(sokol-renderer X11 GL m dl asound)
|
target_link_libraries(sokol X11 GL m dl asound)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
target_include_directories(sokol PRIVATE 3rd-party/sokol)
|
||||||
|
|
||||||
|
################################
|
||||||
|
# Sokol renderer example
|
||||||
|
################################
|
||||||
|
|
||||||
|
set(SOKOL_SRC
|
||||||
|
${EXAMPLE_DIR}/sokol/main.c
|
||||||
|
)
|
||||||
|
|
||||||
|
if(WIN32)
|
||||||
|
add_executable(sokol-renderer WIN32 ${SOKOL_SRC})
|
||||||
|
else()
|
||||||
|
add_executable(sokol-renderer ${SOKOL_SRC})
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(MINGW)
|
||||||
|
target_link_libraries(sokol-renderer mingw32)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# TODO: remove this and define shaders in the sokol lib
|
||||||
|
if(APPLE)
|
||||||
|
target_compile_definitions(sokol-renderer PRIVATE SOKOL_METAL)
|
||||||
|
elseif(WIN32)
|
||||||
|
target_compile_definitions(sokol-renderer PRIVATE SOKOL_D3D11)
|
||||||
|
elseif(LINUX)
|
||||||
|
target_compile_definitions(sokol-renderer PRIVATE SOKOL_GLCORE33)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
target_include_directories(sokol-renderer PRIVATE include)
|
target_include_directories(sokol-renderer PRIVATE include)
|
||||||
target_include_directories(sokol-renderer PRIVATE 3rd-party/sokol)
|
target_include_directories(sokol-renderer PRIVATE 3rd-party/sokol)
|
||||||
target_include_directories(sokol-renderer PRIVATE src)
|
target_include_directories(sokol-renderer PRIVATE src)
|
||||||
|
|
||||||
add_dependencies(sokol-renderer tic80core)
|
add_dependencies(sokol-renderer tic80core sokol)
|
||||||
target_link_libraries(sokol-renderer tic80core)
|
target_link_libraries(sokol-renderer tic80core sokol)
|
||||||
|
|
||||||
################################
|
################################
|
||||||
# SDL GPU
|
# SDL GPU
|
||||||
|
@ -470,19 +493,32 @@ target_compile_definitions(tic80prolib PRIVATE TIC80_PRO)
|
||||||
# TIC-80 app
|
# TIC-80 app
|
||||||
################################
|
################################
|
||||||
|
|
||||||
set(TIC80_DIR src)
|
set(TIC80_OUTPUTS ${TIC80_OUTPUTS} tic80-sokol tic80pro-sokol)
|
||||||
set(TIC80_SRC
|
|
||||||
${TIC80_DIR}/net.c
|
|
||||||
${TIC80_DIR}/system/sdlgpu.c
|
|
||||||
${TIC80_DIR}/ext/file_dialog.c
|
|
||||||
)
|
|
||||||
|
|
||||||
if(APPLE)
|
if(APPLE)
|
||||||
set(TIC80_SRC ${TIC80_SRC} ${TIC80_DIR}/ext/file_dialog.m)
|
set(TIC80_SRC_COMMON ${TIC80_SRC_COMMON} src/ext/file_dialog.m)
|
||||||
|
else()
|
||||||
|
set(TIC80_SRC_COMMON ${TIC80_SRC_COMMON} src/ext/file_dialog.c)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
foreach(TIC80_OUTPUT ${TIC80_OUTPUTS})
|
foreach(TIC80_OUTPUT ${TIC80_OUTPUTS})
|
||||||
|
|
||||||
|
if(TIC80_OUTPUT MATCHES "-sokol")
|
||||||
|
set(SOKOL_RENDERER TRUE)
|
||||||
|
else()
|
||||||
|
set(SOKOL_RENDERER FALSE)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
message("SOKOL_RENDERER ${SOKOL_RENDERER}")
|
||||||
|
|
||||||
|
set(TIC80_SRC ${TIC80_SRC_COMMON})
|
||||||
|
|
||||||
|
if(SOKOL_RENDERER)
|
||||||
|
set(TIC80_SRC ${TIC80_SRC} src/system/sokol.c)
|
||||||
|
else()
|
||||||
|
set(TIC80_SRC ${TIC80_SRC} src/net.c src/system/sdlgpu.c)
|
||||||
|
endif()
|
||||||
|
|
||||||
if(WIN32)
|
if(WIN32)
|
||||||
set(TIC80_SRC ${TIC80_SRC} build/windows/tic80.rc)
|
set(TIC80_SRC ${TIC80_SRC} build/windows/tic80.rc)
|
||||||
add_executable(${TIC80_OUTPUT} WIN32 ${TIC80_SRC})
|
add_executable(${TIC80_OUTPUT} WIN32 ${TIC80_SRC})
|
||||||
|
@ -496,14 +532,23 @@ foreach(TIC80_OUTPUT ${TIC80_OUTPUTS})
|
||||||
|
|
||||||
target_include_directories(${TIC80_OUTPUT} PRIVATE include)
|
target_include_directories(${TIC80_OUTPUT} PRIVATE include)
|
||||||
target_include_directories(${TIC80_OUTPUT} PRIVATE src)
|
target_include_directories(${TIC80_OUTPUT} PRIVATE src)
|
||||||
target_include_directories(${TIC80_OUTPUT} PRIVATE 3rd-party/SDL2-2.0.8/include)
|
|
||||||
target_include_directories(${TIC80_OUTPUT} PRIVATE 3rd-party/sdl-gpu/include)
|
|
||||||
target_include_directories(${TIC80_OUTPUT} PRIVATE 3rd-party/SDL2_net-2.0.1)
|
target_include_directories(${TIC80_OUTPUT} PRIVATE 3rd-party/SDL2_net-2.0.1)
|
||||||
|
target_include_directories(${TIC80_OUTPUT} PRIVATE 3rd-party/SDL2-2.0.8/include)
|
||||||
|
|
||||||
|
if(SOKOL_RENDERER)
|
||||||
|
target_include_directories(${TIC80_OUTPUT} PRIVATE 3rd-party/sokol)
|
||||||
|
else()
|
||||||
|
target_include_directories(${TIC80_OUTPUT} PRIVATE 3rd-party/sdl-gpu/include)
|
||||||
|
endif()
|
||||||
|
|
||||||
if(MINGW)
|
if(MINGW)
|
||||||
target_link_libraries(${TIC80_OUTPUT} mingw32)
|
target_link_libraries(${TIC80_OUTPUT} mingw32)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
if(SOKOL_RENDERER)
|
||||||
|
add_dependencies(${TIC80_OUTPUT} sokol)
|
||||||
|
target_link_libraries(${TIC80_OUTPUT} sokol)
|
||||||
|
else()
|
||||||
if(NOT EMSCRIPTEN)
|
if(NOT EMSCRIPTEN)
|
||||||
add_dependencies(${TIC80_OUTPUT} SDL2main SDL2-static)
|
add_dependencies(${TIC80_OUTPUT} SDL2main SDL2-static)
|
||||||
target_link_libraries(${TIC80_OUTPUT} SDL2-static SDL2main)
|
target_link_libraries(${TIC80_OUTPUT} SDL2-static SDL2main)
|
||||||
|
@ -511,6 +556,7 @@ foreach(TIC80_OUTPUT ${TIC80_OUTPUTS})
|
||||||
|
|
||||||
add_dependencies(${TIC80_OUTPUT} ${TIC80_OUTPUT}lib sdlnet sdlgpu)
|
add_dependencies(${TIC80_OUTPUT} ${TIC80_OUTPUT}lib sdlnet sdlgpu)
|
||||||
target_link_libraries(${TIC80_OUTPUT} ${TIC80_OUTPUT}lib sdlnet sdlgpu)
|
target_link_libraries(${TIC80_OUTPUT} ${TIC80_OUTPUT}lib sdlnet sdlgpu)
|
||||||
|
endif()
|
||||||
|
|
||||||
if(LINUX)
|
if(LINUX)
|
||||||
include(FindPkgConfig)
|
include(FindPkgConfig)
|
||||||
|
|
|
@ -22,9 +22,9 @@
|
||||||
|
|
||||||
#include "file_dialog.h"
|
#include "file_dialog.h"
|
||||||
|
|
||||||
#include <SDL.h>
|
#include <tic80_config.h>
|
||||||
|
|
||||||
#if defined(__WINDOWS__)
|
#if defined(__TIC_WINDOWS__)
|
||||||
|
|
||||||
#include <windows.h>
|
#include <windows.h>
|
||||||
#include <commdlg.h>
|
#include <commdlg.h>
|
||||||
|
@ -36,7 +36,7 @@ wchar_t* wcscpy(wchar_t *, const wchar_t *);
|
||||||
void file_dialog_load(file_dialog_load_callback callback, void* data)
|
void file_dialog_load(file_dialog_load_callback callback, void* data)
|
||||||
{
|
{
|
||||||
OPENFILENAMEW ofn;
|
OPENFILENAMEW ofn;
|
||||||
SDL_zero(ofn);
|
memset(&ofn, 0, sizeof ofn);
|
||||||
|
|
||||||
wchar_t filename[MAX_PATH];
|
wchar_t filename[MAX_PATH];
|
||||||
memset(filename, 0, sizeof(filename));
|
memset(filename, 0, sizeof(filename));
|
||||||
|
@ -83,7 +83,7 @@ void file_dialog_load(file_dialog_load_callback callback, void* data)
|
||||||
void file_dialog_save(file_dialog_save_callback callback, const char* name, const u8* buffer, size_t size, void* data, u32 mode)
|
void file_dialog_save(file_dialog_save_callback callback, const char* name, const u8* buffer, size_t size, void* data, u32 mode)
|
||||||
{
|
{
|
||||||
OPENFILENAMEW ofn;
|
OPENFILENAMEW ofn;
|
||||||
SDL_zero(ofn);
|
memset(&ofn, 0, sizeof ofn);
|
||||||
|
|
||||||
wchar_t filename[MAX_PATH];
|
wchar_t filename[MAX_PATH];
|
||||||
mbstowcs(filename, name, MAX_PATH);
|
mbstowcs(filename, name, MAX_PATH);
|
||||||
|
@ -102,7 +102,7 @@ void file_dialog_save(file_dialog_save_callback callback, const char* name, cons
|
||||||
fwrite(buffer, 1, size, file);
|
fwrite(buffer, 1, size, file);
|
||||||
fclose(file);
|
fclose(file);
|
||||||
|
|
||||||
#if !defined(__WINDOWS__)
|
#if !defined(__TIC_WINDOWS__)
|
||||||
chmod(filename, mode);
|
chmod(filename, mode);
|
||||||
#endif
|
#endif
|
||||||
callback(true, data);
|
callback(true, data);
|
||||||
|
@ -157,7 +157,7 @@ void file_dialog_save(file_dialog_save_callback callback, const char* name, cons
|
||||||
callback(true, data);
|
callback(true, data);
|
||||||
}
|
}
|
||||||
|
|
||||||
#elif defined(__LINUX__)
|
#elif defined(__TIC_LINUX__)
|
||||||
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
@ -267,7 +267,7 @@ void file_dialog_save(file_dialog_save_callback callback, const char* name, cons
|
||||||
callback(false, data);
|
callback(false, data);
|
||||||
}
|
}
|
||||||
|
|
||||||
#elif defined(__MACOSX__)
|
#elif defined(__TIC_MACOSX__)
|
||||||
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
@ -345,7 +345,7 @@ void file_dialog_save(file_dialog_save_callback callback, const char* name, cons
|
||||||
callback(false, data);
|
callback(false, data);
|
||||||
}
|
}
|
||||||
|
|
||||||
#elif defined(__ANDROID__)
|
#elif defined(__TIC_ANDROID__)
|
||||||
|
|
||||||
#include <jni.h>
|
#include <jni.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
|
|
|
@ -0,0 +1,25 @@
|
||||||
|
#include "sokol_app.h"
|
||||||
|
#include "sokol_gfx.h"
|
||||||
|
#include "sokol_time.h"
|
||||||
|
#include "sokol_audio.h"
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <limits.h>
|
||||||
|
|
||||||
|
#include <tic80.h>
|
||||||
|
|
||||||
|
sapp_desc sokol_main(int argc, char* argv[])
|
||||||
|
{
|
||||||
|
return (sapp_desc) {0};
|
||||||
|
// .init_cb = app_init,
|
||||||
|
// .frame_cb = app_frame,
|
||||||
|
// .event_cb = app_input,
|
||||||
|
// .cleanup_cb = app_cleanup,
|
||||||
|
// .width = 3 * TIC80_FULLWIDTH,
|
||||||
|
// .height = 3 * TIC80_FULLHEIGHT,
|
||||||
|
// .window_title = "TIC-80 with Sokol renderer",
|
||||||
|
// .ios_keyboard_resizes_canvas = true
|
||||||
|
// };
|
||||||
|
}
|
Loading…
Reference in New Issue