Text.h 26 KB

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