mirror of
https://github.com/NixOS/nix
synced 2025-07-02 09:21:47 +02:00
The explicit include is needed for clangd to not get confused somehow, which is also what threw me off initially and made me pick the wrong constructor. The (pointer, number, number) constructor first constructs a C string and then takes a substring from that, but we didn't specify that the buffer needs to be NUL-terminated, and then what would be the point of the size argument anyway... basic_string.h: > basic_string(const _Tp& __t, size_type __pos, size_type __n, > const _Alloc& __a = _Alloc()) > : basic_string(_S_to_string_view(__t).substr(__pos, __n), __a) { } Valgrind on nixops4/rust/nix-flake tests: ==1344422== Conditional jump or move depends on uninitialised value(s) ==1344422== at 0x48513E8: strlen (vg_replace_strmem.c:505) ==1344422== by 0x488E941: UnknownInlinedFun (char_traits.h:391) ==1344422== by 0x488E941: UnknownInlinedFun (string_view:141) ==1344422== by 0x488E941: UnknownInlinedFun (basic_string.h:790) ==1344422== by 0x488E941: nix_flake_reference_and_fragment_from_string (nix_api_flake.cc:81) ==1344422== by 0x127332: nix_flake::FlakeReference::parse_with_fragment (lib.rs:123) |
||
---|---|---|
.. | ||
.version | ||
meson.build | ||
nix-meson-build-support | ||
nix_api_flake.cc | ||
nix_api_flake.h | ||
nix_api_flake_internal.hh | ||
package.nix |