aboutsummaryrefslogtreecommitdiff
path: root/src/libexpr/primops.cc
diff options
context:
space:
mode:
authorEelco Dolstra <eelco.dolstra@logicblox.com>2013-02-08 19:36:23 +0100
committerEelco Dolstra <eelco.dolstra@logicblox.com>2013-02-08 19:36:23 +0100
commit52172607cfc33867c0cdb526bef99c315e98baa2 (patch)
tree350c9b7866db892d2bd0cc0e54fb37a9e0a58217 /src/libexpr/primops.cc
parent01a5ea9914b3933e63a88184861900615be76e12 (diff)
Rename "hash" to "hashString" and handle SHA-1
Diffstat (limited to 'src/libexpr/primops.cc')
-rw-r--r--src/libexpr/primops.cc28
1 files changed, 9 insertions, 19 deletions
diff --git a/src/libexpr/primops.cc b/src/libexpr/primops.cc
index 84c4bbb88..f66b24b77 100644
--- a/src/libexpr/primops.cc
+++ b/src/libexpr/primops.cc
@@ -1107,27 +1107,18 @@ static void prim_unsafeDiscardOutputDependency(EvalState & state, Value * * args
}
-static void prim_hash(EvalState & state, Value * * args, Value & v)
+/* Return the cryptographic hash of a string in base-16. */
+static void prim_hashString(EvalState & state, Value * * args, Value & v)
{
- PathSet context;
-
string type = state.forceStringNoCtx(*args[0]);
- string s = state.forceStringNoCtx(*args[1]);
+ HashType ht = parseHashType(type);
+ if (ht == htUnknown)
+ throw Error(format("unknown hash type `%1%'") % type);
- HashType ht;
- if (type == "md5"){
- ht = htMD5;
- } else if (type == "sha256"){
- ht = htSHA256;
- } else {
- throw Error(format("bad hash type `%1%'") % type);
- }
+ PathSet context; // discarded
+ string s = state.forceString(*args[1], context);
- Hash h = hashString(ht, s);
-
- string hash = printHash(h);
-
- mkString(v, hash, context);
+ mkString(v, printHash(hashString(ht, s)), context);
};
@@ -1258,8 +1249,7 @@ void EvalState::createBaseEnv()
addPrimOp("__stringLength", 1, prim_stringLength);
addPrimOp("__unsafeDiscardStringContext", 1, prim_unsafeDiscardStringContext);
addPrimOp("__unsafeDiscardOutputDependency", 1, prim_unsafeDiscardOutputDependency);
-
- addPrimOp("__hash", 2, prim_hash);
+ addPrimOp("__hashString", 2, prim_hashString);
// Versions
addPrimOp("__parseDrvName", 1, prim_parseDrvName);