Hash :
94046104
Author :
Thomas de Grivel
Date :
2020-02-24T15:19:27
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
\chapter{Noyau}
\section{Gestion des donn\'ees}
\label{noyau_donnees}
La gestion des donn\'ees a \'et\'e compl\`etement chang\'ee pour
pouvoir connaitre la taille des donn\'ees et g\'erer les tableaux.
On distinguera d\'esormais un bloc de donn\'ees d'un segment de donn\'ees.\\
Un bloc de donn\'ees est en fait une union de la taille d'un int (32 bits)
o\`u l'on peut donc mettre 4 {\tt char}, 2 {\tt short} ou 1 {\tt long},
sign\'es ou non.
L'union incluait pr\'ec\'edemment un {\tt long long} qui amenait la taile
\`a 64 bits, taille moins adapt\'ee aux processeurs actuels. Nous avons donc
supprim\'e ce champ, puisqu'il est possible de g\'erer des segments de plus
d'un bloc.\\
Un segment de donn\'ees est un tableau de blocs.
Le premier bloc indique le nombre de blocs suivants,
donc si le nombre de blocs est z\'ero le segment comporte un seul bloc,
si le nombre de blocs est 1, le segment contient 2 blocs au total.\\
Cela nous permet de g\'erer des tableaux ainsi que des types structur\'es
plus complexes. Auparavant il \'etait possible de metre un pointeur
dans l'union mais du coup il \'etait impossible de connaitre
la taille des donn\'ees point\'ees.\\
Il \'etait n\'ecessaire de connaitre la taille des donn\'ees pour le cluster,
car celui-ci devra transferer des donn\'ees d'un ordinateur
\`a l'autre. Cela pourra \'egalement servir \`a s\'erialiser les donn\'ees
dans un flux et \`a les lire, sans avoir a faire une fonction pour chaque
type de donn\'ees.\\
Nous avons donc du mettre \`a jour la librairie des patchs standard
pour qu'elle utilise les nouveaux types de don\'ees, c'est \`a dire r\'ecrire
toutes les macros pour chaque type (float, int, {\em etc.}), et adapter
chaque patch pour qu'ils utilisent correctement les nouvelles macros.\\
\newpage
Cette nouvelle gestion des donn\'ees a donc demand\'e du travail,
mais donne beaucoup plus de puissance et de possibilit\'es puisque
l'on connait et qu'on peut faire varier leur taille, y mettre un tableau
ou m\^eme une structure. \\
Cette nouvelle m\'ethode ressemble beaucoup \`a la gestion
des variables dans Objective CAML, r\'ef\'erence s\^ure.\\
\section{Exportation en XML}
Il est d\'esormais possible d'exporter un patchwork dans un fichier XML,
cela grace \`a la librairie {\tt libxml2}.
Une fonction d'exportation est disponible pour chaque objet du noyau :
patchwork, patch\_class, patch, input, output, data\_type, data\ldots\\
Le lien avec l'interface graphique est fait : la commande ``sauvegarder''
dans le menu de la fenetre d'un patchwork permet de s\'electionner
un nom de fichier et exporte le patchwork en XML.\\
L'importation \`a partir d'un XML est pr\'evue pour la prochaine soutenance.
Ces deux fonctionnalit\'es n'\'etaient pas pr\'evues dans le cahier
des charges mais nous avons trouv\'e qu'elles \'etaient un \'el\'ement
important pour pouvoir tester et utliser le projet.\\