refactor(3p/nix): Make all single-argument constructors explicit
Implicit constructors can be confusing, especially in a codebase that is already as unintentionally obfuscated as this one. https://google.github.io/styleguide/cppguide.html#Explicit_Constructors
This commit is contained in:
parent
3908732181
commit
88f337588c
12 changed files with 31 additions and 31 deletions
22
third_party/nix/src/libstore/build.cc
vendored
22
third_party/nix/src/libstore/build.cc
vendored
|
@ -133,7 +133,7 @@ class Goal : public std::enable_shared_from_this<Goal> {
|
|||
/* Whether the goal is finished. */
|
||||
ExitCode exitCode;
|
||||
|
||||
Goal(Worker& worker) : worker(worker) {
|
||||
explicit Goal(Worker& worker) : worker(worker) {
|
||||
nrFailed = nrNoSubstituters = nrIncompleteClosure = 0;
|
||||
exitCode = ecBusy;
|
||||
}
|
||||
|
@ -264,7 +264,7 @@ class Worker {
|
|||
it answers with "decline-permanently", we don't try again. */
|
||||
bool tryBuildHook = true;
|
||||
|
||||
Worker(LocalStore& store);
|
||||
explicit Worker(LocalStore& store);
|
||||
~Worker();
|
||||
|
||||
/* Make a goal (with caching). */
|
||||
|
@ -823,7 +823,7 @@ class DerivationGoal : public Goal {
|
|||
struct ChrootPath {
|
||||
Path source;
|
||||
bool optional;
|
||||
ChrootPath(Path source = "", bool optional = false)
|
||||
explicit ChrootPath(Path source = "", bool optional = false)
|
||||
: source(source), optional(optional) {}
|
||||
};
|
||||
typedef map<Path, ChrootPath>
|
||||
|
@ -2037,12 +2037,12 @@ void DerivationGoal::startBuilder() {
|
|||
}
|
||||
size_t p = i.find('=');
|
||||
if (p == string::npos) {
|
||||
dirsInChroot[i] = {i, optional};
|
||||
dirsInChroot[i] = ChrootPath(i, optional);
|
||||
} else {
|
||||
dirsInChroot[string(i, 0, p)] = {string(i, p + 1), optional};
|
||||
dirsInChroot[string(i, 0, p)] = ChrootPath(string(i, p + 1), optional);
|
||||
}
|
||||
}
|
||||
dirsInChroot[tmpDirInSandbox] = tmpDir;
|
||||
dirsInChroot[tmpDirInSandbox] = ChrootPath(tmpDir);
|
||||
|
||||
/* Add the closure of store paths to the chroot. */
|
||||
PathSet closure;
|
||||
|
@ -2058,7 +2058,7 @@ void DerivationGoal::startBuilder() {
|
|||
}
|
||||
}
|
||||
for (auto& i : closure) {
|
||||
dirsInChroot[i] = i;
|
||||
dirsInChroot[i] = ChrootPath(i);
|
||||
}
|
||||
|
||||
PathSet allowedPaths = settings.allowedImpureHostPrefixes;
|
||||
|
@ -2088,7 +2088,7 @@ void DerivationGoal::startBuilder() {
|
|||
drvPath % i);
|
||||
}
|
||||
|
||||
dirsInChroot[i] = i;
|
||||
dirsInChroot[i] = ChrootPath(i);
|
||||
}
|
||||
|
||||
#if __linux__
|
||||
|
@ -2170,7 +2170,7 @@ void DerivationGoal::startBuilder() {
|
|||
throw SysError(format("getting attributes of path '%1%'") % i);
|
||||
}
|
||||
if (S_ISDIR(st.st_mode)) {
|
||||
dirsInChroot[i] = r;
|
||||
dirsInChroot[i] = ChrootPath(r);
|
||||
} else {
|
||||
Path p = chrootRootDir + i;
|
||||
DLOG(INFO) << "linking '" << p << "' to '" << r << "'";
|
||||
|
@ -2264,9 +2264,9 @@ void DerivationGoal::startBuilder() {
|
|||
} else {
|
||||
auto p = line.find('=');
|
||||
if (p == string::npos) {
|
||||
dirsInChroot[line] = line;
|
||||
dirsInChroot[line] = ChrootPath(line);
|
||||
} else {
|
||||
dirsInChroot[string(line, 0, p)] = string(line, p + 1);
|
||||
dirsInChroot[string(line, 0, p)] = ChrootPath(string(line, p + 1));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -9,7 +9,7 @@ namespace nix {
|
|||
struct HashAndWriteSink : Sink {
|
||||
Sink& writeSink;
|
||||
HashSink hashSink;
|
||||
HashAndWriteSink(Sink& writeSink)
|
||||
explicit HashAndWriteSink(Sink& writeSink)
|
||||
: writeSink(writeSink), hashSink(htSHA256) {}
|
||||
virtual void operator()(const unsigned char* data, size_t len) {
|
||||
writeSink(data, len);
|
||||
|
|
2
third_party/nix/src/libstore/gc.cc
vendored
2
third_party/nix/src/libstore/gc.cc
vendored
|
@ -505,7 +505,7 @@ struct LocalStore::GCState {
|
|||
unsigned long long bytesInvalidated;
|
||||
bool moveToTrash = true;
|
||||
bool shouldDelete;
|
||||
GCState(GCResults& results_) : results(results_), bytesInvalidated(0) {}
|
||||
explicit GCState(GCResults& results_) : results(results_), bytesInvalidated(0) {}
|
||||
};
|
||||
|
||||
bool LocalStore::isActiveTempFile(const GCState& state, const Path& path,
|
||||
|
|
|
@ -12,7 +12,7 @@ LocalFSStore::LocalFSStore(const Params& params) : Store(params) {}
|
|||
struct LocalStoreAccessor : public FSAccessor {
|
||||
ref<LocalFSStore> store;
|
||||
|
||||
LocalStoreAccessor(ref<LocalFSStore> store) : store(store) {}
|
||||
explicit LocalStoreAccessor(ref<LocalFSStore> store) : store(store) {}
|
||||
|
||||
Path toRealPath(const Path& path) {
|
||||
Path storePath = store->toStorePath(path);
|
||||
|
|
2
third_party/nix/src/libstore/misc.cc
vendored
2
third_party/nix/src/libstore/misc.cc
vendored
|
@ -151,7 +151,7 @@ void Store::queryMissing(const PathSet& targets, PathSet& willBuild_,
|
|||
size_t left;
|
||||
bool done = false;
|
||||
PathSet outPaths;
|
||||
DrvState(size_t left) : left(left) {}
|
||||
explicit DrvState(size_t left) : left(left) {}
|
||||
};
|
||||
|
||||
Sync<State> state_(State{PathSet(), unknown_, willSubstitute_, willBuild_,
|
||||
|
|
2
third_party/nix/src/libstore/nar-accessor.cc
vendored
2
third_party/nix/src/libstore/nar-accessor.cc
vendored
|
@ -93,7 +93,7 @@ struct NarAccessor : public FSAccessor {
|
|||
}
|
||||
};
|
||||
|
||||
NarAccessor(ref<const std::string> nar) : nar(nar) {
|
||||
explicit NarAccessor(ref<const std::string> nar) : nar(nar) {
|
||||
NarIndexer indexer(*this, *nar);
|
||||
parseDump(indexer, indexer);
|
||||
}
|
||||
|
|
|
@ -27,7 +27,7 @@ static void makeWritable(const Path& path) {
|
|||
|
||||
struct MakeReadOnly {
|
||||
Path path;
|
||||
MakeReadOnly(const Path& path) : path(path) {}
|
||||
explicit MakeReadOnly(const Path& path) : path(path) {}
|
||||
~MakeReadOnly() {
|
||||
try {
|
||||
/* This will make the path read-only. */
|
||||
|
|
2
third_party/nix/src/libstore/remote-store.cc
vendored
2
third_party/nix/src/libstore/remote-store.cc
vendored
|
@ -215,7 +215,7 @@ struct ConnectionHandle {
|
|||
Pool<RemoteStore::Connection>::Handle handle;
|
||||
bool daemonException = false;
|
||||
|
||||
ConnectionHandle(Pool<RemoteStore::Connection>::Handle&& handle)
|
||||
explicit ConnectionHandle(Pool<RemoteStore::Connection>::Handle&& handle)
|
||||
: handle(std::move(handle)) {}
|
||||
|
||||
ConnectionHandle(ConnectionHandle&& h) : handle(std::move(h.handle)) {}
|
||||
|
|
12
third_party/nix/src/libutil/compression.cc
vendored
12
third_party/nix/src/libutil/compression.cc
vendored
|
@ -34,7 +34,7 @@ struct ChunkedCompressionSink : CompressionSink {
|
|||
|
||||
struct NoneSink : CompressionSink {
|
||||
Sink& nextSink;
|
||||
NoneSink(Sink& nextSink) : nextSink(nextSink) {}
|
||||
explicit NoneSink(Sink& nextSink) : nextSink(nextSink) {}
|
||||
void finish() override { flush(); }
|
||||
void write(const unsigned char* data, size_t len) override {
|
||||
nextSink(data, len);
|
||||
|
@ -47,7 +47,7 @@ struct XzDecompressionSink : CompressionSink {
|
|||
lzma_stream strm = LZMA_STREAM_INIT;
|
||||
bool finished = false;
|
||||
|
||||
XzDecompressionSink(Sink& nextSink) : nextSink(nextSink) {
|
||||
explicit XzDecompressionSink(Sink& nextSink) : nextSink(nextSink) {
|
||||
lzma_ret ret = lzma_stream_decoder(&strm, UINT64_MAX, LZMA_CONCATENATED);
|
||||
if (ret != LZMA_OK) {
|
||||
throw CompressionError("unable to initialise lzma decoder");
|
||||
|
@ -92,7 +92,7 @@ struct BzipDecompressionSink : ChunkedCompressionSink {
|
|||
bz_stream strm;
|
||||
bool finished = false;
|
||||
|
||||
BzipDecompressionSink(Sink& nextSink) : nextSink(nextSink) {
|
||||
explicit BzipDecompressionSink(Sink& nextSink) : nextSink(nextSink) {
|
||||
memset(&strm, 0, sizeof(strm));
|
||||
int ret = BZ2_bzDecompressInit(&strm, 0, 0);
|
||||
if (ret != BZ_OK) {
|
||||
|
@ -140,7 +140,7 @@ struct BrotliDecompressionSink : ChunkedCompressionSink {
|
|||
BrotliDecoderState* state;
|
||||
bool finished = false;
|
||||
|
||||
BrotliDecompressionSink(Sink& nextSink) : nextSink(nextSink) {
|
||||
explicit BrotliDecompressionSink(Sink& nextSink) : nextSink(nextSink) {
|
||||
state = BrotliDecoderCreateInstance(nullptr, nullptr, nullptr);
|
||||
if (!state) {
|
||||
throw CompressionError("unable to initialize brotli decoder");
|
||||
|
@ -284,7 +284,7 @@ struct BzipCompressionSink : ChunkedCompressionSink {
|
|||
bz_stream strm;
|
||||
bool finished = false;
|
||||
|
||||
BzipCompressionSink(Sink& nextSink) : nextSink(nextSink) {
|
||||
explicit BzipCompressionSink(Sink& nextSink) : nextSink(nextSink) {
|
||||
memset(&strm, 0, sizeof(strm));
|
||||
int ret = BZ2_bzCompressInit(&strm, 9, 0, 30);
|
||||
if (ret != BZ_OK) {
|
||||
|
@ -333,7 +333,7 @@ struct BrotliCompressionSink : ChunkedCompressionSink {
|
|||
BrotliEncoderState* state;
|
||||
bool finished = false;
|
||||
|
||||
BrotliCompressionSink(Sink& nextSink) : nextSink(nextSink) {
|
||||
explicit BrotliCompressionSink(Sink& nextSink) : nextSink(nextSink) {
|
||||
state = BrotliEncoderCreateInstance(nullptr, nullptr, nullptr);
|
||||
if (!state) {
|
||||
throw CompressionError("unable to initialise brotli encoder");
|
||||
|
|
6
third_party/nix/src/nix-daemon/nix-daemon.cc
vendored
6
third_party/nix/src/nix-daemon/nix-daemon.cc
vendored
|
@ -74,7 +74,7 @@ struct TunnelLogger {
|
|||
|
||||
unsigned int clientVersion;
|
||||
|
||||
TunnelLogger(unsigned int clientVersion) : clientVersion(clientVersion) {}
|
||||
explicit TunnelLogger(unsigned int clientVersion) : clientVersion(clientVersion) {}
|
||||
|
||||
void enqueueMsg(const std::string& s) {
|
||||
auto state(state_.lock());
|
||||
|
@ -150,7 +150,7 @@ struct TunnelLogger {
|
|||
|
||||
struct TunnelSink : Sink {
|
||||
Sink& to;
|
||||
TunnelSink(Sink& to) : to(to) {}
|
||||
explicit TunnelSink(Sink& to) : to(to) {}
|
||||
virtual void operator()(const unsigned char* data, size_t len) {
|
||||
to << STDERR_WRITE;
|
||||
writeString(data, len, to);
|
||||
|
@ -159,7 +159,7 @@ struct TunnelSink : Sink {
|
|||
|
||||
struct TunnelSource : BufferedSource {
|
||||
Source& from;
|
||||
TunnelSource(Source& from) : from(from) {}
|
||||
explicit TunnelSource(Source& from) : from(from) {}
|
||||
|
||||
protected:
|
||||
size_t readUnbuffered(unsigned char* data, size_t len) override {
|
||||
|
|
4
third_party/nix/src/nix/hash.cc
vendored
4
third_party/nix/src/nix/hash.cc
vendored
|
@ -14,7 +14,7 @@ struct CmdHash : Command {
|
|||
HashType ht = htSHA256;
|
||||
std::vector<std::string> paths;
|
||||
|
||||
CmdHash(Mode mode) : mode(mode) {
|
||||
explicit CmdHash(Mode mode) : mode(mode) {
|
||||
mkFlag(0, "sri", "print hash in SRI format", &base, SRI);
|
||||
mkFlag(0, "base64", "print hash in base-64", &base, Base64);
|
||||
mkFlag(0, "base32", "print hash in base-32 (Nix-specific)", &base, Base32);
|
||||
|
@ -52,7 +52,7 @@ struct CmdToBase : Command {
|
|||
HashType ht = htUnknown;
|
||||
std::vector<std::string> args;
|
||||
|
||||
CmdToBase(Base base) : base(base) {
|
||||
explicit CmdToBase(Base base) : base(base) {
|
||||
mkFlag().longName("type").mkHashTypeFlag(&ht);
|
||||
expectArgs("strings", &args);
|
||||
}
|
||||
|
|
4
third_party/nix/src/nix/installables.cc
vendored
4
third_party/nix/src/nix/installables.cc
vendored
|
@ -100,7 +100,7 @@ Buildable Installable::toBuildable() {
|
|||
struct InstallableStorePath : Installable {
|
||||
Path storePath;
|
||||
|
||||
InstallableStorePath(const Path& storePath) : storePath(storePath) {}
|
||||
explicit InstallableStorePath(const Path& storePath) : storePath(storePath) {}
|
||||
|
||||
std::string what() override { return storePath; }
|
||||
|
||||
|
@ -112,7 +112,7 @@ struct InstallableStorePath : Installable {
|
|||
struct InstallableValue : Installable {
|
||||
SourceExprCommand& cmd;
|
||||
|
||||
InstallableValue(SourceExprCommand& cmd) : cmd(cmd) {}
|
||||
explicit InstallableValue(SourceExprCommand& cmd) : cmd(cmd) {}
|
||||
|
||||
Buildables toBuildables() override {
|
||||
auto state = cmd.getEvalState();
|
||||
|
|
Loading…
Reference in a new issue