Datei.h 9.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197
  1. #ifndef Datei_H
  2. #define Datei_H
  3. #include "Array.h"
  4. #include <fstream>
  5. namespace Framework
  6. {
  7. class Text; // Text.h
  8. class Zeit; // Zeit.h
  9. namespace Encryption
  10. {
  11. class Key; // Schlüssel.h
  12. }
  13. class Datei; // aus dieser Datei
  14. // Ließt und schreibt in eine Datei
  15. class Datei
  16. {
  17. public:
  18. class Style
  19. {
  20. public:
  21. const static int lesen = 0x01; // datei wird zum lesen geöffnet
  22. const static int schreiben = 0x02; // datei wirt zum schreiben geöffnet
  23. const static int ende = 0x04; // setzt dateizeiger ans Ende der Datei
  24. };
  25. private:
  26. int ref;
  27. std::fstream *stream;
  28. Text *pfad;
  29. __int64 gr;
  30. char tmpLByte;
  31. char tmpLBPos;
  32. char tmpSByte;
  33. char tmpSBPos;
  34. Encryption::Key *key;
  35. public:
  36. // Konstruktor
  37. __declspec( dllexport ) Datei();
  38. // Destruktor
  39. __declspec( dllexport ) ~Datei();
  40. // Setzt den Pfad zur Datei
  41. // pfad: Der Pfad
  42. __declspec( dllexport ) void setDatei( const char *pfad );
  43. // Setzt den Pfad zur Datei
  44. // pfad: Der Pfad
  45. __declspec( dllexport ) void setDatei( Text *pfad );
  46. // Benennt die Datei um oder verschiebt sie
  47. // pfad: Der neue Pfad zur Datei. Wenn sich nur der Name ändert, wird sie nur umbenannt
  48. // return: 1, wenn das umbenennen erfolgreich war. 0, sonst
  49. __declspec( dllexport ) bool umbenennen( const char *pfad );
  50. // Benennt die Datei um oder verschiebt sie
  51. // pfad: Der neue Pfad zur Datei. Wenn sich nur der Name ändert, wird sie nur umbenannt
  52. // return: 1, wenn das umbenennen erfolgreich war. 0, sonst
  53. __declspec( dllexport ) bool umbenennen( Text *pfad );
  54. // Löscht die Datei
  55. // return: 1, wenn das löschen erfolgreich war. 0 sonst
  56. __declspec( dllexport ) bool remove();
  57. // Erstellt die Datei neu. Wenn im Pfad Ordner vorkommen, die nicht existieren, so werden sie erstellt
  58. // return 1: wenn das erstellen erfolgreich war. 0, sonst
  59. __declspec( dllexport ) bool erstellen();
  60. // Öffnet die Datei
  61. // style: Legt fest, ob die Datei zum lesen und/oder schreiben geöffnet wird. Alle Elemente aus Datei::Style:: sin möglich
  62. // return 1: wenn die datei erfolgreich geöffnet werden konnte. 0 sonnst
  63. __declspec( dllexport ) bool open( int style );
  64. // Setzt die Position des Bytes, das als nächstes gelesen werden soll
  65. // pos: Der Index des Bytes
  66. // ende: 1, wenn der Index vom ende der Datei zählt. 0, wenn der Index vom Beginn der Datei zählt
  67. __declspec( dllexport ) void setLPosition( __int64 pos, bool ende );
  68. // Setzt die Position des Bytes, das als nächstes überschrieben wird
  69. // pos: Der Index des Bytes
  70. // ende: 1, wenn der Index vom ende der Datei zählt. 0, wenn der Index vom Beginn der Datei zählt
  71. __declspec( dllexport ) void setSPosition( __int64 pos, bool ende );
  72. // Schreibt in die Datei
  73. // bytes: Ein Array von bytes, die geschrieben werden sollen.
  74. // len: Wie viele Bytes in die Datei geschrieben werden sollen
  75. __declspec( dllexport ) void schreibe( char *bytes, int len );
  76. // Ließt aus der Datei
  77. // bytes: Ein Array, der mit Bytes aus der Datei gefüllt werden soll
  78. // len: Wie viele Bytes aus der Datei gelesen werden sollen
  79. __declspec( dllexport ) void lese( char *bytes, int len );
  80. // Ließt die nächste zeile der Datei ein
  81. // return: Die gelesene Zeile als Text mit zeilenumbruch
  82. __declspec( dllexport ) Text *leseZeile();
  83. // Schließt die datei
  84. __declspec( dllexport ) void close();
  85. // Setzt den Schlüssel für die Datei
  86. __declspec( dllexport ) void setKey( char *s, int l );
  87. #ifdef WIN32
  88. // Setzt den Zeitpunkt der letzten Änderung der Datei (nur für Windows)
  89. // zeit: den Zeitpunkt der letzten Änderung
  90. // return: 1, wenn der Zeitpunkt gesetzt wurde. 0 sonst
  91. __declspec( dllexport ) bool setLetzteÄnderung( Zeit *zeit );
  92. #endif
  93. // Ließt das nächste Bit aus der Datei
  94. // bit: Eine Referenz auf deinen bool, in dem das Bit gespeichert wird
  95. // return 1, falls das lesen erfolgreich war. 0, sonst
  96. __declspec( dllexport ) bool getNextBit( bool &bit );
  97. // Speichert ein einzelnes Bit in der Datei
  98. // bit: Das bit, welches gespeichert werden soll
  99. // return 1, falls das speichern erfolgreich war
  100. __declspec( dllexport ) bool setNextBit( bool bit );
  101. // Prüft, ob die Datei ein Verzeichnis ist
  102. // return 1, falls die Datei ein Verzeichnis ist. 0, sonst
  103. __declspec( dllexport ) bool istOrdner() const;
  104. // Prüft, ob die Datei bereits geöffnet wurde
  105. // return: 1, wenn die Datei geöffnet ist. 0 sonnst
  106. __declspec( dllexport ) bool istOffen() const;
  107. // Gibt die Anzahl an Unterdateien von dem Verzeichnis zurück
  108. // return: 0, falls die Datei kein Verzeichnis ist. Sonst die Anzahl der Unterdateien
  109. __declspec( dllexport ) int getUnterdateiAnzahl() const;
  110. // Gibt eine Liste mit unterdateien zurück
  111. // return 0, falls die Datei kein Verzeichnis ist. Eine Liste mit den Namen der Unterdateien
  112. __declspec( dllexport ) RCArray< Text > *getDateiListe() const;
  113. // Gibt die Größe der Datei zurück
  114. // return -1, falls die Datei ein Verzeichnis ist oder ein Fehler auftrat. Sonst die größe der Datei
  115. __declspec( dllexport ) __int64 getSize() const;
  116. // Gibt den Zeitpunkt der letzten änderung zurück
  117. // return: 0, falls ein Fehler aufgetreten ist. Der Zeitpunkt der letzten Änderung sonst
  118. __declspec( dllexport ) Zeit *getLastChange() const;
  119. // Prüft, ob die Datei existiert
  120. // return: 1, falls die Datei existiert. 0 sonnst
  121. __declspec( dllexport ) bool existiert() const;
  122. // Gibt den Index des Bytes aus der Datei zurück, welches als nächstes gelesen werden würde
  123. // return -1, falls ein Fehler aufgetreten ist. Sonst die Position des Lesezeigers
  124. __declspec( dllexport ) __int64 getLPosition() const;
  125. // Gibt den Index des Bytes aus der Datei zurück, welches als nächstes überschrieben werden würde
  126. // return -1, falls ein Fehler aufgetreten ist. Sonst die Position des Schreibzeigers
  127. __declspec( dllexport ) __int64 getSPosition() const;
  128. // Prüft, ob die Datei vollständig gelesen wurde
  129. // return 1, wenn die Datei vollständig gelesen wurde. 0, sonst
  130. __declspec( dllexport ) bool istEnde() const;
  131. // Gibt den Pfad zur Datei zurück
  132. __declspec( dllexport ) Text *getPfad() const;
  133. // Gibt den Pfad zur Datei ohne erhöhten Reference Counter zurück
  134. __declspec( dllexport ) Text *zPfad() const;
  135. // Erhöht den Reference Counting Zähler.
  136. // return: this.
  137. __declspec( dllexport ) Datei *getThis();
  138. // Verringert den Reference Counting Zähler. Wenn der Zähler 0 erreicht, wird das Zeichnung automatisch gelöscht.
  139. // return: 0.
  140. __declspec( dllexport ) Datei *release();
  141. };
  142. // Datei Funktionen
  143. // Sucht einen unbenutzten Dateinamen
  144. // zPfad: Ein Zeiger zu dem Pfad, in dem ein unbenutzter Dateiname gefunden werden soll. Ohne erhöhten Reference Counter.
  145. // Wird auch als rückgabewert benutzt
  146. __declspec( dllexport ) void GetFreePfad( Text *zPfad );
  147. // Erstellt den vollständigen Pfad mit Datei
  148. // pfad: Der Pfad zur Datei
  149. // return: 1, falls das erstellen erfolgreich war.
  150. __declspec( dllexport ) bool DateiPfadErstellen( Text* pfad );
  151. // Löscht die angegebene Datei
  152. // pfad: Der Pfad zur Datei
  153. // return: 1, falls die Datei gelöscht wurde
  154. __declspec( dllexport ) bool DateiRemove( Text *pfad );
  155. // Benennt eine Datei um oder verschiebt sie
  156. // pfad_alt: Der Pfad zur Datei, die umbenannt werden soll.
  157. // pfad_neu: Der neue Pfad zur Datei. Wenn sich nur der Name ändert, wird sie nur umbenannt
  158. // return: 1, wenn das umbenennen erfolgreich war. 0, sonst
  159. __declspec( dllexport ) bool DateiUmbenennen( Text *pfad_alt, Text *pfad_neu );
  160. // Prüft, ob Datei existiert
  161. // pfad: Der Pfad zur Datei
  162. // return: 1, wenn die Datei existiert. 0, wenn die Datei nicht gefunden wurde
  163. __declspec( dllexport ) bool DateiExistiert( Text *pfad );
  164. // prüft, ob pfad ein Verzeichnis ist
  165. // pfad: Der Pfad zur Datei
  166. // return: 1, wenn die Datei ein Verzeichnis ist. 0 sonst
  167. __declspec( dllexport ) bool DateiIstVerzeichnis( Text *pfad );
  168. // Erstellt den vollständigen Pfad mit Datei
  169. // pfad: Der Pfad zur Datei
  170. // return: 1, falls das erstellen erfolgreich war.
  171. __declspec( dllexport ) bool DateiPfadErstellen( const char *pfad );
  172. // Löscht die angegebene Datei
  173. // pfad: Der Pfad zur Datei
  174. // return: 1, falls die Datei gelöscht wurde
  175. __declspec( dllexport ) bool DateiRemove( const char *pfad );
  176. // Benennt eine Datei um oder verschiebt sie
  177. // pfad_alt: Der Pfad zur Datei, die umbenannt werden soll.
  178. // pfad_neu: Der neue Pfad zur Datei. Wenn sich nur der Name ändert, wird sie nur umbenannt
  179. // return: 1, wenn das umbenennen erfolgreich war. 0, sonst
  180. __declspec( dllexport ) bool DateiUmbenennen( const char *pfad_alt, const char *pfad_neu );
  181. // Prüft, ob Datei existiert
  182. // pfad: Der Pfad zur Datei
  183. // return: 1, wenn die Datei existiert. 0, wenn die Datei nicht gefunden wurde
  184. __declspec( dllexport ) bool DateiExistiert( const char *pfad );
  185. // prüft, ob pfad ein Verzeichnis ist
  186. // pfad: Der Pfad zur Datei
  187. // return: 1, wenn die Datei ein Verzeichnis ist. 0 sonst
  188. __declspec( dllexport ) bool DateiIstVerzeichnis( const char *pfad );
  189. }
  190. #endif