Skip site navigation (1)Skip section navigation (2)
Date:      Tue, 29 Jun 2010 13:21:07 -0500
From:      Paul Schmehl <pschmehl_lists@tx.rr.com>
To:        Scot Hetzel <swhetzel@gmail.com>, Paul Schmehl <pschmehl_lists@tx.rr.com>,  Darren Pilgrim <freebsd@bitfreak.org>
Cc:        FreeBSD Ports <freebsd-ports@freebsd.org>
Subject:   Re: This construction doesn't work
Message-ID:  <1A5EC514D68C6B623B044F88@utd65257.utdallas.edu>
In-Reply-To: <AANLkTimNq_7L-_A4oEZRo9aNvb_qUdjEhTbXclcRCWgW@mail.gmail.com>
References:  <F2F73A9F749C437672E35BFB@utd65257.utdallas.edu> <4C2993E8.8000504@bitfreak.org> <AANLkTimNq_7L-_A4oEZRo9aNvb_qUdjEhTbXclcRCWgW@mail.gmail.com>

next in thread | previous in thread | raw e-mail | index | archive | help
--On Tuesday, June 29, 2010 09:02:35 -0500 Scot Hetzel <swhetzel@gmail.com>=20
wrote:

> On Tue, Jun 29, 2010 at 1:34 AM, Darren Pilgrim <freebsd@bitfreak.org> wrote:
>> Paul Schmehl wrote:
>>>
>>> I'm working on a port update for one of the ports that I maintain, and
>>> I've run into a problem that I can't seem to solve.
>>>
>>> I use this construction to ensure that the port doesn't overwrite the conf
>>> file, if one exists:
>>>
>>> .for f in barnyard2.conf
>>> =C2=A0 =C2=A0 =C2=A0 =C2=A0${INSTALL_DATA} ${WRKSRC}/etc/${f} =
${PREFIX}/etc/${f}-sample
>>> =C2=A0 =C2=A0 =C2=A0 =C2=A0[ -f ${PREFIX}/etc/${f} ] || \
>>> =C2=A0 =C2=A0 =C2=A0 =C2=A0${INSTALL_DATA} ${WRKSRC}/etc/${f} =
${PREFIX}/etc/${f}
>>> .endfor
>>>
>>> But it gets overwritten anyway. =C2=A0What am I doing wrong? =C2=A0I =
thought this
>>> worked before, but I can't be sure. =C2=A0Testing proves that it does not =
work
>>> now. =C2=A0I tried to changing to an if [ ! -f construction, but that =
didn't do
>>> a thing.
>
> The above may be working properly, the problem could be that the
> sources have code in them that installs barnyard2.conf to PREFIX/etc/.
>  Check the sources Makefile to see if they are installing this file.
> If they are, patch them to install the file as the *-sample.
>
>>
>> Instead of doing this in Makefile, do it in pkg-plist:
>>
>> @unexec if cmp -s %D/etc/barnyard2.conf.sample %D/etc/barnyard2.conf; then
>> rm -f %D/etc/barnyard2.conf; fi
>> etc/barnyard2.conf.sample
>> @exec if [ ! -f %D/etc/barnyard2.conf ] ; then cp -p %D/%F
>> %D/etc/barnyard2.conf && chmod 600 %D/etc/barnyard2.conf; fi
>>
>> Relevant section of the Porter's Handbook:
>>
>> http://www.freebsd.org/doc/en/books/porters-handbook/plist-config.html
>
> While this works when installing a package, you still need code in the
> Makefile to install barnyard2.conf if it doesn't exist when installing
> the port.

You nailed it Scott.  The problem was with the Makefile.in in the /etc=20
directory.  It's been fixed, and the port upgrade has been submitted.

Thanks for the tipoff.

--=20
Paul Schmehl, Senior Infosec Analyst
As if it wasn't already obvious, my opinions
are my own and not those of my employer.
*******************************************
"It is as useless to argue with those who have
renounced the use of reason as to administer
medication to the dead." Thomas Jefferson




Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?1A5EC514D68C6B623B044F88>