about summary refs log tree commit diff
path: root/nixpkgs/pkgs/development/python-modules/python-dateutil/default.nix
diff options
context:
space:
mode:
Diffstat (limited to 'nixpkgs/pkgs/development/python-modules/python-dateutil/default.nix')
-rw-r--r--nixpkgs/pkgs/development/python-modules/python-dateutil/default.nix47
1 files changed, 47 insertions, 0 deletions
diff --git a/nixpkgs/pkgs/development/python-modules/python-dateutil/default.nix b/nixpkgs/pkgs/development/python-modules/python-dateutil/default.nix
new file mode 100644
index 000000000000..dd7cc0f2ea1a
--- /dev/null
+++ b/nixpkgs/pkgs/development/python-modules/python-dateutil/default.nix
@@ -0,0 +1,47 @@
+{ lib
+, buildPythonPackage
+, fetchPypi
+, setuptools-scm
+, six
+}:
+
+buildPythonPackage rec {
+  pname = "python-dateutil";
+  version = "2.9.0.post0";
+  pyproject = true;
+
+  src = fetchPypi {
+    inherit pname version;
+    hash = "sha256-N91UII2n4c2HU4ghfV4A69QXkkn5D7ckN+kaNUWaCtM=";
+  };
+
+  postPatch = ''
+    substituteInPlace pyproject.toml \
+      --replace-fail "setuptools_scm<8.0" "setuptools_scm"
+  '';
+
+  nativeBuildInputs = [ setuptools-scm ];
+
+  propagatedBuildInputs = [ six ];
+
+  # cyclic dependency: tests need freezegun, which depends on python-dateutil
+  doCheck = false;
+
+  pythonImportsCheck = [
+    "dateutil.easter"
+    "dateutil.parser"
+    "dateutil.relativedelta"
+    "dateutil.rrule"
+    "dateutil.tz"
+    "dateutil.utils"
+    "dateutil.zoneinfo"
+  ];
+
+  meta = with lib; {
+    changelog = "https://github.com/dateutil/dateutil/blob/${version}/NEWS";
+    description = "Powerful extensions to the standard datetime module";
+    homepage = "https://github.com/dateutil/dateutil/";
+    license = with licenses; [ asl20 bsd3 ];
+    maintainers = with maintainers; [ dotlambda ];
+  };
+}