refactor(3p/nix/nix-*): Replace logging with glog in binaries
This commit is contained in:
		
							parent
							
								
									9aa2ecd78c
								
							
						
					
					
						commit
						95a57f15ca
					
				
					 21 changed files with 120 additions and 168 deletions
				
			
		
							
								
								
									
										32
									
								
								third_party/nix/src/build-remote/build-remote.cc
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										32
									
								
								third_party/nix/src/build-remote/build-remote.cc
									
										
									
									
										vendored
									
									
								
							|  | @ -1,3 +1,4 @@ | |||
| #include <glog/logging.h> | ||||
| #include <algorithm> | ||||
| #include <cstdlib> | ||||
| #include <cstring> | ||||
|  | @ -44,16 +45,12 @@ static bool allSupportedLocally(const std::set<std::string>& requiredFeatures) { | |||
| 
 | ||||
| static int _main(int argc, char** argv) { | ||||
|   { | ||||
|     logger = makeJSONLogger(*logger); | ||||
| 
 | ||||
|     /* Ensure we don't get any SSH passphrase or host key popups. */ | ||||
|     unsetenv("DISPLAY"); | ||||
|     unsetenv("SSH_ASKPASS"); | ||||
| 
 | ||||
|     if (argc != 2) throw UsageError("called without required arguments"); | ||||
| 
 | ||||
|     verbosity = (Verbosity)std::stoll(argv[1]); | ||||
| 
 | ||||
|     FdSource source(STDIN_FILENO); | ||||
| 
 | ||||
|     /* Read the parent's settings. */ | ||||
|  | @ -77,7 +74,7 @@ static int _main(int argc, char** argv) { | |||
|     AutoCloseFD bestSlotLock; | ||||
| 
 | ||||
|     auto machines = getMachines(); | ||||
|     debug("got %d remote builders", machines.size()); | ||||
|     DLOG(INFO) << "got " << machines.size() << " remote builders"; | ||||
| 
 | ||||
|     if (machines.empty()) { | ||||
|       std::cerr << "# decline-permanently\n"; | ||||
|  | @ -119,7 +116,8 @@ static int _main(int argc, char** argv) { | |||
|         Machine* bestMachine = nullptr; | ||||
|         unsigned long long bestLoad = 0; | ||||
|         for (auto& m : machines) { | ||||
|           debug("considering building on remote machine '%s'", m.storeUri); | ||||
|           DLOG(INFO) << "considering building on remote machine '" << m.storeUri | ||||
|                      << "'"; | ||||
| 
 | ||||
|           if (m.enabled && | ||||
|               std::find(m.systemTypes.begin(), m.systemTypes.end(), | ||||
|  | @ -183,8 +181,7 @@ static int _main(int argc, char** argv) { | |||
|         lock = -1; | ||||
| 
 | ||||
|         try { | ||||
|           Activity act(*logger, lvlTalkative, actUnknown, | ||||
|                        fmt("connecting to '%s'", bestMachine->storeUri)); | ||||
|           DLOG(INFO) << "connecting to '" << bestMachine->storeUri << "'"; | ||||
| 
 | ||||
|           Store::Params storeParams; | ||||
|           if (hasPrefix(bestMachine->storeUri, "ssh://")) { | ||||
|  | @ -200,8 +197,8 @@ static int _main(int argc, char** argv) { | |||
| 
 | ||||
|         } catch (std::exception& e) { | ||||
|           auto msg = chomp(drainFD(5, false)); | ||||
|           printError("cannot build on '%s': %s%s", bestMachine->storeUri, | ||||
|                      e.what(), (msg.empty() ? "" : ": " + msg)); | ||||
|           LOG(ERROR) << "cannot build on '" << bestMachine->storeUri | ||||
|                      << "': " << e.what() << (msg.empty() ? "" : ": " + msg); | ||||
|           bestMachine->enabled = false; | ||||
|           continue; | ||||
|         } | ||||
|  | @ -222,14 +219,13 @@ static int _main(int argc, char** argv) { | |||
|         currentLoad + "/" + escapeUri(storeUri) + ".upload-lock", true); | ||||
| 
 | ||||
|     { | ||||
|       Activity act(*logger, lvlTalkative, actUnknown, | ||||
|                    fmt("waiting for the upload lock to '%s'", storeUri)); | ||||
|       DLOG(INFO) << "waiting for the upload lock to '" << storeUri << "'"; | ||||
| 
 | ||||
|       auto old = signal(SIGALRM, handleAlarm); | ||||
|       alarm(15 * 60); | ||||
|       if (!lockFile(uploadLock.get(), ltWrite, true)) | ||||
|         printError( | ||||
|             "somebody is hogging the upload lock for '%s', continuing..."); | ||||
|       if (!lockFile(uploadLock.get(), ltWrite, true)) { | ||||
|         LOG(ERROR) << "somebody is hogging the upload lock, continuing..."; | ||||
|       } | ||||
|       alarm(0); | ||||
|       signal(SIGALRM, old); | ||||
|     } | ||||
|  | @ -238,8 +234,7 @@ static int _main(int argc, char** argv) { | |||
|         settings.buildersUseSubstitutes ? Substitute : NoSubstitute; | ||||
| 
 | ||||
|     { | ||||
|       Activity act(*logger, lvlTalkative, actUnknown, | ||||
|                    fmt("copying dependencies to '%s'", storeUri)); | ||||
|       DLOG(INFO) << "copying dependencies to '" << storeUri << "'"; | ||||
|       copyPaths(store, ref<Store>(sshStore), inputs, NoRepair, NoCheckSigs, | ||||
|                 substitute); | ||||
|     } | ||||
|  | @ -261,8 +256,7 @@ static int _main(int argc, char** argv) { | |||
|       if (!store->isValidPath(path)) missing.insert(path); | ||||
| 
 | ||||
|     if (!missing.empty()) { | ||||
|       Activity act(*logger, lvlTalkative, actUnknown, | ||||
|                    fmt("copying outputs from '%s'", storeUri)); | ||||
|       DLOG(INFO) << "copying outputs from '" << storeUri << "'"; | ||||
|       store->locksHeld.insert(missing.begin(), missing.end()); /* FIXME: ugly */ | ||||
|       copyPaths(ref<Store>(sshStore), store, missing, NoRepair, NoCheckSigs, | ||||
|                 NoSubstitute); | ||||
|  |  | |||
							
								
								
									
										4
									
								
								third_party/nix/src/nix-build/nix-build.cc
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								third_party/nix/src/nix-build/nix-build.cc
									
										
									
									
										vendored
									
									
								
							|  | @ -1,3 +1,4 @@ | |||
| #include <glog/logging.h> | ||||
| #include <cstring> | ||||
| #include <fstream> | ||||
| #include <iostream> | ||||
|  | @ -359,8 +360,7 @@ static void _main(int argc, char** argv) { | |||
|         shell = drv->queryOutPath() + "/bin/bash"; | ||||
| 
 | ||||
|       } catch (Error& e) { | ||||
|         printError("warning: %s; will use bash from your environment", | ||||
|                    e.what()); | ||||
|         LOG(WARNING) << e.what() << "; will use bash from your environment"; | ||||
|         shell = "bash"; | ||||
|       } | ||||
|     } | ||||
|  |  | |||
|  | @ -1,3 +1,4 @@ | |||
| #include <glog/logging.h> | ||||
| #include <cerrno> | ||||
| #include <iostream> | ||||
| #include "globals.hh" | ||||
|  | @ -34,7 +35,7 @@ void removeOldGenerations(std::string dir) { | |||
|         if (e.errNo == ENOENT) continue; | ||||
|       } | ||||
|       if (link.find("link") != string::npos) { | ||||
|         printInfo(format("removing old generations of profile %1%") % path); | ||||
|         LOG(INFO) << "removing old generations of profile " << path; | ||||
|         if (deleteOlderThan != "") | ||||
|           deleteGenerationsOlderThan(path, deleteOlderThan, dryRun); | ||||
|         else | ||||
|  |  | |||
|  | @ -1,3 +1,4 @@ | |||
| #include <glog/logging.h> | ||||
| #include "legacy.hh" | ||||
| #include "shared.hh" | ||||
| #include "store-api.hh" | ||||
|  | @ -21,10 +22,10 @@ static int _main(int argc, char** argv) { | |||
|           else if (*arg == "--version") | ||||
|             printVersion("nix-copy-closure"); | ||||
|           else if (*arg == "--gzip" || *arg == "--bzip2" || *arg == "--xz") { | ||||
|             if (*arg != "--gzip") | ||||
|               printMsg(lvlError, format("Warning: '%1%' is not implemented, " | ||||
|                                         "falling back to gzip") % | ||||
|                                      *arg); | ||||
|             if (*arg != "--gzip") { | ||||
|               LOG(WARNING) << "'" << *arg | ||||
|                            << "' is not implemented, falling back to gzip"; | ||||
|             } | ||||
|             gzip = true; | ||||
|           } else if (*arg == "--from") | ||||
|             toMode = false; | ||||
|  | @ -33,7 +34,7 @@ static int _main(int argc, char** argv) { | |||
|           else if (*arg == "--include-outputs") | ||||
|             includeOutputs = true; | ||||
|           else if (*arg == "--show-progress") | ||||
|             printMsg(lvlError, "Warning: '--show-progress' is not implemented"); | ||||
|             LOG(WARNING) << "'--show-progress' is not implemented"; | ||||
|           else if (*arg == "--dry-run") | ||||
|             dryRun = true; | ||||
|           else if (*arg == "--use-substitutes" || *arg == "-s") | ||||
|  |  | |||
							
								
								
									
										62
									
								
								third_party/nix/src/nix-env/nix-env.cc
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										62
									
								
								third_party/nix/src/nix-env/nix-env.cc
									
										
									
									
										vendored
									
									
								
							|  | @ -1,3 +1,4 @@ | |||
| #include <glog/logging.h> | ||||
| #include <sys/stat.h> | ||||
| #include <sys/types.h> | ||||
| #include <unistd.h> | ||||
|  | @ -108,9 +109,8 @@ static void getAllExprs(EvalState& state, const Path& path, StringSet& attrs, | |||
|       if (hasSuffix(attrName, ".nix")) | ||||
|         attrName = string(attrName, 0, attrName.size() - 4); | ||||
|       if (attrs.find(attrName) != attrs.end()) { | ||||
|         printError(format("warning: name collision in input Nix expressions, " | ||||
|                           "skipping '%1%'") % | ||||
|                    path2); | ||||
|         LOG(WARNING) << "name collision in input Nix expressions, skipping '" | ||||
|                      << path2 << "'"; | ||||
|         continue; | ||||
|       } | ||||
|       attrs.insert(attrName); | ||||
|  | @ -264,10 +264,9 @@ static DrvInfos filterBySelector(EvalState& state, const DrvInfos& allElems, | |||
|       matches.clear(); | ||||
|       for (auto& j : newest) { | ||||
|         if (multiple.find(j.second.first.queryName()) != multiple.end()) | ||||
|           printInfo( | ||||
|               "warning: there are multiple derivations named '%1%'; using the " | ||||
|               "first one", | ||||
|               j.second.first.queryName()); | ||||
|           LOG(WARNING) << "warning: there are multiple derivations named '" | ||||
|                        << j.second.first.queryName() | ||||
|                        << "'; using the first one"; | ||||
|         matches.push_back(j.second); | ||||
|       } | ||||
|     } | ||||
|  | @ -401,7 +400,7 @@ static bool keep(DrvInfo& drv) { return drv.queryMetaBool("keep", false); } | |||
| 
 | ||||
| static void installDerivations(Globals& globals, const Strings& args, | ||||
|                                const Path& profile) { | ||||
|   debug(format("installing derivations")); | ||||
|   DLOG(INFO) << "installing derivations"; | ||||
| 
 | ||||
|   /* Get the set of user environment elements to be installed. */ | ||||
|   DrvInfos newElems, newElemsTmp; | ||||
|  | @ -436,12 +435,14 @@ static void installDerivations(Globals& globals, const Strings& args, | |||
|         DrvName drvName(i.queryName()); | ||||
|         if (!globals.preserveInstalled && | ||||
|             newNames.find(drvName.name) != newNames.end() && !keep(i)) | ||||
|           printInfo("replacing old '%s'", i.queryName()); | ||||
|           LOG(INFO) << "replacing old '" << i.queryName() << "'"; | ||||
|         else | ||||
|           allElems.push_back(i); | ||||
|       } | ||||
| 
 | ||||
|       for (auto& i : newElems) printInfo("installing '%s'", i.queryName()); | ||||
|       for (auto& i : newElems) { | ||||
|         LOG(INFO) << "installing " << i.queryName(); | ||||
|       } | ||||
|     } | ||||
| 
 | ||||
|     printMissing(*globals.state, newElems); | ||||
|  | @ -474,7 +475,7 @@ typedef enum { utLt, utLeq, utEq, utAlways } UpgradeType; | |||
| 
 | ||||
| static void upgradeDerivations(Globals& globals, const Strings& args, | ||||
|                                UpgradeType upgradeType) { | ||||
|   debug(format("upgrading derivations")); | ||||
|   DLOG(INFO) << "upgrading derivations"; | ||||
| 
 | ||||
|   /* Upgrade works as follows: we take all currently installed
 | ||||
|      derivations, and for any derivation matching any selector, look | ||||
|  | @ -539,8 +540,8 @@ static void upgradeDerivations(Globals& globals, const Strings& args, | |||
|               compareVersions(drvName.version, bestVersion) <= 0 | ||||
|                   ? "upgrading" | ||||
|                   : "downgrading"; | ||||
|           printInfo("%1% '%2%' to '%3%'", action, i.queryName(), | ||||
|                     bestElem->queryName()); | ||||
|           LOG(INFO) << action << " '" << i.queryName() << "' to '" | ||||
|                     << bestElem->queryName() << "'"; | ||||
|           newElems.push_back(*bestElem); | ||||
|         } else | ||||
|           newElems.push_back(i); | ||||
|  | @ -611,7 +612,7 @@ static void opSetFlag(Globals& globals, Strings opFlags, Strings opArgs) { | |||
|       DrvName drvName(i.queryName()); | ||||
|       for (auto& j : selectors) | ||||
|         if (j.matches(drvName)) { | ||||
|           printInfo("setting flag on '%1%'", i.queryName()); | ||||
|           LOG(INFO) << "setting flag on '" << i.queryName() << "'"; | ||||
|           j.hits++; | ||||
|           setMetaFlag(*globals.state, i, flagName, flagValue); | ||||
|           break; | ||||
|  | @ -660,7 +661,7 @@ static void opSet(Globals& globals, Strings opFlags, Strings opArgs) { | |||
|     globals.state->store->ensurePath(drv.queryOutPath()); | ||||
|   } | ||||
| 
 | ||||
|   debug(format("switching to new user environment")); | ||||
|   DLOG(INFO) << "switching to new user environment"; | ||||
|   Path generation = createGeneration(ref<LocalFSStore>(store2), globals.profile, | ||||
|                                      drv.queryOutPath()); | ||||
|   switchLink(globals.profile, generation); | ||||
|  | @ -684,7 +685,7 @@ static void uninstallDerivations(Globals& globals, Strings& selectors, | |||
|              i.queryOutPath() == | ||||
|                  globals.state->store->followLinksToStorePath(j)) || | ||||
|             DrvName(j).matches(drvName)) { | ||||
|           printInfo("uninstalling '%s'", i.queryName()); | ||||
|           LOG(INFO) << "uninstalling '" << i.queryName() << "'"; | ||||
|           found = true; | ||||
|           break; | ||||
|         } | ||||
|  | @ -799,8 +800,8 @@ static void queryJSON(Globals& globals, vector<DrvInfo>& elems) { | |||
|       auto placeholder = metaObj.placeholder(j); | ||||
|       Value* v = i.queryMeta(j); | ||||
|       if (!v) { | ||||
|         printError("derivation '%s' has invalid meta attribute '%s'", | ||||
|                    i.queryName(), j); | ||||
|         LOG(ERROR) << "derivation '" << i.queryName() | ||||
|                    << "' has invalid meta attribute '" << j << "'"; | ||||
|         placeholder.write(nullptr); | ||||
|       } else { | ||||
|         PathSet context; | ||||
|  | @ -902,10 +903,8 @@ static void opQuery(Globals& globals, Strings opFlags, Strings opArgs) { | |||
|     for (auto& i : elems) try { | ||||
|         paths.insert(i.queryOutPath()); | ||||
|       } catch (AssertionError& e) { | ||||
|         printMsg( | ||||
|             lvlTalkative, | ||||
|             "skipping derivation named '%s' which gives an assertion failure", | ||||
|             i.queryName()); | ||||
|         DLOG(WARNING) << "skipping derivation named '" << i.queryName() | ||||
|                       << "' which gives an assertion failure"; | ||||
|         i.setFailed(); | ||||
|       } | ||||
|     validPaths = globals.state->store->queryValidPaths(paths); | ||||
|  | @ -1065,10 +1064,10 @@ static void opQuery(Globals& globals, Strings opFlags, Strings opArgs) { | |||
|               XMLAttrs attrs2; | ||||
|               attrs2["name"] = j; | ||||
|               Value* v = i.queryMeta(j); | ||||
|               if (!v) | ||||
|                 printError("derivation '%s' has invalid meta attribute '%s'", | ||||
|                            i.queryName(), j); | ||||
|               else { | ||||
|               if (!v) { | ||||
|                 LOG(ERROR) << "derivation '" << i.queryName() | ||||
|                            << "' has invalid meta attribute '" << j << "'"; | ||||
|               } else { | ||||
|                 if (v->type == tString) { | ||||
|                   attrs2["type"] = "string"; | ||||
|                   attrs2["value"] = v->string.s; | ||||
|  | @ -1118,10 +1117,8 @@ static void opQuery(Globals& globals, Strings opFlags, Strings opArgs) { | |||
|       cout.flush(); | ||||
| 
 | ||||
|     } catch (AssertionError& e) { | ||||
|       printMsg( | ||||
|           lvlTalkative, | ||||
|           "skipping derivation named '%1%' which gives an assertion failure", | ||||
|           i.queryName()); | ||||
|       DLOG(WARNING) << "skipping derivation named '" << i.queryName() | ||||
|                     << "' which gives an assertion failure"; | ||||
|     } catch (Error& e) { | ||||
|       e.addPrefix( | ||||
|           fmt("while querying the derivation named '%1%':\n", i.queryName())); | ||||
|  | @ -1167,8 +1164,7 @@ static void switchGeneration(Globals& globals, int dstGen) { | |||
|       throw Error(format("generation %1% does not exist") % dstGen); | ||||
|   } | ||||
| 
 | ||||
|   printInfo(format("switching from generation %1% to %2%") % curGen % | ||||
|             dst.number); | ||||
|   LOG(INFO) << "switching from generation " << curGen << " to " << dst.number; | ||||
| 
 | ||||
|   if (globals.dryRun) return; | ||||
| 
 | ||||
|  | @ -1330,7 +1326,7 @@ static int _main(int argc, char** argv) { | |||
|       else if (*arg == "--delete-generations") | ||||
|         op = opDeleteGenerations; | ||||
|       else if (*arg == "--dry-run") { | ||||
|         printInfo("(dry run; not doing anything)"); | ||||
|         LOG(INFO) << "(dry run; not doing anything)"; | ||||
|         globals.dryRun = true; | ||||
|       } else if (*arg == "--system-filter") | ||||
|         globals.instSource.systemFilter = getArg(*arg, arg, end); | ||||
|  |  | |||
							
								
								
									
										14
									
								
								third_party/nix/src/nix-env/user-env.cc
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										14
									
								
								third_party/nix/src/nix-env/user-env.cc
									
										
									
									
										vendored
									
									
								
							|  | @ -1,4 +1,5 @@ | |||
| #include "user-env.hh" | ||||
| #include <glog/logging.h> | ||||
| #include "derivations.hh" | ||||
| #include "eval-inline.hh" | ||||
| #include "eval.hh" | ||||
|  | @ -30,7 +31,7 @@ bool createUserEnv(EvalState& state, DrvInfos& elems, const Path& profile, | |||
|   for (auto& i : elems) | ||||
|     if (i.queryDrvPath() != "") drvsToBuild.insert(i.queryDrvPath()); | ||||
| 
 | ||||
|   debug(format("building user environment dependencies")); | ||||
|   DLOG(INFO) << "building user environment dependencies"; | ||||
|   state.store->buildPaths(drvsToBuild, state.repair ? bmRepair : bmNormal); | ||||
| 
 | ||||
|   /* Construct the whole top level derivation. */ | ||||
|  | @ -111,7 +112,7 @@ bool createUserEnv(EvalState& state, DrvInfos& elems, const Path& profile, | |||
|   mkApp(topLevel, envBuilder, args); | ||||
| 
 | ||||
|   /* Evaluate it. */ | ||||
|   debug("evaluating user environment builder"); | ||||
|   DLOG(INFO) << "evaluating user environment builder"; | ||||
|   state.forceValue(topLevel); | ||||
|   PathSet context; | ||||
|   Attr& aDrvPath(*topLevel.attrs->find(state.sDrvPath)); | ||||
|  | @ -122,7 +123,7 @@ bool createUserEnv(EvalState& state, DrvInfos& elems, const Path& profile, | |||
|                                         *(aOutPath.value), context); | ||||
| 
 | ||||
|   /* Realise the resulting store expression. */ | ||||
|   debug("building user environment"); | ||||
|   DLOG(INFO) << "building user environment"; | ||||
|   state.store->buildPaths({topLevelDrv}, state.repair ? bmRepair : bmNormal); | ||||
| 
 | ||||
|   /* Switch the current user environment to the output path. */ | ||||
|  | @ -134,13 +135,12 @@ bool createUserEnv(EvalState& state, DrvInfos& elems, const Path& profile, | |||
| 
 | ||||
|     Path lockTokenCur = optimisticLockProfile(profile); | ||||
|     if (lockToken != lockTokenCur) { | ||||
|       printError( | ||||
|           format("profile '%1%' changed while we were busy; restarting") % | ||||
|           profile); | ||||
|       LOG(WARNING) << "profile '" << profile | ||||
|                    << "' changed while we were busy; restarting"; | ||||
|       return false; | ||||
|     } | ||||
| 
 | ||||
|     debug(format("switching to new user environment")); | ||||
|     DLOG(INFO) << "switching to new user environment"; | ||||
|     Path generation = | ||||
|         createGeneration(ref<LocalFSStore>(store2), profile, topLevelOut); | ||||
|     switchLink(profile, generation); | ||||
|  |  | |||
|  | @ -1,4 +1,5 @@ | |||
| #include <fcntl.h> | ||||
| #include <glog/logging.h> | ||||
| #include <sys/stat.h> | ||||
| #include <sys/types.h> | ||||
| #include <iostream> | ||||
|  | @ -10,7 +11,6 @@ | |||
| #include "finally.hh" | ||||
| #include "hash.hh" | ||||
| #include "legacy.hh" | ||||
| #include "progress-bar.hh" | ||||
| #include "shared.hh" | ||||
| #include "store-api.hh" | ||||
| 
 | ||||
|  | @ -92,10 +92,6 @@ static int _main(int argc, char** argv) { | |||
| 
 | ||||
|     if (args.size() > 2) throw UsageError("too many arguments"); | ||||
| 
 | ||||
|     Finally f([]() { stopProgressBar(); }); | ||||
| 
 | ||||
|     if (isatty(STDERR_FILENO)) startProgressBar(); | ||||
| 
 | ||||
|     auto store = openStore(); | ||||
|     auto state = std::make_unique<EvalState>(myArgs.searchPath, store); | ||||
| 
 | ||||
|  | @ -126,7 +122,7 @@ static int _main(int argc, char** argv) { | |||
|       /* Extract the hash mode. */ | ||||
|       attr = v.attrs->find(state->symbols.create("outputHashMode")); | ||||
|       if (attr == v.attrs->end()) | ||||
|         printInfo("warning: this does not look like a fetchurl call"); | ||||
|         LOG(WARNING) << "this does not look like a fetchurl call"; | ||||
|       else | ||||
|         unpack = state->forceString(*attr->value) == "recursive"; | ||||
| 
 | ||||
|  | @ -176,7 +172,7 @@ static int _main(int argc, char** argv) { | |||
| 
 | ||||
|       /* Optionally unpack the file. */ | ||||
|       if (unpack) { | ||||
|         printInfo("unpacking..."); | ||||
|         LOG(INFO) << "unpacking..."; | ||||
|         Path unpacked = (Path)tmpDir + "/unpacked"; | ||||
|         createDirs(unpacked); | ||||
|         if (hasSuffix(baseNameOf(uri), ".zip")) | ||||
|  | @ -210,9 +206,9 @@ static int _main(int argc, char** argv) { | |||
|       assert(storePath == store->makeFixedOutputPath(unpack, hash, name)); | ||||
|     } | ||||
| 
 | ||||
|     stopProgressBar(); | ||||
| 
 | ||||
|     if (!printPath) printInfo(format("path is '%1%'") % storePath); | ||||
|     if (!printPath) { | ||||
|       LOG(INFO) << "path is '" << storePath << "'"; | ||||
|     } | ||||
| 
 | ||||
|     std::cout << printHash16or32(hash) << std::endl; | ||||
|     if (printPath) std::cout << storePath << std::endl; | ||||
|  |  | |||
							
								
								
									
										14
									
								
								third_party/nix/src/nix-store/nix-store.cc
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										14
									
								
								third_party/nix/src/nix-store/nix-store.cc
									
										
									
									
										vendored
									
									
								
							|  | @ -1,4 +1,5 @@ | |||
| #include <fcntl.h> | ||||
| #include <glog/logging.h> | ||||
| #include <sys/stat.h> | ||||
| #include <sys/types.h> | ||||
| #include <algorithm> | ||||
|  | @ -715,7 +716,7 @@ static void opVerify(Strings opFlags, Strings opArgs) { | |||
|       throw UsageError(format("unknown flag '%1%'") % i); | ||||
| 
 | ||||
|   if (store->verifyStore(checkContents, repair)) { | ||||
|     printError("warning: not all errors were fixed"); | ||||
|     LOG(WARNING) << "not all errors were fixed"; | ||||
|     throw Exit(1); | ||||
|   } | ||||
| } | ||||
|  | @ -728,15 +729,15 @@ static void opVerifyPath(Strings opFlags, Strings opArgs) { | |||
| 
 | ||||
|   for (auto& i : opArgs) { | ||||
|     Path path = store->followLinksToStorePath(i); | ||||
|     printMsg(lvlTalkative, format("checking path '%1%'...") % path); | ||||
|     LOG(INFO) << "checking path '" << path << "'..."; | ||||
|     auto info = store->queryPathInfo(path); | ||||
|     HashSink sink(info->narHash.type); | ||||
|     store->narFromPath(path, sink); | ||||
|     auto current = sink.finish(); | ||||
|     if (current.first != info->narHash) { | ||||
|       printError( | ||||
|           format("path '%1%' was modified! expected hash '%2%', got '%3%'") % | ||||
|           path % info->narHash.to_string() % current.first.to_string()); | ||||
|       LOG(ERROR) << "path '" << path << "' was modified! expected hash '" | ||||
|                  << info->narHash.to_string() << "', got '" | ||||
|                  << current.first.to_string() << "'"; | ||||
|       status = 1; | ||||
|     } | ||||
|   } | ||||
|  | @ -788,7 +789,6 @@ static void opServe(Strings opFlags, Strings opArgs) { | |||
|   auto getBuildSettings = [&]() { | ||||
|     // FIXME: changing options here doesn't work if we're
 | ||||
|     // building through the daemon.
 | ||||
|     verbosity = lvlError; | ||||
|     settings.keepLog = false; | ||||
|     settings.useSubstitutes = false; | ||||
|     settings.maxSilentTime = readInt(in); | ||||
|  | @ -836,7 +836,7 @@ static void opServe(Strings opFlags, Strings opArgs) { | |||
|           if (!willSubstitute.empty()) try { | ||||
|               store->buildPaths(willSubstitute); | ||||
|             } catch (Error& e) { | ||||
|               printError(format("warning: %1%") % e.msg()); | ||||
|               LOG(WARNING) << e.msg(); | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|  |  | |||
							
								
								
									
										6
									
								
								third_party/nix/src/nix/edit.cc
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								third_party/nix/src/nix/edit.cc
									
										
									
									
										vendored
									
									
								
							|  | @ -1,8 +1,8 @@ | |||
| #include <glog/logging.h> | ||||
| #include <unistd.h> | ||||
| #include "attr-path.hh" | ||||
| #include "command.hh" | ||||
| #include "eval.hh" | ||||
| #include "progress-bar.hh" | ||||
| #include "shared.hh" | ||||
| 
 | ||||
| using namespace nix; | ||||
|  | @ -36,7 +36,7 @@ struct CmdEdit : InstallableCommand { | |||
|     } | ||||
| 
 | ||||
|     auto pos = state->forceString(*v2); | ||||
|     debug("position is %s", pos); | ||||
|     DLOG(INFO) << "position is " << pos; | ||||
| 
 | ||||
|     auto colon = pos.rfind(':'); | ||||
|     if (colon == std::string::npos) | ||||
|  | @ -61,8 +61,6 @@ struct CmdEdit : InstallableCommand { | |||
| 
 | ||||
|     args.push_back(filename); | ||||
| 
 | ||||
|     stopProgressBar(); | ||||
| 
 | ||||
|     execvp(args.front().c_str(), stringsToCharPtrs(args).data()); | ||||
| 
 | ||||
|     throw SysError("cannot run editor '%s'", editor); | ||||
|  |  | |||
							
								
								
									
										3
									
								
								third_party/nix/src/nix/eval.cc
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								third_party/nix/src/nix/eval.cc
									
										
									
									
										vendored
									
									
								
							|  | @ -2,7 +2,6 @@ | |||
| #include "command.hh" | ||||
| #include "common-args.hh" | ||||
| #include "json.hh" | ||||
| #include "progress-bar.hh" | ||||
| #include "shared.hh" | ||||
| #include "store-api.hh" | ||||
| #include "value-to-json.hh" | ||||
|  | @ -40,8 +39,6 @@ struct CmdEval : MixJSON, InstallableCommand { | |||
|     auto v = installable->toValue(*state); | ||||
|     PathSet context; | ||||
| 
 | ||||
|     stopProgressBar(); | ||||
| 
 | ||||
|     if (raw) { | ||||
|       std::cout << state->coerceToString(noPos, *v, context); | ||||
|     } else if (json) { | ||||
|  |  | |||
							
								
								
									
										6
									
								
								third_party/nix/src/nix/installables.cc
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								third_party/nix/src/nix/installables.cc
									
										
									
									
										vendored
									
									
								
							|  | @ -241,9 +241,9 @@ Buildables build(ref<Store> store, RealiseMode mode, | |||
|     } | ||||
|   } | ||||
| 
 | ||||
|   if (mode == DryRun) | ||||
|     printMissing(store, pathsToBuild, lvlError); | ||||
|   else if (mode == Build) | ||||
|   if (mode == DryRun) { | ||||
|     printMissing(store, pathsToBuild); | ||||
|   } else if (mode == Build) | ||||
|     store->buildPaths(pathsToBuild); | ||||
| 
 | ||||
|   return buildables; | ||||
|  |  | |||
							
								
								
									
										7
									
								
								third_party/nix/src/nix/log.cc
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										7
									
								
								third_party/nix/src/nix/log.cc
									
										
									
									
										vendored
									
									
								
							|  | @ -1,6 +1,6 @@ | |||
| #include <glog/logging.h> | ||||
| #include "command.hh" | ||||
| #include "common-args.hh" | ||||
| #include "progress-bar.hh" | ||||
| #include "shared.hh" | ||||
| #include "store-api.hh" | ||||
| 
 | ||||
|  | @ -45,9 +45,8 @@ struct CmdLog : InstallableCommand { | |||
|         log = sub->getBuildLog(output.second); | ||||
|       } | ||||
|       if (!log) continue; | ||||
|       stopProgressBar(); | ||||
|       printInfo("got build log for '%s' from '%s'", installable->what(), | ||||
|                 sub->getUri()); | ||||
|       LOG(INFO) << "got build log for '" << installable->what() << "' from '" | ||||
|                 << sub->getUri() << "'"; | ||||
|       std::cout << *log; | ||||
|       return; | ||||
|     } | ||||
|  |  | |||
							
								
								
									
										11
									
								
								third_party/nix/src/nix/main.cc
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										11
									
								
								third_party/nix/src/nix/main.cc
									
										
									
									
										vendored
									
									
								
							|  | @ -12,7 +12,6 @@ | |||
| #include "globals.hh" | ||||
| #include "glog/logging.h" | ||||
| #include "legacy.hh" | ||||
| #include "progress-bar.hh" | ||||
| #include "shared.hh" | ||||
| #include "store-api.hh" | ||||
| 
 | ||||
|  | @ -129,7 +128,6 @@ void mainWrapped(int argc, char** argv) { | |||
|     if (legacy) return legacy(argc, argv); | ||||
|   } | ||||
| 
 | ||||
|   verbosity = lvlWarn; | ||||
|   settings.verboseBuild = false; | ||||
| 
 | ||||
|   NixArgs args; | ||||
|  | @ -140,14 +138,9 @@ void mainWrapped(int argc, char** argv) { | |||
| 
 | ||||
|   if (!args.command) args.showHelpAndExit(); | ||||
| 
 | ||||
|   Finally f([]() { stopProgressBar(); }); | ||||
| 
 | ||||
|   startProgressBar(args.printBuildLogs); | ||||
| 
 | ||||
|   if (args.useNet && !haveInternet()) { | ||||
|     warn( | ||||
|         "you don't have Internet access; disabling some network-dependent " | ||||
|         "features"); | ||||
|     LOG(WARNING) << "you don't have Internet access; " | ||||
|                  << "disabling some network-dependent features"; | ||||
|     args.useNet = false; | ||||
|   } | ||||
| 
 | ||||
|  |  | |||
							
								
								
									
										2
									
								
								third_party/nix/src/nix/meson.build
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								third_party/nix/src/nix/meson.build
									
										
									
									
										vendored
									
									
								
							|  | @ -19,7 +19,6 @@ nix_src = files( | |||
|   join_paths(meson.source_root(), 'src/nix/optimise-store.cc'), | ||||
|   join_paths(meson.source_root(), 'src/nix/path-info.cc'), | ||||
|   join_paths(meson.source_root(), 'src/nix/ping-store.cc'), | ||||
|   join_paths(meson.source_root(), 'src/nix/progress-bar.cc'), | ||||
|   join_paths(meson.source_root(), 'src/nix/repl.cc'), | ||||
|   join_paths(meson.source_root(), 'src/nix/run.cc'), | ||||
|   join_paths(meson.source_root(), 'src/nix/search.cc'), | ||||
|  | @ -47,7 +46,6 @@ nix_src = files( | |||
| nix_headers = files ( | ||||
|   join_paths(meson.source_root(), 'src/nix/command.hh'), | ||||
|   join_paths(meson.source_root(), 'src/nix/legacy.hh'), | ||||
|   join_paths(meson.source_root(), 'src/nix/progress-bar.hh'), | ||||
|   join_paths(meson.source_root(), 'src/nix-env/user-env.hh'), | ||||
|   join_paths(meson.source_root(), 'src/nix-store/dotgraph.hh'), | ||||
|   join_paths(meson.source_root(), 'src/nix-store/graphml.hh')) | ||||
|  |  | |||
							
								
								
									
										12
									
								
								third_party/nix/src/nix/repl.cc
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										12
									
								
								third_party/nix/src/nix/repl.cc
									
										
									
									
										vendored
									
									
								
							|  | @ -1,3 +1,4 @@ | |||
| #include <glog/logging.h> | ||||
| #include <setjmp.h> | ||||
| #include <climits> | ||||
| #include <cstdlib> | ||||
|  | @ -242,16 +243,13 @@ void NixRepl::mainLoop(const std::vector<std::string>& files) { | |||
|         // next line of input without clearing the input so far.
 | ||||
|         continue; | ||||
|       } else { | ||||
|         printMsg(lvlError, format(error + "%1%%2%") % | ||||
|                                (settings.showTrace ? e.prefix() : "") % | ||||
|                                e.msg()); | ||||
|         LOG(ERROR) << error << (settings.showTrace ? e.prefix() : "") | ||||
|                    << e.msg(); | ||||
|       } | ||||
|     } catch (Error& e) { | ||||
|       printMsg(lvlError, format(error + "%1%%2%") % | ||||
|                              (settings.showTrace ? e.prefix() : "") % e.msg()); | ||||
|       LOG(ERROR) << error << (settings.showTrace ? e.prefix() : "") << e.msg(); | ||||
|     } catch (Interrupted& e) { | ||||
|       printMsg(lvlError, format(error + "%1%%2%") % | ||||
|                              (settings.showTrace ? e.prefix() : "") % e.msg()); | ||||
|       LOG(ERROR) << error << (settings.showTrace ? e.prefix() : "") << e.msg(); | ||||
|     } | ||||
| 
 | ||||
|     // We handled the current input fully, so we should clear it
 | ||||
|  |  | |||
							
								
								
									
										3
									
								
								third_party/nix/src/nix/run.cc
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								third_party/nix/src/nix/run.cc
									
										
									
									
										vendored
									
									
								
							|  | @ -5,7 +5,6 @@ | |||
| #include "finally.hh" | ||||
| #include "fs-accessor.hh" | ||||
| #include "local-store.hh" | ||||
| #include "progress-bar.hh" | ||||
| #include "shared.hh" | ||||
| #include "store-api.hh" | ||||
| 
 | ||||
|  | @ -135,8 +134,6 @@ struct CmdRun : InstallablesCommand { | |||
|     Strings args; | ||||
|     for (auto& arg : command) args.push_back(arg); | ||||
| 
 | ||||
|     stopProgressBar(); | ||||
| 
 | ||||
|     restoreSignals(); | ||||
| 
 | ||||
|     restoreAffinity(); | ||||
|  |  | |||
							
								
								
									
										7
									
								
								third_party/nix/src/nix/search.cc
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										7
									
								
								third_party/nix/src/nix/search.cc
									
										
									
									
										vendored
									
									
								
							|  | @ -1,3 +1,4 @@ | |||
| #include <glog/logging.h> | ||||
| #include <fstream> | ||||
| #include <regex> | ||||
| #include "command.hh" | ||||
|  | @ -99,7 +100,7 @@ struct CmdSearch : SourceExprCommand, MixJSON { | |||
| 
 | ||||
|     doExpr = [&](Value* v, std::string attrPath, bool toplevel, | ||||
|                  JSONObject* cache) { | ||||
|       debug("at attribute '%s'", attrPath); | ||||
|       DLOG(INFO) << "at attribute '" << attrPath << "'"; | ||||
| 
 | ||||
|       try { | ||||
|         uint found = 0; | ||||
|  | @ -174,7 +175,7 @@ struct CmdSearch : SourceExprCommand, MixJSON { | |||
|             auto attrs = v->attrs; | ||||
|             Bindings::iterator j = attrs->find(sRecurse); | ||||
|             if (j == attrs->end() || !state->forceBool(*j->value, *j->pos)) { | ||||
|               debug("skip attribute '%s'", attrPath); | ||||
|               DLOG(INFO) << "skip attribute '" << attrPath << "'"; | ||||
|               return; | ||||
|             } | ||||
|           } | ||||
|  | @ -209,7 +210,7 @@ struct CmdSearch : SourceExprCommand, MixJSON { | |||
|     Path jsonCacheFileName = getCacheDir() + "/nix/package-search.json"; | ||||
| 
 | ||||
|     if (useCache && pathExists(jsonCacheFileName)) { | ||||
|       warn("using cached results; pass '-u' to update the cache"); | ||||
|       LOG(WARNING) << "using cached results; pass '-u' to update the cache"; | ||||
| 
 | ||||
|       Value vRoot; | ||||
|       parseJSON(*state, readFile(jsonCacheFileName), vRoot); | ||||
|  |  | |||
							
								
								
									
										5
									
								
								third_party/nix/src/nix/sigs.cc
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										5
									
								
								third_party/nix/src/nix/sigs.cc
									
										
									
									
										vendored
									
									
								
							|  | @ -1,3 +1,4 @@ | |||
| #include <glog/logging.h> | ||||
| #include <atomic> | ||||
| #include "command.hh" | ||||
| #include "shared.hh" | ||||
|  | @ -82,7 +83,7 @@ struct CmdCopySigs : StorePathsCommand { | |||
| 
 | ||||
|     pool.process(); | ||||
| 
 | ||||
|     printInfo(format("imported %d signatures") % added); | ||||
|     LOG(INFO) << "imported " << added << " signatures"; | ||||
|   } | ||||
| }; | ||||
| 
 | ||||
|  | @ -126,7 +127,7 @@ struct CmdSignPaths : StorePathsCommand { | |||
|       } | ||||
|     } | ||||
| 
 | ||||
|     printInfo(format("added %d signatures") % added); | ||||
|     LOG(INFO) << "added " << added << " signatures"; | ||||
|   } | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
							
								
								
									
										32
									
								
								third_party/nix/src/nix/upgrade-nix.cc
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										32
									
								
								third_party/nix/src/nix/upgrade-nix.cc
									
										
									
									
										vendored
									
									
								
							|  | @ -1,10 +1,10 @@ | |||
| #include <glog/logging.h> | ||||
| #include "attr-path.hh" | ||||
| #include "command.hh" | ||||
| #include "common-args.hh" | ||||
| #include "download.hh" | ||||
| #include "eval.hh" | ||||
| #include "names.hh" | ||||
| #include "progress-bar.hh" | ||||
| #include "store-api.hh" | ||||
| 
 | ||||
| using namespace nix; | ||||
|  | @ -53,48 +53,43 @@ struct CmdUpgradeNix : MixDryRun, StoreCommand { | |||
| 
 | ||||
|     if (profileDir == "") profileDir = getProfileDir(store); | ||||
| 
 | ||||
|     printInfo("upgrading Nix in profile '%s'", profileDir); | ||||
|     LOG(INFO) << "upgrading Nix in profile '" << profileDir << "'"; | ||||
| 
 | ||||
|     Path storePath; | ||||
|     { | ||||
|       Activity act(*logger, lvlInfo, actUnknown, "querying latest Nix version"); | ||||
|       LOG(INFO) << "querying latest Nix version"; | ||||
|       storePath = getLatestNix(store); | ||||
|     } | ||||
| 
 | ||||
|     auto version = DrvName(storePathToName(storePath)).version; | ||||
| 
 | ||||
|     if (dryRun) { | ||||
|       stopProgressBar(); | ||||
|       printError("would upgrade to version %s", version); | ||||
|       LOG(ERROR) << "would upgrade to version " << version; | ||||
|       return; | ||||
|     } | ||||
| 
 | ||||
|     { | ||||
|       Activity act(*logger, lvlInfo, actUnknown, | ||||
|                    fmt("downloading '%s'...", storePath)); | ||||
|       LOG(INFO) << "downloading '" << storePath << "'..."; | ||||
|       store->ensurePath(storePath); | ||||
|     } | ||||
| 
 | ||||
|     { | ||||
|       Activity act(*logger, lvlInfo, actUnknown, | ||||
|                    fmt("verifying that '%s' works...", storePath)); | ||||
|       LOG(INFO) << "verifying that '" << storePath << "' works..."; | ||||
|       auto program = storePath + "/bin/nix-env"; | ||||
|       auto s = runProgram(program, false, {"--version"}); | ||||
|       if (s.find("Nix") == std::string::npos) | ||||
|         throw Error("could not verify that '%s' works", program); | ||||
|     } | ||||
| 
 | ||||
|     stopProgressBar(); | ||||
| 
 | ||||
|     { | ||||
|       Activity act( | ||||
|           *logger, lvlInfo, actUnknown, | ||||
|           fmt("installing '%s' into profile '%s'...", storePath, profileDir)); | ||||
|       LOG(INFO) << "installing '" << storePath << "' into profile '" | ||||
|                 << profileDir << "'..."; | ||||
|       runProgram(settings.nixBinDir + "/nix-env", false, | ||||
|                  {"--profile", profileDir, "-i", storePath, "--no-sandbox"}); | ||||
|     } | ||||
| 
 | ||||
|     printError(ANSI_GREEN "upgrade to version %s done" ANSI_NORMAL, version); | ||||
|     LOG(INFO) << ANSI_GREEN << "upgrade to version " << version << " done" | ||||
|               << ANSI_NORMAL; | ||||
|   } | ||||
| 
 | ||||
|   /* Return the profile in which Nix is installed. */ | ||||
|  | @ -111,10 +106,11 @@ struct CmdUpgradeNix : MixDryRun, StoreCommand { | |||
|       throw Error( | ||||
|           "couldn't figure out how Nix is installed, so I can't upgrade it"); | ||||
| 
 | ||||
|     printInfo("found Nix in '%s'", where); | ||||
|     LOG(INFO) << "found Nix in '" << where << "'"; | ||||
| 
 | ||||
|     if (hasPrefix(where, "/run/current-system")) | ||||
|     if (hasPrefix(where, "/run/current-system")) { | ||||
|       throw Error("Nix on NixOS must be upgraded via 'nixos-rebuild'"); | ||||
|     } | ||||
| 
 | ||||
|     Path profileDir = dirOf(where); | ||||
| 
 | ||||
|  | @ -123,7 +119,7 @@ struct CmdUpgradeNix : MixDryRun, StoreCommand { | |||
|            isLink(profileDir)) | ||||
|       profileDir = readLink(profileDir); | ||||
| 
 | ||||
|     printInfo("found profile '%s'", profileDir); | ||||
|     LOG(INFO) << "found profile '" << profileDir << "'"; | ||||
| 
 | ||||
|     Path userEnv = canonPath(profileDir, true); | ||||
| 
 | ||||
|  |  | |||
							
								
								
									
										30
									
								
								third_party/nix/src/nix/verify.cc
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										30
									
								
								third_party/nix/src/nix/verify.cc
									
										
									
									
										vendored
									
									
								
							|  | @ -1,3 +1,4 @@ | |||
| #include <glog/logging.h> | ||||
| #include <atomic> | ||||
| #include "command.hh" | ||||
| #include "shared.hh" | ||||
|  | @ -53,29 +54,21 @@ struct CmdVerify : StorePathsCommand { | |||
| 
 | ||||
|     auto publicKeys = getDefaultPublicKeys(); | ||||
| 
 | ||||
|     Activity act(*logger, actVerifyPaths); | ||||
| 
 | ||||
|     std::atomic<size_t> done{0}; | ||||
|     std::atomic<size_t> untrusted{0}; | ||||
|     std::atomic<size_t> corrupted{0}; | ||||
|     std::atomic<size_t> failed{0}; | ||||
|     std::atomic<size_t> active{0}; | ||||
| 
 | ||||
|     auto update = [&]() { | ||||
|       act.progress(done, storePaths.size(), active, failed); | ||||
|     }; | ||||
| 
 | ||||
|     ThreadPool pool; | ||||
| 
 | ||||
|     auto doPath = [&](const Path& storePath) { | ||||
|       try { | ||||
|         checkInterrupt(); | ||||
| 
 | ||||
|         Activity act2(*logger, lvlInfo, actUnknown, | ||||
|                       fmt("checking '%s'", storePath)); | ||||
|         LOG(INFO) << "checking '" << storePath << "'"; | ||||
| 
 | ||||
|         MaintainCount<std::atomic<size_t>> mcActive(active); | ||||
|         update(); | ||||
| 
 | ||||
|         auto info = store->queryPathInfo(storePath); | ||||
| 
 | ||||
|  | @ -87,11 +80,10 @@ struct CmdVerify : StorePathsCommand { | |||
| 
 | ||||
|           if (hash.first != info->narHash) { | ||||
|             corrupted++; | ||||
|             act2.result(resCorruptedPath, info->path); | ||||
|             printError( | ||||
|                 format("path '%s' was modified! expected hash '%s', got '%s'") % | ||||
|                 info->path % info->narHash.to_string() % | ||||
|                 hash.first.to_string()); | ||||
|             LOG(WARNING) << "path '" << info->path | ||||
|                          << "' was modified! expected hash '" | ||||
|                          << info->narHash.to_string() << "', got '" | ||||
|                          << hash.first.to_string() << "'"; | ||||
|           } | ||||
|         } | ||||
| 
 | ||||
|  | @ -130,8 +122,7 @@ struct CmdVerify : StorePathsCommand { | |||
|                 doSigs(info2->sigs); | ||||
|               } catch (InvalidPath&) { | ||||
|               } catch (Error& e) { | ||||
|                 printError(format(ANSI_RED "error:" ANSI_NORMAL " %s") % | ||||
|                            e.what()); | ||||
|                 LOG(ERROR) << e.what(); | ||||
|               } | ||||
|             } | ||||
| 
 | ||||
|  | @ -140,19 +131,16 @@ struct CmdVerify : StorePathsCommand { | |||
| 
 | ||||
|           if (!good) { | ||||
|             untrusted++; | ||||
|             act2.result(resUntrustedPath, info->path); | ||||
|             printError(format("path '%s' is untrusted") % info->path); | ||||
|             LOG(WARNING) << "path '" << info->path << "' is untrusted"; | ||||
|           } | ||||
|         } | ||||
| 
 | ||||
|         done++; | ||||
| 
 | ||||
|       } catch (Error& e) { | ||||
|         printError(format(ANSI_RED "error:" ANSI_NORMAL " %s") % e.what()); | ||||
|         LOG(ERROR) << e.what(); | ||||
|         failed++; | ||||
|       } | ||||
| 
 | ||||
|       update(); | ||||
|     }; | ||||
| 
 | ||||
|     for (auto& storePath : storePaths) | ||||
|  |  | |||
							
								
								
									
										8
									
								
								third_party/nix/src/nix/why-depends.cc
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								third_party/nix/src/nix/why-depends.cc
									
										
									
									
										vendored
									
									
								
							|  | @ -1,7 +1,7 @@ | |||
| #include <glog/logging.h> | ||||
| #include <queue> | ||||
| #include "command.hh" | ||||
| #include "fs-accessor.hh" | ||||
| #include "progress-bar.hh" | ||||
| #include "shared.hh" | ||||
| #include "store-api.hh" | ||||
| 
 | ||||
|  | @ -67,13 +67,11 @@ struct CmdWhyDepends : SourceExprCommand { | |||
|     store->computeFSClosure({packagePath}, closure, false, false); | ||||
| 
 | ||||
|     if (!closure.count(dependencyPath)) { | ||||
|       printError("'%s' does not depend on '%s'", package->what(), | ||||
|                  dependency->what()); | ||||
|       LOG(WARNING) << "'" << package->what() << "' does not depend on '" | ||||
|                    << dependency->what() << "'"; | ||||
|       return; | ||||
|     } | ||||
| 
 | ||||
|     stopProgressBar();  // FIXME
 | ||||
| 
 | ||||
|     auto accessor = store->getFSAccessor(); | ||||
| 
 | ||||
|     auto const inf = std::numeric_limits<size_t>::max(); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue