summaryrefslogtreecommitdiff
path: root/pkgs/development/python-modules/ipyparallel/default.nix
blob: 23c79b1faa3b7d22bff41a9c366e103b986f3e1b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
{
  lib,
  buildPythonPackage,
  decorator,
  fetchPypi,
  hatchling,
  ipykernel,
  ipython,
  jupyter-client,
  psutil,
  python-dateutil,
  pyzmq,
  tornado,
  tqdm,
  traitlets,
}:

buildPythonPackage rec {
  pname = "ipyparallel";
  version = "9.0.2";
  pyproject = true;

  src = fetchPypi {
    inherit pname version;
    hash = "sha256-2ZLt1pipnUXy2QWa8cmujwhtGu7bPoBDYCmi8o0Gn4M=";
  };

  # We do not need the jupyterlab build dependency, because we do not need to
  # build any JS components; these are present already in the PyPI artifact.
  #
  postPatch = ''
    substituteInPlace pyproject.toml \
      --replace '"jupyterlab==4.*",' ""
  '';

  build-system = [ hatchling ];

  dependencies = [
    decorator
    ipykernel
    ipython
    jupyter-client
    psutil
    python-dateutil
    pyzmq
    tornado
    tqdm
    traitlets
  ];

  # Requires access to cluster
  doCheck = false;

  pythonImportsCheck = [ "ipyparallel" ];

  meta = {
    description = "Interactive Parallel Computing with IPython";
    homepage = "https://ipyparallel.readthedocs.io/";
    changelog = "https://github.com/ipython/ipyparallel/blob/${version}/docs/source/changelog.md";
    license = lib.licenses.bsd3;
  };
}