mirror of
https://github.com/amnezia-vpn/amnezia-client.git
synced 2026-06-24 02:00:24 +07:00
conan: use lib linking instead of QT_EXTRA_LIBS for OVPN
This commit is contained in:
@@ -51,9 +51,4 @@ find_package(amnezia-libxray REQUIRED)
|
|||||||
file(COPY ${AMNEZIA_LIBXRAY_PATH} DESTINATION ${CMAKE_CURRENT_SOURCE_DIR}/android/xray/libXray)
|
file(COPY ${AMNEZIA_LIBXRAY_PATH} DESTINATION ${CMAKE_CURRENT_SOURCE_DIR}/android/xray/libXray)
|
||||||
|
|
||||||
find_package(openvpn-pt-android REQUIRED)
|
find_package(openvpn-pt-android REQUIRED)
|
||||||
set_property(TARGET ${PROJECT} APPEND PROPERTY QT_ANDROID_EXTRA_LIBS
|
set(LIBS ${LIBS} amnezia::openvpn-pt-android)
|
||||||
${AMNEZIA_ANDROID_CK_OVPN_PLUGIN_PATH}
|
|
||||||
${AMNEZIA_ANDROID_OVPN3_PATH}
|
|
||||||
${AMNEZIA_ANDROID_OVPNUTIL_PATH}
|
|
||||||
${AMNEZIA_ANDROID_RSAPSS_PATH}
|
|
||||||
)
|
|
||||||
|
|||||||
@@ -16,6 +16,9 @@ class AwgAndroid(ConanFile):
|
|||||||
def layout(self):
|
def layout(self):
|
||||||
cmake_layout(self)
|
cmake_layout(self)
|
||||||
|
|
||||||
|
def build_requirements(self):
|
||||||
|
self.tool_requires("cmake/[>=3.4.1 <4]")
|
||||||
|
|
||||||
def validate(self):
|
def validate(self):
|
||||||
if self.settings.os != "Android":
|
if self.settings.os != "Android":
|
||||||
raise ConanInvalidConfiguration(f"{self.name} v{self.version} does not support {self.settings.os}")
|
raise ConanInvalidConfiguration(f"{self.name} v{self.version} does not support {self.settings.os}")
|
||||||
|
|||||||
@@ -1,42 +1,28 @@
|
|||||||
from conan import ConanFile
|
from conan import ConanFile
|
||||||
from conan.tools.cmake import cmake_layout, CMake, CMakeToolchain
|
from conan.tools.cmake import cmake_layout, CMake, CMakeToolchain
|
||||||
from conan.tools.files import copy
|
from conan.tools.files import copy, collect_libs
|
||||||
from conan.tools.scm import Git
|
from conan.tools.scm import Git
|
||||||
from conan.errors import ConanInvalidConfiguration
|
from conan.errors import ConanInvalidConfiguration
|
||||||
|
|
||||||
import os
|
import os
|
||||||
|
|
||||||
|
|
||||||
class OpenvpnPtAndroid(ConanFile):
|
class OpenvpnPtAndroid(ConanFile):
|
||||||
name = "openvpn-pt-android"
|
name = "openvpn-pt-android"
|
||||||
version = "1.0.0"
|
version = "1.0.0"
|
||||||
package_type = "shared-library"
|
package_type = "shared-library"
|
||||||
|
|
||||||
settings = "os", "arch", "build_type", "compiler"
|
settings = "os", "arch", "build_type", "compiler"
|
||||||
|
|
||||||
# Conan arch → Android ABI
|
|
||||||
_arch_map = {
|
|
||||||
"armv8": "arm64-v8a",
|
|
||||||
"armv7": "armeabi-v7a",
|
|
||||||
"x86": "x86",
|
|
||||||
"x86_64": "x86_64",
|
|
||||||
}
|
|
||||||
|
|
||||||
def layout(self):
|
def layout(self):
|
||||||
cmake_layout(self)
|
cmake_layout(self)
|
||||||
|
|
||||||
def build_requirements(self):
|
def build_requirements(self):
|
||||||
self.tool_requires("swig/4.1.1")
|
self.tool_requires("swig/4.1.1")
|
||||||
self.tool_requires("go/1.26.0")
|
self.tool_requires("go/1.26.0")
|
||||||
|
self.tool_requires("cmake/[>=3.4.1 <4]")
|
||||||
|
|
||||||
def validate(self):
|
def validate(self):
|
||||||
if self.settings.os != "Android":
|
if self.settings.os != "Android":
|
||||||
raise ConanInvalidConfiguration(f"{self.name} only supports Android, got {self.settings.os}")
|
raise ConanInvalidConfiguration(f"{self.name} only supports Android, got {self.settings.os}")
|
||||||
if str(self.settings.arch) not in self._arch_map:
|
|
||||||
raise ConanInvalidConfiguration(f"{self.name} does not support arch {self.settings.arch}")
|
|
||||||
|
|
||||||
def _android_abi(self):
|
|
||||||
return self._arch_map[str(self.settings.arch)]
|
|
||||||
|
|
||||||
def source(self):
|
def source(self):
|
||||||
git = Git(self)
|
git = Git(self)
|
||||||
@@ -58,17 +44,9 @@ class OpenvpnPtAndroid(ConanFile):
|
|||||||
cmake.build(target=["ck_ovpn_plugin_go", "ovpn3", "ovpnutil", "rsapss"])
|
cmake.build(target=["ck_ovpn_plugin_go", "ovpn3", "ovpnutil", "rsapss"])
|
||||||
|
|
||||||
def package(self):
|
def package(self):
|
||||||
build_dir = self.build_folder
|
copy(self, "*.h", src=self.build_folder, dst=os.path.join(self.package_folder, "include"))
|
||||||
copy(self, "libck-ovpn-plugin.so", src=build_dir, dst=os.path.join(self.package_folder, "lib"), keep_path=False)
|
copy(self, "*.so", src=self.build_folder, dst=os.path.join(self.package_folder, "lib"))
|
||||||
for binary in ("ovpn3", "ovpnutil", "rsapss"):
|
|
||||||
copy(self, f"lib{binary}.so", src=build_dir, dst=os.path.join(self.package_folder, "lib"), keep_path=False)
|
|
||||||
|
|
||||||
def package_info(self):
|
def package_info(self):
|
||||||
self.cpp_info.set_property("cmake_target_name", "amnezia::openvpn-pt-android")
|
self.cpp_info.set_property("cmake_target_name", "amnezia::openvpn-pt-android")
|
||||||
self.cpp_info.libs = ["ck-ovpn-plugin", "ovpn3", "ovpnutil", "rsapss"]
|
self.cpp_info.libs = collect_libs(self)
|
||||||
self.cpp_info.set_property("cmake_extra_variables", {
|
|
||||||
"AMNEZIA_ANDROID_CK_OVPN_PLUGIN_PATH": os.path.join(self.package_folder, "lib", "libck-ovpn-plugin.so"),
|
|
||||||
"AMNEZIA_ANDROID_OVPN3_PATH": os.path.join(self.package_folder, "lib", "libovpn3.so"),
|
|
||||||
"AMNEZIA_ANDROID_OVPNUTIL_PATH": os.path.join(self.package_folder, "lib", "libovpnutil.so"),
|
|
||||||
"AMNEZIA_ANDROID_RSAPSS_PATH": os.path.join(self.package_folder, "lib", "librsapss.so"),
|
|
||||||
})
|
|
||||||
|
|||||||
Reference in New Issue
Block a user