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(); } }