File: features.tex

package info (click to toggle)
lorene 0.0.0~cvs20161116%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 26,472 kB
  • sloc: cpp: 212,946; fortran: 21,645; makefile: 1,750; sh: 4
file content (122 lines) | stat: -rw-r--r-- 4,731 bytes parent folder | download | duplicates (2)
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
\documentclass[12pt]{article}

\begin{document}
\begin{center}
\bf \LARGE Some features of {\sc Lorene 2}
\end{center}

\vspace{1cm}

\section{Encapsulation}

(Most of) all data are encapsulated, i.e. one cannot have access to
member data of an object (it is declared {\tt protected} or
{\tt private} in the class definition).
The access to data is performed by member functions {\tt get\_xxx()}
for read-only of data or {\tt set\_xxx()} for modifying the data.
Some read-only is also performed via the {\tt operator()}, e.g.
{\tt a(2)} to read the element no. 2 of the {\tt Tbl a}.

The advantage of encapsulation is a safe handling of the
dependencies among the data. Indeed invoquing the function
{\tt set\_xxx()} will not only modify the data {\tt xxx}, but will
modify accordingly all the data or objects which depend on {\tt xxx}.


\section{Const-correctness}

{\sc Lorene} is const-correct, i.e. the constancy
of objects is systematically specified, by mean of the C++ qualifier
{\tt const}:
\begin{itemize}
\item {\tt A::f(const B\& b)} : the member function {\tt f} of class
{\tt A} does not modify its argument {\tt b}.
\item {\tt A::f() const} : the member function {\tt f} of class {\tt A}
does not modify the object for which it is invoqued.
\item {\tt const B\& A::get\_xxx() const} : the member function
{\tt get\_xxx} of class {\tt A} returns a reference on a constant object
of class {\tt B} (representing the data {\tt xxx}); this
function thus cannot be used to modify the object {\tt A}, hence the
second qualifier {\tt const}.
\end{itemize}

\section{Construction of objects}

There are at least 3 ways to create a {\sc Lorene} object, corresponding
to 3 types of C++ constructors:
\begin{itemize}
\item Constructor from scratch (in {\sc Lorene} terminology,
{\em standard constructor}), i.e. using the basic informations
to set up an object; for example: {\tt Tbl a(5) ;} (construction of a
{\tt Tbl} of dimension 5).
\item Constructor from copy of a pre-existing object of same class;
for example: {\tt Tbl b = a ; } (construction of a {\tt Tbl b} which is
identical to {\tt a}).
\item Constructor from a file; for example: {\tt Tbl c(file) ;}
(where {\tt file} is pointer (of C type {\tt FILE*}) towards a
file where a {\tt Tbl} has been written before, via the function
{\tt Tbl::sauve}).
\end{itemize}
In addition, there exists some constructors {by conversion} of
a object from a different class, for example
{\tt Mtbl::Mtbl(const Coord\& )}, but these are pretty rare and
most of single argument constructors are protected against
automatic type conversion from the compiler by the C++
qualifier {\tt explicit}.


\section{Object states}

Most of {\sc Lorene} objects can exist under three states:

\begin{itemize}
\item {\bf undefined state} ({\tt ETATNONDEF}) :
this states generally results from the creation of the object from
scratch (via the so-called {\em standard constructor}).
\item {\bf zero state} ({\tt ETATZERO}) : the object has the value zero.
\item {\bf ordinary state} ({\tt ETATQCQ}) : the object has a well
defined value, different from zero.
\end{itemize}

In the undefined and zero states, no memory allocation is performed for
the object data. The switch to the ordinary state and the
memory allocation is performed by the method {\tt set\_etat\_qcq()}.
This method is automatically invoqued when necessary
in all global manipulations, such as the the assignment to another
object. However, for efficiency purpose, the function {\tt set\_etat\_qcq()}
is not called by functions of the type {\tt set\_xxx()}.
It should be thus call by hand prior to {\tt set\_xxx()}. For example:
{\tt
\begin{verbatim}
Tbl a(5) ;            // creation of an array of size 5 :
                      //    state = undefined
a.set_etat_qcq() ;      // switches the state to ordinary and
                        //    performs the memory allocation
                        //    for the array elements
a.set(0) = 1 ; 		// OK
\end{verbatim}
}


\section{Input/output}

Most of all {\sc Lorene} objects can be displayed on the
screen, or in a formatted file, by means of the {\tt operator<<}.
For example: {\tt cout << a << endl ;} where {\tt a} is some
{\sc Lorene} object.


Most of all {\sc Lorene} objects can by written in (binary) files
by means of the member function {\tt sauve(FILE* )}.
The reverse operation is possible, i.e. for most all classes
there exists a constructor from a file.

The graphical display is ensured by means of functions
based on the PGPLOT library (2-D drawings) or
formatting data for 3-D visualization via Iris Explorer (NAG).
These functions are not member functions of any class
to ensure full portability of the non-graphical part of
{\sc Lorene}.


\end{document}