mirror of
https://gitee.com/drabel/LibQQt.git
synced 2025-01-04 10:18:44 +08:00
update add sdk work flow, add fix framework in building path
This commit is contained in:
parent
daa753e077
commit
88b6fd1201
@ -85,15 +85,6 @@ msvc {
|
|||||||
#这个功能可用,可是编译问题比较多,不方便,所以默认不开开。
|
#这个功能可用,可是编译问题比较多,不方便,所以默认不开开。
|
||||||
}
|
}
|
||||||
|
|
||||||
#macOS下必须开开bundle
|
|
||||||
contains(QSYS_PRIVATE, macOS){
|
|
||||||
contains(TEMPLATE, app) {
|
|
||||||
CONFIG += app_bundle
|
|
||||||
} else: contains(TEMPLATE, lib) {
|
|
||||||
CONFIG += lib_bundle
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#################################################################
|
#################################################################
|
||||||
##build lib or link lib
|
##build lib or link lib
|
||||||
#################################################################
|
#################################################################
|
||||||
|
@ -12,13 +12,14 @@
|
|||||||
#在build path修复app (macOS专有)
|
#在build path修复app (macOS专有)
|
||||||
#copy lib
|
#copy lib
|
||||||
#fix bundle路径链接
|
#fix bundle路径链接
|
||||||
defineReplace(add_deploy_with_lib_on_mac) {
|
defineReplace(get_fix_app_bundle) {
|
||||||
|
|
||||||
#need QQT_BUILD_PWD
|
#need QQT_BUILD_PWD
|
||||||
deploy_path = $$1
|
create_command = $$add_mac_sdk()
|
||||||
isEmpty(1): error("add_deploy_with_lib_on_mac(deploy_path) requires one argument")
|
|
||||||
create_command = $$create_mac_sdk()
|
APP_DEST_DIR=$${DESTDIR}
|
||||||
APP_DEST_DIR=$${deploy_path}
|
|
||||||
isEmpty(APP_DEST_DIR):APP_DEST_DIR=.
|
isEmpty(APP_DEST_DIR):APP_DEST_DIR=.
|
||||||
|
|
||||||
command =
|
command =
|
||||||
command += chmod +x $${PWD}/linux_cur_path.sh &&
|
command += chmod +x $${PWD}/linux_cur_path.sh &&
|
||||||
command += . $${PWD}/linux_cur_path.sh &&
|
command += . $${PWD}/linux_cur_path.sh &&
|
||||||
@ -49,14 +50,6 @@ defineReplace(add_deploy_with_lib_on_mac) {
|
|||||||
return ($${command})
|
return ($${command})
|
||||||
}
|
}
|
||||||
|
|
||||||
defineReplace(fix_app_bundle_with_qqt_in_building_path_on_mac) {
|
|
||||||
#need QQT_BUILD_PWD
|
|
||||||
APP_DEST_DIR=$${DESTDIR}
|
|
||||||
isEmpty(APP_DEST_DIR):APP_DEST_DIR=.
|
|
||||||
command = $$add_deploy_with_lib_on_mac($${APP_DEST_DIR})
|
|
||||||
return ($$command)
|
|
||||||
}
|
|
||||||
|
|
||||||
##########################################
|
##########################################
|
||||||
#app的发布函数命令
|
#app的发布函数命令
|
||||||
##########################################
|
##########################################
|
||||||
|
@ -6,6 +6,45 @@
|
|||||||
##依赖add_version.pri
|
##依赖add_version.pri
|
||||||
##please don't modify this pri
|
##please don't modify this pri
|
||||||
################################################
|
################################################
|
||||||
|
THIS_PRI_PWD = $${PWD}
|
||||||
|
|
||||||
|
#在build path修复app (macOS专有)
|
||||||
|
#copy lib
|
||||||
|
#fix bundle路径链接
|
||||||
|
defineReplace(get_add_mac_sdk_fix_building_framework) {
|
||||||
|
|
||||||
|
#need QQT_BUILD_PWD
|
||||||
|
create_command = $$get_add_mac_sdk()
|
||||||
|
|
||||||
|
APP_DEST_DIR=$${DESTDIR}
|
||||||
|
isEmpty(APP_DEST_DIR):APP_DEST_DIR=.
|
||||||
|
|
||||||
|
libname = $$TARGET
|
||||||
|
libname_temp = $${libname}_Temp
|
||||||
|
libname_lower = $$lower($${libname})
|
||||||
|
libmajorver = $$APP_MAJOR_VERSION
|
||||||
|
|
||||||
|
command =
|
||||||
|
command += chmod +x $${THIS_PRI_PWD}/linux_cur_path.sh &&
|
||||||
|
command += . $${THIS_PRI_PWD}/linux_cur_path.sh &&
|
||||||
|
#create temp
|
||||||
|
command += $$MK_DIR $${APP_DEST_DIR}/$${libname_temp}.framework &&
|
||||||
|
#进去
|
||||||
|
command += cd $${APP_DEST_DIR}/$${libname_temp}.framework &&
|
||||||
|
#修复framework里的快捷方式
|
||||||
|
command += $${create_command} &&
|
||||||
|
command += chmod +x $${THIS_PRI_PWD}/linux_cd_path.sh &&
|
||||||
|
command += . $${THIS_PRI_PWD}/linux_cd_path.sh &&
|
||||||
|
#拷贝prl到新的里
|
||||||
|
command += $$COPY $${APP_DEST_DIR}/$${libname}.framework/$${libname}.prl $${APP_DEST_DIR}/$${libname_temp}.framework/$${libname}.prl $$CMD_SEP
|
||||||
|
#del 原先的
|
||||||
|
command += $$RM_DIR $${APP_DEST_DIR}/$${libname}.framework &&
|
||||||
|
#rename 临时的 framework 到原先的
|
||||||
|
command += $$MOVE $${APP_DEST_DIR}/$${libname_temp}.framework $${APP_DEST_DIR}/$${libname}.framework
|
||||||
|
|
||||||
|
#message($$command)
|
||||||
|
return ($${command})
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
################################################
|
################################################
|
||||||
@ -13,7 +52,7 @@
|
|||||||
##variable can be private and default inherit
|
##variable can be private and default inherit
|
||||||
##内部实现
|
##内部实现
|
||||||
################################################
|
################################################
|
||||||
defineReplace(add_sdk_dir_struct) {
|
defineReplace(get_add_sdk_dir_struct) {
|
||||||
#if it's qt library, don't create
|
#if it's qt library, don't create
|
||||||
command =
|
command =
|
||||||
!equals(LIB_SDK_PWD , $$[QT_INSTALL_DATA]){
|
!equals(LIB_SDK_PWD , $$[QT_INSTALL_DATA]){
|
||||||
@ -27,7 +66,7 @@ defineReplace(add_sdk_dir_struct) {
|
|||||||
return ($$command)
|
return ($$command)
|
||||||
}
|
}
|
||||||
|
|
||||||
defineReplace(add_windows_sdk) {
|
defineReplace(get_add_windows_sdk) {
|
||||||
#need cd sdk root
|
#need cd sdk root
|
||||||
|
|
||||||
command =
|
command =
|
||||||
@ -39,7 +78,7 @@ defineReplace(add_windows_sdk) {
|
|||||||
return ($$command)
|
return ($$command)
|
||||||
}
|
}
|
||||||
|
|
||||||
defineReplace(add_linux_sdk) {
|
defineReplace(get_add_linux_sdk) {
|
||||||
#need cd sdk root
|
#need cd sdk root
|
||||||
copy_command = $$get_copy_dir_and_file($${LIB_SRC_PWD}, "*.h*", $${LIB_INC_DIR})
|
copy_command = $$get_copy_dir_and_file($${LIB_SRC_PWD}, "*.h*", $${LIB_INC_DIR})
|
||||||
command =
|
command =
|
||||||
@ -50,7 +89,7 @@ defineReplace(add_linux_sdk) {
|
|||||||
return ($$command)
|
return ($$command)
|
||||||
}
|
}
|
||||||
|
|
||||||
defineReplace(add_mac_sdk){
|
defineReplace(get_add_mac_sdk){
|
||||||
#need cd framework root
|
#need cd framework root
|
||||||
#LIB_BUILD_PWD libname libmajorver
|
#LIB_BUILD_PWD libname libmajorver
|
||||||
libname = $$TARGET
|
libname = $$TARGET
|
||||||
@ -89,13 +128,14 @@ defineReplace(add_mac_sdk){
|
|||||||
command += $$LN $$LIB_BUNDLE_CUR_EXE_FILE $${LIB_BUNDLE_EXE_LINK}
|
command += $$LN $$LIB_BUNDLE_CUR_EXE_FILE $${LIB_BUNDLE_EXE_LINK}
|
||||||
lessThan(QT_MAJOR_VERSION, 5){
|
lessThan(QT_MAJOR_VERSION, 5){
|
||||||
command += $$CMD_SEP
|
command += $$CMD_SEP
|
||||||
command += chmod +x $${PWD}/mac_deploy_qt4.sh $$CMD_SEP
|
command += chmod +x $${THIS_PRI_PWD}/mac_deploy_qt4.sh $$CMD_SEP
|
||||||
command += $${PWD}/mac_deploy_qt4.sh $${LIB_BUNDLE_VER_DIR}/$${libname}
|
command += $${THIS_PRI_PWD}/mac_deploy_qt4.sh $${LIB_BUNDLE_VER_DIR}/$${libname}
|
||||||
}
|
}
|
||||||
return ($$command)
|
return ($$command)
|
||||||
}
|
}
|
||||||
|
|
||||||
defineReplace(add_Qt_lib_pri){
|
#这个函数是支持发布Qt Library用的,add_sdk用到了。
|
||||||
|
defineReplace(get_add_Qt_lib_pri){
|
||||||
#need cd sdk root
|
#need cd sdk root
|
||||||
#LIB_BASE_DIR libname LIB_VERSION MODULE_CNAME
|
#LIB_BASE_DIR libname LIB_VERSION MODULE_CNAME
|
||||||
##write qt_lib_qqtcore.pri
|
##write qt_lib_qqtcore.pri
|
||||||
@ -143,7 +183,8 @@ defineReplace(add_Qt_lib_pri){
|
|||||||
##Lib deploy sdk workflow
|
##Lib deploy sdk workflow
|
||||||
##SDK发布过程
|
##SDK发布过程
|
||||||
################################################
|
################################################
|
||||||
defineReplace(add_sdk_work_flow){
|
|
||||||
|
defineReplace(get_add_sdk_work_flow){
|
||||||
#need cd sdk root
|
#need cd sdk root
|
||||||
|
|
||||||
libname = $$TARGET
|
libname = $$TARGET
|
||||||
@ -151,36 +192,43 @@ defineReplace(add_sdk_work_flow){
|
|||||||
libmajorver = $$APP_MAJOR_VERSION
|
libmajorver = $$APP_MAJOR_VERSION
|
||||||
|
|
||||||
command =
|
command =
|
||||||
|
contains(QSYS_PRIVATE, macOS) {
|
||||||
|
#在编译路径里,创作一次sdk,完成framework链接等的修复工作
|
||||||
|
command += $$get_add_mac_sdk_fix_building_framework() $$CMD_SEP
|
||||||
|
command += echo $$libname fix framework success. $$CMD_SEP
|
||||||
|
}
|
||||||
command += $$RM_DIR $${LIB_SDK_PWD} $$CMD_SEP
|
command += $$RM_DIR $${LIB_SDK_PWD} $$CMD_SEP
|
||||||
command += $$MK_DIR $${LIB_SDK_PWD} $$CMD_SEP
|
command += $$MK_DIR $${LIB_SDK_PWD} $$CMD_SEP
|
||||||
command += $$CD $${LIB_SDK_PWD} $$CMD_SEP
|
command += $$CD $${LIB_SDK_PWD} $$CMD_SEP
|
||||||
command += $$add_sdk_dir_struct() $$CMD_SEP
|
command += $$get_add_sdk_dir_struct() $$CMD_SEP
|
||||||
|
|
||||||
#这里不是目标为Windows才拷贝,而是开发机是Windows就得这么拷贝。
|
#这里不是目标为Windows才拷贝,而是开发机是Windows就得这么拷贝。
|
||||||
#Windows下,Win目标、Android目标都走这里。
|
#Windows下,Win目标、Android目标都走这里。
|
||||||
#contains(QSYS_PRIVATE, Win32|Win64) {
|
#contains(QSYS_PRIVATE, Win32|Win64) {
|
||||||
equals(QMAKE_HOST.os, Windows) {
|
equals(QMAKE_HOST.os, Windows) {
|
||||||
#message(create QQt windows struct library)
|
#message(create lib windows struct library)
|
||||||
command += $$add_windows_sdk() $$CMD_SEP
|
command += $$get_add_windows_sdk() $$CMD_SEP
|
||||||
command += $$COPY $${LIB_BUILD_PWD}\\*.prl lib $$CMD_SEP
|
command += $$COPY $${LIB_BUILD_PWD}\\*.prl lib $$CMD_SEP
|
||||||
} else {
|
} else {
|
||||||
contains(QSYS_PRIVATE, macOS) {
|
contains(QSYS_PRIVATE, macOS) {
|
||||||
#message(create QQt mac bundle framework)
|
#message(create lib mac bundle framework)
|
||||||
command += $$MK_DIR lib/$${libname}.framework $$CMD_SEP
|
command += $$MK_DIR lib/$${libname}.framework $$CMD_SEP
|
||||||
command += $$CD lib/$${libname}.framework $$CMD_SEP
|
command += $$CD lib/$${libname}.framework $$CMD_SEP
|
||||||
command += $$add_mac_sdk() $$CMD_SEP
|
command += $$get_add_mac_sdk() $$CMD_SEP
|
||||||
command += $$CD ../../ $$CMD_SEP
|
command += $$CD ../../ $$CMD_SEP
|
||||||
#create prl
|
#create prl
|
||||||
command += $$COPY $${LIB_BUILD_PWD}/$${libname}.framework/$${libname}.prl lib/$${libname}.framework/$${libname}.prl $$CMD_SEP
|
command += $$COPY $${LIB_BUILD_PWD}/$${libname}.framework/$${libname}.prl lib/$${libname}.framework/$${libname}.prl $$CMD_SEP
|
||||||
} else {
|
} else {
|
||||||
#Android在linux开发机下也会走这里,Android目标,LibQQt可以发布Win和Linux两种格式的SDK。
|
#Android在linux开发机下也会走这里,Android目标,Lib可以发布Win和Linux两种格式的SDK。
|
||||||
#message(create QQt linux struct library)
|
#message(create lib linux struct library)
|
||||||
command += $$add_linux_sdk() $$CMD_SEP
|
command += $$get_add_linux_sdk() $$CMD_SEP
|
||||||
command += $$COPY $${LIB_BUILD_PWD}/*.prl lib $$CMD_SEP
|
command += $$COPY $${LIB_BUILD_PWD}/*.prl lib $$CMD_SEP
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
command += $$add_Qt_lib_pri()
|
command += $$get_add_Qt_lib_pri() $$CMD_SEP
|
||||||
|
command += echo $$libname create sdk success.
|
||||||
|
|
||||||
return ($$command)
|
return ($$command)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -188,7 +236,7 @@ defineReplace(add_sdk_work_flow){
|
|||||||
##Lib deploy sdk work flow
|
##Lib deploy sdk work flow
|
||||||
##初始化SDK发布过程需要的变量
|
##初始化SDK发布过程需要的变量
|
||||||
################################################
|
################################################
|
||||||
defineReplace(add_sdk_private){
|
defineReplace(get_add_sdk_private){
|
||||||
libname = $$TARGET
|
libname = $$TARGET
|
||||||
libname_lower = $$lower($${libname})
|
libname_lower = $$lower($${libname})
|
||||||
libmajorver = $$APP_MAJOR_VERSION
|
libmajorver = $$APP_MAJOR_VERSION
|
||||||
@ -225,12 +273,13 @@ defineReplace(add_sdk_private){
|
|||||||
#create library struct
|
#create library struct
|
||||||
#create platform sdk
|
#create platform sdk
|
||||||
#create mkspec module pri
|
#create mkspec module pri
|
||||||
command = $$add_sdk_work_flow()
|
command = $$get_add_sdk_work_flow()
|
||||||
|
|
||||||
#message ($$command)
|
#message ($$command)
|
||||||
return ($${command})
|
return ($${command})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
################################################
|
################################################
|
||||||
##用户调用的函数
|
##用户调用的函数
|
||||||
################################################
|
################################################
|
||||||
@ -290,7 +339,7 @@ defineTest(add_sdk){
|
|||||||
LIB_LIB_PWD~=s,/,\\,g
|
LIB_LIB_PWD~=s,/,\\,g
|
||||||
}
|
}
|
||||||
|
|
||||||
command += $$add_sdk_private()
|
command += $$get_add_sdk_private()
|
||||||
message($$command)
|
message($$command)
|
||||||
QMAKE_POST_LINK += $$command
|
QMAKE_POST_LINK += $$command
|
||||||
|
|
||||||
|
@ -55,3 +55,5 @@ add_sdk()
|
|||||||
|
|
||||||
#包含lib的header.pri用于公开给用户头文件。
|
#包含lib的header.pri用于公开给用户头文件。
|
||||||
include (lib_header.pri)
|
include (lib_header.pri)
|
||||||
|
message($$CONFIG)
|
||||||
|
message($$TEMPLATE)
|
||||||
|
@ -6,3 +6,7 @@ QQtBasedLibTest::QQtBasedLibTest()
|
|||||||
//pline() << res ( "xxx.png" );
|
//pline() << res ( "xxx.png" );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -35,6 +35,6 @@ FORMS += \
|
|||||||
|
|
||||||
system(touch main.cpp)
|
system(touch main.cpp)
|
||||||
include (../../multi-link/add_base_manager.pri)
|
include (../../multi-link/add_base_manager.pri)
|
||||||
|
add_deploy_lib(QQt)
|
||||||
add_deploy()
|
add_deploy()
|
||||||
message($$QMAKE_POST_LINK)
|
message($$QMAKE_POST_LINK)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user