2008-02-29 05:30:29 -05:00
|
|
|
{stdenv, subversion, sshSupport ? false, openssh ? null}:
|
2007-12-04 17:06:13 -05:00
|
|
|
{url, rev ? "HEAD", md5 ? "", sha256 ? ""}:
|
2004-04-14 06:55:33 -04:00
|
|
|
|
2009-10-06 09:36:52 -04:00
|
|
|
let
|
|
|
|
repoName = with stdenv.lib;
|
|
|
|
let
|
|
|
|
fst = head;
|
|
|
|
snd = l: head (tail l);
|
|
|
|
trd = l: head (tail (tail l));
|
|
|
|
path_ = reverseList (splitString "/" url);
|
|
|
|
path = if head path_ == "" then tail path_ else path_;
|
|
|
|
in
|
|
|
|
# ../repo/trunk -> repo
|
|
|
|
if fst path == "trunk" then snd path
|
|
|
|
# ../repo/branches/branch -> repo-branch
|
|
|
|
else if snd path == "branches" then "${trd path}-${fst path}"
|
|
|
|
# ../repo/tags/tag -> repo-tag
|
|
|
|
else if snd path == "tags" then "${trd path}-${fst path}"
|
|
|
|
# ../repo (no trunk) -> repo
|
|
|
|
else fst path;
|
|
|
|
in
|
|
|
|
|
2004-04-14 06:55:33 -04:00
|
|
|
stdenv.mkDerivation {
|
2009-10-06 09:36:52 -04:00
|
|
|
name = "${repoName}-r${toString rev}";
|
2003-11-25 12:38:48 -05:00
|
|
|
builder = ./builder.sh;
|
2008-02-29 05:30:29 -05:00
|
|
|
buildInputs = [subversion];
|
2005-02-22 11:27:28 -05:00
|
|
|
|
2008-02-28 17:36:37 -05:00
|
|
|
outputHashAlgo = if sha256 == "" then "md5" else "sha256";
|
2005-02-22 16:15:13 -05:00
|
|
|
outputHashMode = "recursive";
|
2008-02-28 17:36:37 -05:00
|
|
|
outputHash = if sha256 == "" then md5 else sha256;
|
2005-02-22 11:27:28 -05:00
|
|
|
|
2006-07-17 11:22:20 -04:00
|
|
|
inherit url rev sshSupport openssh;
|
2009-05-19 13:07:20 -04:00
|
|
|
|
|
|
|
impureEnvVars = [
|
|
|
|
# We borrow these environment variables from the caller to allow
|
|
|
|
# easy proxy configuration. This is impure, but a fixed-output
|
|
|
|
# derivation like fetchurl is allowed to do so since its result is
|
|
|
|
# by definition pure.
|
|
|
|
"http_proxy" "https_proxy" "ftp_proxy" "all_proxy" "no_proxy"
|
|
|
|
];
|
2003-11-25 12:38:48 -05:00
|
|
|
}
|