3
0
Fork 0
forked from mirrors/nixpkgs

conan: 1.53.0 -> 2.0.0

Diff: conan-io/conan@refs/tags/1.53.0...2.0.0

Changelog: https://github.com/conan-io/conan/releases/tag/2.0.0
This commit is contained in:
Fabian Affolter 2023-02-24 21:38:15 +01:00
parent 1e21c5807c
commit 7ce7852e0f

View file

@ -1,68 +1,31 @@
{ lib
, stdenv
, python3
, fetchFromGitHub
, git
, pkg-config
, python3
, zlib
}:
# Note:
# 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 {
python3.pkgs.buildPythonApplication rec {
pname = "conan";
version = "1.53.0";
version = "2.0.0";
format = "setuptools";
src = fetchFromGitHub {
owner = "conan-io";
repo = "conan";
rev = "refs/tags/${version}";
hash = "sha256-2DNDNdZO1D30egOiYa3qw8F2xsUTBOm/CHv07v5OrC8=";
hash = "sha256-yx/MO5QAVKnGraQXJitXxaZooLtBqa+L04s73DwiE14=";
};
postPatch = ''
substituteInPlace conans/requirements.txt \
--replace 'PyYAML>=3.11, <6.0' 'PyYAML>=3.11'
'';
propagatedBuildInputs = with newPython.pkgs; [
propagatedBuildInputs = with python3.pkgs; [
bottle
colorama
python-dateutil
deprecation
distro
fasteners
future
jinja2
node-semver
patch-ng
pluginbase
pygments
@ -70,7 +33,6 @@ in newPython.pkgs.buildPythonApplication rec {
pylint # Not in `requirements.txt` but used in hooks, see https://github.com/conan-io/conan/pull/6152
pyyaml
requests
six
tqdm
urllib3
] ++ lib.optionals stdenv.isDarwin [
@ -80,19 +42,44 @@ in newPython.pkgs.buildPythonApplication rec {
];
nativeCheckInputs = [
pkg-config
git
] ++ (with newPython.pkgs; [
codecov
pkg-config
zlib
] ++ (with python3.pkgs; [
mock
nose
parameterized
pytest-xdist
pytestCheckHook
webtest
]);
# TODO: reenable tests now that we fetch tests w/ the source from GitHub.
# Not enabled right now due to time constraints/failing tests that I didn't have time to track down
doCheck = false;
pythonImportsCheck = [
"conan"
];
pytestFlagsArray = [
"-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; {
description = "Decentralized and portable C/C++ package manager";