forked from lix-project/lix
parent
68dcbb187e
commit
b7629778ef
4 changed files with 46 additions and 46 deletions
|
@ -235,6 +235,26 @@ flag, e.g. <literal>--option gc-keep-outputs false</literal>.</para>
|
||||||
</varlistentry>
|
</varlistentry>
|
||||||
|
|
||||||
|
|
||||||
|
<varlistentry xml:id="conf-build-chroot-dirs"><term><literal>build-chroot-dirs</literal></term>
|
||||||
|
|
||||||
|
<listitem><para>When builds are performed in a chroot environment,
|
||||||
|
Nix will mount some directories from the normal file system
|
||||||
|
hierarchy inside the chroot. These are the Nix store, the
|
||||||
|
temporary build directory (usually
|
||||||
|
<filename>/tmp/nix-build-<replaceable>drvname</replaceable>-<replaceable>number</replaceable></filename>),
|
||||||
|
the <literal>/proc</literal> filesystem, and the directories
|
||||||
|
listed here. The default is <literal>/dev /dev/pts</literal>,
|
||||||
|
since these contain files needed by many builds (such as
|
||||||
|
<filename>/dev/null</filename>). You can use the syntax
|
||||||
|
<literal><replaceable>target</replaceable>=<replaceable>source</replaceable></literal>
|
||||||
|
to mount a path in a different location in the chroot; for
|
||||||
|
instance, <literal>/bin=/nix-bin</literal> will mount the
|
||||||
|
directory <literal>/nix-bin</literal> as <literal>/bin</literal>
|
||||||
|
inside the chroot.</para></listitem>
|
||||||
|
|
||||||
|
</varlistentry>
|
||||||
|
|
||||||
|
|
||||||
<varlistentry><term><literal>build-use-substitutes</literal></term>
|
<varlistentry><term><literal>build-use-substitutes</literal></term>
|
||||||
|
|
||||||
<listitem><para>If set to <literal>true</literal> (default), Nix
|
<listitem><para>If set to <literal>true</literal> (default), Nix
|
||||||
|
@ -254,33 +274,6 @@ flag, e.g. <literal>--option gc-keep-outputs false</literal>.</para>
|
||||||
</varlistentry>
|
</varlistentry>
|
||||||
|
|
||||||
|
|
||||||
<varlistentry xml:id="conf-build-chroot-dirs"><term><literal>build-chroot-dirs</literal></term>
|
|
||||||
|
|
||||||
<listitem><para>When builds are performed in a chroot environment,
|
|
||||||
Nix will mount (using <command>mount --bind</command> on Linux)
|
|
||||||
some directories from the normal file system hierarchy inside the
|
|
||||||
chroot. These are the Nix store, the temporary build directory
|
|
||||||
(usually
|
|
||||||
<filename>/tmp/nix-<replaceable>pid</replaceable>-<replaceable>number</replaceable></filename>)
|
|
||||||
and the directories listed here. The default is <literal>dev
|
|
||||||
/proc</literal>. Files in <filename>/dev</filename> (such as
|
|
||||||
<filename>/dev/null</filename>) are needed by many builds, and
|
|
||||||
some files in <filename>/proc</filename> may also be needed
|
|
||||||
occasionally.</para>
|
|
||||||
|
|
||||||
<para>The value used on NixOS is
|
|
||||||
|
|
||||||
<programlisting>
|
|
||||||
build-use-chroot = /dev /proc /bin</programlisting>
|
|
||||||
|
|
||||||
to make the <filename>/bin/sh</filename> symlink available (which
|
|
||||||
is still needed by many builders).</para>
|
|
||||||
|
|
||||||
</listitem>
|
|
||||||
|
|
||||||
</varlistentry>
|
|
||||||
|
|
||||||
|
|
||||||
<varlistentry><term><literal>build-cache-failures</literal></term>
|
<varlistentry><term><literal>build-cache-failures</literal></term>
|
||||||
|
|
||||||
<listitem><para>If set to <literal>true</literal>, Nix will
|
<listitem><para>If set to <literal>true</literal>, Nix will
|
||||||
|
|
|
@ -813,7 +813,8 @@ private:
|
||||||
GoalState state;
|
GoalState state;
|
||||||
|
|
||||||
/* Stuff we need to pass to initChild(). */
|
/* Stuff we need to pass to initChild(). */
|
||||||
PathSet dirsInChroot;
|
typedef map<Path, Path> DirsInChroot; // maps target path to source path
|
||||||
|
DirsInChroot dirsInChroot;
|
||||||
typedef map<string, string> Environment;
|
typedef map<string, string> Environment;
|
||||||
Environment env;
|
Environment env;
|
||||||
|
|
||||||
|
@ -1863,8 +1864,14 @@ void DerivationGoal::startBuilder()
|
||||||
|
|
||||||
/* Bind-mount a user-configurable set of directories from the
|
/* Bind-mount a user-configurable set of directories from the
|
||||||
host file system. */
|
host file system. */
|
||||||
dirsInChroot = settings.dirsInChroot;
|
foreach (StringSet::iterator, i, settings.dirsInChroot) {
|
||||||
dirsInChroot.insert(tmpDir);
|
size_t p = i->find('=');
|
||||||
|
if (p == string::npos)
|
||||||
|
dirsInChroot[*i] = *i;
|
||||||
|
else
|
||||||
|
dirsInChroot[string(*i, 0, p)] = string(*i, p + 1);
|
||||||
|
}
|
||||||
|
dirsInChroot[tmpDir] = tmpDir;
|
||||||
|
|
||||||
/* Make the closure of the inputs available in the chroot,
|
/* Make the closure of the inputs available in the chroot,
|
||||||
rather than the whole Nix store. This prevents any access
|
rather than the whole Nix store. This prevents any access
|
||||||
|
@ -1881,7 +1888,7 @@ void DerivationGoal::startBuilder()
|
||||||
if (lstat(i->c_str(), &st))
|
if (lstat(i->c_str(), &st))
|
||||||
throw SysError(format("getting attributes of path `%1%'") % *i);
|
throw SysError(format("getting attributes of path `%1%'") % *i);
|
||||||
if (S_ISDIR(st.st_mode))
|
if (S_ISDIR(st.st_mode))
|
||||||
dirsInChroot.insert(*i);
|
dirsInChroot[*i] = *i;
|
||||||
else {
|
else {
|
||||||
/* Creating a hard link to *i is impossible if its
|
/* Creating a hard link to *i is impossible if its
|
||||||
immutable bit is set. So clear it first. */
|
immutable bit is set. So clear it first. */
|
||||||
|
@ -2056,9 +2063,9 @@ void DerivationGoal::initChild()
|
||||||
/* Bind-mount all the directories from the "host"
|
/* Bind-mount all the directories from the "host"
|
||||||
filesystem that we want in the chroot
|
filesystem that we want in the chroot
|
||||||
environment. */
|
environment. */
|
||||||
foreach (PathSet::iterator, i, dirsInChroot) {
|
foreach (DirsInChroot::iterator, i, dirsInChroot) {
|
||||||
Path source = *i;
|
Path source = i->second;
|
||||||
Path target = chrootRootDir + source;
|
Path target = chrootRootDir + i->first;
|
||||||
if (source == "/proc") continue; // backwards compatibility
|
if (source == "/proc") continue; // backwards compatibility
|
||||||
debug(format("bind mounting `%1%' to `%2%'") % source % target);
|
debug(format("bind mounting `%1%' to `%2%'") % source % target);
|
||||||
createDirs(target);
|
createDirs(target);
|
||||||
|
|
|
@ -158,7 +158,7 @@ void Settings::get(bool & res, const string & name)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void Settings::get(PathSet & res, const string & name)
|
void Settings::get(StringSet & res, const string & name)
|
||||||
{
|
{
|
||||||
SettingsMap::iterator i = settings.find(name);
|
SettingsMap::iterator i = settings.find(name);
|
||||||
if (i == settings.end()) return;
|
if (i == settings.end()) return;
|
||||||
|
|
|
@ -139,7 +139,7 @@ struct Settings {
|
||||||
|
|
||||||
/* The directories from the host filesystem to be included in the
|
/* The directories from the host filesystem to be included in the
|
||||||
chroot. */
|
chroot. */
|
||||||
PathSet dirsInChroot;
|
StringSet dirsInChroot;
|
||||||
|
|
||||||
/* Whether to impersonate a Linux 2.6 machine on newer kernels. */
|
/* Whether to impersonate a Linux 2.6 machine on newer kernels. */
|
||||||
bool impersonateLinux26;
|
bool impersonateLinux26;
|
||||||
|
@ -181,7 +181,7 @@ private:
|
||||||
|
|
||||||
void get(string & res, const string & name);
|
void get(string & res, const string & name);
|
||||||
void get(bool & res, const string & name);
|
void get(bool & res, const string & name);
|
||||||
void get(PathSet & res, const string & name);
|
void get(StringSet & res, const string & name);
|
||||||
template<class N> void get(N & res, const string & name);
|
template<class N> void get(N & res, const string & name);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue