forked from lix-project/lix
Prevent uninitialized StorePath creation
This commit is contained in:
parent
94c9343702
commit
d8972317fc
3 changed files with 6 additions and 2 deletions
|
@ -18,6 +18,8 @@ extern "C" {
|
|||
|
||||
struct StorePath : rust::Value<3 * sizeof(void *) + 24, ffi_StorePath_drop>
|
||||
{
|
||||
StorePath() = delete;
|
||||
|
||||
static StorePath make(std::string_view path, std::string_view storeDir);
|
||||
|
||||
static StorePath make(unsigned char hash[20], std::string_view name);
|
||||
|
|
|
@ -113,6 +113,8 @@ extern "C" {
|
|||
|
||||
struct String : Vec<char, ffi_String_drop>
|
||||
{
|
||||
String() = delete;
|
||||
|
||||
String(std::string_view s)
|
||||
{
|
||||
ffi_String_new(StringSlice(s), this);
|
||||
|
|
|
@ -103,7 +103,7 @@ struct CmdWhyDepends : SourceExprCommand
|
|||
std::map<StorePath, Node> graph;
|
||||
|
||||
for (auto & path : closure)
|
||||
graph.emplace(path.clone(), Node{path.clone(), cloneStorePathSet(store->queryPathInfo(path)->references)});
|
||||
graph.emplace(path.clone(), Node { .path = path.clone(), .refs = cloneStorePathSet(store->queryPathInfo(path)->references) });
|
||||
|
||||
// Transpose the graph.
|
||||
for (auto & node : graph)
|
||||
|
@ -112,7 +112,7 @@ struct CmdWhyDepends : SourceExprCommand
|
|||
|
||||
/* Run Dijkstra's shortest path algorithm to get the distance
|
||||
of every path in the closure to 'dependency'. */
|
||||
graph[dependencyPath.clone()].dist = 0;
|
||||
graph.emplace(dependencyPath.clone(), Node { .path = dependencyPath.clone(), .dist = 0 });
|
||||
|
||||
std::priority_queue<Node *> queue;
|
||||
|
||||
|
|
Loading…
Reference in a new issue