Text.h 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429
  1. #ifndef Text_H
  2. #define Text_H
  3. #include "Reader.h"
  4. namespace Framework
  5. {
  6. class Text; // aus dieser Datei
  7. // Ein ersatz für String
  8. class Text
  9. {
  10. private:
  11. char *txt;
  12. char suchGBeg;
  13. char suchGEnd;
  14. int precision;
  15. int ref;
  16. public:
  17. // Erstellt ein neues Text Objekt mit dem Wert ""
  18. __declspec( dllexport ) Text();
  19. // Erstellt ein neues Text Objekt indem der Wert aus (txt) kopiert wird
  20. // txt: Der Text, der kopiert werden soll
  21. __declspec( dllexport ) Text( const Text &txt );
  22. // Erstellt ein neues Text Objekt indem der Wert aus (txt) kopiert wird
  23. // txt: Die Zeichenkette, die kopiert werden soll
  24. __declspec( dllexport ) Text( const char *txt );
  25. // Erstellt ein neues Text Objekt mit einer zahl als text
  26. // zahl: Die Zahl, die im Text sein soll
  27. __declspec( dllexport ) Text( int zahl );
  28. // Erstellt ein neues Text Objekt mit einer zahl als text
  29. // num: Die Zahl, die im Text sein soll
  30. __declspec( dllexport ) Text( double num );
  31. // Erstellt ein neues Text Objekt mit einer zahl als text
  32. // num: Die Zahl, die im Text sein soll
  33. __declspec( dllexport ) Text( float num );
  34. // Löscht den Text
  35. __declspec( dllexport ) ~Text();
  36. // Legt die Suchgrenzen fest, die von den Suchfunktionen verwendet werden.
  37. // gBeg: Das Zeichen, bei dem die Suche beginnen soll
  38. // gEnd: Das Zeichen, bei dem die Suche enden soll
  39. __declspec( dllexport ) void setSuchGrenzen( char gBeg, char gEnd );
  40. // Setzt den Text, den das Zeichnung speichert
  41. // t: Eine Zeichenkette, deren Inhalt kopiert wird
  42. __declspec( dllexport ) void setText( const char *t );
  43. // Setzt den Text, den das Zeichnung speichert
  44. // t: Eine Zeichenkette, deren Inhalt kopiert wird
  45. // l: Die Länge des Textes, der aus (t) kopiert werden soll
  46. __declspec( dllexport ) void setText( const char *t, int l );
  47. // Setzt den Text, den das Zeichnung speichert
  48. // t: Das TextZeichnung, dessen Inahlt kopiert werden soll
  49. __declspec( dllexport ) void setText( Text *t );
  50. // Hängt eine Zeichenfolge ans Ende des Textes an, die von der Schrift Klasse beim zeichnen interpretiert wird, so dass der nachfolgende Text in einer anderen Farbe gezeichnet wird.
  51. // fc: Der Farbcode im A8R8G8B8 Format
  52. __declspec( dllexport ) void appendColor( int fc );
  53. // Hängt die übergebene Zahl als Hex Text (0-F) ans Ende des Textes an.
  54. // num: Die Zahl, die ins Hex System umgewandelt und angehängt werden soll
  55. __declspec( dllexport ) void appendHex( int num );
  56. // Fügt den übergebenen Buchtaben der Zeichenkette hinzu
  57. // c: Der Buchstabe, der angehängt werden soll
  58. __declspec( dllexport ) void append( char c );
  59. // Hängt die übergebene Zeichenkette ans Ende des Textes an
  60. // t: Die Zeichenkette, deren Kopie ans Ende des Textes angehängt werden soll
  61. __declspec( dllexport ) void append( const char *t );
  62. // Hängt einen Teil der übergebenen Zeichenkette ans Ende des Textes an
  63. // t: Die Zeichenkette, deren Kopie angehängt werden soll
  64. // l: Die Länge des Textabschnittes der angehängt werden soll
  65. __declspec( dllexport ) void append( const char *t, int l );
  66. // Hängt den Inhalt des eines Textes ans Ende des Textes an
  67. // t: Der Text, dessen Kopie ans Ende des Textes angehängt werden soll
  68. __declspec( dllexport ) void append( Text *t );
  69. // Hängt eine Zahl ans Ende Des Textes an
  70. // num: Die Zahl, die in einen Text umgewandelt und am Ende angehängt werden soll
  71. __declspec( dllexport ) void append( int num );
  72. // Hängt eine Zahl ans Ende Des Textes an
  73. // num: Die Zahl, die in einen Text umgewandelt und am Ende angehängt werden soll
  74. __declspec( dllexport ) void append( __int64 num );
  75. // Hängt eine Zahl ohne Vorzeichenbit am Ende des Textes an
  76. // num: Die Zahl, die in einen Text umgewandelt und am Ende angehängt werden soll
  77. __declspec( dllexport ) void append( unsigned int num );
  78. // Hängt eine Kommazahl am Ende des Textes an
  79. // num: Die Kommazahl, die am Ende des Textes angehängt werden soll
  80. __declspec( dllexport ) void append( double num );
  81. // Hängt eine Kommazahl am Ende des Textes an
  82. // num: Die Kommazahl, die am Ende des Textes angehängt werden soll
  83. __declspec( dllexport ) void append( float num );
  84. // Fügt an einer Bestimmten Stelle ein Zeichen in den Text ein
  85. // p: Die position im Text bei der das Zeichen eingefügt werden soll
  86. // c: Das Zeichen, das eingefügt werden soll
  87. __declspec( dllexport ) void insert( int p, char c );
  88. // Fügt an einer Bestimmten Stelle im Text eine Zeichenkette ein
  89. // p: Die position im Text bei der die Zeichenkette eingefügt werden soll
  90. // t: Die Zeichenkette, deren Kopie an eingefügt werden soll
  91. __declspec( dllexport ) void insert( int p, const char *t );
  92. // Fügt den Inhalt eines Textes an einer Bestimmten Stelle im Text ein
  93. // p: Die Position im Text, bei der der inhalt des Textest eingefügt werden soll
  94. // t: Der Text, dessen Kopie an der Stelle eingefügt werden soll
  95. __declspec( dllexport ) void insert( int p, Text *t );
  96. // Ersetzt einen bestimmten Textabschnitt mit einer anderen Zeichenkette
  97. // p1: Die Startposition des zu ersetzenden Textabschnittes
  98. // p2: Die Endposition des zu ersetzenden Textabschnittes
  99. // t: Die Zeichenkette, die an die entsprechende Stelle kopiert werden soll
  100. // Beispiel: ( "Hallo Welt" ).ersetzen( 2, 5, "lt" ); ergibt: "Halt Welt"
  101. __declspec( dllexport ) void ersetzen( int p1, int p2, const char *t );
  102. // Ersetzt einen bestimmten Textabschnitt mit dem Inhalt eines anderen Textes
  103. // p1: Die Startposition des zu ersetzenden Textabschnittes
  104. // p2: Die Endposition des zu ersetzenden Textabschnittes
  105. // t: Der Text, dessen Inhalt an die entsprechende Stelle kopiert werden soll
  106. // Beispiel: ( "Hallo Welt" ).ersetzen( 2, 5, new Text( "lt" ) ); ergibt: "Halt Welt"
  107. __declspec( dllexport ) void ersetzen( int p1, int p2, Text *t );
  108. // Sucht und erstetzt jedes Vorkommen eines bestimmten Buchstaben durch einen anderen
  109. // c1: Der Buchstabe der ersetzt werden soll
  110. // c2: Der Buchstabe, durch den der Andere ersetzt werden soll
  111. __declspec( dllexport ) void ersetzen( char c1, char c2 );
  112. // Sucht und erstetzt jedes Vorkommen einer bestimmten Zeichenkette durch eine andere
  113. // t1: Die Zeichenkette, die ersetzt werden soll
  114. // t2: Die Zeichenkette, durch welche die Andere ersetzt werden soll
  115. __declspec( dllexport ) void ersetzen( const char *t1, const char *t2 );
  116. // Sucht und erstetzt jedes Vorkommen des Inhalts eines Textes durch eine andere Zeichenkette
  117. // t1: Der Text, dessen Inhalt gesucht und ersetzt wird
  118. // t2: Die Zeichenkette, durch welche das Vorkommen des Textes ersetzt werden soll
  119. __declspec( dllexport ) void ersetzen( Text *t1, const char *t2 );
  120. // Sucht und erstetzt jedes Vorkommen einer Zeichenkette durch den Inhalt eines Textes
  121. // t1: Die Zeichenkette, die ersetzt werden soll
  122. // t2: Der Text, dessen Inhalt das Vorkommen der Zeichenkette ersetzten soll
  123. __declspec( dllexport ) void ersetzen( const char *t1, Text *t2 );
  124. // Sucht und erstetzt jedes Vorkommen des Inhalts eines Textes durch den Inhalt eines anderen Textes
  125. // t1: Der Text, dessen Vorkommen ersetzt werden sollen
  126. // t2: Der Text, dessen Inhalt das Vorkommen der Zeichenkette ersetzten soll
  127. __declspec( dllexport ) void ersetzen( Text *t1, Text *t2 );
  128. // Ersetzt das i-te auftreten eines bestimmten Buchstaben mit einem anderen Buchstaben
  129. // i: Das wie vielte Auftreten des Buchstabens ersetzt werden soll
  130. // c1: Der Buchstabe, dessen i-tes Auftreten erstetzt werden soll
  131. // c2: Der Buchstabe, der das i-te Auftreten des anderen Buchstabens ersetzen soll
  132. __declspec( dllexport ) void ersetzen( int i, char c1, char c2 );
  133. // Ersetzt das i-te auftreten einer bestimmten Zeichenkette mit einer anderen Zeichenkette
  134. // i: Das wie vielte Auftreten der Zeichenkette ersetzt werden soll
  135. // c1: Die Zeichenkette, dessen i-tes Auftreten erstetzt werden soll
  136. // c2: Die Zeichenkette, die das i-te Auftreten der anderen Zeichenkette ersetzen soll
  137. __declspec( dllexport ) void ersetzen( int i, const char *t1, const char *t2 );
  138. // Ersetzt das i-te auftreten des Inhalts eines Textes mit einer Zeichenkette
  139. // i: Das wie vielte Auftreten des Textes ersetzt werden soll
  140. // c1: Der Text, dessen i-tes Auftreten erstetzt werden soll
  141. // c2: Die Zeichenkette, die das i-te Auftreten des Textes ersetzen soll
  142. __declspec( dllexport ) void ersetzen( int i, Text *t1, const char *t2 );
  143. // Ersetzt das i-te auftreten einer bestimmten Zeichenkette mit dem Inhalt eines Textes
  144. // i: Das wie vielte Auftreten der Zeichenkette ersetzt werden soll
  145. // c1: Die Zeichenkette, dessen i-tes Auftreten erstetzt werden soll
  146. // c2: Der Text, dessen Inhalt das i-te Auftreten der Zeichenkette ersetzen soll
  147. __declspec( dllexport ) void ersetzen( int i, const char *t1, Text *t2 );
  148. // Ersetzt das i-te auftreten eines bestimmten Textes mit dem Inhalt eines anderen Textes
  149. // i: Das wie vielte Auftreten des Textes ersetzt werden soll
  150. // c1: Der Text, dessen i-tes Auftreten erstetzt werden soll
  151. // c2: Der Text, dessen Inhalt das i-te Auftreten des anderen Textes ersetzen soll
  152. __declspec( dllexport ) void ersetzen( int i, Text *t1, Text *t2 );
  153. // Löscht den bisherigen Text und erzeugt einen Text, der aus einem Bestimten Buchstaben besteht, mit einer bestimmten Länge
  154. // c: Der Buchstabe, aus dem der Text bestehen soll
  155. // length: Die Länge des Textes
  156. __declspec( dllexport ) void fillText( char c, int length );
  157. // Löscht ein Bestimmtes Zeichen aus dem Text
  158. // p: Die Position des zu löschenden Zeichens
  159. __declspec( dllexport ) void remove( int p );
  160. // Löscht einen Bestimmten Textabschnitt
  161. // p1: Die Startposition des zu löschenden Abschnittes
  162. // p2: Die Endposition des zu löschenden Abschnittes (Das Zeichen bei p2 bleibt erhalten)
  163. __declspec( dllexport ) void remove( int p1, int p2 );
  164. // Löscht jedes Vorkommen eines bestimmten Buchsaben
  165. // c: Der Buchstabe, dessen Vorkommen gelöscht werden soll
  166. __declspec( dllexport ) void remove( char c );
  167. // Löscht jedes Vorkommen einer bestimmten Zeichenkette
  168. // t: Die Zeichenkette, deren Vorkommen entfernt werden sollen
  169. __declspec( dllexport ) void remove( const char *t );
  170. // Löscht jedes Vorkommen des Inhalts eines Textes
  171. // t: Der text, dessen Inhalt gelöscht werden soll
  172. __declspec( dllexport ) void remove( Text *t );
  173. // Löscht das i-te Vorkommen eines bestimmten Buchstaben
  174. // i: Das wie vielte Vorkommen des Buchstabens gelöscht werden soll
  175. // c: Der Buchstabe, dessen i-tes Vorkommen gelöscht werden soll
  176. __declspec( dllexport ) void remove( int i, char c );
  177. // Löscht das i-te Vorkommen einer bestimmten Zechenkette
  178. // i: Das wie vielte Vorkommen der Zeichenkette gelöscht werden soll
  179. // t: Die Zeichenkette, dessen i-tes Vorkommen gelöscht werden soll
  180. __declspec( dllexport ) void remove( int i, const char *t );
  181. // Löscht das i-te Vorkommen eines bestimmten Textinhaltes
  182. // i: Das wie vielte Vorkommen des Textinhaltes gelöscht werden soll
  183. // t: Der Text, dessen i-tes Vorkommen gelöscht werden soll
  184. __declspec( dllexport ) void remove( int i, Text *t );
  185. // Setzt die Anzahl der Nachkommastellen beim Anhängen von Kommazahlen
  186. // p: Die Anzahl der Stellen nach dem Komma
  187. __declspec( dllexport ) void setPrecision( int p );
  188. // Gibt die Länge des Textes zurück
  189. __declspec( dllexport ) int getLength() const;
  190. // Ermittelt die neue Curserposition nachdem Drücken der 'Links' Pfeiltaste
  191. // pos: Die alte Curserposition
  192. __declspec( dllexport ) int getLKick( int pos ) const;
  193. // Ermittelt die neue Curserposition nachdem Drücken der 'Oben' Pfeiltaste
  194. // pos: Die alte Curserposition
  195. __declspec( dllexport ) int getOKick( int pos ) const;
  196. // Ermittelt die neue Curserposition nachdem Drücken der 'Rechts' Pfeiltaste
  197. // pos: Die alte Curserposition
  198. __declspec( dllexport ) int getRKick( int pos ) const;
  199. // Ermittelt die neue Curserposition nachdem Drücken der 'Unten' Pfeiltaste
  200. // pos: Die alte Curserposition
  201. __declspec( dllexport ) int getUKick( int pos ) const;
  202. // Überprüft, ob im Text der Inhalt eines anderen Textes vorkommt
  203. // t: Der Text, nach dessen Inhalt gesucht werden soll
  204. // return: (true), wenn der Inhalt des Textes vorkommt. (false) sonnst
  205. __declspec( dllexport ) bool hat( Text *t ) const;
  206. // Überprüft, ob im Text eine bestimmte Zeichenkette vorkommt
  207. // t: Die Zeichenkette, nach der gesucht werden soll
  208. // return: (true), wenn die Zeichenkette vorkommt. (false) sonnst
  209. __declspec( dllexport ) bool hat( const char *t ) const;
  210. // Überprüft, ob im Text ein bestimmtes Zeichen vorkommt
  211. // c: Das Zeichen, nach dem gesucht werden soll
  212. // return: (true), wenn das Zeichen vorkommt. (false) sonnst
  213. __declspec( dllexport ) bool hat( char c ) const;
  214. // Überprft, ob der Text den selben Inhalt wie eine Zeichenkette hat
  215. // t: Die Zeichenkette, die verglichen werden soll
  216. // return: (true), wenn der Inhalt des Textes gleich der Zeichenkette ist. (false) sonst
  217. __declspec( dllexport ) bool istGleich( const char *t ) const;
  218. // Überprft, ob der Text den selben Inhalt wie ein anderer Text hat
  219. // t: Der Text, dessen Inhalt verglichen werden soll
  220. // return: (true), wenn die Inhalte der Texte übereinstimmen. (false) sonst
  221. __declspec( dllexport ) bool istGleich( Text *t ) const;
  222. // Gibt den Inhalt des Textes als Zeichenkette zurück
  223. __declspec( dllexport ) char *getText() const;
  224. // Zählt, wie oft ein bestimmter Buchstabe im Text vorkomt
  225. // c: Der Buchstabe, der gezählt werden soll
  226. // return: Die Anzahl des Buchstabens im Text
  227. __declspec( dllexport ) int anzahlVon( char c ) const;
  228. // Zählt, wie oft eine bestimmte Zeichenkette im Text vorkommt
  229. // t: Die Zeichenkette, die gezählt werden soll
  230. // return: Die Anzahl der Zeichenkette im Text
  231. __declspec( dllexport ) int anzahlVon( const char *t ) const;
  232. // Zählt, wie oft der Inhalt eines Textest im Text vorkommt
  233. // t: Der Text, dessen Inhalt gezählt werden soll
  234. // return: Die Anzahl des Textinhaltes im Text
  235. __declspec( dllexport ) int anzahlVon( Text *t ) const;
  236. // Gibt die erste Position eines bestimmten Buchstabens im Text zurück
  237. // c: Der Buchstabe, der gefunden werden soll
  238. // return: Die Position des ersten Vorkommens des Buchstabens
  239. __declspec( dllexport ) int positionVon( char c ) const;
  240. // Gibt die erste Position einer bestimmten Zeichenkette im Text zurück
  241. // t: Die Zeichenkette, die gefunden werden soll
  242. // return: Die Position des ersten Vorkommens der Zeichenkette
  243. __declspec( dllexport ) int positionVon( const char *t ) const;
  244. // Gibt die erste Position eines Textinhaltes im Text zurück
  245. // t: Der Text, dessen Inhalt gefunden werden soll
  246. // return: Die Position des ersten Vorkommens des Textinhaltes
  247. __declspec( dllexport ) int positionVon( Text *t ) const;
  248. // Gibt die i-te Position eines bestimmten Buchstabens im Text zurück
  249. // c: Der Buchstabe, der gefunden werden soll
  250. // i: Das wievielte Vorkommen gefunden werden soll
  251. // return: Die Position des i-ten Vorkommens des Buchstabens
  252. __declspec( dllexport ) int positionVon( char c, int i ) const;
  253. // Gibt die i-te Position einer bestimmten Zeichenkette im Text zurück
  254. // t: Die Zeichenkette, die gefunden werden soll
  255. // i: Das wievielte Vorkommen gefunden werden soll
  256. // return: Die Position des i-ten Vorkommens der Zeichenkette
  257. __declspec( dllexport ) int positionVon( const char *t, int i ) const;
  258. // Gibt die i-te Position eines Textinhaltes im Text zurück
  259. // t: Der Text, dessen Inhalt gefunden werden soll
  260. // i: Das wievielte Vorkommen gefunden werden soll
  261. // return: Die Position des i-ten Vorkommens des Textinhaltes
  262. __declspec( dllexport ) int positionVon( Text *t, int i ) const;
  263. // Gibt einen Text zurück, der eine Kopie eines bestimmten Textabschnittes enthält
  264. // p1: Die Startposition des Textabschnittes
  265. // p2: Die Endposition des Textabschnittes (nicht enthalten)
  266. __declspec( dllexport ) Text *getTeilText( int p1, int p2 ) const;
  267. // Gibt einen Text zurück, der eine Kopie eines bestimmten Textabschnittes enthält
  268. // p1: Die Startposition des Textabschnittes (Der Textabschnitt geht bis ans Ende des Textes)
  269. __declspec( dllexport ) Text *getTeilText( int p ) const;
  270. // Erhöht den Reference Counting Zähler.
  271. // return: this.
  272. __declspec( dllexport ) Text *getThis();
  273. // Verringert den Reference Counting Zähler. Wenn der Zähler 0 erreicht, wird das Zeichnung automatisch gelöscht.
  274. // return: 0.
  275. __declspec( dllexport ) Text *release();
  276. // Hängt eine Zahl ans Ende des Textes an
  277. __declspec( dllexport ) Text &operator+=( const int num );
  278. // Hängt eine Zahl ans Ende des Textes an
  279. __declspec( dllexport ) Text &operator+=( const __int64 num );
  280. // Hängt eine Kommazahl ans Ende des Textes an
  281. __declspec( dllexport ) Text &operator+=( const double num );
  282. // Hängt eine Kommazahl ans Ende des Textes an
  283. __declspec( dllexport ) Text &operator+=( const float num );
  284. // Hängt eine Zeichenkette ans Ende des Textes an
  285. __declspec( dllexport ) Text &operator+=( const char *txt );
  286. // Hängt eine Kopie des Inhalts eines Textes ans Ende des Textes an
  287. __declspec( dllexport ) Text &operator+=( const Text &txt );
  288. // Setzt den Inhalt des Textes gleich einer Zahl
  289. __declspec( dllexport ) Text &operator=( const int num );
  290. // Setzt den Inhalt des Textes gleich einer Kommazahl
  291. __declspec( dllexport ) Text &operator=( const double num );
  292. // Setzt den Inhalt des Textes gleich einer Kommazahl
  293. __declspec( dllexport ) Text &operator=( const float num );
  294. // Setzt den Inahlt des Textes gleich einer Zeichenkette
  295. __declspec( dllexport ) Text &operator=( const char *txt );
  296. // Setzt den Inhalt des Textes gleich einer Kopie des Inhalts eines anderen Textes
  297. __declspec( dllexport ) Text &operator=( const Text &txt );
  298. // Gibt den Inhalt des Textes als Zeichenkette zurück
  299. __declspec( dllexport ) operator char*( ) const;
  300. // Konviertiert den Inhalt des Textes zu einer Zahl
  301. __declspec( dllexport ) operator int() const;
  302. // Konviertiert den Inhalt des Textes zu einer Zahl
  303. __declspec( dllexport ) operator __int64() const;
  304. // Konviertiert den Inhalt des Textes zu einer Kommazahl
  305. __declspec( dllexport ) operator double() const;
  306. // Konviertiert den Inhalt des Textes zu einer Kommazahl
  307. __declspec( dllexport ) operator float() const;
  308. // Prüft, ob der Inhalt des Textes nach alphabetischer Ordnung später kommt als der Inhalt eines anderen Textes
  309. __declspec( dllexport ) bool operator>( Text &t ) const;
  310. // Prüft, ob der Inhalt des Textes nach alphabetischer Ordnung früher kommt als der Inhalt eines anderen Textes
  311. __declspec( dllexport ) bool operator<( Text &t ) const;
  312. };
  313. class TextReader : public Reader
  314. {
  315. private:
  316. Text *txt;
  317. __int64 lPos;
  318. int ref;
  319. public:
  320. // Konstructor
  321. // txt: Der Text der gelesen werden soll. Er wird nicht kopiert sondern direkt gelesen.
  322. __declspec( dllexport ) TextReader( Text *txt );
  323. // Destructor
  324. __declspec( dllexport ) virtual ~TextReader();
  325. // Setzt die Position des Bytes, das als nächstes gelesen werden soll
  326. // pos: Der Index des Bytes
  327. // ende: 1, wenn der Index vom ende des Textes zählt. 0, wenn der Index vom Beginn des Textes zählt
  328. __declspec( dllexport ) void setLPosition( __int64 pos, bool ende ) override;
  329. // Ließt aus der Datei
  330. // bytes: Ein Array, der mit Bytes aus dem Text gefüllt werden soll
  331. // len: Wie viele Bytes aus dem Text gelesen werden sollen
  332. __declspec( dllexport ) void lese( char *bytes, int len ) override;
  333. // Ließt die nächste zeile des Textes ein
  334. // return: Die gelesene Zeile als Text mit zeilenumbruch
  335. __declspec( dllexport ) Text *leseZeile() override;
  336. // Prüft, ob die Resource vollständig gelesen wurde
  337. // return 1, wenn die Resource vollständig gelesen wurde. 0, sonst
  338. __declspec( dllexport ) bool istEnde() const override;
  339. // Gibt den Index des Bytes aus dem Text zurück, welches als nächstes gelesen werden würde
  340. // return -1, falls ein Fehler aufgetreten ist. Sonst die Position des Lesezeigers
  341. __declspec( dllexport ) __int64 getLPosition() const;
  342. // Erhöht den Reference Counting Zähler.
  343. // return: this.
  344. __declspec( dllexport ) TextReader *getThis();
  345. // Verringert den Reference Counting Zähler. Wenn der Zähler 0 erreicht, wird das Zeichnung automatisch gelöscht.
  346. // return: 0.
  347. __declspec( dllexport ) TextReader *release();
  348. };
  349. // Durchsucht eine Zeichenkette nach dem num-ten Vorkommen eines bestimmten Buchstabens
  350. // string: Die zu durchsuchende Zeichenkette
  351. // c: Der zu suchende Buchstabe
  352. // num: Das wievielte Vorkommen des Buchtaben gefunden werden soll
  353. // return: (-1), wenn es kein num-tes Vorkommen des Buchstaben gibt. Sonst die Position des num-ten Vorkommens in der Zeichenkette
  354. __declspec( dllexport ) int stringPositionVonChar( char *string, char c, int num ); // sucht die position des num-ten c-s in string, -1 bei nicht gefunden
  355. // Durchsucht eine Zeichenkette nach einer Anderen Zeichenkette
  356. // string: Die zu durchsuchende Zeichenkette
  357. // suche: Die Zeichenkette, nach der gesucht werden soll
  358. // sBegPos: Die Position, ab der die Suche begonnen werden soll
  359. // return: Die Position, an der die zu suchende Zeichenkette erstmals gefunden wurde. (-1) Wenn nichts gefunden wurde.
  360. __declspec( dllexport ) int stringPositionVonString( char *string, char *suche, int sBegPos );
  361. // Kopiert eine bestimmte Zeichenkette in die Zwischenablage des Betriebssystems
  362. // txt: Die Zeichenkette, die kopiert werden soll
  363. __declspec( dllexport ) void TextKopieren( const char *txt );
  364. // Ermittelt, ob in der Zwischenablage des Betriebssystems eine Zeichenkette steht.
  365. // return: Die Zeichenkette aus der Zwischenablage. Wenn keine Zeichenkette kopiert wurde, wird eine lehre Zeichenkette zurückgegeben.
  366. __declspec( dllexport ) char *TextInsert();
  367. // Wandelt einen bestimmten schreibbaren Buchstaben in einen Groß- oder Kleinbuchstaben um
  368. // c: Der Buchstabe, der umgewandelt werden soll
  369. // groß: Wenn (true), so wird der Buchstabe in einen Großbuchstaben umgewandelt. Wenn (false), wird er in einen Kleinbuchstaben umgewandelt.
  370. // return: Den umgewandelten Buchstaben
  371. __declspec( dllexport ) char smallOrBig( char c, bool big );
  372. // Ermittelt, ob ein Buchstabe ein schreibbares Zeichen ist
  373. // zeichen: Der Buchstabe, der geprüft werden soll
  374. // return: (true), wenn der Buchstabe gezeichnet werden kann. (false) sonnst
  375. __declspec( dllexport ) bool istSchreibbar( unsigned char zeichen );
  376. // Konvertiert eine Zahl aus einer Zeichenkette in belibiger Basis zu einer Zahl
  377. // c: Die Zeichenkette, in der Die Zahl steht
  378. // system: Die Basis der Zahl
  379. // return: Die Zahl, die im Text stand
  380. __declspec( dllexport ) unsigned int TextZuInt( char *c, int system );
  381. // Konvertiert eine Zahl aus einer Zeichenkette in belibiger Basis zu einer Zahl
  382. // c: Die Zeichenkette, in der Die Zahl steht
  383. // c_ende: Wird duch die Funktion gesetzt und darf 0 sein. Zeigt auf das nächste Zeichen in der Zeichenkette, das nach der Zah steht
  384. // system: Die Basis der Zahl
  385. // return: Die Zahl, die im Text stand
  386. __declspec( dllexport ) unsigned int TextZuInt( char *c, char **c_ende, int system );
  387. // Konvertiert eine Zahl aus einer Zeichenkette in belibiger Basis zu einer Zahl
  388. // c: Die Zeichenkette, in der Die Zahl steht
  389. // system: Die Basis der Zahl
  390. // return: Die Zahl, die im Text stand
  391. __declspec( dllexport ) unsigned __int64 TextZuInt64( char *c, int system );
  392. // Konvertiert eine Zahl aus einer Zeichenkette in belibiger Basis zu einer Zahl
  393. // c: Die Zeichenkette, in der Die Zahl steht
  394. // c_ende: Wird duch die Funktion gesetzt und darf 0 sein. Zeigt auf das nächste Zeichen in der Zeichenkette, das nach der Zah steht
  395. // system: Die Basis der Zahl
  396. // return: Die Zahl, die im Text stand
  397. __declspec( dllexport ) unsigned __int64 TextZuInt64( char *c, char **c_ende, int system );
  398. // Konvertiert eine Zeichenkette zu einem Double
  399. // c: Die Zeichenkette, die konvertiert werden soll
  400. // return: Das double, was in der Zeichenkette stand
  401. __declspec( dllexport ) double TextZuDouble( char *c );
  402. // Konvertiert eine Zeichenkette zu einem Float
  403. // c: Die Zeichenkette, die konvertiert werden soll
  404. // return: Das float, was in der Zeichenkette stand
  405. __declspec( dllexport ) float TextZuFloat( char *c );
  406. // Konvertiert eine Zeichenkette zu einem Double
  407. // c: Die Zeichenkette, die konvertiert werden soll
  408. // c_ende: Wird duch die Funktion gesetzt und darf 0 sein. Ein Zeiger auf das nächste Zeichen nach dem Double in der Zeichenkette
  409. // return: Das double, was in der Zeichenkette stand
  410. __declspec( dllexport ) double TextZuDouble( char *c, char **c_ende );
  411. // Konvertiert eine Zeichenkette zu einem float
  412. // c: Die Zeichenkette, die konvertiert werden soll
  413. // c_ende: Wird duch die Funktion gesetzt und darf 0 sein. Ein Zeiger auf das nächste Zeichen nach dem float in der Zeichenkette
  414. // return: Das float, was in der Zeichenkette stand
  415. __declspec( dllexport ) float TextZuFloat( char *c, char **c_ende );
  416. // Ermittelt die Länge einer bestimmten Zeichenkette
  417. // txt: Die Zeichenkette, deren Länge ermittelt werden soll
  418. // return: Die Länge der Zeichenkette
  419. __declspec( dllexport ) int textLength( const char *txt );
  420. }
  421. #endif