summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAzul <azul@riseup.net>2013-08-27 14:11:39 +0200
committerAzul <azul@riseup.net>2013-08-27 14:11:39 +0200
commitba5dd8d5c8e09d521ff49f1ebc753601e449f828 (patch)
tree59ffbcee037e3a3b6393dac5a16ca0545d233e91
parent497a1034489e0dc3cab5dab2fb0a857785769734 (diff)
git:changes expect changes to certain filesHEADmaster
You can either ensure assume-unchanged or ensure those changes are tracked. Used to keep the git status clean.
-rw-r--r--manifests/changes.pp33
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}'",
+ }
+ }
+ }
+}
+