Merge pull request #112 from alkama/master

Fixed bugs and cmake build for Windows
This commit is contained in:
Daniel Collin 2016-02-02 12:00:17 +01:00
commit 19862bde87
3 changed files with 141 additions and 60 deletions

172
ogl_editor/CMakeLists.txt Normal file → Executable file
View 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 ()

View File

@ -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);

View File

@ -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;
}
}