2009-02-09 08:51:03 -08:00
|
|
|
# Functions for copying sources to the Nix store.
|
|
|
|
|
|
|
|
let lib = import ./default.nix; in
|
|
|
|
|
|
|
|
rec {
|
|
|
|
|
2016-06-02 08:03:35 -07:00
|
|
|
# Returns the type of a path: regular (for file), symlink, or directory
|
|
|
|
pathType = p: with builtins; getAttr (baseNameOf p) (readDir (dirOf p));
|
|
|
|
|
|
|
|
# Returns true if the path exists and is a directory, false otherwise
|
|
|
|
pathIsDirectory = p: if builtins.pathExists p then (pathType p) == "directory" else false;
|
2009-02-09 08:51:03 -08:00
|
|
|
|
|
|
|
# Bring in a path as a source, filtering out all Subversion and CVS
|
|
|
|
# directories, as well as backup files (*~).
|
|
|
|
cleanSource =
|
|
|
|
let filter = name: type: let baseName = baseNameOf (toString name); in ! (
|
|
|
|
# Filter out Subversion and CVS directories.
|
2014-02-03 14:43:54 -08:00
|
|
|
(type == "directory" && (baseName == ".git" || baseName == ".svn" || baseName == "CVS" || baseName == ".hg")) ||
|
2009-02-09 08:51:03 -08:00
|
|
|
# Filter out backup files.
|
2014-02-06 03:30:03 -08:00
|
|
|
lib.hasSuffix "~" baseName ||
|
|
|
|
# Filter out generates files.
|
|
|
|
lib.hasSuffix ".o" baseName ||
|
2016-08-06 11:53:18 -07:00
|
|
|
lib.hasSuffix ".so" baseName ||
|
|
|
|
# Filter out nix-build result symlinks
|
|
|
|
(type == "symlink" && lib.hasPrefix "result" baseName)
|
2009-02-09 08:51:03 -08:00
|
|
|
);
|
|
|
|
in src: builtins.filterSource filter src;
|
|
|
|
|
|
|
|
|
|
|
|
# Get all files ending with the specified suffices from the given
|
2014-08-25 05:33:17 -07:00
|
|
|
# directory or its descendants. E.g. `sourceFilesBySuffices ./dir
|
|
|
|
# [".xml" ".c"]'.
|
2009-02-09 08:51:03 -08:00
|
|
|
sourceFilesBySuffices = path: exts:
|
|
|
|
let filter = name: type:
|
|
|
|
let base = baseNameOf (toString name);
|
2014-08-25 05:33:17 -07:00
|
|
|
in type == "directory" || lib.any (ext: lib.hasSuffix ext base) exts;
|
2009-02-09 08:51:03 -08:00
|
|
|
in builtins.filterSource filter path;
|
|
|
|
|
2016-06-02 08:03:35 -07:00
|
|
|
|
2016-05-24 15:34:28 -07:00
|
|
|
# Get the commit id of a git repo
|
|
|
|
# Example: commitIdFromGitRepo <nixpkgs/.git>
|
|
|
|
commitIdFromGitRepo =
|
|
|
|
let readCommitFromFile = path: file:
|
|
|
|
with builtins;
|
|
|
|
let fileName = toString path + "/" + file;
|
|
|
|
packedRefsName = toString path + "/packed-refs";
|
|
|
|
in if lib.pathExists fileName
|
|
|
|
then
|
2016-07-31 05:58:54 -07:00
|
|
|
let fileContent = lib.fileContents fileName;
|
2016-05-24 15:34:28 -07:00
|
|
|
# Sometimes git stores the commitId directly in the file but
|
|
|
|
# sometimes it stores something like: «ref: refs/heads/branch-name»
|
2016-07-31 05:58:54 -07:00
|
|
|
matchRef = match "^ref: (.*)$" fileContent;
|
2016-05-24 15:34:28 -07:00
|
|
|
in if isNull matchRef
|
2016-07-31 05:58:54 -07:00
|
|
|
then fileContent
|
2016-05-24 15:34:28 -07:00
|
|
|
else readCommitFromFile path (lib.head matchRef)
|
|
|
|
# Sometimes, the file isn't there at all and has been packed away in the
|
|
|
|
# packed-refs file, so we have to grep through it:
|
|
|
|
else if lib.pathExists packedRefsName
|
|
|
|
then
|
2016-07-27 07:44:26 -07:00
|
|
|
let fileContent = readFile packedRefsName;
|
|
|
|
matchRef = match ".*\n([^\n ]*) " + file + "\n.*" fileContent;
|
|
|
|
in if isNull matchRef
|
|
|
|
then throw ("Could not find " + file + " in " + packedRefsName)
|
|
|
|
else lib.head matchRef
|
2016-05-24 15:34:28 -07:00
|
|
|
else throw ("Not a .git directory: " + path);
|
|
|
|
in lib.flip readCommitFromFile "HEAD";
|
2009-02-09 08:51:03 -08:00
|
|
|
}
|