3 %% Copyright (C) 2000-2012 Simone Piccardi. Permission is granted to
4 %% copy, distribute and/or modify this document under the terms of the GNU Free
5 %% Documentation License, Version 1.1 or any later version published by the
6 %% Free Software Foundation; with the Invariant Sections being "Un preambolo",
7 %% with no Front-Cover Texts, and with no Back-Cover Texts. A copy of the
8 %% license is included in the section entitled "GNU Free Documentation
13 % Defining some special character for use inside typewriter
14 % text without using the verbatim environment
17 \def\bslash{\char'134}
18 \def\circonf{\char'136}
21 \newcommand{\includecodesnip}[1]{\lstinputlisting[stepnumber=0,xleftmargin=\parindent,frame=]{#1}}{}
22 \newcommand{\includestruct}[1]{\lstinputlisting[stepnumber=0]{#1}}{}
23 \newcommand{\includecodesample}[1]{\lstinputlisting{#1}}{}
26 % Defining some commands to manipulate counter to avoid ude of
27 % \label and \ref commands (and related problem to remeber the
28 % used labels) to refer nearest objects
31 \newcounter{usercount} % define a new counter for internal use
35 \newcommand{\cureq}{(\theequation)}
37 \setcounter{usercount}{\value{equation}}%
38 \addtocounter{usercount}{1}%
39 (\thechapter.\theusercount)}
41 \setcounter{usercount}{\value{equation}}%
42 \addtocounter{usercount}{-1}%
43 (\thechapter.\theusercount)}
45 % Macro to put picture (in format PICT) inside a figure
47 \newcommand{\pictfig}[3]{
48 \begin{minipage}[t][#1][b]{#2}
49 \mbox{\special{pict=#3}}
54 % Macro to create a special environment for function prototypes
57 \newenvironment{prototype}[2]
58 {% defining what is done by \begin
61 \begin{boxedminipage}[c]{14cm}
63 \begin{description*}{}{}
64 \item \texttt{\#include <#1>}
65 \item \texttt{#2} \par
66 % \begin{lstlisting}{}
71 {% defining what is done by \end
80 \newenvironment{errlist}{\begin{basedescript}{\desclabelwidth{1.0cm}}}
83 % Slighty different environment to be used for multi-header,
84 % multi-functions boxed description
86 \newcommand{\headdecl}[1]{\item\texttt{\#include <#1>}}
87 \newcommand{\funcdecl}[1]{\item\texttt{#1}\par}
88 \newcommand{\bodydesc}[1]{\par \end{description*} #1
89 \begin{description*}{}{} \baselineskip=0pt
93 \newenvironment{functions}
94 {% defining what is done by \begin
97 \begin{boxedminipage}[c]{14cm}
99 \begin{description*}{}{}
101 {% defining what is done by \end
111 % Wrapper for shell command, functions, filenames, links,
112 % variables, macros, and everything can be useul,
114 \newcommand{\cmd}[1]{\texttt{#1}} % shell command
115 \newcommand{\code}[1]{\texttt{#1}} % for simple code
117 \newcommand{\func}[1]{%
118 \index{funzione!{#1}@{{\tt {#1}}}}\texttt{#1}%
119 %\index{#1@{{\tt {#1}} (funzione)}}\texttt{#1}%
122 \newcommand{\funcd}[1]{%
123 \index{funzione!{#1}@{{\tt {#1}}}!definizione di}\texttt{#1}%
124 %\index{#1@{{\tt {#1}} (funzione)}!definizione di}\texttt{#1}%
126 \newcommand{\funcm}[1]{%
127 \index{funzione!{#1}@{{\tt {#1}}}!menzione di}\texttt{#1}%
128 %\index{#1@{{\tt {#1}} (funzione)}!definizione di}\texttt{#1}%
131 \newcommand{\macro}[1]{%
132 \index{macro!{#1}@{{\tt {#1}}}}\texttt{#1}%
133 %\index{#1@{{\tt {#1}} (macro)}}\texttt{#1}%
136 \newcommand{\errcode}[1]{%
137 \index{errore!{#1}@{{\tt {#1}}}}\texttt{#1}%
138 %\index{#1@{{\tt {#1}} (errore)}}\texttt{#1}%
141 \newcommand{\errval}[1]{\texttt{#1}} % value
142 \newcommand{\var}[1]{\texttt{#1}} % variable
143 \newcommand{\val}[1]{\texttt{#1}} % value
145 \newcommand{\signal}[1]{%
146 \index{segnale!{#1}@{{\tt {#1}}}}\texttt{#1}%
147 %\index{#1@{{\tt {#1}} (costante)}}\texttt{#1}%
150 \newcommand{\const}[1]{%
151 \index{costante!{#1}@{{\tt {#1}}}}\texttt{#1}%
152 %\index{#1@{{\tt {#1}} (costante)}}\texttt{#1}%
155 \newcommand{\instruction}[1]{%
156 \index{istruzione linguaggio C!{#1}@{{\tt {#1}}}}\texttt{#1}%
157 %\index{#1@{{\tt {#1}} (direttiva)}}\texttt{#1}%
160 \newcommand{\direct}[1]{%
161 \index{direttiva linguaggio C!{#1}@{{\tt {#1}}}}\texttt{#1}%
162 %\index{#1@{{\tt {#1}} (direttiva)}}\texttt{#1}%
165 \newcommand{\file}[1]{\texttt{#1}} % file name
166 \newcommand{\link}[1]{\texttt{#1}} % html link
167 \newcommand{\ctyp}[1]{\texttt{#1}} % C standard type
169 \newcommand{\headfile}[1]{%
170 %\index{file!include!{#1}@{{\tt {#1}}}}\texttt{#1}%
174 \newcommand{\procfile}[1]{%
175 \index{file!filesystem~\texttt{/proc}!{#1}@{{\tt {#1}}}}\texttt{#1}%
176 %\index{#1@{{\tt {#1}} (direttiva)}}\texttt{#1}%
178 \newcommand{\sysfile}[1]{%
179 \index{file!di~sistema!{#1}@{{\tt {#1}}}}\texttt{#1}%
180 %\index{#1@{{\tt {#1}} (direttiva)}}\texttt{#1}%
182 \newcommand{\conffile}[1]{%
183 \index{file!di~configurazione!{#1}@{{\tt {#1}}}}\texttt{#1}%
184 %\index{#1@{{\tt {#1}} (direttiva)}}\texttt{#1}%
185 } % configuration file name
186 \newcommand{\procrelfile}[2]{%
187 \index{file!filesystem~\texttt{/proc}!{#1/#2}@{{\tt {#1/#2}}}}\texttt{#2}%
188 %\index{#1@{{\tt {#1}} (direttiva)}}\texttt{#1}%
191 \newcommand{\sysctlfile}[1]{%
192 \index{file!file di controllo (sotto \texttt{/proc/sys})!{#1}@{{\tt {#1}}}}\texttt{/proc/sys/#1}%
193 %\index{#1@{{\tt {#1}} (direttiva)}}\texttt{#1}%
194 } % /proc/sys file name
196 \newcommand{\sysctlrelfile}[2]{%
197 \index{file!file di controllo (sotto \texttt{/proc/sys})!{#1/#2}@{{\tt {#1/#2}}}}\texttt{#2}%
198 %\index{#1@{{\tt {#1}} (direttiva)}}\texttt{#1}%
199 } % /proc/sys file name
202 \newcommand{\kstruct}[1]{%
203 \index{struttura dati del kernel!{#1}@{{\tt {#1}}}}\texttt{#1}%
204 %\index{#1@{{\tt {#1}} (struttura dati)}}\texttt{#1}%
206 \newcommand{\kstructd}[1]{%
207 \index{struttura dati del kernel!{#1}@{{\tt {#1}}}!definizione di}\texttt{#1}%
208 %\index{#1@{{\tt {#1}} (struttura dati)}!definizione di}\texttt{#1}%
210 \newcommand{\type}[1]{%
211 \index{tipo di dato!{#1}@{{\tt {#1}}}}\texttt{#1}%
212 %\index{#1@{{\tt {#1}} (tipo)}}\texttt{#1}%
214 \newcommand{\struct}[1]{%
215 \index{struttura dati!{#1}@{{\tt {#1}}}}\texttt{#1}%
216 %\index{#1@{{\tt {#1}} (struttura dati)}}\texttt{#1}%
218 \newcommand{\structd}[1]{%
219 \index{struttura dati!{#1}@{{\tt {#1}}}!definizione di}\texttt{#1}%
220 %\index{#1@{{\tt {#1}} (struttura dati)}!definizione di}\texttt{#1}%
222 \newcommand{\param}[1]{\texttt{#1}} % function parameter
223 \newcommand{\acr}[1]{\textsl{#1}} % acrostic (for glibc, ext2, ecc.)
225 \newcommand{\ids}[1]{\textsl{#1}} % Identifier (PID, GID, UID, TID, ecc.)
226 \newcommand{\envvar}[1]{\texttt{#1}} % environment variable
227 \newcommand{\samplefunc}[1]{\texttt{#1}} % funzione degli esempi
229 \newcommand{\itindex}[1]{%
230 \index{#1@{\textit{#1}}}%
233 \newcommand{\itindbeg}[1]{%
234 \index{#1@{\textit{#1}}|(}%
236 \newcommand{\itindend}[1]{%
237 \index{#1@{\textit{#1}}|)}%
239 \newcommand{\itindsub}[2]{%
240 \index{#1@{\textit{#1}}!\textit{#2}}%
243 % Aggiunte di Mirko per la gestione delle tabelle complicate come immagini
244 % nella traslazione in HTML
245 \newenvironment{usepicture}{}{}{}{}
248 % Macro di definizione di alcune lunghezze usate per le formattazioni
250 \newlength{\codesamplewidth}
251 \setlength{\codesamplewidth}{0.95\textwidth}
253 \newlength{\funcboxwidth}
254 \setlength{\funcboxwidth}{0.85\textwidth}
258 % Nuove macro per diversa formattazione delle definizioni delle funzioni
260 \newcommand{\fhead}[1]{\texttt{\#include <#1>}\par}
261 \newcommand{\fdecl}[1]{\texttt{#1}\par}
262 \newcommand{\fdesc}[1]{\hfill{#1}\par}
264 \newenvironment{funcproto}[2]
265 {% defining what is done by \begin
274 {% defining what is done by \end
280 \newenvironment{funcbox}
281 {% defining what is done by \begin
283 \begin{boxedminipage}[c]{\funcboxwidth}
286 {% defining what is done by \end
297 %%% TeX-master: "gapil"