Subject: Re: pkg/30956
To: None <pkg-manager@netbsd.org, gnats-admin@netbsd.org,>
From: Chapman Flack <nbgnats@anastigmatix.net>
List: pkgsrc-bugs
Date: 08/10/2005 00:41:02
The following reply was made to PR pkg/30956; it has been noted by GNATS.

From: Chapman Flack <nbgnats@anastigmatix.net>
To: gnats-bugs@netbsd.org
Cc: 
Subject: Re: pkg/30956
Date: Tue, 09 Aug 2005 19:46:53 -0500

 The value of PKGNAME_REQD is not directly usable because it usually contains
 spurious apostrophes that have to be stripped out. However, the apostrophes
 were added (1.1300) as a workaround for a particular platform that had buggy
 behavior in 2003, and if that system is still buggy, the apostrophes will NOT
 be seen when running on that platform (because it will have consumed them as
 quotes, where on a non-buggy system they are part of the literal value).
 That's even worse: users of PKGNAME_REQD now have to treat it as a value that
 will USUALLY BUT NOT ALWAYS have spurious apostrophes, and so now any use of
 PKGNAME_REQD has to contain a conditional workaround of the problem caused by
 the workaround created for a buggy platform in 2003. Also, the change
 reintroduced a a risk of surprise from strange IFS values or globbing with
 unluckily-named files in the filesystem that had been fixed in 1.1275 (Sep
 2003).
 
 Happily, there is only one package I know of at present that uses
 PKGNAME_REQD: lang/python/extension.mk had to have a workaround added (1.6)
 when the apostrophes appeared in the value. Therefore, fixing this issue would
 not require much effort in backing out workarounds: lang/python/extension.mk
 would need to have 1.6 backed out. However, this issue has greater impact than
 just lang/python, because it blocks pkg/30954, which impairs functionality of
 bin-install.
 
 RECOMMENDATION IN BRIEF:
 
   Revert the line
 
     ${MAKE} ${MAKEFLAGS} $$target ... PKGNAME_REQD=\'$$pkg\';
 
   to its form as of 1.1275:
 
     ${MAKE} ${MAKEFLAGS} $$target ... PKGNAME_REQD="$$pkg";
 
   Back out revision 1.6 of lang/python/extension.mk.
 
   Then, IF the symptom seen building mplayer on Linux in 2003 reappears--it
   may not, if an underlying bug with that platform got fixed in the
   meantime--I'll be happy to help look for the real problem, toward developing
   a targeted workaround or genuine fix. A test Makefile and some debugging
   suggestions were included in
   http://mail-index.netbsd.org/tech-pkg/2005/03/19/0011.html. The test
   Makefile can be used to test for problems on a suspect platform without
   waiting for a failed package build.
 
 The recommendation is very short and simple (and there's a patch at the end).
 The reason this PR is long is that it might be counterintuitive--there was a
 problem reported, a change was made that seemed to fix it, why go back? I'll
 try to show carefully why the fix was an accident and something else should be
 done.
 
 HISTORY AND DETAILS:
 
 (to be added)