Skip to content

Commit

Permalink
Merge pull request puppetlabs#61 from hubspotdevops/newline_upstream
Browse files Browse the repository at this point in the history
add ensure_newline
  • Loading branch information
Ashley Penney committed Aug 9, 2013
2 parents 68e5e73 + 1830a68 commit 7313d26
Show file tree
Hide file tree
Showing 3 changed files with 25 additions and 6 deletions.
8 changes: 7 additions & 1 deletion files/concatfragments.sh
Original file line number Diff line number Diff line change
Expand Up @@ -44,21 +44,23 @@ TEST=""
FORCE=""
WARN=""
SORTARG=""
ENSURE_NEWLINE=""

PATH=/sbin:/usr/sbin:/bin:/usr/bin

## Well, if there's ever a bad way to do things, Nexenta has it.
## http://nexenta.org/projects/site/wiki/Personalities
unset SUN_PERSONALITY

while getopts "o:s:d:tnw:f" options; do
while getopts "o:s:d:tnw:fl" options; do
case $options in
o ) OUTFILE=$OPTARG;;
d ) WORKDIR=$OPTARG;;
n ) SORTARG="-n";;
w ) WARNMSG="$OPTARG";;
f ) FORCE="true";;
t ) TEST="true";;
l ) ENSURE_NEWLINE="true";;
* ) echo "Specify output file with -o and fragments directory with -d"
exit 1;;
esac
Expand Down Expand Up @@ -111,6 +113,10 @@ else
printf '%s\n' "$WARNMSG" > "fragments.concat"
fi

if [ x${ENSURE_NEWLINE} != x ]; then
find fragments/ -type f -follow -print0 | xargs -0 -I '{}' sh -c 'if [ -n "$(tail -c 1 < {} )" ]; then echo >> {} ; fi'
fi

# find all the files in the fragments directory, sort them numerically and concat to fragments.concat in the working dir
IFS_BACKUP=$IFS
IFS='
Expand Down
19 changes: 16 additions & 3 deletions manifests/init.pp
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,8 @@
$backup = 'puppet',
$replace = true,
$gnu = undef,
$order='alpha'
$order='alpha',
$ensure_newline = false
) {
include concat::setup

Expand Down Expand Up @@ -108,6 +109,18 @@
}
}

case $ensure_newline {
'true', true, yes, on: {
$newlineflag = '-l'
}
'false', false, no, off: {
$newlineflag = ''
}
default: {
fail("Improper 'ensure_newline' value given to concat: ${ensure_newline}")
}
}

File {
owner => $::id,
group => $group,
Expand Down Expand Up @@ -155,15 +168,15 @@

exec { "concat_${name}":
alias => "concat_${fragdir}",
command => "${concat::setup::concatdir}/bin/concatfragments.sh -o ${fragdir}/${concat_name} -d ${fragdir} ${warnflag} ${forceflag} ${orderflag}",
command => "${concat::setup::concatdir}/bin/concatfragments.sh -o ${fragdir}/${concat_name} -d ${fragdir} ${warnflag} ${forceflag} ${orderflag} ${newlineflag}",
notify => File[$name],
require => [
File[$fragdir],
File["${fragdir}/fragments"],
File["${fragdir}/fragments.concat"],
],
subscribe => File[$fragdir],
unless => "${concat::setup::concatdir}/bin/concatfragments.sh -o ${fragdir}/${concat_name} -d ${fragdir} -t ${warnflag} ${forceflag} ${orderflag}",
unless => "${concat::setup::concatdir}/bin/concatfragments.sh -o ${fragdir}/${concat_name} -d ${fragdir} -t ${warnflag} ${forceflag} ${orderflag} ${newlineflag}",
}

if $::id == 'root' {
Expand Down
4 changes: 2 additions & 2 deletions spec/defines/init_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,7 @@
should contain_exec("concat_/etc/foo.bar").with_command(
"#{basedir}/bin/concatfragments.sh " +
"-o #{basedir}/_etc_foo.bar/fragments.concat.out " +
"-d #{basedir}/_etc_foo.bar "
"-d #{basedir}/_etc_foo.bar "
)
end
end
Expand Down Expand Up @@ -105,7 +105,7 @@
should contain_exec("concat_foobar").with_command(
"#{basedir}/bin/concatfragments.sh " +
"-o #{basedir}/foobar/fragments.concat.out " +
"-d #{basedir}/foobar "
"-d #{basedir}/foobar "
)
end

Expand Down

0 comments on commit 7313d26

Please sign in to comment.