Merge pull request #218078 from fabaff/conan-bump

conan: 1.53.0 -> 2.0.0
This commit is contained in:
Fabian Affolter 2023-02-26 12:20:27 +01:00 committed by GitHub
commit e4d894be9f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -1,57 +1,31 @@
{ lib, stdenv, python3, fetchFromGitHub, git, pkg-config }: { lib
, stdenv
, fetchFromGitHub
, git
, pkg-config
, python3
, zlib
}:
# Note: python3.pkgs.buildPythonApplication rec {
# Conan has specific dependency demands; check
# https://github.com/conan-io/conan/blob/master/conans/requirements.txt
# https://github.com/conan-io/conan/blob/master/conans/requirements_server.txt
# on the release branch/commit we're packaging.
#
# Two approaches are used here to deal with that:
# Pinning the specific versions it wants in `newPython`,
# and using `substituteInPlace conans/requirements.txt ...`
# in `postPatch` to allow newer versions when we know
# (e.g. from changelogs) that they are compatible.
let newPython = python3.override {
packageOverrides = self: super: {
node-semver = super.node-semver.overridePythonAttrs (oldAttrs: rec {
version = "0.6.1";
src = oldAttrs.src.override {
inherit version;
sha256 = "1dv6mjsm67l1razcgmq66riqmsb36wns17mnipqr610v0z0zf5j0";
};
});
distro = super.distro.overridePythonAttrs (oldAttrs: rec {
version = "1.5.0";
src = oldAttrs.src.override {
inherit version;
hash = "sha256-Dlh1auOPvY/DAg1UutuOrhfFudy+04ixe7Vbilko35I=";
};
});
};
};
in newPython.pkgs.buildPythonApplication rec {
version = "1.53.0";
pname = "conan"; pname = "conan";
version = "2.0.0";
format = "setuptools";
src = fetchFromGitHub { src = fetchFromGitHub {
owner = "conan-io"; owner = "conan-io";
repo = "conan"; repo = "conan";
rev = version; rev = "refs/tags/${version}";
hash = "sha256-2DNDNdZO1D30egOiYa3qw8F2xsUTBOm/CHv07v5OrC8="; hash = "sha256-yx/MO5QAVKnGraQXJitXxaZooLtBqa+L04s73DwiE14=";
}; };
propagatedBuildInputs = with newPython.pkgs; [ propagatedBuildInputs = with python3.pkgs; [
bottle bottle
colorama colorama
python-dateutil python-dateutil
deprecation
distro distro
fasteners fasteners
future
jinja2 jinja2
node-semver
patch-ng patch-ng
pluginbase pluginbase
pygments pygments
@ -59,33 +33,58 @@ in newPython.pkgs.buildPythonApplication rec {
pylint # Not in `requirements.txt` but used in hooks, see https://github.com/conan-io/conan/pull/6152 pylint # Not in `requirements.txt` but used in hooks, see https://github.com/conan-io/conan/pull/6152
pyyaml pyyaml
requests requests
six
tqdm tqdm
urllib3 urllib3
] ++ lib.optionals stdenv.isDarwin [ idna cryptography pyopenssl ]; ] ++ lib.optionals stdenv.isDarwin [
idna
cryptography
pyopenssl
];
nativeCheckInputs = [ nativeCheckInputs = [
pkg-config
git git
] ++ (with newPython.pkgs; [ pkg-config
codecov zlib
] ++ (with python3.pkgs; [
mock mock
nose
parameterized parameterized
pytest-xdist
pytestCheckHook
webtest webtest
]); ]);
# TODO: reenable tests now that we fetch tests w/ the source from GitHub. pythonImportsCheck = [
# Not enabled right now due to time constraints/failing tests that I didn't have time to track down "conan"
doCheck = false; ];
postPatch = '' pytestFlagsArray = [
substituteInPlace conans/requirements.txt --replace 'PyYAML>=3.11, <6.0' 'PyYAML>=3.11' "-n"
''; "$NIX_BUILD_CORES"
];
disabledTests = [
# Tests require network access
"TestFTP"
];
disabledTestPaths = [
# Requires cmake, meson, autotools, apt-get, etc.
"conans/test/functional/command/new_test.py"
"conans/test/functional/command/test_install_deploy.py"
"conans/test/functional/layout/test_editable_cmake.py"
"conans/test/functional/layout/test_in_subfolder.py"
"conans/test/functional/layout/test_source_folder.py"
"conans/test/functional/toolchains/"
"conans/test/functional/tools_versions_test.py"
"conans/test/functional/tools/system/package_manager_test.py"
"conans/test/functional/util/test_cmd_args_to_string.py"
"conans/test/unittests/tools/env/test_env_files.py"
];
meta = with lib; { meta = with lib; {
homepage = "https://conan.io";
description = "Decentralized and portable C/C++ package manager"; description = "Decentralized and portable C/C++ package manager";
homepage = "https://conan.io";
changelog = "https://github.com/conan-io/conan/releases/tag/${version}";
license = licenses.mit; license = licenses.mit;
maintainers = with maintainers; [ HaoZeke ]; maintainers = with maintainers; [ HaoZeke ];
}; };