testing the value of ${CXX} in ports Makefile
Elizabeth Myers
elizabeth at interlinked.me
Fri Jan 30 05:27:44 UTC 2015
On 01/29/15 21:43, Don Lewis wrote:
> I need to test the value of ${CXX} in the Makefile for a port and am
> getting unexpected results. Here is a simplified version of the
> Makefile:
>
> PORTNAME= junk
> PORTVERSION= 0.0.0
> CATEGORIES= devel
> DISTFILES=
>
> MAINTAINER= truckman at FreeBSD.org
> COMMENT= junk
>
> USE_GCC= 4.9+
>
> .include <bsd.port.pre.mk>
>
> post-patch:
> echo CXX=${CXX}
> .if ${CXX} == g++49
> echo detected g++49
> .else
> echo did not detect g++49
> .endif
>
> .include <bsd.port.post.mk>
>
>
> If I run "make patch", this is what I get:
>
> # make patch
> ===> junk-0.0.0 depends on file: /usr/local/sbin/pkg - found
> ===> Fetching all distfiles required by junk-0.0.0 for building
> ===> Extracting for junk-0.0.0
> ===> Patching for junk-0.0.0
> echo CXX=g++49
> CXX=g++49
> echo did not detect g++49
> did not detect g++49
>
>
> If I run "make -dA patch" and look at the debug output, I observe
> bsd.gcc.mk getting processed after the .if is evaluated. When the .if
> is processed, the value of ${CXX} is still c++. It sort of looks like
> bsd.gcc.mk isn't getting included until bsd.port.post.mk and we are
> relying on lazy expansion to get the correct value of ${CXX} for the
> actions.
>
> It sort of looks like I'll have to do something like:
>
> post-patch:
> [ ${CXX} = g++49 ] && echo detected g++49
>
> but that just seems goofy.
>
>
>
> _______________________________________________
> freebsd-ports at freebsd.org mailing list
> http://lists.freebsd.org/mailman/listinfo/freebsd-ports
> To unsubscribe, send any mail to "freebsd-ports-unsubscribe at freebsd.org"
Why do you need to detect it? Shouldn't USE_GCC ensure it's there? In
any case, browsing through the ports tree, you could try .if
!empty(CXX:M*g++49*)
--
Cheers,
Elizabeth Myers
More information about the freebsd-ports
mailing list