Skip to content

Commit

Permalink
Merge branch 'master' into migrate/makefile-project-workspace-creator
Browse files Browse the repository at this point in the history
  • Loading branch information
valgur authored Nov 7, 2023
2 parents 003388d + 0077d76 commit 0ae6b64
Show file tree
Hide file tree
Showing 81 changed files with 1,064 additions and 648 deletions.
29 changes: 25 additions & 4 deletions docs/package_templates/autotools_package/all/conanfile.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,9 +4,10 @@
from conan.tools.build import check_min_cppstd, cross_building
from conan.tools.env import Environment, VirtualBuildEnv, VirtualRunEnv
from conan.tools.files import apply_conandata_patches, copy, export_conandata_patches, get, rm, rmdir
from conan.tools.gnu import Autotools, AutotoolsToolchain, AutotoolsDeps, PkgConfigDeps
from conan.tools.gnu import Autotools, AutotoolsDeps, AutotoolsToolchain, PkgConfigDeps
from conan.tools.layout import basic_layout
from conan.tools.microsoft import is_msvc, unix_path
from conan.tools.scm import Version
import os


Expand Down Expand Up @@ -41,6 +42,21 @@ class PackageConan(ConanFile):
"with_foobar": True,
}

@property
def _min_cppstd(self):
return 14

# in case the project requires C++14/17/20/... the minimum compiler version should be listed
@property
def _compilers_minimum_version(self):
return {
"apple-clang": "10",
"clang": "7",
"gcc": "7",
"msvc": "191",
"Visual Studio": "15",
}

@property
def _settings_build(self):
return getattr(self, "settings_build", self.settings)
Expand All @@ -58,8 +74,8 @@ def configure(self):
if self.options.shared:
self.options.rm_safe("fPIC")
# for plain C projects only
self.settings.rm_safe("compiler.libcxx")
self.settings.rm_safe("compiler.cppstd")
self.settings.rm_safe("compiler.libcxx")

def layout(self):
# src_folder must use the same source folder name the project
Expand All @@ -74,7 +90,12 @@ def requirements(self):
def validate(self):
# validate the minimum cpp standard supported. Only for C++ projects
if self.settings.compiler.get_safe("cppstd"):
check_min_cppstd(self, 11)
check_min_cppstd(self, self._min_cppstd)
minimum_version = self._compilers_minimum_version.get(str(self.settings.compiler), False)
if minimum_version and Version(self.settings.compiler.version) < minimum_version:
raise ConanInvalidConfiguration(
f"{self.ref} requires C++{self._min_cppstd}, which your compiler does not support."
)
if self.settings.os not in ["Linux", "FreeBSD", "Macos"]:
raise ConanInvalidConfiguration(f"{self.ref} is not supported on {self.settings.os}.")

Expand Down Expand Up @@ -155,7 +176,7 @@ def build(self):
autotools.make()

def package(self):
copy(self, pattern="LICENSE", src=self.source_folder, dst=os.path.join(self.package_folder, "licenses"))
copy(self, "LICENSE", self.source_folder, os.path.join(self.package_folder, "licenses"))
autotools = Autotools(self)
autotools.install()

Expand Down
30 changes: 15 additions & 15 deletions docs/package_templates/cmake_package/all/conanfile.py
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
from conan import ConanFile
from conan.errors import ConanInvalidConfiguration
from conan.tools.microsoft import check_min_vs, is_msvc_static_runtime, is_msvc
from conan.tools.files import apply_conandata_patches, export_conandata_patches, get, copy, rm, rmdir, replace_in_file
from conan.tools.build import check_min_cppstd
from conan.tools.scm import Version
from conan.tools.cmake import CMake, CMakeDeps, CMakeToolchain, cmake_layout
from conan.tools.env import VirtualBuildEnv
from conan.tools.files import apply_conandata_patches, copy, export_conandata_patches, get, replace_in_file, rm, rmdir
from conan.tools.microsoft import check_min_vs, is_msvc, is_msvc_static_runtime
from conan.tools.scm import Version
import os


Expand Down Expand Up @@ -40,15 +40,17 @@ class PackageConan(ConanFile):

@property
def _min_cppstd(self):
return 17
return 14

# in case the project requires C++14/17/20/... the minimum compiler version should be listed
@property
def _compilers_minimum_version(self):
return {
"gcc": "7",
"clang": "7",
"apple-clang": "10",
"clang": "7",
"gcc": "7",
"msvc": "191",
"Visual Studio": "15",
}

# no exports_sources attribute, but export_sources(self) method instead
Expand All @@ -64,8 +66,8 @@ def configure(self):
if self.options.shared:
self.options.rm_safe("fPIC")
# for plain C projects only
self.settings.rm_safe("compiler.libcxx")
self.settings.rm_safe("compiler.cppstd")
self.settings.rm_safe("compiler.libcxx")

def layout(self):
# src_folder must use the same source folder name the project
Expand All @@ -79,13 +81,11 @@ def validate(self):
# validate the minimum cpp standard supported. For C++ projects only
if self.settings.compiler.cppstd:
check_min_cppstd(self, self._min_cppstd)
check_min_vs(self, 191)
if not is_msvc(self):
minimum_version = self._compilers_minimum_version.get(str(self.settings.compiler), False)
if minimum_version and Version(self.settings.compiler.version) < minimum_version:
raise ConanInvalidConfiguration(
f"{self.ref} requires C++{self._min_cppstd}, which your compiler does not support."
)
minimum_version = self._compilers_minimum_version.get(str(self.settings.compiler), False)
if minimum_version and Version(self.settings.compiler.version) < minimum_version:
raise ConanInvalidConfiguration(
f"{self.ref} requires C++{self._min_cppstd}, which your compiler does not support."
)
# in case it does not work in another configuration, it should validated here too
if is_msvc(self) and self.options.shared:
raise ConanInvalidConfiguration(f"{self.ref} can not be built as shared on Visual Studio and msvc.")
Expand Down Expand Up @@ -131,7 +131,7 @@ def build(self):
cmake.build()

def package(self):
copy(self, pattern="LICENSE", dst=os.path.join(self.package_folder, "licenses"), src=self.source_folder)
copy(self, "LICENSE", self.source_folder, os.path.join(self.package_folder, "licenses"))
cmake = CMake(self)
cmake.install()

Expand Down
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
cmake_minimum_required(VERSION 3.15)

project(test_package C) # if the project is pure C
# project(test_package CXX) # if the project uses c++
project(test_package LANGUAGES C) # if the project is pure C
# project(test_package LANGUAGES CXX) # if the project uses c++

find_package(package REQUIRED CONFIG)

Expand Down
18 changes: 9 additions & 9 deletions docs/package_templates/header_only/all/conanfile.py
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
from conan import ConanFile
from conan.errors import ConanInvalidConfiguration
from conan.tools.build import check_min_cppstd
from conan.tools.files import apply_conandata_patches, export_conandata_patches, get, copy
from conan.tools.files import apply_conandata_patches, copy, export_conandata_patches, get
from conan.tools.layout import basic_layout
from conan.tools.scm import Version
import os
Expand Down Expand Up @@ -35,11 +35,11 @@ def _min_cppstd(self):
@property
def _compilers_minimum_version(self):
return {
"Visual Studio": "15",
"apple-clang": "10",
"clang": "7",
"gcc": "7",
"msvc": "191",
"gcc": "5",
"clang": "5",
"apple-clang": "5.1",
"Visual Studio": "15",
}

# Use the export_sources(self) method instead of the exports_sources attribute.
Expand Down Expand Up @@ -85,12 +85,12 @@ def build(self):

# Copy all files to the package folder
def package(self):
copy(self, pattern="LICENSE", dst=os.path.join(self.package_folder, "licenses"), src=self.source_folder)
copy(self, "LICENSE", self.source_folder, os.path.join(self.package_folder, "licenses"))
copy(
self,
pattern="*.h",
dst=os.path.join(self.package_folder, "include"),
src=os.path.join(self.source_folder, "include"),
"*.h",
os.path.join(self.source_folder, "include"),
os.path.join(self.package_folder, "include"),
)

def package_info(self):
Expand Down
4 changes: 2 additions & 2 deletions docs/package_templates/meson_package/all/conanfile.py
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,7 @@ class PackageConan(ConanFile):

@property
def _min_cppstd(self):
return 17
return 14

# in case the project requires C++14/17/20/... the minimum compiler version should be listed
@property
Expand Down Expand Up @@ -98,7 +98,7 @@ def validate(self):
# if another tool than the compiler or Meson is required to build the project (pkgconf, bison, flex etc)
def build_requirements(self):
# CCI policy assumes that Meson may not be installed on consumers machine
self.tool_requires("meson/1.2.2")
self.tool_requires("meson/1.2.3")
# pkgconf is largely used by Meson, it should be added in build requirement when there are dependencies
if not self.conf.get("tools.gnu:pkg_config", default=False, check_type=str):
self.tool_requires("pkgconf/2.0.3")
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ def requirements(self):
self.requires(self.tested_reference_str)

def build_requirements(self):
self.tool_requires("meson/1.2.2")
self.tool_requires("meson/1.2.3")
if not self.conf.get("tools.gnu:pkg_config", default=False, check_type=str):
self.tool_requires("pkgconf/2.0.3")

Expand Down
12 changes: 6 additions & 6 deletions docs/package_templates/msbuild_package/all/conanfile.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
from conan.errors import ConanInvalidConfiguration
from conan.tools.files import apply_conandata_patches, copy, export_conandata_patches, get, replace_in_file, rm
from conan.tools.layout import basic_layout
from conan.tools.microsoft import is_msvc, MSBuild, MSBuildDeps, MSBuildToolchain
from conan.tools.microsoft import MSBuild, MSBuildDeps, MSBuildToolchain, is_msvc
import os


Expand Down Expand Up @@ -44,8 +44,8 @@ def configure(self):
if self.options.shared:
self.options.rm_safe("fPIC")
# for plain C projects only
self.settings.rm_safe("compiler.libcxx")
self.settings.rm_safe("compiler.cppstd")
self.settings.rm_safe("compiler.libcxx")

def layout(self):
basic_layout(self, src_folder="src")
Expand Down Expand Up @@ -125,10 +125,10 @@ def build(self):
msbuild.build(sln="project_2017.sln")

def package(self):
copy(self, "LICENSE", src=self.source_folder, dst=os.path.join(self.package_folder, "licenses"))
copy(self, "*.lib", src=self.source_folder, dst=os.path.join(self.package_folder, "lib"), keep_path=False)
copy(self, "*.dll", src=self.source_folder, dst=os.path.join(self.package_folder, "bin"), keep_path=False)
copy(self, "*.h", src=os.path.join(self.source_folder, "include"), dst=os.path.join(self.package_folder, "include"))
copy(self, "LICENSE", self.source_folder, os.path.join(self.package_folder, "licenses"))
copy(self, "*.lib", self.source_folder, os.path.join(self.package_folder, "lib"), keep_path=False)
copy(self, "*.dll", self.source_folder, os.path.join(self.package_folder, "bin"), keep_path=False)
copy(self, "*.h", os.path.join(self.source_folder, "include"), os.path.join(self.package_folder, "include"))

def package_info(self):
self.cpp_info.libs = ["package_lib"]
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
cmake_minimum_required(VERSION 3.15)

project(test_package C) # if the project is pure C
project(test_package CXX) # if the project uses c++
project(test_package LANGUAGES C) # if the project is pure C
# project(test_package LANGUAGES CXX) # if the project uses C++

find_package(package REQUIRED CONFIG)

Expand Down
10 changes: 5 additions & 5 deletions docs/package_templates/prebuilt_tool_package/all/conanfile.py
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
from conan import ConanFile
from conan.tools.files import get, copy
from conan.tools.scm import Version
from conan.errors import ConanInvalidConfiguration
from conan.tools.files import copy, get
from conan.tools.scm import Version
import os


Expand Down Expand Up @@ -48,9 +48,9 @@ def build(self):
# copy all needed files to the package folder
def package(self):
# a license file is always mandatory
copy(self, pattern="LICENSE", dst=os.path.join(self.package_folder, "licenses"), src=self.source_folder)
copy(self, pattern="*.exe", dst=os.path.join(self.package_folder, "bin"), src=self.source_folder)
copy(self, pattern="foo", dst=os.path.join(self.package_folder, "bin"), src=self.source_folder)
copy(self, "LICENSE", self.source_folder, os.path.join(self.package_folder, "licenses"))
copy(self, "*.exe", self.source_folder, os.path.join(self.package_folder, "bin"))
copy(self, "foo", self.source_folder, os.path.join(self.package_folder, "bin"))

def package_info(self):
# folders not used for pre-built binaries
Expand Down
28 changes: 7 additions & 21 deletions recipes/c-blosc2/all/conandata.yml
Original file line number Diff line number Diff line change
@@ -1,4 +1,7 @@
sources:
"2.11.1":
url: "https://github.com/Blosc/c-blosc2/archive/v2.11.1.tar.gz"
sha256: "1e9923e0f026eb6e6caee608b4b9a523837806076fc79409055a6386cf5de1ea"
"2.10.5":
url: "https://github.com/Blosc/c-blosc2/archive/v2.10.5.tar.gz"
sha256: "a88f94bf839c1371aab8207a6a43698ceb92c72f65d0d7fe5b6e59f24c138b4d"
Expand All @@ -20,16 +23,11 @@ sources:
"2.4.3":
url: "https://github.com/Blosc/c-blosc2/archive/v2.4.3.tar.gz"
sha256: "d4aa5e0794598794f20ab950e973d44f0d0d9c133ea1a5a07cb200fa54d2e036"
"2.4.2":
url: "https://github.com/Blosc/c-blosc2/archive/v2.4.2.tar.gz"
sha256: "763ded7a6286abd248a79b1560ce8bfda11018b699a450b3e43c529f284a5232"
"2.4.1":
url: "https://github.com/Blosc/c-blosc2/archive/refs/tags/v2.4.1.tar.gz"
sha256: "f09a43bfac563ceda611a213c799ca5359c3b629281e0a4f3a543e692a64a931"
"2.2.0":
url: "https://github.com/Blosc/c-blosc2/archive/refs/tags/v2.2.0.tar.gz"
sha256: "66f9977de26d6bc9ea1c0e623d873c3225e4fff709aa09b3335fd09d41d57c0e"
patches:
"2.11.1":
- patch_file: "patches/2.11.1-0001-fix-cmake.patch"
patch_description: "use cci package"
patch_type: "conan"
"2.10.5":
- patch_file: "patches/2.10.5-0001-fix-cmake.patch"
patch_description: "use cci package"
Expand Down Expand Up @@ -58,15 +56,3 @@ patches:
- patch_file: "patches/2.4.1-0001-fix-cmake.patch"
patch_description: "use cci package"
patch_type: "conan"
"2.4.2":
- patch_file: "patches/2.4.1-0001-fix-cmake.patch"
patch_description: "use cci package"
patch_type: "conan"
"2.4.1":
- patch_file: "patches/2.4.1-0001-fix-cmake.patch"
patch_description: "use cci package"
patch_type: "conan"
"2.2.0":
- patch_file: "patches/2.2.0-0001-fix-cmake.patch"
patch_description: "use cci package"
patch_type: "conan"
15 changes: 11 additions & 4 deletions recipes/c-blosc2/all/conanfile.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
from conan import ConanFile
from conan.errors import ConanInvalidConfiguration
from conan.tools.cmake import CMake, CMakeDeps, CMakeToolchain, cmake_layout
from conan.tools.env import VirtualBuildEnv
from conan.tools.files import export_conandata_patches, apply_conandata_patches, get, copy, rm, rmdir
Expand All @@ -23,7 +24,7 @@ class CBlosc2Conan(ConanFile):
options = {
"shared": [True, False],
"fPIC": [True, False],
"simd_intrinsics": [None, "sse2", "avx2"],
"simd_intrinsics": [None, "sse2", "avx2", "avx512"],
"with_lz4": [True, False],
"with_zlib": [None, "zlib", "zlib-ng", "zlib-ng-compat"],
"with_zstd": [True, False],
Expand Down Expand Up @@ -73,9 +74,14 @@ def requirements(self):
if self.options.with_zstd:
self.requires("zstd/1.5.5")

def validate(self):
if Version(self.version) < "2.11.0" \
and self.info.settings.arch in ["x86", "x86_64"] \
and self.options.simd_intrinsics == "avx512":
raise ConanInvalidConfiguration(f"{self.ref} doesn't support 'avx512' SIMD intrinsics")

def build_requirements(self):
if Version(self.version) >= "2.4.1":
self.tool_requires("cmake/[>=3.16.3 <4]")
self.tool_requires("cmake/[>=3.16.3 <4]")

def source(self):
get(self, **self.conan_data["sources"][self.version], strip_root=True)
Expand All @@ -94,7 +100,8 @@ def generate(self):
tc.cache_variables["BUILD_BENCHMARKS"] = False
tc.cache_variables["BUILD_EXAMPLES"] = False
simd_intrinsics = self.options.get_safe("simd_intrinsics", False)
tc.cache_variables["DEACTIVATE_AVX2"] = simd_intrinsics != "avx2"
tc.cache_variables["DEACTIVATE_AVX2"] = simd_intrinsics not in ["avx2", "avx512"]
tc.cache_variables["DEACTIVATE_AVX512"] = simd_intrinsics != "avx512"
tc.cache_variables["DEACTIVATE_LZ4"] = not bool(self.options.with_lz4)
tc.cache_variables["PREFER_EXTERNAL_LZ4"] = True
tc.cache_variables["DEACTIVATE_ZLIB"] = self.options.with_zlib is None
Expand Down
Loading

0 comments on commit 0ae6b64

Please sign in to comment.