Fix setup cmake files and some relative sources

This commit is contained in:
halx99 2022-07-08 14:20:41 +08:00
parent 955c42c7a2
commit 906c60e40e
32 changed files with 102 additions and 108 deletions

View File

@ -42,8 +42,8 @@ set(CMAKE_MODULE_PATH ${AXIS_ROOT_PATH}/cmake/Modules/)
# prevent in-source-build # prevent in-source-build
include(PreventInSourceBuilds) include(PreventInSourceBuilds)
# works before build libcocos2d # works before build libaxis
include(CocosBuildSet) include(AxisBuildSet)
option(AX_BUILD_TESTS "Build cpp & lua tests" ON) option(AX_BUILD_TESTS "Build cpp & lua tests" ON)
option(AX_BUILD_EXAMPLES "Build examples" ON) option(AX_BUILD_EXAMPLES "Build examples" ON)

View File

@ -17,7 +17,7 @@ function(cocos_copy_target_res cocos_target)
get_filename_component(link_folder_abs ${opt_LINK_TO} ABSOLUTE) get_filename_component(link_folder_abs ${opt_LINK_TO} ABSOLUTE)
add_custom_command(TARGET SYNC_RESOURCE-${cocos_target} POST_BUILD add_custom_command(TARGET SYNC_RESOURCE-${cocos_target} POST_BUILD
COMMAND ${CMAKE_COMMAND} -E echo " copying to ${link_folder_abs}" COMMAND ${CMAKE_COMMAND} -E echo " copying to ${link_folder_abs}"
COMMAND ${PYTHON_COMMAND} ARGS ${ADXE_ROOT_PATH}/cmake/scripts/sync_folder.py COMMAND ${PYTHON_COMMAND} ARGS ${AXIS_ROOT_PATH}/cmake/scripts/sync_folder.py
-s ${cc_folder} -d ${link_folder_abs} -s ${cc_folder} -d ${link_folder_abs}
) )
endforeach() endforeach()
@ -49,18 +49,18 @@ function(cocos_copy_lua_scripts cocos_target src_dir dst_dir)
endif() endif()
if(MSVC) if(MSVC)
add_custom_command(TARGET ${luacompile_target} POST_BUILD add_custom_command(TARGET ${luacompile_target} POST_BUILD
COMMAND ${PYTHON_COMMAND} ARGS ${ADXE_ROOT_PATH}/cmake/scripts/sync_folder.py COMMAND ${PYTHON_COMMAND} ARGS ${AXIS_ROOT_PATH}/cmake/scripts/sync_folder.py
-s ${src_dir} -d ${dst_dir} -m $<CONFIG> -s ${src_dir} -d ${dst_dir} -m $<CONFIG>
) )
else() else()
if("${CMAKE_BUILD_TYPE}" STREQUAL "") if("${CMAKE_BUILD_TYPE}" STREQUAL "")
add_custom_command(TARGET ${luacompile_target} POST_BUILD add_custom_command(TARGET ${luacompile_target} POST_BUILD
COMMAND ${PYTHON_COMMAND} ARGS ${ADXE_ROOT_PATH}/cmake/scripts/sync_folder.py COMMAND ${PYTHON_COMMAND} ARGS ${AXIS_ROOT_PATH}/cmake/scripts/sync_folder.py
-s ${src_dir} -d ${dst_dir} -s ${src_dir} -d ${dst_dir}
) )
else() else()
add_custom_command(TARGET ${luacompile_target} POST_BUILD add_custom_command(TARGET ${luacompile_target} POST_BUILD
COMMAND ${PYTHON_COMMAND} ARGS ${ADXE_ROOT_PATH}/cmake/scripts/sync_folder.py COMMAND ${PYTHON_COMMAND} ARGS ${AXIS_ROOT_PATH}/cmake/scripts/sync_folder.py
-s ${src_dir} -d ${dst_dir} -m ${CMAKE_BUILD_TYPE} -s ${src_dir} -d ${dst_dir} -m ${CMAKE_BUILD_TYPE}
) )
endif() endif()
@ -154,10 +154,10 @@ endfunction()
function(copy_thirdparty_dlls cocos_target destDir) function(copy_thirdparty_dlls cocos_target destDir)
# init dependency list with direct dependencies # init dependency list with direct dependencies
get_property(DEPENDENCIES TARGET ${ADXE_THIRDPARTY_NAME} PROPERTY LINK_LIBRARIES) get_property(DEPENDENCIES TARGET ${AXIS_THIRDPARTY_NAME} PROPERTY LINK_LIBRARIES)
# We're not intersted in interface link libraries of the top-most target # We're not intersted in interface link libraries of the top-most target
# if (INCLUDE_INTERFACE_LINK_LIBRARIES) # if (INCLUDE_INTERFACE_LINK_LIBRARIES)
# get_property(INTERFACE_LINK_LIBRARIES TARGET ${ADXE_THIRDPARTY_NAME} PROPERTY # get_property(INTERFACE_LINK_LIBRARIES TARGET ${AXIS_THIRDPARTY_NAME} PROPERTY
# INTERFACE_LINK_LIBRARIES) # INTERFACE_LINK_LIBRARIES)
# list(APPEND DEPENDENCIES ${INTERFACE_LINK_LIBRARIES}) # list(APPEND DEPENDENCIES ${INTERFACE_LINK_LIBRARIES})
# endif() # endif()
@ -175,7 +175,7 @@ function(copy_thirdparty_dlls cocos_target destDir)
SET(EXT_LIB_FILES "") SET(EXT_LIB_FILES "")
foreach(DEPENDENCY ${DEPENDENCIES}) foreach(DEPENDENCY ${DEPENDENCIES})
# message(STATUS ${DEPENDENCY} " depends by ${ADXE_THIRDPARTY_NAME}") # message(STATUS ${DEPENDENCY} " depends by ${AXIS_THIRDPARTY_NAME}")
get_property(IMPORTLIB TARGET ${DEPENDENCY} PROPERTY IMPORTED_IMPLIB) get_property(IMPORTLIB TARGET ${DEPENDENCY} PROPERTY IMPORTED_IMPLIB)
get_property(IMPORTDLL TARGET ${DEPENDENCY} PROPERTY IMPORTED_LOCATION) get_property(IMPORTDLL TARGET ${DEPENDENCY} PROPERTY IMPORTED_LOCATION)
if(IMPORTLIB) if(IMPORTLIB)
@ -223,9 +223,9 @@ function(cocos_copy_target_dll cocos_target)
# Copy windows angle binaries # Copy windows angle binaries
add_custom_command(TARGET ${cocos_target} POST_BUILD add_custom_command(TARGET ${cocos_target} POST_BUILD
COMMAND ${CMAKE_COMMAND} -E copy_if_different COMMAND ${CMAKE_COMMAND} -E copy_if_different
${ADXE_ROOT_PATH}/${ADXE_THIRDPARTY_NAME}/angle/prebuilt/${ARCH_ALIAS}/libGLESv2.dll ${AXIS_ROOT_PATH}/${AXIS_THIRDPARTY_NAME}/angle/prebuilt/${ARCH_ALIAS}/libGLESv2.dll
${ADXE_ROOT_PATH}/${ADXE_THIRDPARTY_NAME}/angle/prebuilt/${ARCH_ALIAS}/libEGL.dll ${AXIS_ROOT_PATH}/${AXIS_THIRDPARTY_NAME}/angle/prebuilt/${ARCH_ALIAS}/libEGL.dll
${ADXE_ROOT_PATH}/${ADXE_THIRDPARTY_NAME}/angle/prebuilt/${ARCH_ALIAS}/d3dcompiler_47.dll ${AXIS_ROOT_PATH}/${AXIS_THIRDPARTY_NAME}/angle/prebuilt/${ARCH_ALIAS}/d3dcompiler_47.dll
$<TARGET_FILE_DIR:${cocos_target}> $<TARGET_FILE_DIR:${cocos_target}>
) )
@ -487,8 +487,8 @@ function(cocos_use_pkg target pkg)
endfunction() endfunction()
# The adxe preprocessors config helper macro # The axis preprocessors config helper macro
macro(adxe_config_pred target_name pred) macro(axis_config_pred target_name pred)
if(${pred}) if(${pred})
target_compile_definitions(${target_name} PUBLIC ${pred}=1) target_compile_definitions(${target_name} PUBLIC ${pred}=1)
endif() endif()

View File

@ -15,12 +15,12 @@ if(CMAKE_TOOLCHAIN_FILE)
endif() endif()
find_program(PYTHON_COMMAND NAMES python3 python2 python) find_program(PYTHON_COMMAND NAMES python3 python2 python)
find_program(COCOS_COMMAND NAME adxe find_program(COCOS_COMMAND NAME axis
PATHS ${ADXE_ROOT_PATH}/tools/cocos2d-console/bin $ENV{ADXE_CONSOLE_ROOT}) PATHS ${AXIS_ROOT_PATH}/tools/axis-console/bin $ENV{AXIS_CONSOLE_ROOT})
message(STATUS "PROJECT_NAME:" ${PROJECT_NAME}) message(STATUS "PROJECT_NAME:" ${PROJECT_NAME})
message(STATUS "PROJECT_SOURCE_DIR:" ${PROJECT_SOURCE_DIR}) message(STATUS "PROJECT_SOURCE_DIR:" ${PROJECT_SOURCE_DIR})
message(STATUS "ADXE_ROOT_PATH:" ${ADXE_ROOT_PATH}) message(STATUS "AXIS_ROOT_PATH:" ${AXIS_ROOT_PATH})
message(STATUS "CMAKE_MODULE_PATH:" ${CMAKE_MODULE_PATH}) message(STATUS "CMAKE_MODULE_PATH:" ${CMAKE_MODULE_PATH})
# delete binary dir if you hope a full clean re-build # delete binary dir if you hope a full clean re-build
message(STATUS "PROJECT_BINARY_DIR:" ${PROJECT_BINARY_DIR}) message(STATUS "PROJECT_BINARY_DIR:" ${PROJECT_BINARY_DIR})
@ -35,26 +35,26 @@ option(AX_ENABLE_EXT_LUA "Build lua libraries" OFF)
set(_AX_EXTENSION_LIBS "" CACHE INTERNAL "extensions for auto link to target application") set(_AX_EXTENSION_LIBS "" CACHE INTERNAL "extensions for auto link to target application")
# include helper functions # include helper functions
include(CocosBuildHelpers) include(AxisBuildHelpers)
# set common compiler options # set common compiler options
# add target compile define function # add target compile define function
# add target compile options function # add target compile options function
include(CocosConfigDefine) include(AxisConfigDefine)
# config libraries dependence # config libraries dependence
include(CocosConfigDepend) include(AxisConfigDepend)
if(COCOS_COMMAND) if(COCOS_COMMAND)
get_filename_component(cocos2dx_console_dir ${COCOS_COMMAND} DIRECTORY) get_filename_component(axis_console_dir ${COCOS_COMMAND} DIRECTORY)
set(COCOS2DX_LUAJIT_ROOT ${cocos2dx_console_dir}/../plugins/plugin_luacompile/bin) set(AXIS_LUAJIT_ROOT ${axis_console_dir}/../plugins/plugin_luacompile/bin)
message(STATUS "COCOS2DX_LUAJIT_ROOT:" ${COCOS2DX_LUAJIT_ROOT}) message(STATUS "AXIS_LUAJIT_ROOT:" ${AXIS_LUAJIT_ROOT})
if("${CMAKE_HOST_SYSTEM_NAME}" STREQUAL "Windows") if("${CMAKE_HOST_SYSTEM_NAME}" STREQUAL "Windows")
find_program(LUAJIT32_COMMAND NAMES luajit-win32 PATHS ${COCOS2DX_LUAJIT_ROOT}/32bit NO_SYSTEM_ENVIRONMENT_PATH) find_program(LUAJIT32_COMMAND NAMES luajit-win32 PATHS ${AXIS_LUAJIT_ROOT}/32bit NO_SYSTEM_ENVIRONMENT_PATH)
find_program(LUAJIT64_COMMAND NAMES luajit-win32 PATHS ${COCOS2DX_LUAJIT_ROOT}/64bit NO_SYSTEM_ENVIRONMENT_PATH) find_program(LUAJIT64_COMMAND NAMES luajit-win32 PATHS ${AXIS_LUAJIT_ROOT}/64bit NO_SYSTEM_ENVIRONMENT_PATH)
elseif("${CMAKE_HOST_SYSTEM_NAME}" STREQUAL "Linux") elseif("${CMAKE_HOST_SYSTEM_NAME}" STREQUAL "Linux")
find_program(LUAJIT32_COMMAND NAMES luajit-linux PATHS ${COCOS2DX_LUAJIT_ROOT}/32bit NO_SYSTEM_ENVIRONMENT_PATH) find_program(LUAJIT32_COMMAND NAMES luajit-linux PATHS ${AXIS_LUAJIT_ROOT}/32bit NO_SYSTEM_ENVIRONMENT_PATH)
find_program(LUAJIT64_COMMAND NAMES luajit-linux PATHS ${COCOS2DX_LUAJIT_ROOT}/64bit NO_SYSTEM_ENVIRONMENT_PATH) find_program(LUAJIT64_COMMAND NAMES luajit-linux PATHS ${AXIS_LUAJIT_ROOT}/64bit NO_SYSTEM_ENVIRONMENT_PATH)
endif() endif()
endif() endif()

View File

@ -54,15 +54,10 @@ endif()
message(STATUS "CMAKE_GENERATOR: ${CMAKE_GENERATOR}") message(STATUS "CMAKE_GENERATOR: ${CMAKE_GENERATOR}")
# custom target property for lua/js link # custom target property for lua/js link
define_property(TARGET
PROPERTY CC_JS_DEPEND
BRIEF_DOCS "cocos2d js depend libs"
FULL_DOCS "use to save depend libs of cocos2d js project"
)
define_property(TARGET define_property(TARGET
PROPERTY CC_LUA_DEPEND PROPERTY CC_LUA_DEPEND
BRIEF_DOCS "cocos2d lua depend libs" BRIEF_DOCS "axis lua depend libs"
FULL_DOCS "use to save depend libs of cocos2d lua project" FULL_DOCS "use to save depend libs of axis lua project"
) )
# config c standard # config c standard
@ -91,7 +86,7 @@ endif()
set(CMAKE_DEBUG_POSTFIX "" CACHE STRING "Library postfix for debug builds. Normally left blank." FORCE) set(CMAKE_DEBUG_POSTFIX "" CACHE STRING "Library postfix for debug builds. Normally left blank." FORCE)
# set hash style to both for android old device compatible # set hash style to both for android old device compatible
# see also: https://github.com/adxeproject/adxe/discussions/614 # see also: https://github.com/axis-project/axis/discussions/614
if (ANDROID) if (ANDROID)
set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -Wl,--hash-style=both") set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -Wl,--hash-style=both")
endif() endif()
@ -103,20 +98,20 @@ if(WINDOWS)
# Visual Studio 2015, MSVC_VERSION 1900 (v140 toolset) # Visual Studio 2015, MSVC_VERSION 1900 (v140 toolset)
# Visual Studio 2017, MSVC_VERSION 1910-1919 (v141 toolset) # Visual Studio 2017, MSVC_VERSION 1910-1919 (v141 toolset)
if(${MSVC_VERSION} EQUAL 1900 OR ${MSVC_VERSION} GREATER 1900) if(${MSVC_VERSION} EQUAL 1900 OR ${MSVC_VERSION} GREATER 1900)
message(STATUS "using Windows MSVC generate adxe project, MSVC_VERSION:${MSVC_VERSION}") message(STATUS "using Windows MSVC generate axis project, MSVC_VERSION:${MSVC_VERSION}")
else() else()
message(FATAL_ERROR "using Windows MSVC generate adxe project, MSVC_VERSION:${MSVC_VERSION} lower than needed") message(FATAL_ERROR "using Windows MSVC generate axis project, MSVC_VERSION:${MSVC_VERSION} lower than needed")
endif() endif()
else() else()
message(FATAL_ERROR "please using Windows MSVC compile adxe project, support other compile tools not yet") message(FATAL_ERROR "please using Windows MSVC compile axis project, support other compile tools not yet")
endif() endif()
endif() endif()
# Set macro definitions for special platforms # Set macro definitions for special platforms
function(use_cocos2dx_compile_define target) function(use_axis_compile_define target)
target_compile_definitions(${target} PUBLIC $<$<CONFIG:Debug>:COCOS2D_DEBUG=1>) target_compile_definitions(${target} PUBLIC $<$<CONFIG:Debug>:COCOS2D_DEBUG=1>)
# !important adxe not use double precision # !important axis not use double precision
# target_compile_definitions(${target} PUBLIC CP_USE_CGTYPES=0) # target_compile_definitions(${target} PUBLIC CP_USE_CGTYPES=0)
# target_compile_definitions(${target} PUBLIC CP_USE_DOUBLES=0) # target_compile_definitions(${target} PUBLIC CP_USE_DOUBLES=0)
@ -162,7 +157,7 @@ function(use_cocos2dx_compile_define target)
endfunction() endfunction()
# Set compiler options # Set compiler options
function(use_cocos2dx_compile_options target) function(use_axis_compile_options target)
if(MSVC) if(MSVC)
target_compile_options(${target} target_compile_options(${target}
PUBLIC /MP PUBLIC /MP

View File

@ -1,4 +1,4 @@
macro(cocos2dx_depend) macro(axis_depend)
# confim the libs, prepare to link # confim the libs, prepare to link
set(PLATFORM_SPECIFIC_LIBS) set(PLATFORM_SPECIFIC_LIBS)
@ -104,8 +104,8 @@ macro(cocos2dx_depend)
endif() endif()
endmacro() endmacro()
macro(use_cocos2dx_libs_depend target) macro(use_axis_libs_depend target)
cocos2dx_depend() axis_depend()
foreach(platform_lib ${PLATFORM_SPECIFIC_LIBS}) foreach(platform_lib ${PLATFORM_SPECIFIC_LIBS})
target_link_libraries(${target} ${platform_lib}) target_link_libraries(${target} ${platform_lib})
endforeach() endforeach()

View File

@ -14,7 +14,7 @@ endif()
message(STATUS "AX_ENABLE_MSEDGE_WEBVIEW2=${AX_ENABLE_MSEDGE_WEBVIEW2}") message(STATUS "AX_ENABLE_MSEDGE_WEBVIEW2=${AX_ENABLE_MSEDGE_WEBVIEW2}")
function(adxe_link_cxx_prebuilt APP_NAME AX_ROOT_DIR AX_PREBUILT_DIR) function(axis_link_cxx_prebuilt APP_NAME AX_ROOT_DIR AX_PREBUILT_DIR)
if (NOT AX_USE_SHARED_PREBUILT) if (NOT AX_USE_SHARED_PREBUILT)
target_compile_definitions(${APP_NAME} target_compile_definitions(${APP_NAME}
PRIVATE CC_STATIC=1 PRIVATE CC_STATIC=1
@ -87,7 +87,7 @@ function(adxe_link_cxx_prebuilt APP_NAME AX_ROOT_DIR AX_PREBUILT_DIR)
assets-manager.lib assets-manager.lib
cocostudio.lib cocostudio.lib
DragonBones.lib DragonBones.lib
adxe.lib axis.lib
box2d.lib box2d.lib
chipmunk.lib chipmunk.lib
freetype.lib freetype.lib
@ -156,19 +156,19 @@ function(adxe_link_cxx_prebuilt APP_NAME AX_ROOT_DIR AX_PREBUILT_DIR)
target_link_libraries(${APP_NAME} ${AX_ROOT_DIR}/build/packages/Microsoft.Web.WebView2/build/native/Microsoft.Web.WebView2.targets) target_link_libraries(${APP_NAME} ${AX_ROOT_DIR}/build/packages/Microsoft.Web.WebView2/build/native/Microsoft.Web.WebView2.targets)
endif() endif()
endif() endif()
endfunction(adxe_link_cxx_prebuilt) endfunction(axis_link_cxx_prebuilt)
function(adxe_link_lua_prebuilt APP_NAME AX_ROOT_DIR AX_PREBUILT_DIR) function(axis_link_lua_prebuilt APP_NAME AX_ROOT_DIR AX_PREBUILT_DIR)
adxe_link_cxx_prebuilt(${APP_NAME} ${AX_ROOT_DIR} ${AX_PREBUILT_DIR}) axis_link_cxx_prebuilt(${APP_NAME} ${AX_ROOT_DIR} ${AX_PREBUILT_DIR})
if (NOT AX_USE_SHARED_PREBUILT) if (NOT AX_USE_SHARED_PREBUILT)
target_compile_definitions(${APP_NAME} target_compile_definitions(${APP_NAME}
PRIVATE _USRLUASTATIC=1 PRIVATE _USRLUASTATIC=1
) )
endif() endif()
target_link_libraries(${APP_NAME} adxelua lua-cjson tolua plainlua) target_link_libraries(${APP_NAME} axislua lua-cjson tolua plainlua)
add_custom_command(TARGET ${APP_NAME} POST_BUILD add_custom_command(TARGET ${APP_NAME} POST_BUILD
COMMAND ${CMAKE_COMMAND} -E copy_if_different COMMAND ${CMAKE_COMMAND} -E copy_if_different
"${AX_ROOT_DIR}/${AX_PREBUILT_DIR}/bin/${THIRD_PARTY_ARCH}plainlua.dll" "${AX_ROOT_DIR}/${AX_PREBUILT_DIR}/bin/${THIRD_PARTY_ARCH}plainlua.dll"
$<TARGET_FILE_DIR:${APP_NAME}>) $<TARGET_FILE_DIR:${APP_NAME}>)
endfunction(adxe_link_lua_prebuilt) endfunction(axis_link_lua_prebuilt)

View File

@ -9,23 +9,23 @@ function(AssureOutOfSourceBuilds)
# disallow in-source builds # disallow in-source builds
if("${srcdir}" STREQUAL "${bindir}") if("${srcdir}" STREQUAL "${bindir}")
message("######################################################") message("######################################################")
message("# adxe should not be configured & built in the adxe source directory") message("# axis should not be configured & built in the axis source directory")
message("# You must run cmake in a build directory.") message("# You must run cmake in a build directory.")
message("# For example:") message("# For example:")
message("# mkdir Cocos ; cd Cocos") message("# mkdir axis ; cd axis")
message("# download & unpack the adxe tarball") message("# download & unpack the axis tarball")
message("# mkdir adxe-Build") message("# mkdir build")
message("# this will create the following directory structure") message("# this will create the following directory structure")
message("#") message("#")
message("# Cocos") message("# axis")
message("# +--adxe") message("# +--axis")
message("# +--adxe-Build") message("# +--build")
message("#") message("#")
message("# Then you can proceed to configure and build") message("# Then you can proceed to configure and build")
message("# by using the following commands") message("# by using the following commands")
message("#") message("#")
message("# cd adxe-Build") message("# cd build")
message("# cmake ../adxe # or ccmake, or cmake-gui ") message("# cmake ../axis # or ccmake, or cmake-gui ")
message("# make") message("# make")
message("#") message("#")
message("# NOTE: Given that you already tried to make an in-source build") message("# NOTE: Given that you already tried to make an in-source build")
@ -33,7 +33,7 @@ function(AssureOutOfSourceBuilds)
message("# in your source tree. run 'git status' to find them and") message("# in your source tree. run 'git status' to find them and")
message("# remove them by doing:") message("# remove them by doing:")
message("#") message("#")
message("# cd Cocos/adxe") message("# cd axis")
message("# git clean -n -d") message("# git clean -n -d")
message("# git clean -f -d") message("# git clean -f -d")
message("# git checkout --") message("# git checkout --")

View File

@ -10,14 +10,14 @@ CMake is an open-source, cross-platform family of tools designed to build, test
``` ```
if the CMake version is lower than 3.14, please upgrade. if the CMake version is lower than 3.14, please upgrade.
2. You should use **out-of-source** builds, this means you need to create a different directory than **adxe** to execute the `cmake` command. 2. You should use **out-of-source** builds, this means you need to create a different directory than **axis** to execute the `cmake` command.
## Step by Step ## Step by Step
### Linux ### Linux
```sh ```sh
cd adxe cd axis
mkdir linux-build && cd linux-build mkdir linux-build && cd linux-build
cmake .. cmake ..
make make
@ -28,35 +28,35 @@ Execute `make help` to see all build targets, `make <target>` build specified ta
### Generate Visual Studio projects ### Generate Visual Studio projects
```sh ```sh
cd adxe cd axis
mkdir win32-build mkdir win32-build
cmake -B win32-build -G"Visual Studio 16 2019" cmake -B win32-build -G"Visual Studio 16 2019"
# build # build
cmake --build win32-build --config Debug cmake --build win32-build --config Debug
``` ```
or open **adxe.sln** in Explorer to use the generated project. or open **axis.sln** in Explorer to use the generated project.
### Generate macOS Project ### Generate macOS Project
```sh ```sh
cd adxe cd axis
mkdir mac-build mkdir mac-build
cmake -B mac-build -GXcode cmake -B mac-build -GXcode
open mac-build/adxe.xcodeproj open mac-build/axis.xcodeproj
``` ```
### Generate iOS Project ### Generate iOS Project
```sh ```sh
cd adxe cd axis
mkdir ios-build mkdir ios-build
cmake -B ios-build -GXcode -DCMAKE_TOOLCHAIN_FILE=cmake/ios.mini.cmake cmake -B ios-build -GXcode -DCMAKE_TOOLCHAIN_FILE=cmake/ios.mini.cmake
open ios-build/adxe.xcodeproj open ios-build/axis.xcodeproj
``` ```
#### How do I customize the generated Xcode project? #### How do I customize the generated Xcode project?
Xcode project settings that you want to affect both the app project and the adxe library project should be passed on the command Xcode project settings that you want to affect both the app project and the axis library project should be passed on the command
line when invoking `cmake`. line when invoking `cmake`.
Xcode project settings that you want to affect the app project only shoudl be put into the its `CMakeLists.txt` file. Xcode project settings that you want to affect the app project only shoudl be put into the its `CMakeLists.txt` file.
@ -75,7 +75,7 @@ set_xcode_property(${APP_NAME} XXX "Value")
##### Deployment Target ##### Deployment Target
As explained above, pass this on the command line so both the app the adxe are built using the same version: As explained above, pass this on the command line so both the app the axis are built using the same version:
For iOS pass `-DCMAKE_XCODE_ATTRIBUTE_IPHONEOS_DEPLOYMENT_TARGET=version`, where `version` is `9.0`, `10.0`, etc. For iOS pass `-DCMAKE_XCODE_ATTRIBUTE_IPHONEOS_DEPLOYMENT_TARGET=version`, where `version` is `9.0`, `10.0`, etc.
@ -103,7 +103,7 @@ from `cmake`:
### Android Studio ### Android Studio
We use the Gradle for Android applications, and Gradle use cmake to build the native code, see [gradle.properties](https://github.com/c4games/adxe/blob/84be684e3858393a6f3efc50e3f95d4e0ac92a20/tests/cpp-empty-test/proj.android/gradle.properties#L38): `PROP_NDK_MODE`, it controls how native builds work. We use the Gradle for Android applications, and Gradle use cmake to build the native code, see [gradle.properties](https://github.com/c4games/axis/blob/84be684e3858393a6f3efc50e3f95d4e0ac92a20/tests/cpp-empty-test/proj.android/gradle.properties#L38): `PROP_NDK_MODE`, it controls how native builds work.
```sh ```sh
# android native code build type # android native code build type
@ -113,7 +113,7 @@ We use the Gradle for Android applications, and Gradle use cmake to build the na
PROP_BUILD_TYPE=cmake PROP_BUILD_TYPE=cmake
``` ```
If you want to add cmake build arguments, please add it at [external Native Build](https://github.com/c4games/adxe/blob/84be684e3858393a6f3efc50e3f95d4e0ac92a20/tests/cpp-empty-test/proj.android/app/build.gradle#L25) block of __app/build.gradle__ file. If you want to add cmake build arguments, please add it at [external Native Build](https://github.com/c4games/axis/blob/84be684e3858393a6f3efc50e3f95d4e0ac92a20/tests/cpp-empty-test/proj.android/app/build.gradle#L25) block of __app/build.gradle__ file.
## Build Options ## Build Options
@ -131,7 +131,7 @@ If you want to add cmake build arguments, please add it at [external Native Buil
1. __`-H -B`__, `-H` specify the CMake project Home directory, `-B` specify CMake-generated project binary directory. for example 1. __`-H -B`__, `-H` specify the CMake project Home directory, `-B` specify CMake-generated project binary directory. for example
* `-H..\adxe -Bmsvc_build` the generated native project's location will be `msvc_build` directory. * `-H..\axis -Bmsvc_build` the generated native project's location will be `msvc_build` directory.
1. __`--build <dir>`__, build a CMake-generated project binary tree, for example 1. __`--build <dir>`__, build a CMake-generated project binary tree, for example

View File

@ -25,7 +25,7 @@
# THE SOFTWARE. # THE SOFTWARE.
# ****************************************************************************/ # ****************************************************************************/
# this CMakeLists is to generate Cocos2d-x Engine Library # this CMakeLists is to generate Axis Engine Library
# build axis # build axis
# build axislua if AX_ENABLE_EXT_LUA=ON # build axislua if AX_ENABLE_EXT_LUA=ON
@ -119,11 +119,11 @@ add_subdirectory(${AXIS_ROOT_PATH}/thirdparty ${ENGINE_BINARY_PATH}/thirdparty)
target_link_libraries(${AXIS_CORE_LIB} thirdparty) target_link_libraries(${AXIS_CORE_LIB} thirdparty)
# add base macro define and compile options # add base macro define and compile options
use_cocos2dx_compile_define(${AXIS_CORE_LIB}) use_axis_compile_define(${AXIS_CORE_LIB})
use_cocos2dx_compile_options(${AXIS_CORE_LIB}) use_axis_compile_options(${AXIS_CORE_LIB})
# use all platform related system libs # use all platform related system libs
use_cocos2dx_libs_depend(${AXIS_CORE_LIB}) use_axis_libs_depend(${AXIS_CORE_LIB})
target_include_directories(${AXIS_CORE_LIB} target_include_directories(${AXIS_CORE_LIB}
PUBLIC ${AXIS_ROOT_PATH} PUBLIC ${AXIS_ROOT_PATH}

View File

@ -33,7 +33,7 @@ NS_CC_BEGIN
CC_DLL const char* axisVersion() CC_DLL const char* axisVersion()
{ {
return "adxe-1.0.0b8"; return "adxe-1.0.0b9";
} }
CC_DLL const char* cocos2dVersion() CC_DLL const char* cocos2dVersion()

View File

@ -35,7 +35,7 @@ THE SOFTWARE.
NS_CC_BEGIN NS_CC_BEGIN
extern const char* adxeVersion(); extern const char* axisVersion();
Configuration* Configuration::s_sharedConfiguration = nullptr; Configuration* Configuration::s_sharedConfiguration = nullptr;
@ -66,7 +66,7 @@ Configuration::Configuration()
bool Configuration::init() bool Configuration::init()
{ {
_valueDict["adxe.version"] = Value(adxeVersion()); _valueDict["adxe.version"] = Value(axisVersion());
#if CC_ENABLE_PROFILERS #if CC_ENABLE_PROFILERS
_valueDict["adxe.compiled_with_profiler"] = Value(true); _valueDict["adxe.compiled_with_profiler"] = Value(true);

View File

@ -70,7 +70,7 @@
NS_CC_BEGIN NS_CC_BEGIN
extern const char* adxeVersion(void); extern const char* axisVersion(void);
#define PROMPT "> " #define PROMPT "> "
#define DEFAULT_COMMAND_SEPARATOR '|' #define DEFAULT_COMMAND_SEPARATOR '|'
@ -1562,7 +1562,7 @@ void Console::commandUpload(socket_native_type fd)
void Console::commandVersion(socket_native_type fd, std::string_view /*args*/) void Console::commandVersion(socket_native_type fd, std::string_view /*args*/)
{ {
Console::Utility::mydprintf(fd, "%s\n", adxeVersion()); Console::Utility::mydprintf(fd, "%s\n", axisVersion());
} }
// helper free functions // helper free functions

View File

@ -33,7 +33,6 @@ THE SOFTWARE.
#include "axis.h" #include "axis.h"
#define COCOS2D_VERSION 0x00040000 #define COCOS2D_VERSION 0x00040000
#define ENGINEX_VERSION ADXE_VERSION
NS_CC_BEGIN NS_CC_BEGIN

View File

@ -24,7 +24,7 @@
THE SOFTWARE. THE SOFTWARE.
****************************************************************************/ ****************************************************************************/
#if CC_TARGET_PLATFORM == CC_PLATFORM_WIN32 && defined(ADXE_HAVE_WEBVIEW2) #if CC_TARGET_PLATFORM == CC_PLATFORM_WIN32 && defined(AXIS_HAVE_WEBVIEW2)
# include "UIWebViewImpl-win32.h" # include "UIWebViewImpl-win32.h"
# include "UIWebView.h" # include "UIWebView.h"

View File

@ -28,7 +28,7 @@
#include "platform/CCPlatformConfig.h" #include "platform/CCPlatformConfig.h"
#if CC_TARGET_PLATFORM == CC_PLATFORM_WIN32 && defined(ADXE_HAVE_WEBVIEW2) #if CC_TARGET_PLATFORM == CC_PLATFORM_WIN32 && defined(AXIS_HAVE_WEBVIEW2)
# include <string> # include <string>
# include "CCStdC.h" # include "CCStdC.h"

View File

@ -52,7 +52,7 @@ if(NOT DEFINED BUILD_ENGINE_DONE) # to test HelloCpp into root project
set(CMAKE_MODULE_PATH ${AXIS_ROOT_PATH}/cmake/Modules/) set(CMAKE_MODULE_PATH ${AXIS_ROOT_PATH}/cmake/Modules/)
include(CocosBuildSet) include(AxisBuildSet)
set(_AX_USE_PREBUILT FALSE) set(_AX_USE_PREBUILT FALSE)
if (WIN32 AND DEFINED AX_PREBUILT_DIR AND IS_DIRECTORY ${AXIS_ROOT_PATH}/${AX_PREBUILT_DIR}) if (WIN32 AND DEFINED AX_PREBUILT_DIR AND IS_DIRECTORY ${AXIS_ROOT_PATH}/${AX_PREBUILT_DIR})
set(_AX_USE_PREBUILT TRUE) set(_AX_USE_PREBUILT TRUE)

View File

@ -1,5 +1,5 @@
# default value for cocos2dx extensions modules to Build # default value for axis extensions modules to Build
# currently 7 extensions # currently 7 extensions
# extensions dependicies: COCOSTUDIO may depend on spine & dragonBones if they are present in buildset # extensions dependicies: COCOSTUDIO may depend on spine & dragonBones if they are present in buildset

View File

@ -1,6 +1,6 @@
#include "ImGuiPresenter.h" #include "ImGuiPresenter.h"
#include <assert.h> #include <assert.h>
#include "imgui_impl_adxe.h" #include "imgui_impl_axis.h"
#include "imgui_internal.h" #include "imgui_internal.h"
// TODO: mac metal // TODO: mac metal

View File

@ -54,7 +54,7 @@
// 2017-08-25: Inputs: MousePos set to -FLT_MAX,-FLT_MAX when mouse is unavailable/missing (instead of -1,-1). // 2017-08-25: Inputs: MousePos set to -FLT_MAX,-FLT_MAX when mouse is unavailable/missing (instead of -1,-1).
// 2016-10-15: Misc: Added a void* user_data parameter to Clipboard function handlers. // 2016-10-15: Misc: Added a void* user_data parameter to Clipboard function handlers.
#include "imgui_impl_adxe.h" #include "imgui_impl_axis.h"
#include "cocos2d.h" #include "cocos2d.h"
#include "renderer/backend/Backend.h" #include "renderer/backend/Backend.h"
#include <functional> #include <functional>

View File

@ -30,7 +30,7 @@ target_include_directories(${LIB_NAME}
if(NOT IS_DIRECTORY ${CMAKE_CURRENT_LIST_DIR}/Core) if(NOT IS_DIRECTORY ${CMAKE_CURRENT_LIST_DIR}/Core)
message(AUTHOR_WARNING "Downloading liblive2d-core-dev ...") message(AUTHOR_WARNING "Downloading liblive2d-core-dev ...")
file(DOWNLOAD https://github.com/axis-project/extensions/releases/download/v1.0.0/Live2D-4.4-Core.zip ${CMAKE_CURRENT_LIST_DIR}/Core.zip) file(DOWNLOAD https://github.com/axis-project/archive/releases/download/v1.0.0/Live2D-4.4-Core.zip ${CMAKE_CURRENT_LIST_DIR}/Core.zip)
file(ARCHIVE_EXTRACT INPUT ${CMAKE_CURRENT_LIST_DIR}/Core.zip DESTINATION ${CMAKE_CURRENT_LIST_DIR}/) file(ARCHIVE_EXTRACT INPUT ${CMAKE_CURRENT_LIST_DIR}/Core.zip DESTINATION ${CMAKE_CURRENT_LIST_DIR}/)
endif() endif()

View File

@ -1,7 +1,7 @@
#include "TranslationHelper.h" #include "TranslationHelper.h"
#include "PackageItem.h" #include "PackageItem.h"
#include "UIPackage.h" #include "UIPackage.h"
#if defined(ADXE_VERSION) #if defined(AXIS_VERSION)
#include "pugixml/pugixml.hpp" #include "pugixml/pugixml.hpp"
#else #else
#include "tinyxml2/tinyxml2.h" #include "tinyxml2/tinyxml2.h"
@ -21,7 +21,7 @@ void TranslationHelper::loadFromXML(const char* xmlString, size_t nBytes)
{ {
TranslationHelper::strings.clear(); TranslationHelper::strings.clear();
#if defined(ADXE_VERSION) #if defined(AXIS_VERSION)
pugi::xml_document doc; pugi::xml_document doc;
if (doc.load_buffer(xmlString, nBytes)) { if (doc.load_buffer(xmlString, nBytes)) {
auto root = doc.document_element(); auto root = doc.document_element();

View File

@ -643,7 +643,7 @@ void UIPackage::loadAtlas(PackageItem* item)
return; return;
} }
#if defined(ADXE_VERSION) #if defined(AXIS_VERSION)
if(image->getFileType() == Image::Format::ETC1) if(image->getFileType() == Image::Format::ETC1)
tex->updateWithImage(image, Texture2D::getDefaultAlphaPixelFormat(), 1); tex->updateWithImage(image, Texture2D::getDefaultAlphaPixelFormat(), 1);
#else #else
@ -769,7 +769,7 @@ void UIPackage::loadFont(PackageItem* item)
{ {
item->bitmapFont = BitmapFont::create(); item->bitmapFont = BitmapFont::create();
auto bitmapFont = item->bitmapFont; auto bitmapFont = item->bitmapFont;
#if defined(ADXE_VERSION) #if defined(AXIS_VERSION)
auto fontAtlas = bitmapFont->resetFontAtlas(bitmapFont->newFontAtlas()); auto fontAtlas = bitmapFont->resetFontAtlas(bitmapFont->newFontAtlas());
#else #else
auto fontAtlas = bitmapFont->resetFontAtlas(bitmapFont->createFontAtlas()); auto fontAtlas = bitmapFont->resetFontAtlas(bitmapFont->createFontAtlas());

View File

@ -16,7 +16,7 @@ public:
static BitmapFont* create(); static BitmapFont* create();
virtual int* getHorizontalKerningForTextUTF32(const std::u32string& text, int &outNumLetters) const override; virtual int* getHorizontalKerningForTextUTF32(const std::u32string& text, int &outNumLetters) const override;
# if defined(ADXE_VERSION) # if defined(AXIS_VERSION)
virtual cocos2d::FontAtlas* newFontAtlas() override { return new cocos2d::FontAtlas(this); } virtual cocos2d::FontAtlas* newFontAtlas() override { return new cocos2d::FontAtlas(this); }
#else #else
virtual cocos2d::FontAtlas* createFontAtlas() override { return new cocos2d::FontAtlas(*this); } virtual cocos2d::FontAtlas* createFontAtlas() override { return new cocos2d::FontAtlas(*this); }

View File

@ -100,7 +100,7 @@ void FUISprite::setScaleByTile(bool value)
void FUISprite::setGrayed(bool value) void FUISprite::setGrayed(bool value)
{ {
#if defined(ADXE_VERSION) #if defined(AXIS_VERSION)
Sprite::setProgramState(value ? backend::ProgramType::GRAY_SCALE : backend::ProgramType::POSITION_TEXTURE_COLOR); Sprite::setProgramState(value ? backend::ProgramType::GRAY_SCALE : backend::ProgramType::POSITION_TEXTURE_COLOR);
#elif COCOS2D_VERSION >= 0x00040000 #elif COCOS2D_VERSION >= 0x00040000
auto isETC1 = getTexture() && getTexture()->getAlphaTextureName(); auto isETC1 = getTexture() && getTexture()->getAlphaTextureName();

View File

@ -87,7 +87,7 @@ SkeletonBatch::~SkeletonBatch () {
backend::ProgramState* SkeletonBatch::updateCommandPipelinePS(SkeletonCommand* command, backend::ProgramState* programState) backend::ProgramState* SkeletonBatch::updateCommandPipelinePS(SkeletonCommand* command, backend::ProgramState* programState)
{ {
auto& currentState = command->getPipelineDescriptor().programState; auto& currentState = command->getPipelineDescriptor().programState;
#if defined(ADXE_VERSION) #if defined(AXIS_VERSION)
if(currentState == nullptr || currentState->getProgram() != programState->getProgram() || currentState->getUniformID() != programState->getUniformID()) { if(currentState == nullptr || currentState->getProgram() != programState->getProgram() || currentState->getUniformID() != programState->getUniformID()) {
#else #else
if(currentState == nullptr || currentState->getProgram() != programState->getProgram()) { if(currentState == nullptr || currentState->getProgram() != programState->getProgram()) {

View File

@ -52,7 +52,7 @@ if(NOT DEFINED BUILD_ENGINE_DONE) # to test HelloCpp into root project
set(CMAKE_MODULE_PATH ${AXIS_ROOT_PATH}/cmake/Modules/) set(CMAKE_MODULE_PATH ${AXIS_ROOT_PATH}/cmake/Modules/)
include(CocosBuildSet) include(AxisBuildSet)
set(_AX_USE_PREBUILT FALSE) set(_AX_USE_PREBUILT FALSE)
if (WIN32 AND DEFINED AX_PREBUILT_DIR AND IS_DIRECTORY ${AXIS_ROOT_PATH}/${AX_PREBUILT_DIR}) if (WIN32 AND DEFINED AX_PREBUILT_DIR AND IS_DIRECTORY ${AXIS_ROOT_PATH}/${AX_PREBUILT_DIR})
set(_AX_USE_PREBUILT TRUE) set(_AX_USE_PREBUILT TRUE)
@ -198,8 +198,8 @@ if (AX_WITH_YAML_CPP)
endif() endif()
if (_AX_USE_PREBUILT) # support windows only if (_AX_USE_PREBUILT) # support windows only
include(${AXIS_ROOT_PATH}/cmake/Modules/CocosConfigDefine.cmake) include(${AXIS_ROOT_PATH}/cmake/Modules/AxisConfigDefine.cmake)
use_cocos2dx_compile_define(${APP_NAME}) use_axis_compile_define(${APP_NAME})
include(${AXIS_ROOT_PATH}/cmake/Modules/AxisLinkHelpers.cmake) include(${AXIS_ROOT_PATH}/cmake/Modules/AxisLinkHelpers.cmake)
axis_link_cxx_prebuilt(${APP_NAME} ${AXIS_ROOT_PATH} ${AX_PREBUILT_DIR}) axis_link_cxx_prebuilt(${APP_NAME} ${AXIS_ROOT_PATH} ${AX_PREBUILT_DIR})

View File

@ -54,7 +54,7 @@ if(NOT DEFINED BUILD_ENGINE_DONE) # to test HelloLua into root project
set(CMAKE_MODULE_PATH ${AXIS_ROOT_PATH}/cmake/Modules/) set(CMAKE_MODULE_PATH ${AXIS_ROOT_PATH}/cmake/Modules/)
include(CocosBuildSet) include(AxisBuildSet)
set(AX_ENABLE_EXT_LUA ON) set(AX_ENABLE_EXT_LUA ON)
set(_AX_USE_PREBUILT FALSE) set(_AX_USE_PREBUILT FALSE)
@ -212,8 +212,8 @@ if (AX_WITH_YAML_CPP)
endif() endif()
if (_AX_USE_PREBUILT) # support windows only if (_AX_USE_PREBUILT) # support windows only
include(${AXIS_ROOT_PATH}/cmake/Modules/CocosConfigDefine.cmake) include(${AXIS_ROOT_PATH}/cmake/Modules/AxisConfigDefine.cmake)
use_cocos2dx_compile_define(${APP_NAME}) use_axis_compile_define(${APP_NAME})
include(${AXIS_ROOT_PATH}/cmake/Modules/AxisLinkHelpers.cmake) include(${AXIS_ROOT_PATH}/cmake/Modules/AxisLinkHelpers.cmake)
axis_link_lua_prebuilt(${APP_NAME} ${AXIS_ROOT_PATH} ${AX_PREBUILT_DIR}) axis_link_lua_prebuilt(${APP_NAME} ${AXIS_ROOT_PATH} ${AX_PREBUILT_DIR})

View File

@ -29,7 +29,7 @@ if(NOT DEFINED BUILD_ENGINE_DONE)
set(CMAKE_MODULE_PATH ${AXIS_ROOT_PATH}/cmake/Modules/) set(CMAKE_MODULE_PATH ${AXIS_ROOT_PATH}/cmake/Modules/)
include(CocosBuildSet) include(AxisBuildSet)
add_subdirectory(${AXIS_ROOT_PATH}/core ${ENGINE_BINARY_PATH}/axis/core) add_subdirectory(${AXIS_ROOT_PATH}/core ${ENGINE_BINARY_PATH}/axis/core)
endif() endif()

View File

@ -42,7 +42,7 @@ if(NOT DEFINED BUILD_ENGINE_DONE)
endif() endif()
set(CMAKE_MODULE_PATH ${AXIS_ROOT_PATH}/cmake/Modules/) set(CMAKE_MODULE_PATH ${AXIS_ROOT_PATH}/cmake/Modules/)
include(CocosBuildSet) include(AxisBuildSet)
add_subdirectory(${AXIS_ROOT_PATH}/core ${ENGINE_BINARY_PATH}/axis/core) add_subdirectory(${AXIS_ROOT_PATH}/core ${ENGINE_BINARY_PATH}/axis/core)
endif() endif()

View File

@ -45,7 +45,7 @@ if(NOT DEFINED BUILD_ENGINE_DONE)
set(CMAKE_MODULE_PATH ${AXIS_ROOT_PATH}/cmake/Modules/) set(CMAKE_MODULE_PATH ${AXIS_ROOT_PATH}/cmake/Modules/)
include(CocosBuildSet) include(AxisBuildSet)
add_subdirectory(${AXIS_ROOT_PATH}/core ${ENGINE_BINARY_PATH}/axis/core) add_subdirectory(${AXIS_ROOT_PATH}/core ${ENGINE_BINARY_PATH}/axis/core)
endif() endif()

View File

@ -19,7 +19,7 @@ if(NOT DEFINED BUILD_ENGINE_DONE)
endif() endif()
set(CMAKE_MODULE_PATH ${AXIS_ROOT_PATH}/cmake/Modules/) set(CMAKE_MODULE_PATH ${AXIS_ROOT_PATH}/cmake/Modules/)
include(CocosBuildSet) include(AxisBuildSet)
set(AX_ENABLE_EXT_LUA ON) set(AX_ENABLE_EXT_LUA ON)
set(_AX_USE_PREBUILT FALSE) set(_AX_USE_PREBUILT FALSE)