#ifndef M2Datei_H
#define M2Datei_H

#include "Array.h"

namespace Framework
{
    class Model2DData; //! Model2D.h
    class Text;        //! Text.h

    //! Diese Klasse verwaltet das Framework eigenen Dateivormat f�r 2D Modell
    //! Daten Es k�nnen mehrere 2D Modell Daten in einer Datei gespeichert
    //! werden
    class M2Datei : public virtual ReferenceCounter
    {
    private:
        Text* pfad;
        RCArray<Text>* modelName;
        Array<__int64>* modelPos;

    public:
        //! Konstruktor
        DLLEXPORT M2Datei();
        //! Konstruktor
        //! \param pfad Der Pfad zur Datei
        DLLEXPORT M2Datei(const char* pfad);
        //! Konstruktor
        //! \param pfad Der Pfad zur Datei
        DLLEXPORT M2Datei(Text* pfad);
        //! Destruktor
        DLLEXPORT ~M2Datei();
        //! Setzt den Pfad zur Datei
        //! \param pfad Pfad zur Datei
        DLLEXPORT void setPfad(const char* pfad);
        //! Setzt einen Zeiger auf den Pfad zur Datei
        //! \param pfad Zeiger auf den Pfad zur Datei
        DLLEXPORT void setPfadZ(Text* pfad);
        //! Lie�t grundlegende Informationen aus der Datei, die f�r ihre
        //! Verwendung ben�tigt werden
        DLLEXPORT void leseDaten();
        //! Speichert 2D Modell Daten in der Datei
        //! \param zMdr Ein Zeiger auf die zu speichernden Daten ohne erh�htem
        //! Reference Counter \param name Der Name, unter dem die Daten in der
        //! Datei gespeichert werden sollen \return 1, falls das Modell
        //! gespeichert wurde. 0, falls ein fehler beim speichern auftrat
        DLLEXPORT bool saveModel(Model2DData* zMdr, Text* name);
        //! Speichert 2D Modell Daten in der Datei
        //! \param zMdr Ein Zeiger auf die zu speichernden Daten ohne erh�htem
        //! Reference Counter \param name Der Name, unter dem die Daten in der
        //! Datei gespeichert werden sollen \return 1, falls das Modell
        //! gespeichert wurde. 0, falls ein fehler beim speichern auftrat
        DLLEXPORT bool saveModel(Model2DData* zMdr, const char* name);
        //! L�scht ein 2D Modell aus der Datei
        //! \param name Der Name des Modells
        //! \return 1, wenn das Modell gel�scht wurde. 0, wenn das Modell nicht
        //! gefunden wurde, oder ein fehler beim speichern auftrat
        DLLEXPORT bool removeModel(Text* name);
        //! L�scht ein 2D Modell aus der Datei
        //! \param name Der Name des Modells
        //! \return 1, wenn das Modell gel�scht wurde. 0, wenn das Modell nicht
        //! gefunden wurde, oder ein fehler beim speichern auftrat
        DLLEXPORT bool removeModel(const char* name);
        //! L�hd ein 2D Modell aus der Datei
        //! \param name Der name des zu ladenden Modells
        //! \return Die geladenen Daten
        DLLEXPORT Model2DData* ladeModel(Text* name) const;
        //! L�hd ein 2D Modell aus der Datei
        //! \param name Der name des zu ladenden Modells
        //! \return Die geladenen Daten
        DLLEXPORT Model2DData* ladeModel(const char* name) const;
        //! �berprft, ob ein bestimmtes 2D Modell in der Datei existiert
        //! \param name Der Name des zu suchenden 2D Modells
        //! \return 1, wenn das Modell gefunden wurde. 0 sonst
        DLLEXPORT bool hatModel(const char* name) const;
        //! �gibt die Anzahl der gespeicherten Modelle zur�ck
        DLLEXPORT int getModelAnzahl() const;
        //! Gibt den Namen eines Bestimmten Modells zur�ck
        //! \param i Der Index des Modells
        //! \return Ein Zeiger aud den Namen des Modells ohne erh�hten Reference
        //! Counter
        DLLEXPORT Text* zModelName(int i) const;
    };
} // namespace Framework

#endif