libutil: cleanup savedCwd logic
Co-authored-by: Eelco Dolstra <edolstra@gmail.com>
This commit is contained in:
parent
2a45cf54e4
commit
e5b70d47aa
|
@ -1698,20 +1698,7 @@ void saveMountNamespace()
|
||||||
#if __linux__
|
#if __linux__
|
||||||
static std::once_flag done;
|
static std::once_flag done;
|
||||||
std::call_once(done, []() {
|
std::call_once(done, []() {
|
||||||
#ifdef __GNU__
|
savedCwd = absPath(".");
|
||||||
// getcwd allocating its return value is a GNU extension.
|
|
||||||
char *cwd = getcwd(NULL, 0);
|
|
||||||
if (cwd == NULL)
|
|
||||||
#else
|
|
||||||
char cwd[PATH_MAX];
|
|
||||||
if (!getcwd(cwd, sizeof(cwd)))
|
|
||||||
#endif
|
|
||||||
throw SysError("getting cwd");
|
|
||||||
savedCwd.emplace(cwd);
|
|
||||||
#ifdef __GNU__
|
|
||||||
free(cwd);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
AutoCloseFD fd = open("/proc/self/ns/mnt", O_RDONLY);
|
AutoCloseFD fd = open("/proc/self/ns/mnt", O_RDONLY);
|
||||||
if (!fd)
|
if (!fd)
|
||||||
throw SysError("saving parent mount namespace");
|
throw SysError("saving parent mount namespace");
|
||||||
|
|
Loading…
Reference in a new issue