Merge pull request #112 from alkama/master
Fixed bugs and cmake build for Windows
This commit is contained in:
commit
19862bde87
172
ogl_editor/CMakeLists.txt
Normal file → Executable file
172
ogl_editor/CMakeLists.txt
Normal file → Executable file
@ -9,61 +9,117 @@ set(VERSION_MAJOR "1")
|
||||
set(VERSION_MINOR "1")
|
||||
set(VERSION_PATCH "0")
|
||||
|
||||
if(APPLE)
|
||||
add_definitions(-DMACOSX)
|
||||
add_definitions(-DEMGUI_MACOSX)
|
||||
add_compile_options(-Wall)
|
||||
add_compile_options(-Wno-format-security)
|
||||
add_compile_options(-Wno-deprecated-declarations)
|
||||
endif()
|
||||
set(CMAKE_INSTALL_PREFIX ${CMAKE_BINARY_DIR})
|
||||
|
||||
if (APPLE)
|
||||
add_definitions(-DMACOSX -DEMGUI_MACOSX)
|
||||
add_compile_options(-Wall -Wno-format-security -Wno-deprecated-declarations)
|
||||
elseif (UNIX)
|
||||
add_definitions(-DEMGUI_UNIX)
|
||||
add_compile_options(-Wall -Wno-format-security -Wno-deprecated-declarations)
|
||||
elseif (MSVC)
|
||||
add_definitions(-DEMGUI_WINDOWS -DUNICODE -D_UNICODE -DWIN32)
|
||||
add_compile_options(/W4 /FS /wd4996 /wd4389)
|
||||
endif ()
|
||||
|
||||
##############################################################################
|
||||
# SDL (linux only)
|
||||
if (UNIX AND NOT APPLE)
|
||||
|
||||
endif ()
|
||||
|
||||
##############################################################################
|
||||
# MXML
|
||||
file(GLOB MXML_SRCS
|
||||
external/mxml/*.c
|
||||
file(GLOB RKT_MXML_SRCS
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/external/mxml/*.c
|
||||
)
|
||||
add_library(mxml ${MXML_SRCS})
|
||||
target_include_directories(mxml PUBLIC external/mxml)
|
||||
target_compile_definitions(mxml PUBLIC _THREAD_SAFE _REENTRANT)
|
||||
add_library(rkt_mxml ${RKT_MXML_SRCS})
|
||||
target_include_directories(rkt_mxml PUBLIC ${CMAKE_CURRENT_SOURCE_DIR}/external/mxml)
|
||||
if (APPLE)
|
||||
target_compile_definitions(rkt_mxml PUBLIC -D_THREAD_SAFE -D_REENTRANT)
|
||||
target_compile_options(rkt_mxml PUBLIC -Wall)
|
||||
elseif (UNIX)
|
||||
target_compile_definitions(rkt_mxml PUBLIC -D_THREAD_SAFE -D_REENTRANT)
|
||||
target_compile_options(rkt_mxml PUBLIC -Wall)
|
||||
elseif (MSVC)
|
||||
set_target_properties(rkt_mxml PROPERTIES LINK_FLAGS "/SUBSYSTEM:WINDOWS")
|
||||
endif ()
|
||||
set(RKT_PROJECT_INCLUDES ${RKT_PROJECT_INCLUDES} ${CMAKE_CURRENT_SOURCE_DIR}/external/mxml)
|
||||
set(RKT_PROJECT_LIBS ${RKT_PROJECT_LIBS} rkt_mxml)
|
||||
|
||||
##############################################################################
|
||||
# SYNC
|
||||
file(GLOB SYNC_SRCS
|
||||
../lib/*.c
|
||||
file(GLOB RKT_SYNC_SRCS
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../lib/*.c
|
||||
)
|
||||
add_library(sync ${SYNC_SRCS})
|
||||
target_include_directories(sync PUBLIC ../lib)
|
||||
add_library(rkt_sync ${RKT_SYNC_SRCS})
|
||||
target_include_directories(rkt_sync PUBLIC ${CMAKE_CURRENT_SOURCE_DIR}/../lib)
|
||||
set(RKT_PROJECT_INCLUDES ${RKT_PROJECT_INCLUDES} ${CMAKE_CURRENT_SOURCE_DIR}/../lib)
|
||||
set(RKT_PROJECT_LIBS ${RKT_PROJECT_LIBS} rkt_sync)
|
||||
|
||||
##############################################################################
|
||||
# EMGUI
|
||||
file(GLOB_RECURSE EMGUI_SRCS
|
||||
emgui/src/*.c
|
||||
emgui/src/*.h
|
||||
file(GLOB_RECURSE RKT_EMGUI_SRCS
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/emgui/src/*.c
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/emgui/src/*.h
|
||||
)
|
||||
add_library(emgui ${EMGUI_SRCS})
|
||||
target_include_directories(emgui PUBLIC emgui/src emgui/include)
|
||||
target_compile_definitions(emgui PUBLIC _THREAD_SAFE _REENTRANT)
|
||||
target_compile_options(emgui PUBLIC -Werror -pedantic-errors)
|
||||
add_library(rkt_emgui ${RKT_EMGUI_SRCS})
|
||||
target_include_directories(rkt_emgui PUBLIC ${CMAKE_CURRENT_SOURCE_DIR}/emgui/src ${CMAKE_CURRENT_SOURCE_DIR}/emgui/include)
|
||||
if (APPLE)
|
||||
target_compile_definitions(rkt_emgui PUBLIC -DEMGUI_MACOSX)
|
||||
target_compile_options(rkt_emgui PUBLIC -Werror -pedantic-errors -Wall -Wno-format-security)
|
||||
elseif (UNIX)
|
||||
target_compile_definitions(rkt_emgui PUBLIC -DEMGUI_UNIX)
|
||||
target_compile_options(rkt_emgui PUBLIC -Werror -pedantic-errors -Wall -Wno-format-security)
|
||||
elseif (MSVC)
|
||||
target_compile_definitions(rkt_emgui PUBLIC -DEMGUI_WINDOWS)
|
||||
set_target_properties(rkt_emgui PROPERTIES LINK_FLAGS "/SUBSYSTEM:WINDOWS")
|
||||
endif ()
|
||||
set(RKT_PROJECT_INCLUDES ${RKT_PROJECT_INCLUDES} ${CMAKE_CURRENT_SOURCE_DIR}/emgui/include)
|
||||
set(RKT_PROJECT_LIBS ${RKT_PROJECT_LIBS} rkt_emgui)
|
||||
|
||||
##############################################################################
|
||||
# EDITOR
|
||||
file(GLOB PROJECT_SRCS
|
||||
src/*.c
|
||||
src/*.m
|
||||
src/*.h
|
||||
# ROCKET EDITOR
|
||||
file(GLOB RKT_PROJECT_SRCS
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/src/*.c
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/src/*.m
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/src/*.h
|
||||
)
|
||||
if (APPLE)
|
||||
file(GLOB PROJECT_PLATFORM_SRCS
|
||||
src/macosx/*.c
|
||||
src/macosx/*.m
|
||||
src/macosx/*.h
|
||||
file(GLOB RKT_PLATFORM_SRCS
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/src/macosx/*.c
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/src/macosx/*.m
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/src/macosx/*.h
|
||||
)
|
||||
endif()
|
||||
file(GLOB RESOURCES_DATA
|
||||
data/macosx/icon.icns
|
||||
)
|
||||
source_group("Data" FILES ${RESOURCES_DATA})
|
||||
|
||||
file(GLOB RKT_RESOURCES_DATA
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/data/macosx/icon.icns
|
||||
)
|
||||
source_group("Data" FILES ${RKT_RESOURCES_DATA})
|
||||
elseif (UNIX)
|
||||
file(GLOB RKT_PLATFORM_SRCS
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/src/linux/*.c
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/src/linux/*.h
|
||||
)
|
||||
elseif (MSVC)
|
||||
file(GLOB RKT_PLATFORM_SRCS
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/src/windows/*.c
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/src/windows/*.h
|
||||
)
|
||||
|
||||
file(GLOB RKT_RESOURCES_DATA
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/data/windows/appicon.ico
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/data/windows/editor.rc
|
||||
)
|
||||
source_group("Data" FILES ${RKT_RESOURCES_DATA})
|
||||
endif ()
|
||||
|
||||
set(RKT_PROJECT_SRCS ${RKT_PROJECT_SRCS} ${RKT_PLATFORM_SRCS} ${RKT_RESOURCES_DATA})
|
||||
|
||||
set(RKT_PROJECT_INCLUDES ${CMAKE_CURRENT_SOURCE_DIR}/src ${RKT_PROJECT_INCLUDES})
|
||||
|
||||
##############################################################################
|
||||
#### APPLE BUNDLE, RESSOURCES AND DYNAMIC LIBS
|
||||
if (APPLE)
|
||||
set(GUI_TYPE MACOSX_BUNDLE)
|
||||
|
||||
@ -85,25 +141,47 @@ if (APPLE)
|
||||
set(MACOSX_BUNDLE_BUNDLE_VERSION "${VERSION_MAJOR}.${VERSION_MINOR}.${VERSION_PATCH}")
|
||||
set(MACOSX_BUNDLE_COPYRIGHT "Copyright © 2012-2016 GNU Rocket Contributors. All rights reserved.")
|
||||
|
||||
set_source_files_properties(${RESOURCES_DATA} PROPERTIES MACOSX_PACKAGE_LOCATION Resources)
|
||||
set_source_files_properties(${RKT_RESOURCES_DATA} PROPERTIES MACOSX_PACKAGE_LOCATION Resources)
|
||||
|
||||
set(PROJECT_SRCS ${GUI_TYPE} ${PROJECT_SRCS} ${RESOURCES_DATA})
|
||||
set(RKT_PROJECT_SRCS ${GUI_TYPE} ${RKT_PROJECT_SRCS} ${CMAKE_CURRENT_SOURCE_DIR}/data/macosx/appnib.xib)
|
||||
elseif (UNIX)
|
||||
find_package(SDL REQUIRED)
|
||||
if (NOT SDL_FOUND)
|
||||
message(FATAL_ERROR "SDL not found!")
|
||||
endif ()
|
||||
|
||||
endif (APPLE)
|
||||
add_executable(${RKT_EXE_NAME} ${PROJECT_SRCS} ${PROJECT_PLATFORM_SRCS} data/macosx/appnib.xib)
|
||||
set(PLATFORM_LIBS ${SDL_LIBRARY} SDLmain GL m)
|
||||
set(RKT_PROJECT_INCLUDES ${RKT_PROJECT_INCLUDES} ${SDL_INCLUDE_DIR})
|
||||
elseif (MSVC)
|
||||
set(PLATFORM_LIBS wsock32 opengl32 glu32 kernel32 user32 gdi32 Comdlg32 Advapi32)
|
||||
endif ()
|
||||
set(RKT_PROJECT_LIBS ${RKT_PROJECT_LIBS} ${PLATFORM_LIBS})
|
||||
##############################################################################
|
||||
|
||||
add_executable(${RKT_EXE_NAME} ${RKT_PROJECT_SRCS})
|
||||
target_include_directories(${RKT_EXE_NAME} PUBLIC ${RKT_PROJECT_INCLUDES})
|
||||
if (APPLE)
|
||||
set_target_properties(${RKT_EXE_NAME} PROPERTIES MACOSX_BUNDLE_INFO_PLIST ${CMAKE_CURRENT_SOURCE_DIR}/data/macosx/MacOSXBundleInfo.plist.in)
|
||||
elseif (MSVC)
|
||||
set_target_properties(${RKT_EXE_NAME} PROPERTIES LINK_FLAGS "/SUBSYSTEM:WINDOWS")
|
||||
endif ()
|
||||
target_include_directories(${RKT_EXE_NAME} PUBLIC . src emgui/include external/mxml)
|
||||
target_compile_options(${RKT_EXE_NAME} PUBLIC -Werror -pedantic-errors)
|
||||
target_link_libraries(${RKT_EXE_NAME} sync mxml emgui ${PLATFORM_LIBS})
|
||||
if (APPLE)
|
||||
target_compile_definitions(${RKT_EXE_NAME} PUBLIC -DEMGUI_MACOSX)
|
||||
target_compile_options(${RKT_EXE_NAME} PUBLIC -Werror -pedantic-errors -Wall -Wno-format-security)
|
||||
elseif (UNIX)
|
||||
target_compile_definitions(${RKT_EXE_NAME} PUBLIC -DEMGUI_UNIX)
|
||||
target_compile_options(${RKT_EXE_NAME} PUBLIC -Werror -pedantic-errors -Wall -Wno-format-security)
|
||||
elseif (MSVC)
|
||||
target_compile_definitions(${RKT_EXE_NAME} PUBLIC -DEMGUI_WIN32)
|
||||
endif ()
|
||||
target_link_libraries(${RKT_EXE_NAME} ${RKT_PROJECT_LIBS})
|
||||
|
||||
# compile the nibs
|
||||
if (APPLE)
|
||||
find_program(IBTOOL ibtool HINTS "/usr/bin" "${OSX_DEVELOPER_ROOT}/usr/bin")
|
||||
if (${IBTOOL} STREQUAL "IBTOOL-NOTFOUND")
|
||||
message(SEND_ERROR "ibtool can not be found and is needed to compile the .xib files. It should have been installed with the Apple developer tools. The default system paths were searched in addition to ${OSX_DEVELOPER_ROOT}/usr/bin")
|
||||
endif()
|
||||
endif ()
|
||||
|
||||
# Make sure the 'Resources' Directory is correctly created before we build
|
||||
#add_custom_command (TARGET ${RKT_EXE_NAME} PRE_BUILD COMMAND echo ${CMAKE_BINARY_DIR}/\${CONFIGURATION}/${RKT_EXE_NAME}.app/Contents/Resources/appnib.nib)
|
||||
@ -111,7 +189,7 @@ if (APPLE)
|
||||
# Compile the .xib files using the 'ibtool' program with the destination being the app package
|
||||
add_custom_command (TARGET ${RKT_EXE_NAME} POST_BUILD
|
||||
COMMAND ${IBTOOL} --errors --warnings --notices --output-format human-readable-text
|
||||
--compile ${CMAKE_BINARY_DIR}/\${CONFIGURATION}/${RKT_EXE_NAME}.app/Contents/Resources/appnib.nib
|
||||
--compile ${CMAKE_CURRENT_BINARY_DIR}/\${CONFIGURATION}/${RKT_EXE_NAME}.app/Contents/Resources/appnib.nib
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/data/macosx/appnib.xib
|
||||
COMMENT "Compiling appnib.xib")
|
||||
endif (APPLE)
|
||||
endif ()
|
||||
|
||||
@ -17,6 +17,9 @@
|
||||
#include "../../lib/sync.h"
|
||||
#include "../../lib/base.h"
|
||||
#include <emgui/Emgui.h>
|
||||
#if defined(_WIN32)
|
||||
#include <winsock2.h>
|
||||
#endif
|
||||
|
||||
enum {
|
||||
SET_KEY = 0,
|
||||
@ -954,9 +957,9 @@ static void setWindowTitle(const text_t* path, bool needsSave)
|
||||
text_t windowTitle[4096];
|
||||
#if defined(_WIN32)
|
||||
if (needsSave)
|
||||
swprintf_s(windowTitle, sizeof(windowTitle), L"RocketEditor" EDITOR_VERSION L"- (%s) *", path);
|
||||
swprintf_s(windowTitle, sizeof_array(windowTitle), L"RocketEditor" EDITOR_VERSION L"- (%s) *", path);
|
||||
else
|
||||
swprintf_s(windowTitle, sizeof(windowTitle), L"RocketEditor" EDITOR_VERSION L" - (%s)", path);
|
||||
swprintf_s(windowTitle, sizeof_array(windowTitle), L"RocketEditor" EDITOR_VERSION L" - (%s)", path);
|
||||
#else
|
||||
if (needsSave)
|
||||
sprintf(windowTitle, "RocketEditor" EDITOR_VERSION "- (%s) *", path);
|
||||
|
||||
@ -210,17 +210,17 @@ static void formatName(wchar_t* outName, int keyMod, int key, const wchar_t* nam
|
||||
{
|
||||
switch (key)
|
||||
{
|
||||
case EMGUI_KEY_ARROW_DOWN : wcscpy_s(keyName, sizeof(keyName), L"Down"); break;
|
||||
case EMGUI_KEY_ARROW_UP: wcscpy_s(keyName, sizeof(keyName), L"Up"); break;
|
||||
case EMGUI_KEY_ARROW_RIGHT: wcscpy_s(keyName, sizeof(keyName), L"Right"); break;
|
||||
case EMGUI_KEY_ARROW_LEFT: wcscpy_s(keyName, sizeof(keyName), L"Left"); break;
|
||||
case EMGUI_KEY_ESC: wcscpy_s(keyName, sizeof(keyName), L"ESC"); break;
|
||||
case EMGUI_KEY_TAB: wcscpy_s(keyName, sizeof(keyName), L"TAB"); break;
|
||||
case EMGUI_KEY_BACKSPACE: wcscpy_s(keyName, sizeof(keyName), L"Delete"); break;
|
||||
case EMGUI_KEY_ENTER: wcscpy_s(keyName, sizeof(keyName), L"Enter"); break;
|
||||
case EMGUI_KEY_SPACE: wcscpy_s(keyName, sizeof(keyName), L"Space"); break;
|
||||
case EMGUI_KEY_PAGE_UP: wcscpy_s(keyName, sizeof(keyName), L"Page Up"); break;
|
||||
case EMGUI_KEY_PAGE_DOWN: wcscpy_s(keyName, sizeof(keyName), L"Page Down"); break;
|
||||
case EMGUI_KEY_ARROW_DOWN : wcscpy_s(keyName, sizeof_array(keyName), L"Down"); break;
|
||||
case EMGUI_KEY_ARROW_UP: wcscpy_s(keyName, sizeof_array(keyName), L"Up"); break;
|
||||
case EMGUI_KEY_ARROW_RIGHT: wcscpy_s(keyName, sizeof_array(keyName), L"Right"); break;
|
||||
case EMGUI_KEY_ARROW_LEFT: wcscpy_s(keyName, sizeof_array(keyName), L"Left"); break;
|
||||
case EMGUI_KEY_ESC: wcscpy_s(keyName, sizeof_array(keyName), L"ESC"); break;
|
||||
case EMGUI_KEY_TAB: wcscpy_s(keyName, sizeof_array(keyName), L"TAB"); break;
|
||||
case EMGUI_KEY_BACKSPACE: wcscpy_s(keyName, sizeof_array(keyName), L"Delete"); break;
|
||||
case EMGUI_KEY_ENTER: wcscpy_s(keyName, sizeof_array(keyName), L"Enter"); break;
|
||||
case EMGUI_KEY_SPACE: wcscpy_s(keyName, sizeof_array(keyName), L"Space"); break;
|
||||
case EMGUI_KEY_PAGE_UP: wcscpy_s(keyName, sizeof_array(keyName), L"Page Up"); break;
|
||||
case EMGUI_KEY_PAGE_DOWN: wcscpy_s(keyName, sizeof_array(keyName), L"Page Down"); break;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user