summaryrefslogtreecommitdiff
path: root/elpa/auctex-13.1.3/doc/quickstart.texi
blob: 9731d15eb1378633ec5e076dbabfe139e3c74a28 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
@include macros.texi

@node Quick Start
@chapter Quick Start

@AUCTeX{} is a powerful program offering many features and configuration
options.  If you are new to @AUCTeX{} this might be deterrent.
Fortunately you do not have to learn everything at once.  This Quick
Start Guide will give you the knowledge of the most important commands
and enable you to prepare your first @LaTeX{} document with @AUCTeX{}
after only a few minutes of reading.

In this introduction, we assume that @AUCTeX{} is already installed on
your system.  If this is not the case, you should read the file
@file{INSTALL} in the base directory of the unpacked distribution
tarball.  These installation instructions are available in this manual
as well, @ref{Installation}.  We also assume that you are familiar with
the way keystrokes are written in Emacs manuals.  If not, have a look at
the Emacs Tutorial in the Help menu.

If @AUCTeX{} is installed in any other way than from the Emacs package
manager (@acronym{ELPA}), you might still need to activate it, by
inserting

@lisp
(load "auctex.el" nil t t)
@end lisp
@noindent
in your user init file.@footnote{This usually is a file in your home
directory called @file{.emacs}, or @file{.emacs.d/init.el}.}

If @AUCTeX{} is installed from @acronym{ELPA}, the installation
procedure already cares about loading @AUCTeX{} correctly and you
@strong{must not} have the line above in your init file.  Note that this
also applies if you have the following line in your init file

@lisp
(package-initialize)
@end lisp

In order to get support for many of the @LaTeX{} packages you will use
in your documents, you should enable document parsing as well, which can
be achieved by putting

@lisp
(setq TeX-auto-save t)
(setq TeX-parse-self t)
@end lisp
@noindent
into your init file.  Finally, if you often use @code{\include} or
@code{\input}, you should make @AUCTeX{} aware of the multifile
document structure.  You can do this by inserting

@lisp
(setq-default TeX-master nil)
@end lisp

into your init file.  Each time you open a new file, @AUCTeX{} will then
ask you for a master file.

@menu
* Editing Facilities::          Functions for editing TeX files
* Processing Facilities::       Creating and viewing output, debugging
@end menu

@iftex
This Quick Start Guide covers two main topics: First we explain how
@AUCTeX{} helps you in editing your input file for @TeX{}, @LaTeX{}, and
some other formats.  Then we describe the functions that @AUCTeX{}
provides for processing the input files with @LaTeX{}, Bib@TeX{}, etc.,
and for viewing and debugging.
@end iftex

@node Editing Facilities
@section Functions for editing TeX files

@subsection Making your @TeX{} code more readable

@AUCTeX{} can do syntax highlighting of your source code, that means
commands will get special colors or fonts.  This is enabled by default.
You can disable it locally by typing @kbd{M-x font-lock-mode @key{RET}}.

@AUCTeX{} will indent new lines to indicate their syntactical
relationship to the surrounding text.  For example, the text of a
@code{\footnote} or text inside of an environment will be indented
relative to the text around it.  If the indenting has gotten wrong after
adding or deleting some characters, use @key{TAB} to reindent the line,
@kbd{M-q} for the whole paragraph, or @kbd{M-x LaTeX-fill-buffer @key{RET}}
for the whole buffer.

@subsection Entering sectioning commands
@cindex Sectioning
@cindex Sections
@cindex Chapters
@cindex @code{\chapter}
@cindex @code{\section}
@cindex @code{\subsection}
@cindex @code{\label}

Insertion of sectioning macros, that is @samp{\chapter},
@samp{\section}, @samp{\subsection}, etc.@: and accompanying @samp{\label}
commands may be eased by using @kbd{C-c C-s}.  You will be asked for the
section level.  As nearly everywhere in @AUCTeX{}, you can use the
@key{TAB} or @key{SPC} key to get a list of available level names, and
to auto-complete what you started typing.  Next, you will be asked for
the printed title of the section, and last you will be asked for a label
to be associated with the section.

@subsection Inserting environments

Similarly, you can insert environments, that is
@samp{\begin@{@}}--@samp{\end@{@}} pairs: Type @kbd{C-c C-e}, and select
an environment type.  Again, you can use @key{TAB} or @key{SPC} to get a
list, and to complete what you type.  Actually, the list will not only
provide standard @LaTeX{} environments, but also take your
@samp{\documentclass} and @samp{\usepackage} commands into account if
you have parsing enabled by setting @code{TeX-parse-self} to @code{t}.
If you use a couple of environments frequently, you can use the @key{up} and
@key{down} arrow keys (or @kbd{M-p} and @kbd{M-n}) in the minibuffer to get
back to the previously inserted commands.

Some environments need additional arguments.  Often, @AUCTeX{} knows about
this and asks you to enter a value. 

@subsection Inserting macros

@kbd{C-c C-m}, or simply @kbd{C-c RET} will give you a prompt that asks
you for a @LaTeX{} macro.  You can use @key{TAB} for completion, or the
@key{up}/@key{down} arrow keys (or @kbd{M-p} and @kbd{M-n}) to browse the command
history.  In many cases, @AUCTeX{} knows which arguments a macro needs
and will ask you for that.  It even can differentiate between mandatory
and optional arguments---for details, see @ref{Completion}.

An additional help for inserting macros is provided by the possibility
to complete macros right in the buffer.  With point at the end of a
partially written macro, you can complete it by typing @kbd{M-@key{TAB}}.

@subsection Changing the font 

@AUCTeX{} provides convenient keyboard shortcuts for inserting macros
which specify the font to be used for typesetting certain parts of the
text.  They start with @kbd{C-c C-f}, and the last @kbd{C-} combination
tells @AUCTeX{} which font you want:

@table @kbd
@item C-c C-f C-b
@kindex C-c C-f C-b
@cindex @code{\textbf}
Insert @b{bold face} @samp{\textbf@{@point{}@}} text.

@item C-c C-f C-i
@kindex C-c C-f C-i
@cindex @code{\textit}
Insert @i{italics} @samp{\textit@{@point{}@}} text.

@item C-c C-f C-e
@kindex C-c C-f C-e
@cindex @code{\emph}
Insert @emph{emphasized} @samp{\emph@{@point{}@}} text.

@item C-c C-f C-s
@kindex C-c C-f C-s
@cindex @code{\textsl}
Insert @slanted{slanted} @samp{\textsl@{@point{}@}} text.

@item C-c C-f C-r
@kindex C-c C-f C-r
@cindex @code{\textrm}
Insert @r{roman} @samp{\textrm@{@point{}@}} text.

@item C-c C-f C-f
@kindex C-c C-f C-f
@cindex @code{\textsf}
Insert  @sansserif{sans serif} @samp{\textsf@{@point{}@}} text.

@item C-c C-f C-t
@kindex C-c C-f C-t
@cindex @code{\texttt}
Insert @t{typewriter} @samp{\texttt@{@point{}@}} text.

@item C-c C-f C-c
@kindex C-c C-f C-c
@cindex @code{\textsc}
Insert @sc{small caps} @samp{\textsc@{@point{}@}} text.

@item C-c C-f C-d
@kindex C-c C-f C-c
@cindex Deleting fonts
Delete the innermost font specification containing point.

@end table

If you want to change font attributes of existing text, mark it as an
active region, and then invoke the commands.  If no region is selected,
the command will be inserted with empty braces, and you can start typing
the changed text.

Most of those commands will also work in math mode, but then macros like
@code{\mathbf} will be inserted.


@subsection Other useful features

@AUCTeX{} also tries to help you when inserting the right ``quote''
signs for your language, dollar signs to typeset math, or pairs of
braces.  It offers shortcuts for commenting out text (@kbd{C-c ;} for
the current region or @kbd{C-c %} for the paragraph you are in).  The
same keystrokes will remove the % signs, if the region or paragraph is
commented out yet.  With @code{TeX-fold-mode}, you can hide certain
parts (like footnotes, references etc.)@: that you do not edit currently.
Support for Emacs' outline mode is provided as well.  And there's more,
but this is beyond the scope of this Quick Start Guide.



@node Processing Facilities
@section Creating and viewing output, debugging

@subsection One Command for @LaTeX{}, helpers, viewers, and printing

If you have typed some text and want to run @LaTeX{} (or @TeX{}, or
other programs---see below) on it, type @kbd{C-c C-c}.  If applicable,
you will be asked whether you want to save changes, and which program
you want to invoke.  In many cases, the choice that @AUCTeX{} suggests
will be just what you want: first @command{latex}, then a viewer.  If a
@command{latex} run produces or changes input files for
@command{makeindex}, the next suggestion will be to run that program,
and @AUCTeX{} knows that you need to run @command{latex} again
afterwards---the same holds for Bib@TeX{}.

When no processor invocation is necessary anymore, @AUCTeX{} will
suggest to run a viewer, or you can chose to create a PostScript file
using @command{dvips}, or to directly print it.

Actually, there is another command which comes in handy to compile
documents: type @kbd{C-c C-a} (@code{TeX-command-run-all}) and @AUCTeX{}
will compile the document for you until it is ready and then run the
viewer.  This is the same as issuing repeatedly @kbd{C-c C-c} and
letting @AUCTeX{} guess the next command to run.

At this place, a warning needs to be given: First, although @AUCTeX{} is
really good in detecting the standard situations when an additional
@command{latex} run is necessary, it cannot detect it always.  Second,
the creation of PostScript files or direct printing currently only works
when your output file is a @acronym{DVI} file, not a @acronym{PDF} file.

Ah, you didn't know you can do both?  That brings us to the next topic.

@subsection Choosing an output format

From a @LaTeX{} file, you can produce @acronym{DVI} output, or a
@acronym{PDF} file directly @i{via} @command{pdflatex}.  You can switch
on source specials for easier navigation in the output file, or tell
@command{latex} to stop after an error (usually @option{--noninteractive}
is used, to allow you to detect all errors in a single run).

These options are controlled by toggles, the keystrokes should be easy
to memorize:

@table @kbd
@item C-c C-t C-p
@kindex C-c C-t C-p
This command toggles between @acronym{DVI} and @acronym{PDF} output

@item C-c C-t C-i
@kindex C-c C-t C-i
toggles interactive mode

@item C-c C-t C-s
@kindex C-c C-t C-s
toggles Sync@TeX{} (or source specials) support

@item C-c C-t C-o
@kindex C-c C-t C-o
toggles usage of Omega/lambda.

@end table

There is also another possibility: compile the document with
@command{tex} (or @command{latex}) and then convert the resulting
@acronym{DVI} file to @acronym{PDF} using
@command{dvips}--@command{ps2pdf} sequence or @command{dvipdfmx} command.
If you want to go by this route, customize @code{TeX-PDF-from-DVI} option.
Then @AUCTeX{} will suggest you to run the appropriate command when
you type @kbd{C-C C-c}.  For details, see @ref{Processor Options}.

@subsection Debugging @LaTeX{}

When @AUCTeX{} runs a program, it creates an output buffer in which it
displays the output of the command.  If there is a syntactical error in
your file, @command{latex} will not complete successfully. @AUCTeX{}
will tell you that, and you can get to the place where the first error
occured by pressing @kbd{C-c `} (the last character is a backtick).  The
view will be split in two windows, the output will be displayed in the
lower buffer, and both buffers will be centered around the place where
the error ocurred.  You can then try to fix it in the document buffer,
and use the same keystrokes to get to the next error.  This procedure
may be repeated until all errors have been dealt with.  By pressing
@kbd{C-c C-w} (@code{TeX-toggle-debug-boxes}) you can toggle whether
@AUCTeX{} should notify you of overfull and underfull boxes in addition
to regular errors.

Issue @kbd{M-x TeX-error-overview @key{RET}} to see a nicely formatted list of
all errors and warnings reported by the compiler.

If a command got stuck in a seemingly infinite loop, or you want to stop
execution for other reasons, you can use @kbd{C-c C-k} (for ``kill'').
Similar to @kbd{C-l}, which centers the buffer you are in around your
current position, @kbd{C-c C-l} centers the output buffer so that the
last lines added at the bottom become visible.

@subsection Running @LaTeX{} on parts of your document

If you want to check how some part of your text looks like, and do not
want to wait until the whole document has been typeset, then mark it as
a region and use @kbd{C-c C-r}.  It behaves just like @kbd{C-c C-c}, but
it only uses the document preamble and the region you marked.

If you are using @code{\include} or @code{\input} to structure your
document, try @kbd{C-c C-b} while you are editing one of the included
files.  It will run @command{latex} only on the current buffer, using the
preamble from the master file.

@c Local Variables: 
@c mode: texinfo
@c TeX-master: "auctex"
@c End: