Automating Tasks with make

Learn how to use the make command to automate tasks.

We'll cover the following

The make command

The make command is an automation tool aimed at creating builds for software. It’s commonly used to compile and install software. Package managers often don’t have the latest version of a particular piece of software available, so the only way to install the most recent version is to download the source code and compile it ourselves. The process usually involves downloading the source code archive, extracting it, switching to the directory containing the code, running a script called configure to set some variables based on our environment, and running make to compile the software. It usually looks something like this:

$ ./configure
$ make
$ sudo make install

The make command works by reading a file named Makefile and looking for tasks to run. We create these tasks by defining rules that tell make what commands to run to produce the desired result. Most of the time, we define rules by specifying files we want to create. These are called targets.

Here’s an example of a rule:

%.class : %.java javac $<

This rule compiles a Java class from a source file. To run this, we type make Hello.class. Then, make would look for a file named Hello.java The $< variable represents the input file.

Here’s another example:

book.md:
         cat chapter1.md chapter2.md chapter3.md chapter4.md > $@

This rule describes making a file named book.md by concatenating four Markdown files. The $@ variable in this rule references the name of the output file. To run it, we type make book.md.

We can use Makefiles to automate all sorts of tasks. To explore how Makefiles work, we’ll create a very basic static site generator. We’ll have files containing a generic header and a footer that we’ll use on all of our pages. Then, we’ll have some files that contain just the content we want to use. Our Makefile will let us take the content and apply the template, creating a full HTML page. And for completeness, we’ll add a rule that builds all of the pages for the site. The directory structure for the project will look like this:

Get hands-on with 1300+ tech skills courses.