X-Git-Url: https://gapil.gnulinux.it/gitweb/?p=gapil.git;a=blobdiff_plain;f=session.tex;h=dbee21978dc0b1289126948d8f0e2716d19e03ef;hp=b53320ce2f6196f8a8a2088bd13b4b870d5ac2e9;hb=d47f15496fa85c8ec22edcde608f2665ec5b95ae;hpb=a051e3c3d3b403ee210274d8c2ec7d756c531a21 diff --git a/session.tex b/session.tex index b53320c..dbee219 100644 --- a/session.tex +++ b/session.tex @@ -1092,18 +1092,7 @@ ulteriori informazioni.\footnote{la definizione della struttura si trova in \begin{figure}[!htb] \footnotesize \centering \begin{minipage}[c]{15cm} - \begin{lstlisting}[stepnumber=0]{} -struct termios { - tcflag_t c_iflag; /* input modes */ - tcflag_t c_oflag; /* output modes */ - tcflag_t c_cflag; /* control modes */ - tcflag_t c_lflag; /* local modes */ - cc_t c_cc[NCCS]; /* control characters */ - cc_t c_line; /* line discipline */ - speed_t c_ispeed; /* input speed */ - speed_t c_ospeed; /* output speed */ -; - \end{lstlisting} + \includestruct{listati/termios.h} \end{minipage} \normalsize \caption{La struttura \structd{termios}, che identifica le proprietà di un @@ -1284,10 +1273,7 @@ della maschera, i valori da immettere infatti (quelli riportati nella spiegazione corrispondente) sono numerici e non per bit, per cui possono sovrapporsi fra di loro. Occorrerà perciò utilizzare un codice del tipo: -\begin{lstlisting}[stepnumber=0,frame=]{} - c_oflag &= (~CRDLY); - c_oflag |= CR1; -\end{lstlisting} +\includecodesnip{listati/oflag.c} \noindent che prima cancella i bit della maschera in questione e poi setta il valore. @@ -1556,9 +1542,7 @@ completo dei caratteri di controllo, con le costanti e delle funzionalit associate è riportato in \tabref{tab:sess_termios_cc}, usando quelle definizioni diventa possibile assegnare un nuovo carattere di controllo con un codice del tipo: -\begin{lstlisting}[stepnumber=0,frame=]{} - value.c_cc[VEOL2] = '\n'; -\end{lstlisting} +\includecodesnip{listati/value_c_cc.c} La maggior parte di questi caratteri (tutti tranne \const{VTIME} e \const{VMIN}) hanno effetto solo quando il terminale viene utilizzato in modo @@ -1651,30 +1635,11 @@ effettuano pi chiamata a \func{tcgetattr} che essi siano stati eseguiti tutti quanti. \begin{figure}[!htb] - \footnotesize - \begin{lstlisting}{} -#include -#include -#include - -int SetTermAttr(int fd, tcflag_t flag) -{ - struct termios values; - int res; - res = tcgetattr (desc, &values); - if (res) { - perror("Cannot get attributes"); - return res; - } - values.c_lflag |= flag; - res = tcsetattr (desc, TCSANOW, &values); - if (res) { - perror("Cannot set attributes"); - return res; - } - return 0; -} - \end{lstlisting} + \footnotesize \centering + \begin{minipage}[c]{15cm} + \includecodesample{listati/SetTermAttr.c} + \end{minipage} + \normalsize \caption{Codice della funzione \func{SetTermAttr} che permette di impostare uno dei flag di controllo locale del terminale.} \label{fig:term_set_attr} @@ -1703,33 +1668,18 @@ infine si scrive il nuovo valore modificato con \func{tcsetattr} o uscendo normalmente. \begin{figure}[!htb] - \footnotesize - \begin{lstlisting}{} -int UnSetTermAttr(int fd, tcflag_t flag) -{ - struct termios values; - int res; - res = tcgetattr (desc, &values); - if (res) { - perror("Cannot get attributes"); - return res; - } - values.c_lflag &= (~flag); - res = tcsetattr (desc, TCSANOW, &values); - if (res) { - perror("Cannot set attributes"); - return res; - } - return 0; -} - \end{lstlisting} + \footnotesize \centering + \begin{minipage}[c]{15cm} + \includecodesample{listati/UnSetTermAttr.c} + \end{minipage} + \normalsize \caption{Codice della funzione \func{UnSetTermAttr} che permette di rimuovere uno dei flag di controllo locale del terminale.} \label{fig:term_unset_attr} \end{figure} La seconda funzione, \func{UnSetTermAttr}, è assolutamente identica alla -prima, solo che in questo caso (in \texttt{\small 15}) si rimuovono i bit +prima, solo che in questo caso, in (\texttt{\small 15}), si rimuovono i bit specificati dall'argomento \param{flag} usando un AND binario del valore negato.