using System;
using System.Collections.Generic;
using System.IO;
using System.Xml.Serialization;
///
/// Représente un gestionnaire de sauvegarde et de lecture d'un ou plusieurs Syllabaires pour l'application en exposant des méthodes permettant de gérer des fichiers XML représentant des Syllabaires.
///
public class SyllabaryIoManager : FileIoManager {
///
/// Représente le dossier local applicatif et utilisateur.
///
public String UserAppData = Environment.GetFolderPath(Environment.SpecialFolder.LocalApplicationData);
///
/// Sauvegarde le Syllabaire dans un fichier a l'emplacement indiqué. Utilise le titre comme nom de fichier.
///
/// Le sillabraire à sauvegarder dans un fichier XML
/// L'emplacement du dossier dans lequel ce Syllabaire sera créé. Si l'URI est un fichier, son nom est utilisé à la place du titre du Syllabaire.
public void saveSyllabary(Syllabary thisSyllabary, Uri thisFolder) {
XmlSerializer xs = new XmlSerializer(typeof(Syllabary));
using (StreamWriter wr = new StreamWriter(thisFolder.AbsolutePath)) {
xs.Serialize(wr, thisSyllabary);
}
}
///
/// Charge le Syllabaire depuis le fichier précisé
///
/// L'emplacement du fichier XML représentant un Syllabaire
public Syllabary loadSyllabary(Uri thisSillabaryFile) {
XmlSerializer xs = new XmlSerializer(typeof(Syllabary));
using (StreamReader sr = new StreamReader(thisSillabaryFile.AbsolutePath)) {
Syllabary mySylla = xs.Deserialize(sr) as Syllabary;
return mySylla;
}
}
///
/// Charge l'ensemble des fichier Syllabaire depuis le dossier précisé
///
/// L'emplacement du dossier dans lequel les Syllabaires seront chargés.
public List loadAllSyllabaries(Uri thisFolder) {
throw new System.NotImplementedException();
}
///
/// Sauvegarde l'ensemble des objets Syllabaires spécifiés à l'emplacement spécifié.
///
/// La liste des Syllabaires à sauvegarder dans des fichiers XML.
/// L'emplacement du dossier dans lequel les Syllabaires seront créés.
public void saveAllSyllabaries(List thosesSillabaries, Uri thisFolder) {
throw new System.NotImplementedException();
}
}