aboutsummaryrefslogtreecommitdiff
path: root/src/libexpr
diff options
context:
space:
mode:
authorEelco Dolstra <e.dolstra@tudelft.nl>2007-02-02 01:52:42 +0000
committerEelco Dolstra <e.dolstra@tudelft.nl>2007-02-02 01:52:42 +0000
commit451dbf687f65b42d70e64c3858771abaab51b356 (patch)
tree2954eb3c33c2d3800ac1f4296d4c694613485079 /src/libexpr
parentf52de527c7743d8fe28574f02b632566a1006244 (diff)
* nix-env now maintains meta info (from the `meta' derivation
attribute) about installed packages in user environments. Thus, an operation like `nix-env -q --description' shows useful information not only on available packages but also on installed packages. * nix-env now passes the entire manifest as an argument to the Nix expression of the user environment builder (not just a list of paths), so that in particular the user environment builder has access to the meta attributes. * New operation `--set-flag' in nix-env to change meta info of installed packages. This will be useful to pass per-package policies to the user environment builder (e.g., how to resolve collision or whether to disable a package (NIX-80)) or upgrade policies in nix-env (e.g., that a package should be "masked", that is, left untouched by upgrade actions). Example: $ nix-env --set-flag enabled false ghc-6.4
Diffstat (limited to 'src/libexpr')
-rw-r--r--src/libexpr/get-drvs.cc10
-rw-r--r--src/libexpr/get-drvs.hh5
-rw-r--r--src/libexpr/nixexpr.cc2
-rw-r--r--src/libexpr/nixexpr.hh2
4 files changed, 17 insertions, 2 deletions
diff --git a/src/libexpr/get-drvs.cc b/src/libexpr/get-drvs.cc
index ba9fbcd6d..bd0ec4781 100644
--- a/src/libexpr/get-drvs.cc
+++ b/src/libexpr/get-drvs.cc
@@ -60,6 +60,16 @@ MetaInfo DrvInfo::queryMetaInfo(EvalState & state) const
}
+void DrvInfo::setMetaInfo(const MetaInfo & meta)
+{
+ ATermMap metaAttrs;
+ for (MetaInfo::const_iterator i = meta.begin(); i != meta.end(); ++i)
+ metaAttrs.set(toATerm(i->first),
+ makeAttrRHS(makeStr(i->second), makeNoPos()));
+ attrs->set(toATerm("meta"), makeAttrs(metaAttrs));
+}
+
+
/* Cache for already evaluated derivations. Usually putting ATerms in
a STL container is unsafe (they're not scanning for GC roots), but
here it doesn't matter; everything in this set is reachable from
diff --git a/src/libexpr/get-drvs.hh b/src/libexpr/get-drvs.hh
index 3dac56a4f..920197d1f 100644
--- a/src/libexpr/get-drvs.hh
+++ b/src/libexpr/get-drvs.hh
@@ -26,6 +26,9 @@ public:
string attrPath; /* path towards the derivation */
string system;
+ /* !!! these should really be hidden, and setMetaInfo() should
+ make a copy since the ATermMap can be shared between multiple
+ DrvInfos. */
boost::shared_ptr<ATermMap> attrs;
string queryDrvPath(EvalState & state) const;
@@ -41,6 +44,8 @@ public:
{
outPath = s;
}
+
+ void setMetaInfo(const MetaInfo & meta);
};
diff --git a/src/libexpr/nixexpr.cc b/src/libexpr/nixexpr.cc
index 7502fd166..123513594 100644
--- a/src/libexpr/nixexpr.cc
+++ b/src/libexpr/nixexpr.cc
@@ -319,7 +319,7 @@ struct Canonicalise : TermFun
};
-Expr canonicaliseExpr(Expr & e)
+Expr canonicaliseExpr(Expr e)
{
Canonicalise canonicalise;
return bottomupRewrite(canonicalise, e);
diff --git a/src/libexpr/nixexpr.hh b/src/libexpr/nixexpr.hh
index d76bc1060..420911a87 100644
--- a/src/libexpr/nixexpr.hh
+++ b/src/libexpr/nixexpr.hh
@@ -96,7 +96,7 @@ void checkVarDefs(const ATermMap & def, Expr e);
/* Canonicalise a Nix expression by sorting attributes and removing
location information. */
-Expr canonicaliseExpr(Expr & e);
+Expr canonicaliseExpr(Expr e);
/* Create an expression representing a boolean. */