-
Notifications
You must be signed in to change notification settings - Fork 14
/
Copy pathimta_extra.sty
311 lines (245 loc) · 10.7 KB
/
imta_extra.sty
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
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% File Name: imta_extra
%
% Description: Enables advanced functionalities of the IMT Atlantique
% LaTeX Template.
%
% Note: some functionalities require the Minted Package.
% This package further requires:
% 1. To use the --shell-escape option when compiling
% the document (with PDFLaTeX for instance)
% 2. To have Pymentize installed (Having Python installed,
% you can simply run the command: pip install Pygments)
%
% Package options: nouppersectioninlof and nouppersectioninlot
%
% Limitations: /
%
% Errors: None known
%
% Dependencies: mdframed
% minted
%
% Author: A. Foucault - [email protected]
% Contributors: B. Porteboeuf - [email protected]
%
% University: IMT Atlantique, Brest (France)
%
% TeX Environment: TeXLive + pdfLaTeX
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% Revision List:
% Version Author Date Changes
% 1.0 BP 31.10.2017 Original imta.sty package split into
% imta_core.sty and imta_extra.sty
% 1.1 AF 02.11.2017 \imtaConsole and \imtaCode environments
% introduced
% 1.2 BP 02.11.2017 \frontmatter & \mainmatter commands
% introduced - support for uppersection
% display in List of Tables/Figures
% 1.3 BP 05.12.2017 Bug fixed in the \chapter redefinition
% 1.4 BP 17.02.2018 Added \imtaCodeFromFile and
% \imtaConsoleFromFrile commands
% 1.5 AF 22.02.2018 line number rendering changed in code
% highlighting environments
% 1.6 BP 18.06.2018 Fixed rare bug in \chapter command
% existance verification
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\NeedsTeXFormat{LaTeX2e}
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% P A C K A G E S %
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% Fancy code listings
\RequirePackage{minted}
% Fancy frames and boxes
\RequirePackage{mdframed}
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% D E F A U L T E X P O R T S E T T I N G S %
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% Some export-related booleans are introduced
\makeatletter
\newif\if@printuppersectioninLOF \@printuppersectioninLOFtrue
\newif\if@printuppersectioninLOT \@printuppersectioninLOTtrue
\makeatother
\makeatletter
\global\newif\if@uppersectionprintedinLOF \global\@uppersectionprintedinLOFfalse
\global\newif\if@uppersectionprintedinLOT \global\@uppersectionprintedinLOTfalse
\gdef\imtaUpperSectionTitle{\thetitle}
\gdef\imtaUpperSectionNumber{\relax}
\makeatother
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% O P T I O N S D E C L A R A T I O N %
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\makeatletter
% Disables the printing of the upper section in the List Of Figures
\DeclareOption{nouppersectioninlof}{\@printuppersectioninLOFfalse}
% Disables the printing of the upper section in the List Of Tables
\DeclareOption{nouppersectioninlot}{\@printuppersectioninLOTfalse}
\makeatother
\ExecuteOptions{}
\ProcessOptions\relax
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% C O L O R S %
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% Colors related to code formatting
\definecolor{imtaCodeBackground}{RGB}{235, 235, 235}
\definecolor{imtaCodeLinenosFrame}{RGB}{205, 205, 205}
\definecolor{imtaInlineCodeBackground}{RGB}{230, 230, 230}
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% C O M M A N D S %
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% \imtaInlinecode
% Typeset inline code
% First parameter is the language of the text to typeset
% Second parameter is the text to typeset
\newcommand{\imtaInlinecode}[2]{%
\setlength{\fboxsep}{2pt}\colorbox{imtaInlineCodeBackground}{\mintinline{#1}{#2}}%
}
% \imtaFrontMatter
% Resets the page counter and switches to roman numbers (useful for the preamble)
\makeatletter
\newif\if@imtaMainMatter \@imtaMainMattertrue
\def\imtaFrontMatter{%
\@imtaMainMatterfalse \pagenumbering{roman} \setcounter{page}{1}}
% \imtaMainMatter
% Resets the page counter and switches to arabic numbers (useful for the main content)
\def\imtaMainMatter{%
\@imtaMainMattertrue \pagenumbering{arabic} \setcounter{page}{1}}
\makeatother
% \chapter
% \chapter is redefined when relevant, in order to update the upper section informations
\makeatletter
\@ifundefined{chapter}{%
\relax
}{%
\let\imtaExtraOldChapter\chapter
\renewcommand*{\chapter}{\@ifstar{\imtaExtraStarChapter}{\@dblarg\imtaExtraNoStarChapter}}
\newcommand*\imtaExtraStarChapter[1]{%
\imtaExtraOldChapter*{#1}
\gdef\imtaUpperSectionNumber{\relax}
\gdef\imtaUpperSectionTitle{#1}
\global\@uppersectionprintedinLOFfalse
\global\@uppersectionprintedinLOTfalse}
\def\imtaExtraNoStarChapter[#1]#2{%
\imtaExtraOldChapter[{#1}]{#2}
\gdef\imtaUpperSectionNumber{\thechapter. }
\gdef\imtaUpperSectionTitle{#1}
\global\@uppersectionprintedinLOFfalse
\global\@uppersectionprintedinLOTfalse}
}
\makeatother
% \section
% \section is redefined, in order to update the upper section informations
\makeatletter
\@ifundefined{chapter}{%
\let\imtaExtraOldSection\section
\renewcommand{\section}{\@ifstar{\imtaExtraStarSection}{\@dblarg\imtaExtraNoStarSection}}
\newcommand\imtaExtraStarSection[1]{%
\imtaExtraOldSection*{#1} \gdef\imtaUpperSectionTitle{#1} \gdef\imtaUpperSectionNumber{\relax} \global\@uppersectionprintedinLOFfalse \global\@uppersectionprintedinLOTfalse}
\def\imtaExtraNoStarSection[#1]#2{%
\imtaExtraOldSection[{#1}]{#2} \gdef\imtaUpperSectionTitle{#1} \gdef\imtaUpperSectionNumber{\thesection. } \global\@uppersectionprintedinLOFfalse \global\@uppersectionprintedinLOTfalse}
}{%
\relax
}
\makeatother
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% E N V I R O N M E N T S %
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% imtaCode
% Format a listing of code
% The only argument of this environment is the language of the code to format
%% This environment wraps around minted, and is therefore a verbatim environment
\newenvironment{imtaCode}[1]{%
\VerbatimEnvironment%
\renewcommand{\theFancyVerbLine}{\texttt{\textcolor{gray!150}{\normalsize \oldstylenums{\arabic{FancyVerbLine}}}}}%
\vspace{0.5\baselineskip}%
\begin{mdframed}[backgroundcolor=imtaCodeLinenosFrame, innerrightmargin=0pt, innertopmargin=0pt, innerbottommargin=0pt, linewidth=1pt]
\begin{mdframed}[backgroundcolor=imtaCodeBackground, skipabove=0pt, skipbelow=0pt, rightmargin=0pt, leftmargin=3ex, linewidth=0pt,
innertopmargin=5pt, innerbottommargin=5pt, innerleftmargin=1ex]%
\begin{minted}[linenos, breaklines]{#1}%
}{
\end{minted}%
\end{mdframed}%
\end{mdframed}%
}
% imtaCodeFromFile{<file>}{<language>}
% Formats a listing of code from an input file
% Where <file> is the path to the file and <language> is the minted label
% for the corresponding language
\newcommand{\imtaCodeFromFile}[2]{% \VerbatimEnvironment%
\renewcommand{\theFancyVerbLine}{\texttt{\textcolor{gray!150}{\normalsize \oldstylenums{\arabic{FancyVerbLine}}}}}%
\vspace{0.5\baselineskip}%
\begin{mdframed}[backgroundcolor=imtaCodeLinenosFrame, innerrightmargin=0pt, innertopmargin=0pt, innerbottommargin=0pt, linewidth=1pt]
\begin{mdframed}[backgroundcolor=imtaCodeBackground, skipabove=0pt, skipbelow=0pt, rightmargin=0pt, leftmargin=3ex, linewidth=0pt,
innertopmargin=5pt, innerbottommargin=5pt, innerleftmargin=1ex]%
\inputminted[linenos, breaklines]{#2}{#1}
\end{mdframed}%
\end{mdframed}%
}
% imtaConsole
% Format a console session
\newenvironment{imtaConsole}{%
\VerbatimEnvironment%
\vspace{0.5\baselineskip}%
\begin{mdframed}[backgroundcolor=imtaCodeBackground, innerleftmargin=5pt]%
\begin{minted}[breaklines]{text}%
}{
\end{minted}%
\end{mdframed}%
}
% imtaConsoleFromFile{<file>}
% Formats a console session from an input file
% Where <file> is the path to the file
\newcommand{\imtaConsoleFromFile}[1]{%
\vspace{0.5\baselineskip}%
\begin{mdframed}[backgroundcolor=imtaCodeBackground, innerleftmargin=5pt]%
\inputminted[breaklines]{text}{#1}
\end{mdframed}%
}
%\figure
% The figure environment is redefined to update the LOF with the upper section title when relevant
\makeatletter
\def\printuppersectioninlof{%
\if@uppersectionprintedinLOF
\relax
\else
\if@printuppersectioninLOF
\if@chapterdefined
\addcontentsline{lof}{chapter}{\imtaUpperSectionNumber \imtaUpperSectionTitle}
\else
\addcontentsline{lof}{section}{\imtaUpperSectionNumber \imtaUpperSectionTitle}
\fi
\fi
\fi
\global\@uppersectionprintedinLOFtrue}
\let\imtaOldfigure\figure
\def\figure{\@ifnextchar{[}{\imtaFigurewarg}{\imtaFigurewotarg}}
\def\imtaFigurewarg[#1]{%
\imtaOldfigure[#1]\printuppersectioninlof}
\def\imtaFigurewotarg{%
\imtaOldfigure\printuppersectioninlof}
\makeatother
% \table
% The table environment is redefined to update the LOT with the upper section title when relevant
\makeatletter
\def\printuppersectioninlot{%
\if@uppersectionprintedinLOT
\relax
\else
\if@printuppersectioninLOT
\if@chapterdefined
\addcontentsline{lot}{chapter}{\imtaUpperSectionNumber \imtaUpperSectionTitle}
\else
\addcontentsline{lot}{section}{\imtaUpperSectionNumber \imtaUpperSectionTitle}
\fi
\fi
\fi
\global\@uppersectionprintedinLOTtrue}
\let\imtaOldtable\table
\def\table{\@ifnextchar{[}{\imtaTablewarg}{\imtaTablewotarg}}
\def\imtaTablewarg[#1]{%
\imtaOldtable[#1]\printuppersectioninlot}
\def\imtaTablewotarg{%
\imtaOldtable\printuppersectioninlot}
\makeatother
%%%%%%%%%% END %%%%%%%%%%
%%%%%%%%%%%%%%%%%%%%%%%%%