forked from lix-project/lix
Remove Lazy
This fixes a crash during startup when compiling Nix as a single compilation unit.
This commit is contained in:
parent
87157b2bd3
commit
e845d19ae3
2 changed files with 18 additions and 64 deletions
|
@ -1,48 +0,0 @@
|
||||||
#include <exception>
|
|
||||||
#include <functional>
|
|
||||||
#include <mutex>
|
|
||||||
|
|
||||||
namespace nix {
|
|
||||||
|
|
||||||
/* A helper class for lazily-initialized variables.
|
|
||||||
|
|
||||||
Lazy<T> var([]() { return value; });
|
|
||||||
|
|
||||||
declares a variable of type T that is initialized to 'value' (in a
|
|
||||||
thread-safe way) on first use, that is, when var() is first
|
|
||||||
called. If the initialiser code throws an exception, then all
|
|
||||||
subsequent calls to var() will rethrow that exception. */
|
|
||||||
template<typename T>
|
|
||||||
class Lazy
|
|
||||||
{
|
|
||||||
|
|
||||||
typedef std::function<T()> Init;
|
|
||||||
|
|
||||||
Init init;
|
|
||||||
|
|
||||||
std::once_flag done;
|
|
||||||
|
|
||||||
T value;
|
|
||||||
|
|
||||||
std::exception_ptr ex;
|
|
||||||
|
|
||||||
public:
|
|
||||||
|
|
||||||
Lazy(Init init) : init(init)
|
|
||||||
{ }
|
|
||||||
|
|
||||||
const T & operator () ()
|
|
||||||
{
|
|
||||||
std::call_once(done, [&]() {
|
|
||||||
try {
|
|
||||||
value = init();
|
|
||||||
} catch (...) {
|
|
||||||
ex = std::current_exception();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
if (ex) std::rethrow_exception(ex);
|
|
||||||
return value;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
}
|
|
|
@ -1,4 +1,3 @@
|
||||||
#include "lazy.hh"
|
|
||||||
#include "util.hh"
|
#include "util.hh"
|
||||||
#include "affinity.hh"
|
#include "affinity.hh"
|
||||||
#include "sync.hh"
|
#include "sync.hh"
|
||||||
|
@ -522,21 +521,24 @@ std::string getUserName()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static Lazy<Path> getHome2([]() {
|
Path getHome()
|
||||||
auto homeDir = getEnv("HOME");
|
{
|
||||||
if (!homeDir) {
|
static Path homeDir = []()
|
||||||
std::vector<char> buf(16384);
|
{
|
||||||
struct passwd pwbuf;
|
auto homeDir = getEnv("HOME");
|
||||||
struct passwd * pw;
|
if (!homeDir) {
|
||||||
if (getpwuid_r(geteuid(), &pwbuf, buf.data(), buf.size(), &pw) != 0
|
std::vector<char> buf(16384);
|
||||||
|| !pw || !pw->pw_dir || !pw->pw_dir[0])
|
struct passwd pwbuf;
|
||||||
throw Error("cannot determine user's home directory");
|
struct passwd * pw;
|
||||||
homeDir = pw->pw_dir;
|
if (getpwuid_r(geteuid(), &pwbuf, buf.data(), buf.size(), &pw) != 0
|
||||||
}
|
|| !pw || !pw->pw_dir || !pw->pw_dir[0])
|
||||||
return *homeDir;
|
throw Error("cannot determine user's home directory");
|
||||||
});
|
homeDir = pw->pw_dir;
|
||||||
|
}
|
||||||
Path getHome() { return getHome2(); }
|
return *homeDir;
|
||||||
|
}();
|
||||||
|
return homeDir;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
Path getCacheDir()
|
Path getCacheDir()
|
||||||
|
|
Loading…
Reference in a new issue