example 'cl-repl': add files for android 15 (using Qt6.9)

This commit is contained in:
pls.153 2025-08-15 10:56:43 +02:00
parent 395b6f2145
commit ee72fc8847
5 changed files with 177 additions and 4 deletions

View file

@ -0,0 +1,161 @@
LISP_FILES = $$files(lisp/*) app.asd make.lisp
android {
32bit {
ECL = $$(ECL_ANDROID_32)
} else {
ECL = $$(ECL_ANDROID)
}
lisp.commands = $$ECL/../ecl-android-host/bin/ecl \
-norc -shell $$PWD/make.lisp
} else:ios {
lisp.commands = $$(ECL_IOS)/../ecl-ios-host/bin/ecl \
-norc -shell $$PWD/make.lisp
} else:unix {
lisp.commands = /usr/local/bin/ecl -shell $$PWD/make.lisp
} else:win32 {
lisp.commands = ecl.exe -shell $$PWD/make.lisp
}
lisp.input = LISP_FILES
win32: lisp.output = tmp/app.lib
!win32: lisp.output = tmp/libapp.a
QMAKE_EXTRA_COMPILERS += lisp
win32: PRE_TARGETDEPS = tmp/app.lib
!win32: PRE_TARGETDEPS = tmp/libapp.a
QT += quick qml quickcontrols2
TEMPLATE = app
CONFIG += c++17 no_keywords release
DEFINES += DESKTOP_APP INI_LISP INI_ASDF INI_ECL_CONTRIB QT_EXTENSION NO_USB
INCLUDEPATH = /usr/local/include
ECL_VERSION = $$lower($$system(ecl -v))
ECL_VERSION = $$replace(ECL_VERSION, " ", "-")
LIBS = -L/usr/local/lib -lecl
LIBS += -L/usr/local/lib/$$ECL_VERSION
LIBS += -lasdf -lecl-help -ldeflate -lecl-cdb -lecl-curl -lql-minitar -lsockets
DESTDIR = .
TARGET = app
OBJECTS_DIR = tmp
MOC_DIR = tmp
linux: LIBS += -L../../../platforms/linux/lib
macx: LIBS += -L../../../platforms/macos/lib
win32: LIBS += -L../../../platforms/windows/lib
win32 {
LIBS += -lws2_32
RC_ICONS = platforms/windows/icon.ico
include(../../src/windows.pri)
}
android {
DEFINES += NO_TEXT_HANDLES NO_USB
DEFINES -= DESKTOP_APP
INCLUDEPATH = $$ECL/include
ECL_VERSION = $$lower($$system($$ECL/../ecl-android-host/bin/ecl -v))
ECL_VERSION = $$replace(ECL_VERSION, " ", "-")
LIBS = -L$$ECL/lib -lecl
LIBS += -L$$ECL/lib/$$ECL_VERSION
LIBS += -lasdf -lecl-help -ldeflate -lecl-cdb -lecl-curl -lql-minitar -lsockets
LIBS += -L../../../platforms/android/lib
equals(QT_MAJOR_VERSION, 6) {
QT += core-private
}
lessThan(QT_MAJOR_VERSION, 6) {
QT += androidextras
}
ANDROID_MIN_SDK_VERSION = 28
ANDROID_TARGET_SDK_VERSION = 35
ANDROID_EXTRA_LIBS += $$ECL/lib/libecl.so
ANDROID_EXTRA_LIBS += /home/polos/lqml/platforms/android/lib/libsqlite3.so # for Quicklisp libs
ANDROID_PACKAGE_SOURCE_DIR = ../platforms/android
# OpenSSL libs can be downloaded from: https://github.com/KDAB/android_openssl
32bit {
SSL_PATH = ../../../platforms/android/lib32
} else {
SSL_PATH = /home/polos/lqml/platforms/android/lib
}
ANDROID_EXTRA_LIBS += $$SSL_PATH/libcrypto.so $$SSL_PATH/libssl.so
32bit {
ANDROID_ABIS = "armeabi-v7a"
} else {
ANDROID_ABIS = "arm64-v8a"
}
}
ios {
DEFINES += NO_TEXT_HANDLES DISABLE_SMART_QUOTES NO_USB
DEFINES -= DESKTOP_APP
INCLUDEPATH = $$(ECL_IOS)/include
ECL_VERSION = $$lower($$system($ECL_IOS/../ecl-ios-host/bin/ecl -v))
ECL_VERSION = $$replace(ECL_VERSION, " ", "-")
LIBS = -L$$(ECL_IOS)/lib -lecl
LIBS += -leclatomic -leclffi -leclgc -leclgmp
LIBS += -L$$(ECL_IOS)/lib/$$ECL_VERSION
LIBS += -lasdf -lecl-help -ldeflate -lecl-cdb -lecl-curl -lql-minitar -lsockets
LIBS += -L../../../platforms/ios/lib
QMAKE_INFO_PLIST = platforms/ios/Info.plist
QMAKE_ASSET_CATALOGS += platforms/ios/Assets.xcassets
assets.files = $$files($$PWD/platforms/ios/assets)
QMAKE_BUNDLE_DATA += assets
launch.files = platforms/ios/designable.storyboard platforms/img/logo.png
QMAKE_BUNDLE_DATA += launch
}
32bit {
android {
equals(QT_MAJOR_VERSION, 6) {
LIBS += -llqml32_armeabi-v7a
}
lessThan(QT_MAJOR_VERSION, 6) {
LIBS += -llqml32
}
}
!android {
LIBS += -llqml32
}
LIBS += -llisp32
} else {
android {
equals(QT_MAJOR_VERSION, 6) {
LIBS += -llqml_arm64-v8a
}
lessThan(QT_MAJOR_VERSION, 6) {
LIBS += -llqml
}
}
!android {
LIBS += -llqml
}
LIBS += -llisp
}
LIBS += -Ltmp -lapp
INCLUDEPATH += ../../../src/cpp
HEADERS += ../../src/cpp/main.h cpp/qt.h
SOURCES += ../../src/cpp/main.cpp cpp/qt.cpp
#unix {
# QT += serialport
# HEADERS += cpp/usb/usb.h
# SOURCES += cpp/usb/usb.cpp
#}
RESOURCES += $$files(qml/*)
RESOURCES += $$files(i18n/*.qm)
lupdate_only {
SOURCES += i18n/tr.h
}

View file

@ -0,0 +1,5 @@
android {
packagingOptions.jniLibs.useLegacyPackaging true // add for APK compression
//...
}

View file

@ -0,0 +1,7 @@
<?xml version="1.0" encoding="UTF-8"?>
<resources>
<style name="splashScreenTheme">
<item name="android:windowBackground">@drawable/splashscreen</item>
<item name="android:windowOptOutEdgeToEdgeEnforcement">true</item>
</style>
</resources>

View file

@ -71,8 +71,8 @@ android {
QT += androidextras QT += androidextras
} }
ANDROID_MIN_SDK_VERSION = 21 # set >= 25 when using Qt6 ANDROID_MIN_SDK_VERSION = 21
ANDROID_TARGET_SDK_VERSION = 34 # starting from 35 you need to use Qt6, NDK >= 25 ANDROID_TARGET_SDK_VERSION = 34
ANDROID_EXTRA_LIBS += $$ECL/lib/libecl.so ANDROID_EXTRA_LIBS += $$ECL/lib/libecl.so
ANDROID_EXTRA_LIBS += ../../../platforms/android/lib/libsqlite3.so # for Quicklisp libs ANDROID_EXTRA_LIBS += ../../../platforms/android/lib/libsqlite3.so # for Quicklisp libs
ANDROID_PACKAGE_SOURCE_DIR = ../platforms/android ANDROID_PACKAGE_SOURCE_DIR = ../platforms/android

View file

@ -1,4 +1,4 @@
;;; for Qt6 & NDK 25 ;;; for Qt6.9, NDK 27
(in-package :cl-user) (in-package :cl-user)
@ -29,7 +29,7 @@
(setf c::*cc* (let ((path (or (probe-file (cc *ndk-toolchain* (setf c::*cc* (let ((path (or (probe-file (cc *ndk-toolchain*
"/bin/" "/bin/"
(if *32bit* "armv7a-linux-androideabi" *arch-triple*) (if *32bit* "armv7a-linux-androideabi" *arch-triple*)
"25-clang")) "27-clang"))
(error "clang compiler not found")))) (error "clang compiler not found"))))
(namestring path)) (namestring path))
c::*ld* (cc *ndk-toolchain* "/bin/" *arch-triple* "-ld") c::*ld* (cc *ndk-toolchain* "/bin/" *arch-triple* "-ld")