Text.h 26 KB

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