Documentation de la bibliothèque MLV-1.2.1

Définitions de type | Énumérations | Fonctions
Référence du fichier MLV_xml.h

Ce fichier définit les prototypes des fonctions permettant de lire des fichiers xml. Plus de détails...

Aller au code source de ce fichier.

Définitions de type

typedef struct _MLV_Xml MLV_Xml
 Définit le type de donnée stockée au format xml dans la bibliothèque MLV.

Énumérations

enum  MLV_Xml_error {
  MLV_XML_NONE, MLV_XML_THE_FIELD_DOESNT_EXIST, MLV_XML_THE_FIELD_IS_NOT_A_REAL, MLV_XML_THE_FIELD_IS_NOT_AN_INTEGER,
  MLV_XML_THE_FIELD_IS_TOO_BIG
}
 Énumère les différents codes d'erreurs que l'on peut rencontrer lorsque l'ordinateur lit un document xml. Plus de détails...

Fonctions

MLV_XmlMLV_load_xml (const char *xml_file_path)
 Charge en mémoire un fichier au format xml.
void MLV_free_xml (MLV_Xml *xml_data)
 Libère la mémoire utilisée par les données du fichier xml.
MLV_Xml_error MLV_get_string_value_from_xml (const MLV_Xml *xml_data, char **result, const char *xpath,...)
 Permet d'accéder à l'interieur d'un champs donné du fichier xml.
MLV_Xml_error MLV_get_integer_value_from_xml (const MLV_Xml *xml_data, int *result, const char *xpath,...)
 Permet de récupérer l'entier d'un champs donné du fichier xml.
MLV_Xml_error MLV_get_double_value_from_xml (const MLV_Xml *xml_data, double *result, const char *xpath,...)
 Permet de récupérer le reel d'un champs donné du fichier xml.
MLV_Xml_error MLV_get_float_value_from_xml (const MLV_Xml *xml_data, float *result, const char *xpath,...)
 Permet de récupérer le réel d'un champs donné du fichier xml.
int MLV_get_number_of_objects_from_xml (const MLV_Xml *xml_data, const char *xpath,...)
 Compte le nombre d'objets présents dans le fichier xml verifiant un certain nombre de critères passés en paramètre de la fonction.
MLV_XmlMLV_get_xml_object_of (const MLV_Xml *xml_data, const char *xpath,...)
 Permet de récupérer un noeud interne de l'arbre représentant le fichier XML.
void MLV_print_xml (const MLV_Xml *xml_data)
 Écrit sur le terminal le contenu d'un fichier xml.

Description détaillée

Ce fichier définit les prototypes des fonctions permettant de lire des fichiers xml.

Auteur
Adrien Boussicault
Marc Zipstein

Les fichiers xml sont utilisés pour stocker les données nécessaires au fonctionnement d'un programme. Ils permettent de modifier facilement l'exécution du programme sans avoir à le modifier. En effet, ils sont lisibles par l'homme et par la machine en même temps. Ils constituent donc une interface pratique entre l'ordinateur et l'utilisateur.

Documentation du type de l'énumération

Énumère les différents codes d'erreurs que l'on peut rencontrer lorsque l'ordinateur lit un document xml.

Valeurs énumérées:
MLV_XML_NONE 

Aucune erreur detectée.

MLV_XML_THE_FIELD_DOESNT_EXIST 

Le champs n'existe pas dans le document xml.

MLV_XML_THE_FIELD_IS_NOT_A_REAL 

Le champs ne contient pas une chaîne de caractères codant un reel.

MLV_XML_THE_FIELD_IS_NOT_AN_INTEGER 

Le champs ne contient pas un chaîne de caractères codant un entier.

MLV_XML_THE_FIELD_IS_TOO_BIG 

La chaîne code un réel/entier trop long pour être stocké dans la variable.

Documentation des fonctions

void MLV_free_xml ( MLV_Xml xml_data)

Libère la mémoire utilisée par les données du fichier xml.

Paramètres
xml_dataLes données xml a supprimer.
Exemples:
advanced/10_read_xml_file.c.
MLV_Xml_error MLV_get_double_value_from_xml ( const MLV_Xml xml_data,
double *  result,
const char *  xpath,
  ... 
)

Permet de récupérer le reel d'un champs donné du fichier xml.

Tout comme la fonction MLV_get_string_value_from_xml(), cette fonction peut contenir un nombre variable de paramètres. Pour plus d'informations, veuillez lire la documentation de la fonction MLV_get_string_value_from_xml().

Paramètres
xml_dataLes données xml.
resultUn pointeur vers un réel dans lequel le résultat de la fonction sera enregistré.
xpathLe chemin d'accès.
Renvoie
renvoie un code d'erreur (voir MLV_Xml_error) si la fonction n'a pas reussie à extraire la donnée souhaitée du document xml.
Exemples:
advanced/10_read_xml_file.c.
MLV_Xml_error MLV_get_float_value_from_xml ( const MLV_Xml xml_data,
float *  result,
const char *  xpath,
  ... 
)

Permet de récupérer le réel d'un champs donné du fichier xml.

Tout comme la fonction MLV_get_string_value_from_xml(), cette fonction peut contenir un nombre variable de paramètres. Pour plus d'informations, veuillez lire la documentation de la fonction MLV_get_string_value_from_xml().

Paramètres
xml_dataLes données xml.
resultUn pointeur vers un réel dans lequel le résultat de la fonction sera enregistré.
xpathLe chemin d'accès.
Renvoie
renvoie un code d'erreur (voir MLV_Xml_error) si la fonction n'a pas reussie à extraire la donnée souhaitée du document xml.
MLV_Xml_error MLV_get_integer_value_from_xml ( const MLV_Xml xml_data,
int *  result,
const char *  xpath,
  ... 
)

Permet de récupérer l'entier d'un champs donné du fichier xml.

Tout comme la fonction MLV_get_string_value_from_xml(), cette fonction peut contenir un nombre variable de paramètres. Pour plus d'informations, veuillez lire la documentation de la fonction MLV_get_string_value_from_xml().

Paramètres
xml_dataLes données xml.
resultUn pointeur vers un entier dans lequel le résultat de la fonction sera enregistré.
xpathLe chemin d'accès.
Renvoie
renvoie un code d'erreur si la fonction n'a pa reussie à extraire la donnée souhaitée du document xml.
Exemples:
advanced/10_read_xml_file.c.
int MLV_get_number_of_objects_from_xml ( const MLV_Xml xml_data,
const char *  xpath,
  ... 
)

Compte le nombre d'objets présents dans le fichier xml verifiant un certain nombre de critères passés en paramètre de la fonction.

Paramètres
xml_dataLes données xml.
xpathLe chemin d'accès.
...Les paramètres de la fonction.
Renvoie
Cette fonction renvoie le nombre d'objet ayant pour chemin d'accès "xpath".
Exemples:
advanced/10_read_xml_file.c.
MLV_Xml_error MLV_get_string_value_from_xml ( const MLV_Xml xml_data,
char **  result,
const char *  xpath,
  ... 
)

Permet d'accéder à l'interieur d'un champs donné du fichier xml.

Cette fonction peut contenir un nombre variable de paramètres. Comme avec la fonction printf les paramètres suplémentaires, situées après le paramètre xpath, permettent de construire des requêtes xpath évolué.

Par exemple,

int id_batiment = 2;
char * type_salle = "informatique"
int id_salle = 4;
char* nom_salle;
xml_data, &(nom_salle),
"/batiment[%d]/salle[type=%s][%d]/nom",
id_batiment, type_salle, id_salle
)
free( nom_salle ); // on oublie pas de libérer la mémoire après avoir
// utilisé nom_salle

permet de recupérer le contenu du champs "nom" situé dans la 4eme salle informatique du 2eme batiment.

Attention: Il ne faut pas oublier de libérer la mémoire associée au champs result.

Paramètres
xml_dataLes données xml.
resultUn pointeur vers une addresse vide qui contiendra l'addresse de la chaîne de caractères correspondant au résultat de la fonction.
xpathLe chemin d'accès.
Renvoie
renvoie un code d'erreur si la fonction n'a pa reussie à extraire la donnée souhaitée du document xml.
Exemples:
advanced/10_read_xml_file.c.
MLV_Xml* MLV_get_xml_object_of ( const MLV_Xml xml_data,
const char *  xpath,
  ... 
)

Permet de récupérer un noeud interne de l'arbre représentant le fichier XML.

Cette fonction n'est pas encore implémentée.

Paramètres
xml_dataLes données xml.
xpathLe chemin d'accès.
...Les paramètres de la fonction.
Renvoie
Un noeud interne de l'arbre XML.
MLV_Xml* MLV_load_xml ( const char *  xml_file_path)

Charge en mémoire un fichier au format xml.

Cette fonction renvoi NULL, lorsque le fichier n'a pas pu être correctement chargé.

Paramètres
xml_file_pathChemin d'accès du fichier xml.
Renvoie
Le fichier xml lu, analysé et chargé.
Exemples:
advanced/10_read_xml_file.c.
void MLV_print_xml ( const MLV_Xml xml_data)

Écrit sur le terminal le contenu d'un fichier xml.

Cette fonction n'est pas encore implémentée.

Paramètres
xml_dataLes données xml.
...Les paramètres de la fonction.