diff options
| -rw-r--r-- | README.md | 11 | ||||
| -rw-r--r-- | lib/types/populate.nix | 34 | ||||
| -rw-r--r-- | pkgs/populate/default.nix | 7 | 
3 files changed, 50 insertions, 2 deletions
| @@ -157,6 +157,17 @@ Supported attributes:    manual](https://download.samba.org/pub/rsync/rsync.html) for further    information. +* `filters` (optional) +  List of filters that should be passed to rsync. Filters are specified as +  attribute sets with the attributes `type` and `pattern`. Supported filter +  types are `include` and `exclude`. This allows for more advanced +  configurations. + +* `deleteExcluded` (optional) +  boolean that controls whether the excluded directories should be deleted +  if they exist on the target. This is passed to the `--delete-excluded` option +  of rsync. Defaults to `true`. +  ### `git` diff --git a/lib/types/populate.nix b/lib/types/populate.nix index e23ddb0..0427dbd 100644 --- a/lib/types/populate.nix +++ b/lib/types/populate.nix @@ -54,6 +54,18 @@      };    }); +  filter = lib.types.submodule { +    options = { +      type = lib.mkOption { +        type = lib.types.enum ["include" "exclude"]; +        default = "exclude"; +      }; +      pattern = lib.mkOption { +        type = lib.types.str; +      }; +    }; +  }; +    source-types = {      derivation = lib.types.submodule {        options = { @@ -76,6 +88,28 @@            default = [];            example = [".git"];          }; +        filters = lib.mkOption { +          type = lib.types.listOf filter; +          default = []; +          example = [ +            { +              type = "include"; +              pattern = "*.nix"; +            } +            { +              type = "include"; +              pattern = "*/"; +            } +            { +              type = "exclude"; +              pattern = "*"; +            } +          ]; +        }; +        deleteExcluded = lib.mkOption { +          default = true; +          type = lib.types.bool; +        };        };      };      git = lib.types.submodule { diff --git a/pkgs/populate/default.nix b/pkgs/populate/default.nix index 736376e..78bf3c8 100644 --- a/pkgs/populate/default.nix +++ b/pkgs/populate/default.nix @@ -45,7 +45,7 @@ let    '';    pop.file = target: source: let -    configAttrs = ["useChecksum" "exclude"]; +    configAttrs = ["useChecksum" "exclude" "filters" "deleteExcluded"];      config = filterAttrs (name: _: elem name configAttrs) source;    in      rsync' target config (quote source.path); @@ -161,9 +161,12 @@ let          ${concatMapStringsSep " "            (pattern: /* sh */ "--exclude ${quote pattern}")            (config.exclude or [])} \ +        ${concatMapStringsSep " " +          (filter: /* sh */ "--${filter.type} ${quote filter.pattern}") +          (config.filters or [])} \          -e ${quote (ssh' target)} \          -vFrlptD \ -        --delete-excluded \ +        ${optionalString (config.deleteExcluded or true) /* sh */ "--delete-excluded"} \          "$source_path" \          ${quote (            optionalString (!isLocalTarget target) ( | 
