8 May 2024 |
l0b0 | *
pyproj/_datadir.pyx:148:33: Cannot assign type 'void (void *, int, const char ) except * nogil' to 'PJ_LOG_FUNCTION' (alias of 'void ()(void *, int, const char *) noexcept nogil'). Exception values are incompatible. Suggest adding 'noexcept' to the type of 'pyproj_log_function'.
https://github.com/nix-community/poetry2nix/issues/1645
Any ideas?
Update: I've created a PR with the relevant failing test.
| 02:13:15 |
| checooh joined the room. | 11:55:19 |
x10an14 | Anyone experienced "missing attribute" error recently? Wrt. `inputs.flake-utils.lib.eachDefaultSystem`. Once I made it follow my existing `flake-utils` input I get nix complaining about line 82 in poetry2nix's `flake.nix` on current `master` (`5a62572`). | 12:27:23 |
x10an14 | In reply to @x10an14:matrix.org Anyone experienced "missing attribute" error recently? Wrt. `inputs.flake-utils.lib.eachDefaultSystem`. Once I made it follow my existing `flake-utils` input I get nix complaining about line 82 in poetry2nix's `flake.nix` on current `master` (`5a62572`). Here's my flake.nix , stripped of non-Nix/poetry2nix related sturr: {
description = "A Nix-flake for poetry based python development ";
inputs = {
flake-utils.url = "github:numtide/flake-utils";
nixpkgs.url = "github:NixOS/nixpkgs/nixpkgs-unstable";
poetry2nix = {
url = "github:nix-community/poetry2nix";
inputs.nixpkgs.follows = "nixpkgs";
inputs.flake-utils.follows = "nixpkgs";
};
};
outputs = {
self,
...
} @ inputs:
inputs.flake-utils.lib.eachDefaultSystem (system: let
pkgs = import inputs.nixpkgs {localSystem = {inherit system;};};
inherit (inputs.poetry2nix.lib.mkPoetry2Nix { inherit pkgs; }) mkPoetryApplication;
myapp = mkPoetryApplication {projectDir = self;};
in {
devShells.default = pkgs.mkShell {
inputsFrom = [myapp];
packages = with pkgs; [
poetry
(
python3.withPackages (
exts: [
exts.ipython
]
)
)
];
shellHook = ''
${pkgs.python3}/bin/python3 --version
${pkgs.poetry}/bin/poetry --version
'';
};
packages = {
inherit myapp;
};
packages.default = myapp;
});
}
| 12:32:31 |
x10an14 |  Download Screenshot from 2024-05-08 14-33-56.png | 12:35:13 |
truh | In reply to @x10an14:matrix.org
Here's my flake.nix , stripped of non-Nix/poetry2nix related sturr: {
description = "A Nix-flake for poetry based python development ";
inputs = {
flake-utils.url = "github:numtide/flake-utils";
nixpkgs.url = "github:NixOS/nixpkgs/nixpkgs-unstable";
poetry2nix = {
url = "github:nix-community/poetry2nix";
inputs.nixpkgs.follows = "nixpkgs";
inputs.flake-utils.follows = "nixpkgs";
};
};
outputs = {
self,
...
} @ inputs:
inputs.flake-utils.lib.eachDefaultSystem (system: let
pkgs = import inputs.nixpkgs {localSystem = {inherit system;};};
inherit (inputs.poetry2nix.lib.mkPoetry2Nix { inherit pkgs; }) mkPoetryApplication;
myapp = mkPoetryApplication {projectDir = self;};
in {
devShells.default = pkgs.mkShell {
inputsFrom = [myapp];
packages = with pkgs; [
poetry
(
python3.withPackages (
exts: [
exts.ipython
]
)
)
];
shellHook = ''
${pkgs.python3}/bin/python3 --version
${pkgs.poetry}/bin/poetry --version
'';
};
packages = {
inherit myapp;
};
packages.default = myapp;
});
}
You could try nixpkgs.follows = "poetry2nix/nixpkgs"; rather than the other way around. | 12:42:20 |
x10an14 | In reply to @truh:matrix.org You could try nixpkgs.follows = "poetry2nix/nixpkgs"; rather than the other way around. Thanks for taking a look @truh! Huhm... I agree that there's a channel mismatch between the two... But how do you figure it's related to the error message? I don't see anywhere there might be a reference to a flake-utils version missing https://github.com/numtide/flake-utils?tab=readme-ov-file#eachdefaultsystem--system---attrs. | 12:48:23 |
truh | `inputs.flake-utils.follows = "nixpkgs";` this shouldn't follow nixpkgs
| 12:51:03 |
x10an14 | In reply to @truh:matrix.org You could try nixpkgs.follows = "poetry2nix/nixpkgs"; rather than the other way around. Deleting inputs.poetry2nix.inputs.nixpkgs.follows = "nixpkgs"; had indeed zero effect. | 12:51:05 |
truh | * `inputs.flake-utils.follows = "nixpkgs";`
this shouldn't follow nixpkgs
| 12:51:25 |
truh | * inputs.flake-utils.follows = "nixpkgs";
this shouldn't follow nixpkgs
| 12:52:08 |
x10an14 | In reply to @truh:matrix.org
`inputs.flake-utils.follows = "nixpkgs";` this shouldn't follow nixpkgs
Derp, I've become blind to my own code... Thanks! | 12:53:25 |
truh | My previous suggestion is indeed unrelated to the problem, just my usual debug procedure. | 12:54:11 |
x10an14 | Thanks for saving me from this instance of "code blindness"! =) | 12:57:45 |
| Rok Roškar changed their display name from rrrrrok to Rok Roškar. | 16:38:40 |
9 May 2024 |
| dagenix joined the room. | 04:34:29 |
wk | is it possible to use overrideAttrs inject additional python packages into a package defined with mkPoetryApplication? | 04:38:05 |
dagenix | I'm trying to build an older version of poetry, specifically version 1.4.2. I have this derivation:
{ fetchFromGitHub, poetry2nix }:
poetry2nix.mkPoetryApplication {
projectDir = fetchFromGitHub {
owner = "python-poetry";
repo = "poetry";
rev = "1.4.2";
hash = "sha256-AiRQFZA5+M1niTzj1RO2lx0QFOMmSzpQo1gzauyTblg=";
};
}
The derivation builds fine. However, the resulting package depends on the build module version 1.0.3. This is a problem, since the poetry.lock from that version of poetry requires build version 0.10. As a result, the poetry package doesn't work since that version of poetry breaks with that version of the build package.
I have attempted to override the build package version:
{ fetchFromGitHub, poetry2nix }:
poetry2nix.mkPoetryApplication {
projectDir = fetchFromGitHub {
owner = "python-poetry";
repo = "poetry";
rev = "1.4.2";
hash = "sha256-AiRQFZA5+M1niTzj1RO2lx0QFOMmSzpQo1gzauyTblg=";
};
overrides = poetry2nix.defaultPoetryOverrides.extend (final: prev: {
build = prev.build.overridePythonAttrs (old: {
version = "0.10.0";
src = fetchFromGitHub {
owner = "pypa";
repo = "build";
rev = "0.10.0";
hash = "sha256-kXFrfTb7+68EV+gSENL81IFSR+ue7Fl6R2gsuFFBJhI=";
};
});
});
}
But, when I do that, I get a build error:
> patching script interpreter paths in /nix/store/i2mwa5yrz6lgllq3rvqim6ldwgj2bcfv-python3.11-zipp-3.14.0
> stripping (with command strip and flags -S) in /nix/store/i2mwa5yrz6lgllq3rvqim6ldwgj2bcfv-python3.11-zipp-3.14.0/lib
> Executing pythonRemoveTestsDir
> Finished executing pythonRemoveTestsDir
> Running phase: pythonCatchConflictsPhase
> Found duplicated packages in closure for dependency 'wheel':
> wheel 0.41.1 (/nix/store/k0hkn48yfv05f6a1nf4qfri3ajilxgzb-python3.11-wheel-0.41.1/lib/python3.11/site-packages/wheel-0.41.1.dist-info)
> wheel 0.41.1 (/nix/store/lq0ayfkzrgp69r5g7ia7ln597qa5dv18-python3.11-wheel-0.41.1/lib/python3.11/site-packages/wheel-0.41.1.dist-info)
>
> Package duplicates found in closure, see above. Usually this happens if two packages depend on different version of the same dependency.
I've tried searching the edgecases documentation but didn't find anything that seems to explain what I should do in this case.
Anyway, I was about to open an issue, but saw that it asked that I first post problems to the Matrix chat and I was wondering if anyone had any idea what I was doing wrong or if I should open up an issue.
Thanks in advance!
| 04:39:35 |
| @morgrimm:matrix.org changed their display name from morgrimm to remi-gelinas. | 13:21:58 |
| @morgrimm:matrix.org left the room. | 13:22:52 |
10 May 2024 |
| grw00 joined the room. | 07:16:01 |
11 May 2024 |
Andrea Mangrella | hello, I'm having problems to make some packages build with poetry2nix, by reading various sources online I've found out about overrides and how to add default packages to the build environment of mkPoetry application. I just started using nix 2 weeks ago and I don;t understand what I'm doing wrong with this flake setup, can someone help me out ? | 14:52:03 |
Andrea Mangrella | description = "Application packaged using poetry2nix";
inputs = {
flake-utils.url = "github:numtide/flake-utils";
nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable-small";
poetry2nix = {
url = "github:nix-community/poetry2nix";
inputs.nixpkgs.follows = "nixpkgs";
};
};
outputs = { self, nixpkgs, flake-utils, poetry2nix }:
flake-utils.lib.eachDefaultSystem (system:
let
pkgs = nixpkgs.legacyPackages.${system};
inherit (poetry2nix.lib.mkPoetry2Nix { inherit pkgs; }) mkPoetryApplication overrides;
mk = mkPoetryApplication {
projectDir = ./.;
overrides = overrides.withDefaults (self: super: {
pathspec = super.pathspec.overridePythonAttrs (
old: {
buildInputs = (old.buildInputs or [ ]) ++ [ self.flit-core ];
}
);
});
};
in
{
packages = {
myapp = mk;
default = self.packages.${system}.myapp;
};
# Shell for app dependencies:
# Use this shell for developing your app: nix develop
devShells.default = pkgs.mkShell {
inputsFrom = [ self.packages.${system}.myapp ];
};
# Shell for poetry.
# Use this shell for changes to pyproject.toml and poetry.lock: nix develop .#poetry
devShells.poetry = pkgs.mkShell {
packages = [ pkgs.poetry ];
};
});
}
| 14:52:22 |
Andrea Mangrella | Redacted or Malformed Event | 14:53:29 |
Andrea Mangrella | with the following error: ``` warning: Git tree '/home/kativen/universita/statistical_learning' is dirty error: builder for '/nix/store/65p128giakz2k87slj0mphllvk9fcn2r-python3.11-docutils-0.21.2.drv' failed with exit code 2; last 10 log lines: > File "<frozen importlib._bootstrap>", line 1204, in _gcd_import > File "<frozen importlib._bootstrap>", line 1176, in _find_and_load > File "<frozen importlib._bootstrap>", line 1126, in _find_and_load_unlocked > File "<frozen importlib._bootstrap>", line 241, in _call_with_frames_removed > File "<frozen importlib._bootstrap>", line 1204, in _gcd_import > File "<frozen importlib._bootstrap>", line 1176, in _find_and_load > File "<frozen importlib._bootstrap>", line 1140, in _find_and_load_unlocked > ModuleNotFoundError: No module named 'flit_core' > > For full logs, run 'nix log /nix/store/65p128giakz2k87slj0mphllvk9fcn2r-python3.11-docutils-0.21.2.drv'. error: 1 dependencies of derivation '/nix/store/qhqqkxwv2hn4iyqh6i7bp8yrnz2gazih-python3.11-flit-3.9.0.drv' failed to build error (ignored): error: cannot unlink '/tmp/nix-build-python3.11-pyyaml-6.0.1.drv-0': Directory not empty error: 1 dependencies of derivation '/nix/store/sbhbrhkfx74cwklf0vccjffm659v3wd8-nix-shell-env.drv' failed to build
| 14:54:17 |
Andrea Mangrella | * with the following error: ``` warning: Git tree '/home/kativen/universita/statistical_learning' is dirty
error: builder for '/nix/store/65p128giakz2k87slj0mphllvk9fcn2r-python3.11-docutils-0.21.2.drv' failed with exit code 2;
last 10 log lines:
> File "<frozen importlib._bootstrap>", line 1204, in _gcd_import
> File "<frozen importlib._bootstrap>", line 1176, in _find_and_load
> File "<frozen importlib._bootstrap>", line 1126, in _find_and_load_unlocked
> File "<frozen importlib._bootstrap>", line 241, in _call_with_frames_removed
> File "<frozen importlib._bootstrap>", line 1204, in _gcd_import
> File "<frozen importlib._bootstrap>", line 1176, in _find_and_load
> File "<frozen importlib._bootstrap>", line 1140, in _find_and_load_unlocked
> ModuleNotFoundError: No module named 'flit_core'
>
>
For full logs, run 'nix log /nix/store/65p128giakz2k87slj0mphllvk9fcn2r-python3.11-docutils-0.21.2.drv'.
error: 1 dependencies of derivation '/nix/store/qhqqkxwv2hn4iyqh6i7bp8yrnz2gazih-python3.11-flit-3.9.0.drv' failed to build
error (ignored): error: cannot unlink '/tmp/nix-build-python3.11-pyyaml-6.0.1.drv-0': Directory not empty
error: 1 dependencies of derivation '/nix/store/sbhbrhkfx74cwklf0vccjffm659v3wd8-nix-shell-env.drv' failed to build ``` | 14:54:29 |
Andrea Mangrella | * with the following error: ``` warning: Git tree '/home/kativen/universita/statistical_learning' is dirty error: builder for '/nix/store/65p128giakz2k87slj0mphllvk9fcn2r-python3.11-docutils-0.21.2.drv' failed with exit code 2; last 10 log lines:
File "<frozen importlib._bootstrap>", line 1204, in _gcd_import File "<frozen importlib._bootstrap>", line 1176, in _find_and_load File "<frozen importlib._bootstrap>", line 1126, in _find_and_load_unlocked File "<frozen importlib._bootstrap>", line 241, in _call_with_frames_removed File "<frozen importlib._bootstrap>", line 1204, in _gcd_import File "<frozen importlib._bootstrap>", line 1176, in _find_and_load File "<frozen importlib._bootstrap>", line 1140, in _find_and_load_unlocked ModuleNotFoundError: No module named 'flit_core'
For full logs, run 'nix log /nix/store/65p128giakz2k87slj0mphllvk9fcn2r-python3.11-docutils-0.21.2.drv'. error: 1 dependencies of derivation '/nix/store/qhqqkxwv2hn4iyqh6i7bp8yrnz2gazih-python3.11-flit-3.9.0.drv' failed to build error (ignored): error: cannot unlink '/tmp/nix-build-python3.11-pyyaml-6.0.1.drv-0': Directory not empty error: 1 dependencies of derivation '/nix/store/sbhbrhkfx74cwklf0vccjffm659v3wd8-nix-shell-env.drv' failed to build ```
| 14:54:46 |
Andrea Mangrella | * with the following error: warning: Git tree '/home/kativen/universita/statistical_learning' is dirty error: builder for '/nix/store/65p128giakz2k87slj0mphllvk9fcn2r-python3.11-docutils-0.21.2.drv' failed with exit code 2; last 10 log lines:
File "<frozen importlib._bootstrap>", line 1204, in _gcd_import File "<frozen importlib._bootstrap>", line 1176, in _find_and_load File "<frozen importlib._bootstrap>", line 1126, in _find_and_load_unlocked File "<frozen importlib._bootstrap>", line 241, in _call_with_frames_removed File "<frozen importlib._bootstrap>", line 1204, in _gcd_import File "<frozen importlib._bootstrap>", line 1176, in _find_and_load File "<frozen importlib._bootstrap>", line 1140, in _find_and_load_unlocked ModuleNotFoundError: No module named 'flit_core'
For full logs, run 'nix log /nix/store/65p128giakz2k87slj0mphllvk9fcn2r-python3.11-docutils-0.21.2.drv'. error: 1 dependencies of derivation '/nix/store/qhqqkxwv2hn4iyqh6i7bp8yrnz2gazih-python3.11-flit-3.9.0.drv' failed to build error (ignored): error: cannot unlink '/tmp/nix-build-python3.11-pyyaml-6.0.1.drv-0': Directory not empty error: 1 dependencies of derivation '/nix/store/sbhbrhkfx74cwklf0vccjffm659v3wd8-nix-shell-env.drv' failed to build ```
| 14:55:07 |
Andrea Mangrella | * error: builder for '/nix/store/65p128giakz2k87slj0mphllvk9fcn2r-python3.11-docutils-0.21.2.drv' failed with exit code 2;
last 10 log lines:
> File "\<frozen importlib.\_bootstrap>", line 1204, in \_gcd\_import
> File "\<frozen importlib.\_bootstrap>", line 1176, in \_find\_and\_load
> File "\<frozen importlib.\_bootstrap>", line 1126, in \_find\_and\_load\_unlocked
> File "\<frozen importlib.\_bootstrap>", line 241, in \_call\_with\_frames\_removed
> File "\<frozen importlib.\_bootstrap>", line 1204, in \_gcd\_import
> File "\<frozen importlib.\_bootstrap>", line 1176, in \_find\_and\_load
> File "\<frozen importlib.\_bootstrap>", line 1140, in \_find\_and\_load\_unlocked
> ModuleNotFoundError: No module named flit\_core
For full logs, run 'nix log /nix/store/65p128giakz2k87slj0mphllvk9fcn2r-python3.11-docutils-0.21.2.drv'.
error: 1 dependencies of derivation '/nix/store/qhqqkxwv2hn4iyqh6i7bp8yrnz2gazih-python3.11-flit-3.9.0.drv' failed to build
error (ignored): error: cannot unlink '/tmp/nix-build-python3.11-pyyaml-6.0.1.drv-0': Directory not empty
error: 1 dependencies of derivation '/nix/store/sbhbrhkfx74cwklf0vccjffm659v3wd8-nix-shell-env.drv' failed to build ```
| 14:55:40 |
12 May 2024 |
nim65s | Andrea Mangrella: do you have a link to your repo with your pyproject.toml ? | 09:19:59 |