mirror of
https://github.com/NixOS/nix.git
synced 2025-10-14 10:57:58 +08:00
libfetchers: Remove toRealPath in SourceHutInputScheme::getRevFromRef
This code had several issues: 1. Not going through the SourceAccessor means that we can only work with physical paths. 2. It did not actually check that the file exists. (std::ifstream does not check it by default).
This commit is contained in:
@@ -548,13 +548,10 @@ struct SourceHutInputScheme : GitArchiveInputScheme
|
|||||||
|
|
||||||
std::string refUri;
|
std::string refUri;
|
||||||
if (ref == "HEAD") {
|
if (ref == "HEAD") {
|
||||||
auto file = store->toRealPath(
|
auto downloadFileResult = downloadFile(store, *input.settings, fmt("%s/HEAD", base_url), "source", headers);
|
||||||
downloadFile(store, *input.settings, fmt("%s/HEAD", base_url), "source", headers).storePath);
|
auto contents = nix::ref(store->getFSAccessor(downloadFileResult.storePath))->readFile(CanonPath::root);
|
||||||
std::ifstream is(file);
|
|
||||||
std::string line;
|
|
||||||
getline(is, line);
|
|
||||||
|
|
||||||
auto remoteLine = git::parseLsRemoteLine(line);
|
auto remoteLine = git::parseLsRemoteLine(getLine(contents).first);
|
||||||
if (!remoteLine) {
|
if (!remoteLine) {
|
||||||
throw BadURL("in '%d', couldn't resolve HEAD ref '%d'", input.to_string(), ref);
|
throw BadURL("in '%d', couldn't resolve HEAD ref '%d'", input.to_string(), ref);
|
||||||
}
|
}
|
||||||
@@ -564,9 +561,10 @@ struct SourceHutInputScheme : GitArchiveInputScheme
|
|||||||
}
|
}
|
||||||
std::regex refRegex(refUri);
|
std::regex refRegex(refUri);
|
||||||
|
|
||||||
auto file = store->toRealPath(
|
auto downloadFileResult =
|
||||||
downloadFile(store, *input.settings, fmt("%s/info/refs", base_url), "source", headers).storePath);
|
downloadFile(store, *input.settings, fmt("%s/info/refs", base_url), "source", headers);
|
||||||
std::ifstream is(file);
|
auto contents = nix::ref(store->getFSAccessor(downloadFileResult.storePath))->readFile(CanonPath::root);
|
||||||
|
std::istringstream is(contents);
|
||||||
|
|
||||||
std::string line;
|
std::string line;
|
||||||
std::optional<std::string> id;
|
std::optional<std::string> id;
|
||||||
|
Reference in New Issue
Block a user