diff options
author | Azul <azul@riseup.net> | 2013-08-27 14:11:39 +0200 |
---|---|---|
committer | Azul <azul@riseup.net> | 2013-08-27 14:11:39 +0200 |
commit | ba5dd8d5c8e09d521ff49f1ebc753601e449f828 (patch) | |
tree | 59ffbcee037e3a3b6393dac5a16ca0545d233e91 | |
parent | 497a1034489e0dc3cab5dab2fb0a857785769734 (diff) |
You can either ensure assume-unchanged or ensure those changes are tracked.
Used to keep the git status clean.
-rw-r--r-- | manifests/changes.pp | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/manifests/changes.pp b/manifests/changes.pp new file mode 100644 index 0000000..7111205 --- /dev/null +++ b/manifests/changes.pp @@ -0,0 +1,33 @@ +# Usage +# git::changes { name: +# cwd => "/path/to/git/" +# user => "me", +# ensure => {*assume-unchanged*, tracked} +# } +# + +define git::changes ( $cwd, $user, $ensure='assume-unchanged' ) { + + case $ensure { + default: { err ( "unknown ensure value '${ensure}'" ) } + + assume-unchanged: { + exec { "assume-unchanged ${name}": + command => "/usr/bin/git update-index --assume-unchanged ${name}", + cwd => $cwd, + user => $user, + unless => "/usr/bin/git ls-files -v | grep '^[ch] ${name}'", + } + } + + tracked: { + exec { "track changes ${name}": + command => "/usr/bin/git update-index --no-assume-unchanged ${name}", + cwd => $cwd, + user => $user, + onlyif => "/usr/bin/git ls-files -v | grep '^[ch] ${name}'", + } + } + } +} + |