2009-02-09 19:51:03 +03:00
|
|
|
# Functions for copying sources to the Nix store.
|
|
|
|
|
|
|
|
let lib = import ./default.nix; in
|
|
|
|
|
|
|
|
rec {
|
|
|
|
|
|
|
|
|
|
|
|
# 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-04 02:43:54 +04:00
|
|
|
(type == "directory" && (baseName == ".git" || baseName == ".svn" || baseName == "CVS" || baseName == ".hg")) ||
|
2009-02-09 19:51:03 +03:00
|
|
|
# Filter out backup files.
|
2014-02-06 15:30:03 +04:00
|
|
|
lib.hasSuffix "~" baseName ||
|
|
|
|
# Filter out generates files.
|
|
|
|
lib.hasSuffix ".o" baseName ||
|
|
|
|
lib.hasSuffix ".so" baseName
|
2009-02-09 19:51:03 +03:00
|
|
|
);
|
|
|
|
in src: builtins.filterSource filter src;
|
|
|
|
|
|
|
|
|
|
|
|
# Get all files ending with the specified suffices from the given
|
|
|
|
# directory. E.g. `sourceFilesBySuffices ./dir [".xml" ".c"]'.
|
|
|
|
sourceFilesBySuffices = path: exts:
|
|
|
|
let filter = name: type:
|
|
|
|
let base = baseNameOf (toString name);
|
|
|
|
in type != "directory" && lib.any (ext: lib.hasSuffix ext base) exts;
|
|
|
|
in builtins.filterSource filter path;
|
|
|
|
|
|
|
|
|
|
|
|
}
|