JB Enterprises

JB Enterprises - Johan Bezem

Interim Management & Consulting

Creating a Make Template using GNU make

Recursive use of make systems is not very well looked at. But then it has some advantages. I have taken the advantages, and created a structure that addresses several, if not most, disadvantages:

  • It will automatically find all directories to be included in the build, with a possibility to specify dependencies between directories
  • It will automatically find all sources to be included in the build
  • It supports the use of source code generators like lex, yacc or IDL
  • It will automatically determine the dependencies between source files
  • The Makefiles in each source directory are mostly one- or two-liners, the complexity is encapsulated in centralized make-includes
  • It will walk the source tree just once
  • If supported by your platform, you may use the parallel-build options GNU Make offers
  • It will store the objects in architecture/variant dependent directories
  • It will run on Windows XP or later with CMD, Windows/Cygwin with bash, and Linux/Unix
  • It will work with GNU Make version 3.79.1 or upwards

Of course, most automatic functions can also be overridden.
This project has been implemented successfully in at least three different sites. And now I started to document the system in such a way, that interested readers can follow the various steps and intricacies.
The documentation will grow step by step, with each step building on the previous one. And for each step, I will provide the full test-environment demonstrating the features.

And here's what I've been creating so far:

  • The descriptive document (Version 005, 300k PDF) containing an extensive explanation of what, how and why.
  • 001Traverse.zip (7k) - The first instalment in a ZIP container, with all files, and directories. This instalment automatically traverses the source tree, while recognizing and observing dependencies between directories.
  • 002Objects.zip (8k) - The second instalment creates and traverses the objects' tree instead, while taking Makefiles from the source tree.
  • 003Sources.zip (19k) - The third instalment creates object files (pretends to, using "touch", for now) in the intermediates' tree.
  • 004Compilation.zip (19k) - The fourth instalment really creates objects using GCC, contains a 'clean' target and shows a few tricks.
  • 005Differentiate.zip (24k) - The fifth instalment differentiates between Windows and Linux, bash and CMD.EXE, and GCC and Visual Studio, as examples. Compilation is possible with each of the choices, and compilation variants are held separately, supporting multiple variants using one source tree. Further choices as to platform, compiler and/or shell are possible, if not supported out of the box. The Makefile is split into several files, in order not to lose the overview and enable reuse.

What else do you need?

If you need GNU make (the Cygwin environment provides its own version. Others don't necessarily, but many Linux distribtions offer GNU Make at least as an option), go to the make homepage at http://www.gnu.org/software/make/make.html. You may have to build GNU make yourself.

For information on Cygwin, go to their main site, http://www.cygwin.com/, download and execute the "setup.exe" (Look for "Install or update now!"), and make sure to install the development tools (Category 'Devel') 'make' 3.81 or newer, and GCC, as well as 'coreutils' and 'bash', both in the category 'Base', installed by default. Later we may add more, when the projects grows.

And, finally (for now), you might need a utility called 'touch'. In many Unix/Linux variants it belongs to a standard installation, only for Windows this is not the case. Later we'll possibly create a windows version ourselves, for now I refer to a CodeProject site, http://www.codeproject.com/KB/applications/touch_win.aspx (registration required, freeware with source code).

Valid XHTML 1.0 Strict Valid CSS www.bezem.de: © 1999 – 2025 by Johan Bezem, all rights reserved.
This page was last updated on Monday, 2018-07-23 06:28.