Next: , Previous: , Up: The Macros  





This macro searches for a GNU version of make. If a match is found:

  * The makefile variable `ifGNUmake' is set to the empty string, otherwise
    it is set to "#". This is useful for including a special features in a
    Makefile, which cannot be handled by other versions of make.
  * The variable `_cv_gnu_make_command` is set to the command to invoke
    GNU make if it exists, the empty string otherwise.
  * The variable `ax_cv_gnu_make_command` is set to the command to invoke
    GNU make by copying `_cv_gnu_make_command`, otherwise it is unset.
  * If GNU Make is found, its version is extracted from the output of
    `make --version` as the last field of a record of space-separated
    columns and saved into the variable `ax_check_gnu_make_version`.

Here is an example of its use: might contain:

  # A failsafe way of putting a dependency rule into a makefile
          $(CC) -MM $(srcdir)/*.c > $(DEPEND)
  @ifGNUmake@ ifeq ($(DEPEND),$(wildcard $(DEPEND)))
  @ifGNUmake@ include $(DEPEND)
  @ifGNUmake@ endif

Then would normally contain:


Then perhaps to cause gnu make to override any other make, we could do something like this (note that GNU make always looks for GNUmakefile first):

  if  ! test x$_cv_gnu_make_command = x ; then
          mv Makefile GNUmakefile
          echo .DEFAULT: > Makefile ;
          echo \  $_cv_gnu_make_command \$@ >> Makefile;

Then, if any (well almost any) other make is called, and GNU make also exists, then the other make wraps the GNU make.

Source Code

Download the latest version of ax_check_gnu_make.m4 or browse the macro’s revision history.


Copyright © 2008 John Darrington
Copyright © 2015 Enrico M. Crisostomo

Copying and distribution of this file, with or without modification, are permitted in any medium without royalty provided the copyright notice and this notice are preserved. This file is offered as-is, without any warranty.

Next: , Previous: , Up: The Macros