From f28dae0379ebcc63522ef36c3cb67553e27cd2bf Mon Sep 17 00:00:00 2001 From: Jordan Williams Date: Tue, 10 Oct 2023 16:39:44 -0500 Subject: [PATCH] libmount: Add version 2.40, use Meson --- recipes/libmount/all/conanfile.py | 12 +- recipes/libmount/config.yml | 2 + recipes/libmount/meson/conandata.yml | 4 + recipes/libmount/meson/conanfile.py | 109 ++++++++++++++++++ .../meson/test_package/CMakeLists.txt | 7 ++ .../libmount/meson/test_package/conanfile.py | 26 +++++ .../meson/test_package/test_package.c | 16 +++ 7 files changed, 168 insertions(+), 8 deletions(-) create mode 100644 recipes/libmount/meson/conandata.yml create mode 100644 recipes/libmount/meson/conanfile.py create mode 100644 recipes/libmount/meson/test_package/CMakeLists.txt create mode 100644 recipes/libmount/meson/test_package/conanfile.py create mode 100644 recipes/libmount/meson/test_package/test_package.c diff --git a/recipes/libmount/all/conanfile.py b/recipes/libmount/all/conanfile.py index ea963a9965bfc4..b9ec541d71963d 100644 --- a/recipes/libmount/all/conanfile.py +++ b/recipes/libmount/all/conanfile.py @@ -72,11 +72,7 @@ def package(self): rm(self, "*.la", os.path.join(self.package_folder, "lib")) def package_info(self): - self.cpp_info.components["libblkid"].libs = ["blkid"] - self.cpp_info.components["libblkid"].set_property("pkg_config_name", "blkid") - - self.cpp_info.components["libmount"].libs = ["mount"] - self.cpp_info.components["libmount"].system_libs = ["rt"] - self.cpp_info.components["libmount"].includedirs.append(os.path.join("include", "libmount")) - self.cpp_info.components["libmount"].set_property("pkg_config_name", "mount") - self.cpp_info.components["libmount"].requires = ["libblkid"] + self.cpp_info.libs = ["mount", "blkid"] + self.cpp_info.system_libs = ["rt"] + self.cpp_info.includedirs.append(os.path.join("include", "libmount")) + self.cpp_info.set_property("pkg_config_name", "mount") diff --git a/recipes/libmount/config.yml b/recipes/libmount/config.yml index 867141253ca23f..40f9f0f053f450 100644 --- a/recipes/libmount/config.yml +++ b/recipes/libmount/config.yml @@ -1,4 +1,6 @@ versions: + "2.40-rc2": + folder: meson "2.39.2": folder: all "2.39": diff --git a/recipes/libmount/meson/conandata.yml b/recipes/libmount/meson/conandata.yml new file mode 100644 index 00000000000000..eb446937a807eb --- /dev/null +++ b/recipes/libmount/meson/conandata.yml @@ -0,0 +1,4 @@ +sources: + "2.40-rc2": + url: "https://github.com/util-linux/util-linux/archive/refs/tags/v2.40-rc2.tar.gz" + sha256: "0fdf4a47eb415639cfcdf2ca4cb76919ca971dc173ce5bb034857a77188a7c27" diff --git a/recipes/libmount/meson/conanfile.py b/recipes/libmount/meson/conanfile.py new file mode 100644 index 00000000000000..74d1c20a54036c --- /dev/null +++ b/recipes/libmount/meson/conanfile.py @@ -0,0 +1,109 @@ +from conan import ConanFile +from conan.errors import ConanInvalidConfiguration +from conan.tools.env import VirtualBuildEnv +from conan.tools.files import copy, get, replace_in_file, rm, rmdir +from conan.tools.layout import basic_layout +from conan.tools.meson import Meson, MesonToolchain +import os + +required_conan_version = ">=1.53.0" + + +class LibmountConan(ConanFile): + name = "libmount" + description = ( + "The libmount library is used to parse /etc/fstab, /etc/mtab and " + "/proc/self/mountinfo files, manage the mtab file, evaluate mount options, etc" + ) + topics = ("mount", "linux", "util-linux") + url = "https://github.com/conan-io/conan-center-index" + homepage = "https://git.kernel.org/pub/scm/utils/util-linux/util-linux.git" + license = "LGPL-2.1-or-later" + package_type = "library" + settings = "os", "arch", "compiler", "build_type" + options = { + "shared": [True, False], + "fPIC": [True, False], + } + default_options = { + "shared": False, + "fPIC": True, + } + + def configure(self): + if self.options.shared: + self.options.rm_safe("fPIC") + self.settings.rm_safe("compiler.cppstd") + self.settings.rm_safe("compiler.libcxx") + + def layout(self): + basic_layout(self, src_folder="src") + + def requirements(self): + self.requires("linux-headers-generic/6.5.9") + + def validate(self): + if self.settings.os != "Linux": + raise ConanInvalidConfiguration(f"{self.ref} only supports Linux") + + def build_requirements(self): + self.tool_requires("bison/3.8.2") + self.tool_requires("flex/2.6.4") + self.tool_requires("meson/1.3.2") + if not self.conf.get("tools.gnu:pkg_config", default=False, check_type=str): + self.tool_requires("pkgconf/2.1.0") + + def source(self): + get(self, **self.conan_data["sources"][self.version], strip_root=True) + + def generate(self): + tc = MesonToolchain(self) + for dependency, _value in self.dependencies.direct_host.items(): + if dependency.ref.name == "linux-headers-generic": + for includedir in self.dependencies.direct_host["linux-headers-generic"].cpp_info.includedirs: + tc.c_args.append(f"-I{includedir}") + break + tc.project_options["auto_features"] = "disabled" + tc.project_options["build-libblkid"] = "enabled" + tc.project_options["build-libmount"] = "enabled" + # Enable libutil for older versions of glibc which still provide an actual libutil library. + tc.project_options["libutil"] = "enabled" + tc.generate() + virtual_build_env = VirtualBuildEnv(self) + virtual_build_env.generate() + + def _patch_sources(self): + # Disable translations. + replace_in_file(self, os.path.join(self.source_folder, "meson.build"), "subdir('po')", "#subdir('po')") + # Disable tests for libmount. + replace_in_file(self, os.path.join(self.source_folder, "libmount", "meson.build"), "foreach libmount_test: libmount_tests", "foreach libmount_test: []") + + def build(self): + self._patch_sources() + meson = Meson(self) + meson.configure() + meson.build() + + def package(self): + copy(self, "COPYING", os.path.join(self.source_folder, "libmount"), os.path.join(self.package_folder, "licenses")) + copy(self, "COPYING.LGPL-2.1-or-later", os.path.join(self.source_folder, "Documentation", "licenses"), os.path.join(self.package_folder, "licenses")) + meson = Meson(self) + meson.install() + rmdir(self, os.path.join(self.package_folder, "sbin")) + rmdir(self, os.path.join(self.package_folder, "share")) + rmdir(self, os.path.join(self.package_folder, "lib", "pkgconfig")) + rmdir(self, os.path.join(self.package_folder, "usr")) + rm(self, "*.la", os.path.join(self.package_folder, "lib")) + # util-linux always builds both the shared and static libraries of libblkid, so delete the one that isn't needed. + rm(self, "libblkid.a" if self.options.shared else "libblkid.so*", os.path.join(self.package_folder, "lib")) + + def package_info(self): + self.cpp_info.components["libblkid"].libs = ["blkid"] + self.cpp_info.components["libblkid"].set_property("pkg_config_name", "blkid") + self.cpp_info.components["libblkid"].requires = ["linux-headers-generic::linux-headers-generic"] + + self.cpp_info.components["libmount"].libs = ["mount"] + self.cpp_info.components["libmount"].system_libs = ["rt"] + self.cpp_info.components["libmount"].includedirs.append(os.path.join("include", "libmount")) + self.cpp_info.components["libmount"].set_property("pkg_config_name", "mount") + self.cpp_info.components["libmount"].requires = ["libblkid"] diff --git a/recipes/libmount/meson/test_package/CMakeLists.txt b/recipes/libmount/meson/test_package/CMakeLists.txt new file mode 100644 index 00000000000000..4b97a71d1061a5 --- /dev/null +++ b/recipes/libmount/meson/test_package/CMakeLists.txt @@ -0,0 +1,7 @@ +cmake_minimum_required(VERSION 3.15) +project(test_package LANGUAGES C) + +find_package(libmount REQUIRED CONFIG) + +add_executable(${PROJECT_NAME} test_package.c) +target_link_libraries(${PROJECT_NAME} PRIVATE libmount::libmount) diff --git a/recipes/libmount/meson/test_package/conanfile.py b/recipes/libmount/meson/test_package/conanfile.py new file mode 100644 index 00000000000000..0a6bc68712d901 --- /dev/null +++ b/recipes/libmount/meson/test_package/conanfile.py @@ -0,0 +1,26 @@ +from conan import ConanFile +from conan.tools.build import can_run +from conan.tools.cmake import CMake, cmake_layout +import os + + +class TestPackageConan(ConanFile): + settings = "os", "arch", "compiler", "build_type" + generators = "CMakeToolchain", "CMakeDeps", "VirtualRunEnv" + test_type = "explicit" + + def layout(self): + cmake_layout(self) + + def requirements(self): + self.requires(self.tested_reference_str) + + def build(self): + cmake = CMake(self) + cmake.configure() + cmake.build() + + def test(self): + if can_run(self): + bin_path = os.path.join(self.cpp.build.bindirs[0], "test_package") + self.run(bin_path, env="conanrun") diff --git a/recipes/libmount/meson/test_package/test_package.c b/recipes/libmount/meson/test_package/test_package.c new file mode 100644 index 00000000000000..d4e4d653742e8c --- /dev/null +++ b/recipes/libmount/meson/test_package/test_package.c @@ -0,0 +1,16 @@ +#include + +#include +#include + +int main() +{ + struct libmnt_context *ctx = mnt_new_context(); + if (!ctx) { + printf("failed to initialize libmount\n"); + return EXIT_FAILURE; + } + printf("path to fstab: %s", mnt_get_fstab_path()); + mnt_free_context(ctx); + return EXIT_SUCCESS; +}