Structuring longer documents
This lesson shows how LaTeX allows you to split your sources into smaller, more manageable files, and how this can make building a long document easier and faster.
When you are writing a longer document, you’ll likely want to split up the source into multiple files. For example, it’s very common to have one ‘main’/’root’ file, then one source file per chapter (for a book or thesis), or per significant section (for a long article).
Structuring your sources
LaTeX allows us to split up sources in a controlled way. There are two important commands here, \input
and \include
. We can use \input
to make a file work ‘as though it was typed in here’, so it can be used for (essentially) any material. The \include
command works for chapters only: it starts a new page and makes some internal adjustments. But it has a big advantage: it allows us to be selective in which chapters to include, so you can work on part of your document rather than the whole thing.
A longer document might therefore look something like the following:
\documentclass{book}
\usepackage[T1]{fontenc}
\usepackage{biblatex}
\addbibresource{biblatex-examples.bib}
\title{A Sample Book}
\author{John Doe \and Joe Bloggs}
\IfFileExists{\jobname.run.xml}
{
\includeonly{
front,
% chap1,
chap2,
% append
}
}
{
% Do a full document initially to generate
% all the aux files
}
\begin{document}
\frontmatter
\include{front}
% =========================
\mainmatter
\include{chap1}
\include{chap2}
\appendix
\include{append}
% ========================
\backmatter
\printbibliography
\newpage
\input{backcover}
\end{document}
We’ll look at the various aspects of this file below. (The various support files are at the end of this page.)
Using \input
The \input
command is good for parts of a long file that are not separate chapters. In the example, we have used it to separate out the front- and backcovers, keeping the main file short and clear, and also meaning we could re-use the covers in another document. We’ve also used it for the ‘non-chapter’ sections at the start of our ‘book’: things like the preface. Again, this is to help keep the main file clear.
Using \include
and \includeonly
The \include
command is good for chapters, so we have used it for each full chapter; it always starts a new page. We have selected which chapters will actually be typeset using \includeonly
, which as you can see takes a comma-separated list of file names. When you use \includeonly
, you can shorten how long your typesetting takes and produce a ‘selective’ PDF for proofreading. In addition, the key advantage of \includeonly
is that LaTeX will use all of the cross reference information from the .aux
files of other included files.
Creating a table of contents
The \tableofcontents
command uses the information from sectioning commands to populate the table of contents. It has its own auxiliary file, with extension .toc
, so you may need to run LaTeX twice to resolve the information. The table is generated automatically from the section titles. There are similar commands for \listoffigures
and \listoftables
, which work from the float environment captions, and use files with extension .lof
and .lot
respectively.
Splitting the document into parts
The \frontmatter
, \mainmatter
, and \backmatter
commands affect the formatting. For instance, \frontmatter
changes the page numbering to Roman numbers. The \appendix
command changes the numbering to A
, B
, etc., so for instance in the first chapter after \appendix
, the header says Appendix A
.
Exercises
Experiment with the basic structure of the demonstration document, try adding and removing entries for \includeonly
and see the effect.
Add some floats and produce a list of figures and tables. If using a locally installed LaTeX, do you see how many LaTeX runs are required? (The online systems re-run LaTeX “behind the scenes” so the additional required runs are not so obvious.)
front.tex
\input{frontcover}
\maketitle
\input{dedication}
\input{copyright}
\tableofcontents
\input{pref}
pref.tex
\chapter{Preface}
The preface text. See \cite{doody}.
chap1.tex
\chapter{Introduction}
The first chapter text.
chap2.tex
\chapter{Something}
The second chapter text.
append.tex
\chapter*{Appendix}
The first appendix text.
frontcover.tex
\begin{center}
The front cover
\end{center}
dedication.tex
\begin{center}
\large
For \ldots
\end{center}
copyright.tex
\begin{center}
Copyright 2020 learnlatex.
\end{center}
backcover.tex
\begin{center}
The back cover
\end{center}