patch 9.1.1644: configure: doesn't separate CPPFLAGS and CFLAGS
Problem:  configure: doesn't separate CPPFLAGS and CFLAGS
Solution: Split CPPFLAGS and CFLAGS for pkg-config
          (Damien Lejay)
Previously, all flags returned by pkg-config --cflags were dumped into
CFLAGS, mixing include paths with compiler options. This commit uses
--cflags-only-I and --cflags-only-other to properly separate include
flags into CPPFLAGS and keep compiler flags in CFLAGS.
closes: #18019
Signed-off-by: Damien Lejay <damien@lejay.be>
Signed-off-by: Christian Brabandt <cb@256bit.org>
			
			
This commit is contained in:
		
				
					committed by
					
						 Christian Brabandt
						Christian Brabandt
					
				
			
			
				
	
			
			
			
						parent
						
							308a3130be
						
					
				
				
					commit
					ce288c7fb0
				
			| @ -2415,12 +2415,15 @@ AC_ARG_WITH(wayland, | ||||
| 			 AC_MSG_RESULT([yes])])) | ||||
|  | ||||
| if test "$with_wayland" = yes; then | ||||
| cppflags_save=$CPPFLAGS | ||||
| cflags_save=$CFLAGS | ||||
|   AC_MSG_CHECKING(for wayland) | ||||
|   if "$PKG_CONFIG" --exists 'wayland-client'; then | ||||
|     AC_MSG_RESULT([yes]) | ||||
|     AC_DEFINE(HAVE_WAYLAND) | ||||
|     WAYLAND_CFLAGS=`$PKG_CONFIG --cflags wayland-client` | ||||
|     WAYLAND_CPPFLAGS=`$PKG_CONFIG --cflags-only-I wayland-client` | ||||
|     WAYLAND_CFLAGS=`$PKG_CONFIG --cflags-only-other wayland-client` | ||||
|     CPPFLAGS="$CPPFLAGS $WAYLAND_CPPFLAGS" | ||||
|     CFLAGS="$CFLAGS $WAYLAND_CFLAGS" | ||||
|     WAYLAND_LIBS=`$PKG_CONFIG --libs wayland-client` | ||||
|     WAYLAND_SRC=" \ | ||||
| @ -2435,6 +2438,7 @@ cflags_save=$CFLAGS | ||||
|       objects/xdg-shell.o \ | ||||
|       objects/primary-selection-unstable-v1.o \ | ||||
|       objects/wayland.o" | ||||
|     AC_SUBST(WAYLAND_CPPFLAGS) | ||||
|     AC_SUBST(WAYLAND_CFLAGS) | ||||
|     AC_SUBST(WAYLAND_LIBS) | ||||
|     AC_SUBST(WAYLAND_SRC) | ||||
| @ -2443,6 +2447,7 @@ cflags_save=$CFLAGS | ||||
|     AC_MSG_RESULT(no) | ||||
|     with_wayland=no | ||||
|   fi | ||||
| CPPFLAGS=$cppflags_save | ||||
| CFLAGS=$cflags_save | ||||
| fi | ||||
|  | ||||
| @ -2714,7 +2719,8 @@ AC_DEFUN(AM_PATH_GTK, | ||||
| 	     dnl We should be using PKG_CHECK_MODULES() instead of this hack. | ||||
| 	     dnl But I guess the dependency on pkgconfig.m4 is not wanted or | ||||
| 	     dnl something like that. | ||||
| 	     GTK_CFLAGS=`$PKG_CONFIG --cflags $gtk_pkg_name` | ||||
| 	     GTK_CPPFLAGS=`$PKG_CONFIG --cflags-only-I $gtk_pkg_name` | ||||
| 	     GTK_CFLAGS=`$PKG_CONFIG --cflags-only-other $gtk_pkg_name` | ||||
| 	     GTK_LIBDIR=`$PKG_CONFIG --libs-only-L $gtk_pkg_name` | ||||
| 	     GTK_LIBS=`$PKG_CONFIG --libs $gtk_pkg_name` | ||||
| 	     gtk_major_version=`$PKG_CONFIG --modversion $gtk_pkg_name | \ | ||||
| @ -2726,6 +2732,7 @@ AC_DEFUN(AM_PATH_GTK, | ||||
| 	     AC_MSG_RESULT([yes; found version $gtk_major_version.$gtk_minor_version.$gtk_micro_version]) | ||||
| 	   ], | ||||
| 	   [ | ||||
| 	      GTK_CPPFLAGS="" | ||||
| 	      GTK_CFLAGS="" | ||||
| 	      GTK_LIBDIR="" | ||||
| 	      GTK_LIBS="" | ||||
| @ -2745,8 +2752,10 @@ AC_DEFUN(AM_PATH_GTK, | ||||
|   gtktest_success="yes" | ||||
|   if test "$enable_gtktest" = "yes"; then | ||||
|   { | ||||
|     ac_save_CPPFLAGS="$CPPFLAGS" | ||||
|     ac_save_CFLAGS="$CFLAGS" | ||||
|     ac_save_LIBS="$LIBS" | ||||
|     CPPFLAGS="$CPPFLAGS $GTK_CPPFLAGS" | ||||
|     CFLAGS="$CFLAGS $GTK_CFLAGS" | ||||
|     LIBS="$LIBS $GTK_LIBS" | ||||
|  | ||||
| @ -2793,6 +2802,7 @@ main () | ||||
|     [gtktest_success="yes"; AC_MSG_RESULT(yes)], | ||||
|     [gtktest_success="no"; AC_MSG_RESULT(no)], | ||||
|     [echo $ac_n "cross compiling; assumed OK... $ac_c"]) | ||||
|     CPPFLAGS="$ac_save_CPPFLAGS" | ||||
|     CFLAGS="$ac_save_CFLAGS" | ||||
|     LIBS="$ac_save_LIBS" | ||||
|   } | ||||
| @ -2802,6 +2812,7 @@ main () | ||||
|     ifelse([$2], , :, [$2]) | ||||
|   else | ||||
|     dnl Reset flags sourced from pkg-config if the compilation test failed. | ||||
|     GTK_CPPFLAGS="" | ||||
|     GTK_CFLAGS="" | ||||
|     GTK_LIBDIR="" | ||||
|     GTK_LIBS="" | ||||
| @ -2810,6 +2821,7 @@ main () | ||||
|     fi | ||||
|   fi | ||||
|  | ||||
|   AC_SUBST(GTK_CPPFLAGS) | ||||
|   AC_SUBST(GTK_CFLAGS) | ||||
|   AC_SUBST(GTK_LIBS) | ||||
| ]) | ||||
| @ -2857,7 +2869,7 @@ AC_DEFUN([GNOME_INIT_HOOK], | ||||
|       AC_MSG_RESULT(yes) | ||||
|       GNOME_LIBS=`$PKG_CONFIG --libs-only-l libgnomeui-2.0` | ||||
|       GNOME_LIBDIR=`$PKG_CONFIG --libs-only-L libgnomeui-2.0` | ||||
|       GNOME_INCLUDEDIR=`$PKG_CONFIG --cflags libgnomeui-2.0` | ||||
|       GNOME_INCLUDEDIR=`$PKG_CONFIG --cflags-only-I libgnomeui-2.0` | ||||
|  | ||||
|       dnl On FreeBSD we need -pthread but pkg-config doesn't include it. | ||||
|       dnl This might not be the right way but it works for me... | ||||
| @ -2901,8 +2913,8 @@ if test -z "$SKIP_GTK3"; then | ||||
|     AM_PATH_GTK(3.0.0, | ||||
| 		[GUI_LIB_LOC="$GTK_LIBDIR" | ||||
| 		 GTK_LIBNAME="$GTK_LIBS" | ||||
| 		 GUI_INC_LOC="$GTK_CFLAGS"]) | ||||
|     if test -n "$GTK_CFLAGS"; then | ||||
| 		 GUI_INC_LOC="$GTK_CPPFLAGS"]) | ||||
|     if test -n "$GTK_CPPFLAGS"; then | ||||
|       SKIP_GTK2=YES | ||||
|       SKIP_GNOME=YES | ||||
|       SKIP_MOTIF=YES | ||||
| @ -2932,8 +2944,8 @@ if test -z "$SKIP_GTK2"; then | ||||
|     AM_PATH_GTK(2.2.0, | ||||
| 		[GUI_LIB_LOC="$GTK_LIBDIR" | ||||
| 		 GTK_LIBNAME="$GTK_LIBS" | ||||
| 		 GUI_INC_LOC="$GTK_CFLAGS"]) | ||||
|     if test -n "$GTK_CFLAGS"; then | ||||
| 		 GUI_INC_LOC="$GTK_CPPFLAGS"]) | ||||
|     if test -n "$GTK_CPPFLAGS"; then | ||||
|       SKIP_MOTIF=YES | ||||
|       GUITYPE=GTK | ||||
|       AC_SUBST(GTK_LIBNAME) | ||||
| @ -3833,15 +3845,21 @@ fi | ||||
| if test "$enable_canberra" = "yes"; then | ||||
|   if test "x$PKG_CONFIG" != "xno"; then | ||||
|     canberra_lib=`$PKG_CONFIG --libs libcanberra 2>/dev/null` | ||||
|     canberra_cflags=`$PKG_CONFIG --cflags libcanberra 2>/dev/null` | ||||
|     canberra_cppflags=`$PKG_CONFIG --cflags-only-I libcanberra 2>/dev/null` | ||||
|     canberra_cflags=`$PKG_CONFIG --cflags-only-other libcanberra 2>/dev/null` | ||||
|   fi | ||||
|   if test "x$canberra_lib" = "x"; then | ||||
|     canberra_lib=-lcanberra | ||||
|     canberra_cppflags=-D_REENTRANT | ||||
|     canberra_cflags=-D_REENTRANT | ||||
|   fi | ||||
|   AC_MSG_CHECKING(for libcanberra) | ||||
|   ac_save_CPPFLAGS="$CPPFLAGS" | ||||
|   ac_save_CFLAGS="$CFLAGS" | ||||
|   ac_save_LIBS="$LIBS" | ||||
|   if `echo "$CPPFLAGS" | grep -v "$canberra_cppflags" 2>/dev/null`; then | ||||
|     CPPFLAGS="$CPPFLAGS $canberra_cflags" | ||||
|   fi | ||||
|   if `echo "$CFLAGS" | grep -v "$canberra_cflags" 2>/dev/null`; then | ||||
|     CFLAGS="$CFLAGS $canberra_cflags" | ||||
|   fi | ||||
| @ -3852,7 +3870,7 @@ if test "$enable_canberra" = "yes"; then | ||||
|      ca_context *hello; | ||||
|      ca_context_create(&hello);])], | ||||
|        AC_MSG_RESULT(yes); AC_DEFINE(HAVE_CANBERRA), | ||||
|        AC_MSG_RESULT(no; try installing libcanberra-dev); CFLAGS="$ac_save_CFLAGS"; LIBS="$ac_save_LIBS") | ||||
|        AC_MSG_RESULT(no; try installing libcanberra-dev); CFLAGS="$ac_save_CFLAGS"; LIBS="$ac_save_LIBS", CPPFLAGS="ac_save_CPPFLAGS") | ||||
| fi | ||||
|  | ||||
| AC_MSG_CHECKING(--enable-libsodium argument) | ||||
| @ -3874,15 +3892,19 @@ fi | ||||
| if test "$enable_libsodium" = "yes"; then | ||||
|   if test "x$PKG_CONFIG" != "xno"; then | ||||
|     libsodium_lib=`$PKG_CONFIG --libs libsodium 2>/dev/null` | ||||
|     libsodium_cflags=`$PKG_CONFIG --cflags libsodium 2>/dev/null` | ||||
|     libsodium_cppflags=`$PKG_CONFIG --cflags-only-I libsodium 2>/dev/null` | ||||
|     libsodium_cflags=`$PKG_CONFIG --cflags-only-other libsodium 2>/dev/null` | ||||
|   fi | ||||
|   if test "x$libsodium_lib" = "x"; then | ||||
|     libsodium_lib=-lsodium | ||||
|     libsodium_cppflags= | ||||
|     libsodium_cflags= | ||||
|   fi | ||||
|   AC_MSG_CHECKING(for libsodium) | ||||
|   ac_save_CPPFLAGS="$CPPFLAGS" | ||||
|   ac_save_CFLAGS="$CFLAGS" | ||||
|   ac_save_LIBS="$LIBS" | ||||
|   CPPFLAGS="$CPPFLAGS $libsodium_cppflags" | ||||
|   CFLAGS="$CFLAGS $libsodium_cflags" | ||||
|   LIBS="$LIBS $libsodium_lib" | ||||
|   AC_LINK_IFELSE([AC_LANG_PROGRAM([ | ||||
| @ -3890,7 +3912,7 @@ if test "$enable_libsodium" = "yes"; then | ||||
|       ], [ | ||||
|      printf("%d", sodium_init()); ])], | ||||
|        AC_MSG_RESULT(yes); AC_DEFINE(HAVE_SODIUM), | ||||
|        AC_MSG_RESULT(no; try installing libsodium-dev); CFLAGS="$ac_save_CFLAGS"; LIBS="$ac_save_LIBS") | ||||
|        AC_MSG_RESULT(no; try installing libsodium-dev); CFLAGS="$ac_save_CFLAGS"; LIBS="$ac_save_LIBS"; CPPFLAGS="$ac_save_CPPFLAGS") | ||||
| fi | ||||
|  | ||||
| dnl fstatfs() can take 2 to 4 arguments, try to use st_blksize if possible | ||||
| @ -4150,11 +4172,13 @@ else | ||||
|   AC_MSG_RESULT(yes) | ||||
| fi | ||||
|  | ||||
| if test "x$GTK_CFLAGS" != "x"; then | ||||
| if test "x$GTK_CPPFLAGS" != "x"; then | ||||
|   dnl pango_shape_full() is new, fall back to pango_shape(). | ||||
|   AC_MSG_CHECKING(for pango_shape_full) | ||||
|   ac_save_CPPFLAGS="$CPPFLAGS" | ||||
|   ac_save_CFLAGS="$CFLAGS" | ||||
|   ac_save_LIBS="$LIBS" | ||||
|   CPPFLAGS="$CPPFLAGS $GTK_CPPFLAGS" | ||||
|   CFLAGS="$CFLAGS $GTK_CFLAGS" | ||||
|   LIBS="$LIBS $GTK_LIBS" | ||||
|   AC_LINK_IFELSE([AC_LANG_PROGRAM( | ||||
| @ -4162,6 +4186,7 @@ if test "x$GTK_CFLAGS" != "x"; then | ||||
|   [ pango_shape_full(NULL, 0, NULL, 0, NULL, NULL); ])], | ||||
| 	  AC_MSG_RESULT(yes); AC_DEFINE(HAVE_PANGO_SHAPE_FULL), | ||||
| 	  AC_MSG_RESULT(no)) | ||||
|   CPPFLAGS="$ac_save_CPPFLAGS" | ||||
|   CFLAGS="$ac_save_CFLAGS" | ||||
|   LIBS="$ac_save_LIBS" | ||||
| fi | ||||
| @ -4736,7 +4761,7 @@ dnl (e.g. ino_t and off_t), all of Vim's modules must be compiled with a | ||||
| dnl consistent value.  It's therefore safest to force the use of the define | ||||
| dnl if it's present in any of the *_CFLAGS variables. | ||||
| AC_MSG_CHECKING(whether we need to force -D_FILE_OFFSET_BITS=64) | ||||
| if echo "$CFLAGS $LUA_CFLAGS $MZSCHEME_CFLAGS $PERL_CFLAGS $PYTHON_CFLAGS $PYTHON3_CFLAGS $TCL_CFLAGS $RUBY_CFLAGS $GTK_CFLAGS" | grep -q D_FILE_OFFSET_BITS 2>/dev/null; then | ||||
| if echo "$CPPFLAGS $CFLAGS $LUA_CFLAGS $MZSCHEME_CFLAGS $PERL_CFLAGS $PYTHON_CFLAGS $PYTHON3_CFLAGS $TCL_CFLAGS $RUBY_CFLAGS $GTK_CPPFLAGS" | grep -q D_FILE_OFFSET_BITS 2>/dev/null; then | ||||
|   AC_MSG_RESULT(yes) | ||||
|   AC_DEFINE(_FILE_OFFSET_BITS, 64) | ||||
| else | ||||
|  | ||||
		Reference in New Issue
	
	Block a user