forked from tohecz/ctuthesis
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathctuman.tex
757 lines (522 loc) · 25.8 KB
/
ctuman.tex
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
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
% arara: pdflatex: { synctex: yes }
% arara: makeindex: { style: ctuthesis }
%% arara: bibtex
%\listfiles
%\PassOptionsToPackage{cp1250}{inputenc}
% The class takes all the key=value arguments that \ctusetup does,
% and couple more: draft and oneside
\documentclass[twoside]{ctuthesis}
\makeatletter
\edef\mytoday{\expandafter\@gobbletwo\the\year\ifnum\month<10 0\fi\the\month\ifnum\day<10 0\fi\the\day}
\makeatother
% LaTeX logo with better kerning in sf bf font
\makeatletter
\newcommand\LaTeX@lmss@bx{L\kern -.33em{\sbox \z@ T\vbox to\ht \z@ {\hbox {\check@mathfonts \fontsize \sf@size \z@ \math@fontsfalse \selectfont A}\vss }}\kern -.15em\TeX}
\DeclareRobustCommand\myLaTeX{%
\ifcsname LaTeX@\f@family @\f@series\endcsname
\csname LaTeX@\f@family @\f@series\endcsname
\else
\LaTeX
\fi
}
\ctusetup{
% preprint = {\ctuverlog \\ ctuman \mytoday},
mainlanguage = english,
% titlelanguage = english,
% otherlanguages = {czech},
title-czech = {Manuál ke třídě ctuthesis pro {\myLaTeX}},
title-english = {Manual for {\myLaTeX} class ctuthesis},
doctype-english = {User Manual},
% xfaculty = F4,
% department-czech = {Katedra matematiky},
% department-english = {Department of Mathematics},
author = {Tomáš Hejda \emph{et al.}},
% supervisor = {Prof. Krutoš Spravedlivý},
% supervisor-address = {Ústav X, \\ Uliční 5, \\ Praha 99},
keywords-czech = {manuál, závěrečnná práce, \LaTeX},
keywords-english = {manual, degree project, \LaTeX},
day = 16,
month = 4,
year = 2015,
% list-of-figures = false,
% list-of-tables = false,
% monochrome = true,
% savetoner = true,
pkg-listings = true,
ctulstbg = none,
% layout-short = true,
% pkg-hyperref = false,
}
\ctuprocess
% Theorem declarations, this is the reasonable default, anybody can do what they wish.
% If you prefer theorems in italics rather than slanted, use \theoremstyle{plainit}
\theoremstyle{plain}
\newtheorem{theorem}{Theorem}[chapter]
\newtheorem{corollary}[theorem]{Corollary}
\newtheorem{lemma}[theorem]{Lemma}
\newtheorem{proposition}[theorem]{Proposition}
\theoremstyle{definition}
\newtheorem{definition}[theorem]{Definition}
\newtheorem{example}[theorem]{Example}
\newtheorem{conjecture}[theorem]{Conjecture}
\theoremstyle{note}
\newtheorem*{remark*}{Remark}
\newtheorem{remark}[theorem]{Remark}
% Marginpars used as navigation aids.
\usepackage{mparhack}
\newcommand\indexmp[1]{{\sffamily\bfseries#1}}
\ExplSyntaxOn
\cs_new:Nn \ctuman_domarginpar:n {
\marginpar
[ \raggedleft \footnotesize \sffamily #1 ]
{ \raggedright \footnotesize \sffamily #1 }
}
\cs_generate_variant:Nn \ctuman_domarginpar:n { x }
\DeclareDocumentCommand \ctump { m } {
\clist_set:Nn \ctuman_temp_clist { #1 }
\ctuman_domarginpar:x { \clist_use:Nnnn \ctuman_temp_clist { \\ } { \\ } { \\ } }
\clist_map_inline:Nn \ctuman_temp_clist { \index{##1|indexmp} }
\ignorespaces
}
\ExplSyntaxOff
% Abstract in Czech
\begin{abstract-czech}
Tento mánuál představuje \LaTeX ovou třídu ctuthesis, její použití, požadavky na systém atd.
\end{abstract-czech}
% Abstract in English
\begin{abstract-english}
This manual shows how to use the ctuthesis \LaTeX\ class, what are the requirements, etc.
\end{abstract-english}
% Acknowledgements / Podekovani
\begin{thanks}
We thank the CTU in Prague for being a~very good \emph{alma mater}.
\end{thanks}
% Declaration / Prohlaseni
\begin{declaration}
I declare that this work is all my own work and I have cited all sources I have
used in the bibliography.
\medskip
Prague, \monthinlanguage{title} \ctufield{day}, \ctufield{year}
\vspace*{2cm}
Prohlašuji, že jsem předloženou práci vypracoval samostatně, a že jsem uvedl veškerou použitou literaturu.
\medskip
V Praze, \ctufield{day}.~\monthinlanguage{second}~\ctufield{year}
\end{declaration}
\usepackage{url}
\usepackage{tabularx,array}
\usepackage{mathtools,amssymb}
% A savebox for typesetting listings in the titles
\newsavebox{\myboxa}
%\newcommand*\symbO{$\color{red}\bowtie$}
\newcommand*\symbO{\raisebox{0.5\height}{\scalebox{0.7}{\color{red}${\vartriangleright}\mkern-6mu{\vartriangleleft}$}}}
\newcommand*\symbM{\raisebox{0.5\height}{\scalebox{0.7}{\color{red}${\blacktriangleright}\mkern-6mu{\blacktriangleleft}$}}}
\newcommand*\itemO{\item\leavevmode\kern-0.33em\symbO}
\newcommand*\itemM{\item\leavevmode\kern-0.33em\symbM}
\begin{document}
% We actually don't want inline listings to have a background color
\renewcommand \ctulstsep {0pt}
% \ctuclsname for typesetting the class' name
\newcommand\ctuclsname{\leavevmode\unhcopy\ctuclsnamebox}
\newsavebox\ctuclsnamebox
\begin{lrbox}{\ctuclsnamebox}
\ctulst!ctuthesis!
\end{lrbox}
\maketitle
\chapter{Introduction}
In this manual, we want to explain how to use the class \ctuclsname.
The manual consists of three main parts:
\begin{itemize}
\item basic user guide;
\item reference manual;
\item guide for template authors.
\end{itemize}
Students and other `users' of the class should carefully read the basic user guide (Chapter~\ref{chap:ug}),
and visit the reference when needed (Chapter~\ref{chap:rm}).
\section*{Why was this project created}
The \ctuclsname\@ \LaTeX\@ template was written by Tomáš Hejda because there is wider demand for it at CTU. The aim has been to provide a \LaTeX\@ tool to students and their advisors for writing qualification theses (\emph{e.g.}, bachelor, master, Ph.D.). \LaTeX\@ as a tool for professional typesetting has had a significant group of users at CTU. The \ctuclsname\@ template can be selected and used voluntarily, \emph{i.e.}, if the student and the advisor agree on this.
There were several more local attempts in creating \LaTeX\@ templates for qualification theses at CTU. Let us give only two examples. First, the package \ctulst!ctu!, \url{https://github.com/kyrcore/ctu-latex}\footnote{All URLs in this section were retrived on March 15, 2015.}. Its development seems to be interrupted since 2013. Second, the package \ctulst!CMPthesis! written and maintained up to now by Vít Zýka, which is provided only internally at \url{http://www-cmp.felk.cvut.cz/proceedings/TeX/texmf-cmp/tex/latex/cmpthesis/cmpthesis.pdf}.
Petr Olšák from Department of Mathematics FEE came with the initiative to create a \TeX\@ package for qualification theses and offered it to the whole CTU in 2013, see \url{http://petr.olsak.net/ctustyle.html} (in Czech). The package is less spread because there are fewer \TeX\@ users than \LaTeX\@ users at CTU.
The \ctuclsname\@ \LaTeX\@ package, described in this document, was inspired by P.~Olšák's \TeX\@ package. The aim is to preserve very similar graphical look. T.~Hejda volunteered to write a \LaTeX\@ package with similar properties as P.~Olšák's \ctulst!ctustyle! package. P.~Olšák has supported this initiative.
The small team around the \ctuclsname\@ package (Tomáš Hejda, Václav Hlaváč, Petr Olšák) has attempted persuading CTU leaders to support this package and help offering it at university-wide scale for the voluntary use. As many students and supervisors use other publishing/typesetting tools, such as Microsoft Word, the mentioned team encourages someone to write a template, maybe with similar outer look to P.~Olšák's \TeX\@ template \ctulst!ctustyle! and T.~Hejda's \LaTeX\@ template \ctuclsname.
\chapter{User Guide}
\label{chap:ug}
\section{Installing the class}
\begin{table}[!b]
\begin{ctucolortab}\begin{tabularx}{0.95\linewidth}{l>{\sloppy}X}
\bfseries File name & \bfseries Description \\\Midrule
\ctulst(none)!ctuthesis.cls! & Class file itself \\[\smallskipamount]
\ctulst(none)!ctu_logo_blue.pdf! & Logo of the university; this file is subject to different license and copyright than the rest of the class files \\[\smallskipamount]
\ctulst(none)!ctuthesis.ist! & Nicely loooking style for \ctulst(none)!makeindex! \\[\smallskipamount]
\ctulst(none)!latex3-tl2014.zip! & ZIP file containing the ``good'' version of \LaTeX3 \\[\smallskipamount]
\ctulst(none)!ctuman.pdf! & This manual \\[\smallskipamount]
\ctulst(none)!ctuman-*.tex! & Source code to this manual \\[\smallskipamount]
\ctulst(none)!ctuth-core.tex! & Core definitions for the class; users do not need to ever load this file manually \\[\smallskipamount]
\ctulst(none)!ctuth-pkg.tex! & Package loading code for the class; users do not need to ever load this file manually \\[\smallskipamount]
\ctulst(none)!ctuth-names.tex! & Language-dependent part of the class; users should not need to modify this file or load it manually \\[\smallskipamount]
\ctulst(none)!ctuth-templates.tex! & Templates for various parts of the document; users may look inside this file and see how things are done;
this is discussed in more detail in Chapter~\ref{chap:ta}
\end{tabularx}\end{ctucolortab}
\caption[The files of the class ctuthesis.]{The files of the class \ctuclsname.}
\label{tab:class-files}
\end{table}
The class comprises the files listed in Table~\ref{tab:class-files}.
The class is build over the \LaTeX3 bundle, which is a project under development and new programming features are added regularly.
This means that the class works as is only with \TeX~Live 2014.
If you have an eariler version of \LaTeX\@ distribution, you have basically two options:
\begin{enumerate}
\item Install \TeX~Live 2014 or newer; it is not difficult and it will save you all the troubles.
The installing guide is on TUG's website at \url{http://tug.org/texlive/}.
\item Install just the new version of \LaTeX3.
This is tested to work on \TeX~Live from version 2010.
The bundle is attached as a ZIP file, it is sufficient to extract all the files in the working directory.
\end{enumerate}
\section{Minimal example}
The minimal example of a Bachelor project at the Nuclear Faculty looks like this:
% lstinputting utf8 files doesn't really work, so we do the following "hack":
\begingroup
% Change encoding to cp1250
\inputencoding{cp1250}
% Disable the conflicting shorthands
\shorthandoff{-}
\shorthandoff{"}
% Convert the file from utf8 to cp1250
\immediate\write18{iconv -fUTF8 -tCP1250 <ctuman-mwe.tex >ctuman-mwe-cp1250.tex}
% Input the cp1250 version
\lstinputlisting{ctuman-mwe-cp1250.tex}
\endgroup
\noindent
At the first sight, it may look complicated, but the basic structure is pretty simple:
\begin{lstlisting}
\documentclass{ctuthesis}
\ctusetup{
< key = value settings >
}
\ctuprocess
< abstracts and other frontmatter text here,
and standard preamble contents >
\begin{document}
\maketitle
< the whole text here >
\end{document}
\end{lstlisting}
\section{Setting up the class}
This section lists all various settings that can be made to the class.
The ones marked `\symbM' are \emph{always mandatory}.
The ones marked `\symbO' are \emph{mandatory in almost all cases, with some small exceptions}.
For most of them, no errors are issued if they are missing, though.
\begin{lrbox}{\myboxa}\bfseries
\ctulst!\documentclass!
\end{lrbox}
\subsection[Options to \protect\string\protect\documentclass]{Options to \box\myboxa}
The
\ctump{documentclass, draft, oneside}
class \ctuclsname\@ itself takes an optional argument \ctulst!draft!
that sets some draft options (the ones common in \LaTeX).
It also takes the option \ctulst!oneside! which switches to one-sided mode;
however, \emph{we strongly advice against using this option}.
\begin{lrbox}{\myboxa}\bfseries
\ctulst!\ctusetup!
\end{lrbox}
\subsection[Parameters to \texorpdfstring{\protect\string\protect\ctusetup}{ctusetup}]{Parameters to \box\myboxa}
The
\ctump{ctusetup}
parameters can be diveded into several groups.
\paragraph{Text fields}
Some of the fields --- like the theses title --- are language-dependent.
They are marked \ctulst!key-<lang>! below, and it means that multiple keys exist: \ctulst!key-english!, \ctulst!key-czech! and \ctulst!key-slovak!.
\begin{itemize}
\itemM \ctulst!author!
\ctump{author}
--- author's name, including titles.
\itemO \ctulst!supervisor!
\ctump{supervisor}
--- supervisor's name, including titles.
\itemO \ctulst!supervisor-address!
\ctump{supervisor-address} ---
supervisor's affiliation and address; use \ctulst!\\! to format it with linebreaks.
\itemO \ctulst!supervisor-specialist!
\ctump{supervisor}
--- supervisor-specialist's name, including titles.
\itemO \ctulst!year!, \symbO\ctulst!month!, \ctulst!day! ---
\ctump{year, month, day}
numerical values of the date of theses publishing.
\itemO \ctulst!title-<lang>! ---
\ctump{title-<lang>}
title of the thesis.
\item \ctulst!subtitle-<lang>! ---
\ctump{subtitle-<lang>}
subtitle.
\item \ctulst!university-<lang>! ---
\ctump{university-<lang>}
name of the university (is preset for CTU).
\item \ctulst!university-endl-<lang>! ---
\ctump{university-endl-<lang>}
name of the univesity broken in 4 lines using \ctulst!\\!.
\item \ctulst!faculty-<lang>! ---
\ctump{faculty-<lang>}
name of the faculty (set up automatically, see \ctulst!xfaculty! below).
\item \ctulst!facultynum! ---
\ctump{facultynum}
standard number of the faculty (set up automatically, see \ctulst!xfaculty! below).
\item \ctulst!doctype-<lang>! ---
\ctump{doctype-<lang>}
type of the document/thesis (set up automatically, see \ctulst!xdoctype! below).
\itemO \ctulst!department-<lang>! ---
\ctump{department-<lang>}
name of the department.
\itemO \ctulst!fieldofstudy-<lang>!, \ctulst!subfieldofstudy-<lang>! ---
\ctump{fieldofstudy-<lang>, subfieldofstudy-<lang>}
field of study.
\itemO \ctulst!keywords-<lang>! ---
\ctump{keywords-<lang>}
comma-separated list of keywords.
\end{itemize}
\paragraph{General fields}
\begin{itemize}
\itemM \ctulst!mainlanguage!
\ctump{mainlanguage}
--- main language of the thesis; the choices are \ctulst!czech!, \ctulst!english! and \ctulst!slovak!.
\item \ctulst!titlelanguage!
\ctump{titlelanguage}
--- language in which the title pages are typeset (defaults to \ctulst!mainlanguage!).
\item \ctulst!secondlanguage!
\ctump{secondlanguage}
--- language of the second abstract (set up automatically so that two abstracts appear: one in English and one in Czech,
unless the thesis is in Slovakian, in which case the two abstracts are in English and in Slovakian).
\item \ctulst!otherlanguages!
\ctump{otherlanguages}
--- allows more languages to be loaded by \ctulst!babel! package, accepts a comma-separated list.
\itemO \ctulst!xfaculty!
\ctump{xfaculty}
--- takes values \ctulst!F1!, \ctulst!F2!, \ldots, \ctulst!F8! and sets up the faculty name and number automatically.
\itemO \ctulst!xdoctype!
\ctump{xdoctype}
--- takes values \ctulst!B! (bachelor), \ctulst!M! (master) or \ctulst!D! (dissertation) and sets up the document
type automatically; for non-thesis-like documents, use \ctulst!doctype-<lang>!.
\itemO \ctulst!specification-file! ---
\ctump{specification-file}
the path to the specification file (usually something like \ctulst!zadani.pdf!,
the current directory is searched for the file of course).
\item \ctulst!front-specification!
\ctump{front-specification}
--- if set to true, the specification will appear just after
the titlepage (defaults to \ctulst!false!).
\item \ctulst!front-list-of-figures!, \ctulst!front-list-of-tables!
\ctump{front-list-of-figures, front-list-of-tables}
--- says whether the list of figures/tables will be set
in the frontmatter (default to \ctulst!true!)
\item \ctulst!monochrome!
\ctump{monochrome}
--- switches to optimized monochrome setup, in case the work will not be printed in colour.
\item \ctulst!savetoner!
\ctump{savetoner}
--- disables background and other too dark things to save toner while printing drafts.
\end{itemize}
\paragraph{Default package loading}
The class attempts to set up some packages nicely if the user wants to use them.
So for instance, the package \ctulst!listings! can be pre-set to include the blue background of all listings.
In order to leave the user the chance to mess with things ``his own way'', options are offered to enable or disable certain packages.
The format of the option name is always \ctulst!pkg-<packagename>! and it accepts either \ctulst!true! or \ctulst!false!
\begin{itemize}
\item \ctulst!pkg-hyperref! (default: \ctulst!true!) ---
\ctump{pkg-hyperref}
sets up all the fields of the PDF document.
\item \ctulst!pkg-listings! (default: \ctulst!false!) ---
\ctump{pkg-listings}
sets up \ctulst!\ttfamily! font for all listings, and adds a background to all display listings.
For inline listings, this is a bit more complicated; we rather implemented a new macro
\ctump{ctulst} % Be careful, lstinline (LSTINLINE) is mentioned explicitly here!
\ctulst:\ctulst(color)[settings]!<text>!: that behaves exactly like \ctulst:\lstinline!<text>!:,
but applies the background; the color is an optional argument (in parentheses \ctulst!()!)
and defaults to the blue background color seen in this manual. Any printable symbol but one of \ctulst![({}!
can be used in place of \ctulst:!:.
Using \ctulst!none! makes the background transparent.
The default background for inline listings can be changed by \ctulst!\ctusetup{ ctulstbg = <color> }!.
\item \ctulst!pkg-amsthm! (default: \ctulst!true!) ---
\ctump{pkg-amsthm}
sets up nicely the basic styles for theorems, but does not set up the theorem environment themselves.
More information is in Section~\ref{subsect:math}
\item \ctulst!pkg-biblatex! (default: \ctulst!false!) ---
\ctump{pkg-biblatex}
more details in Section~\ref{sect:biblio}.
\end{itemize}
\subsection{Text environments used in the preamble}
There is a small number of environments that should be used in the preamble in order to set up various text fields,
mostly used in the front matter.
\begin{itemize}
\itemO \ctulst!{abstract-<lang>}! --- abstract;
\ctump{abstract-<lang>}
the language has to be always specified.
\itemO \ctulst!{thanks}! --- acknowledgements;
\ctump{thanks}
can be used for both personal and grant ackowledgements.
\itemO \ctulst!{declaration}! --- students
\ctump{declaration}
are oblidged to declare that the works is their works, and maybe some more things,
depending on the faculty's or deparment's regulations.
\end{itemize}
\section{Various parts of the document}
\subsection{Frontmatter}
Typically,
\ctump{maketitle}
the frontmatter will be only one command: \ctulst!\maketitle!.
This typesets the titlepage, the acknowledgements, the declaration, the two abstracts, the table of contents,
\ctump{mainmatter}
and possibly the lists of figures and tables. Afterwards, it immediately switches to \ctulst!\mainmatter!.
Another
\ctump{frontmatter}
option, which should be used only in special cases, is to start the frontmatter with \ctulst!\frontmatter!,
include whatever material should be there and close it by \ctulst!\mainmatter!.
This is discussed in detail in Chapter~\ref{ch:ta}.
\subsection{Mainmatter and backmatter. Sectioning}
Standard
\ctump{chapter, section, subsection, subsubsection, paragraph, subparagraph, part}
sectioning commands are suported, they are \ctulst!\chapter!, \ctulst!\section!, \ctulst!\subsection!, \ctulst!\subsubsection!.
These ought to follow the hierarchy from top to bottom.
There is also \ctulst!\paragraph! and \ctulst!\subparagraph! which can be used as lowest-level sectioning commands.
Long works can be divided into parts using \ctulst!\part!; its numbering is independent of the other ones.
All these commands take standard optional argument and star; however, we advice against using starred sections.
The
\ctump{appendix}
appendices are introduced by command \ctulst!\appendix!.
Then, each appendix is a chapter, so the standard \ctulst!\chapter! command ought to be used.
In appendix, even chapters started by \ctulst!\chapter*! such as the bibliography and the index are numbered.
(In a document without appendices, these should be unnumbered. Once appendices are used, all indexes and alike should be standard numbered appendices.)
For unnumbered appendices, \ctulst!\chapter**! can be used.
If
\ctump{appendix*, appendix**}
the document is divided into parts, the appendices are introduced by a part-like title ``Appendices'', both in the document and in the table of contents.
This can be suppressed by using \ctulst!\appendix*! (keeps the line in the table of contents) or \ctulst!\appendix**!.
If
\ctump{specification as chapter}
the project specification is to be included as an appendix, it can be done by \ctulst!\ctutemplate{specification as chapter}!.
There is no true backmatter behaviour defined in the class.
The only thing that would belong to the backmatter is the colophon (`\textit{\foreignlanguage{czech}{tiráž}}').
Users are advised to use \ctulst!\cleardoublepage* \thispagestyle{empty}! and then typeset the colophon to their liking.
\subsection{Bibliography}
There are three ways how to include the bibliography:
\begin{enumerate}
\item
Using Biblatex.
In that case, setting up \ctulst!pkg-biblatex = true! is recommended.
The bibliography is then included using \ctulst!\addbibresource! and \ctulst!\printbibliography!.
\item
Using \textsc{Bib}\TeX.
No special setting is needed, and the bibliography is included using \ctulst!\bibliographystyle! and \ctulst!\bibliography!.
\item
By direct input.
The standard environment \ctulst!{thebibliography}! can be used for this.
\end{enumerate}
We kindly ask users to consult the manuals to the specific packages for their usage.
\subsection{Index}
To
\ctump{makeidx, makeindex, printindex}
generate the index, use \ctulst!pkg-makeidx = true!, and put \ctulst!\printindex! where the index should appear.
We provide an in-house style for the index called \ctulst!ctuthesis.ist!.
The index generation is dependent on calling the external tool \ctulst!makeindex!, in a similar way in which the bibliography generation depends
on \ctulst!bibtex! or \ctulst!biber!.
The proper way how to call this tool is the following:
\begin{lstlisting}
makeindex -s ctuthesis.ist <filename>
\end{lstlisting}
where
\ctump{ctuthesis.ist}
\ctulst!<filename>! is the root name of your main project file (without \ctulst!.tex!).
\subsection{List of notation. Nomenclature}
We do not preset any special environment for typesetting appendices such as list of notation or nomenclature.
One of the possible standard way how to do it is with the help of the packages \ctulst!tabularx!,
\ctump{tabularx, array, booktabs}
\ctulst!array! and \ctulst!booktabs! as follows:
% lstinputting files doesn't really work with shorthands:
\begingroup
% Disable the shorthands
\shorthandoff{-}
\shorthandoff{"}
% Input the file; it's easy here since the file doesn't contain any utf8 characters
\lstinputlisting{ctuman-notation.tex}
\endgroup
\noindent
In the case the notation is longer than one page, the package
\ctump{ltxtable, ltablex}
\ctulst!ltxtable! or \ctulst!ltablex! can be used.
\subsection{Floating objects: Figures and tables}
Floats
\ctump{figure, table}
are input either as \ctulst!{figure}! or \ctulst!{table}! environment.
All floats are automatically typeset centered, so a typical code for a figure is the following:
\begin{lstlisting}
\begin{figure}
\includegraphics[width=0.8\linewidth]{mygraphicfile.pdf}
\caption{We depict a foo-bar here.}
\label{fig:foobar}
\end{figure}
\end{lstlisting}
\noindent
For a table, it is the following:
\begin{lstlisting}
\begin{table}
\begin{ctucolortab}
\begin{tabular}{cc}
\bfseries Foo & \bfseries Bar \\\Midrule
foo1 & bar1 \\
foo2 & bar2
\end{tabular}
\end{ctucolortab}
\caption{Table of foo-bar.}
\label{tab:foobar}
\end{table}
\end{lstlisting}
Note
\ctump{ctucolortab, Midrule, midrule}
the usage of the environment \ctulst!{ctucolortab}! to make the table get a blue background,
and the usage of \ctulst!\Midrule! to get a horizontal line in the table
(a thinner line can be obtained using \ctulst!\midrule!).
Also note the deliberate absence of verical rules.
\subsection{Mathematics}\label{subsect:math}
All standard concepts for typesetting mathematics are working as in any other \LaTeX\@ class.
We only emphasize how the class behaves in relation to theorem-like environments and proofs.
The default behaviour is that the package \ctulst!amsthm! is loaded and theorem styles \ctulst!plain!, \ctulst!definition! and \ctulst!note!.
Theorems (plain style) are by default slanted rather than italic, should italic theorems be preferred, use \ctulst!plainit!.
However, no theorem-like environments are predefined, everybody can do this to their liking.
The preamble declarations could look like this:
\begin{lstlisting}
\theoremstyle{plain} % not necessary, it is the default
\newtheorem{theorem}{Theorem}[chapter] % per-chapter numbering
\newtheorem{lemma}[theorem]{Lemma} % use the same counter for
% all of them
\newtheorem{proposition}[theorem]{Proposition}
\theoremstyle{definition}
\newtheorem{definition}[theorem]{Definition}
\newtheorem{example}[theorem]{Example}
\theoremstyle{note}
\newtheorem{remark}[theorem]{Remark} % numbered remark
\newtheorem*{remark*}{Remark} % unnumbered remark*
\end{lstlisting}
\noindent
The environment \ctulst!{proof}! is provided by default.
All theorem handling can be disabled by \ctulst!\ctusetup{ pkg-amsthm = false }!.
\subsection{Colors}
The class uses internally many named colors.
For the general use, two non-standard colors are provided:
\begin{itemize}
\item
{\color{white}\ctulst(ctublue)!ctublue!}
\ctump{ctublue}
{\color{ctublue}\ctulst(white)!ctublue!};
\item
{\color{black}\ctulst(ctulightblue)!ctulightblue!}
\ctump{ctulightblue}
{\color{ctulightblue}\ctulst(white)!ctulightblue!}.
\end{itemize}
The colors are used for the headers, rules in the titles, title texts, backgrounds for listings and tables etc.
\section{Features not described in this manual. Troubleshooting}
I may happen that some of the features of the class are not described in this manual.
If the users struggle with anything, they can contact the class authors at \href{mailto:[email protected]}{\url{[email protected]}}
or via the GitHub repository \href{https://github.com/tohecz/ctuthesis}{\url{github.com/tohecz/ctuthesis}}.
\chapter{Creating and modifying templates}\label{chap:ta}
We apologize, this chapter of the manual is still under construction.
\appendix
\printindex
%\bibliographystyle{amsalpha}
%\bibliography{ctutest}
\end{document}