Array.h 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850
  1. #ifndef Array_H
  2. #define Array_H
  3. #include "Betriebssystem.h"
  4. #include <stdexcept>
  5. #include "Text.h"
  6. #include "ReferenceCounter.h"
  7. namespace Framework
  8. {
  9. template< class TYP >
  10. //! Ein Eintrag in einer Linked List
  11. struct ArrayEintrag
  12. {
  13. TYP var;
  14. bool set = false;
  15. ArrayEintrag< TYP > *next = 0;
  16. //! Setzt den Eintrag auf die Werte des anderen Eintrages
  17. ArrayEintrag &operator=( ArrayEintrag &r )
  18. {
  19. var = r.var;
  20. set = r.set;
  21. next = r.next;
  22. return *this;
  23. }
  24. //! Gibt den aktuell gespeicherten Wert zurück
  25. operator TYP()
  26. {
  27. if( !set )
  28. {
  29. Text err = "Index out of Range Exception File: ";
  30. err += __FILE__;
  31. err += " Line: ";
  32. err += __LINE__;
  33. throw std::out_of_range( (char *)err );
  34. }
  35. return var;
  36. }
  37. //! inkrementiert durch die Linked List durch
  38. ArrayEintrag< TYP > &operator++() //! prefix
  39. {
  40. if( !next )
  41. {
  42. ArrayEintrag<TYP> tmp;
  43. tmp.set = 0;
  44. tmp.next = 0;
  45. *this = tmp;
  46. return *this;
  47. }
  48. *this = *next;
  49. return *next;
  50. }
  51. //! inkrementiert durch die Linked List durch
  52. ArrayEintrag< TYP > &operator++( int ) //! postfix
  53. {
  54. if( !next )
  55. {
  56. ArrayEintrag<TYP> tmp;
  57. tmp.set = 0;
  58. tmp.next = 0;
  59. *this = tmp;
  60. return *this;
  61. }
  62. *this = *next;
  63. return *next;
  64. }
  65. #ifdef WIN32
  66. #pragma warning( once : 26495 )
  67. #endif
  68. };
  69. template< class TYP >
  70. class Iterator
  71. {
  72. private:
  73. ArrayEintrag< TYP > *current;
  74. public:
  75. Iterator( ArrayEintrag< TYP > *start )
  76. {
  77. current = start;
  78. while( current && !current->set )
  79. {
  80. current = current->next;
  81. }
  82. }
  83. Iterator( const Iterator &it )
  84. {
  85. current = it.current;
  86. }
  87. Iterator< TYP > &operator=( Iterator< TYP > r )
  88. {
  89. current = r.current;
  90. return *this;
  91. }
  92. bool hasNext()
  93. {
  94. ArrayEintrag< TYP > *next = current->next;
  95. while( next && !next->set )
  96. {
  97. next = next->next;
  98. }
  99. return next != 0;
  100. }
  101. Iterator< TYP > next()
  102. {
  103. if( !current )
  104. {
  105. Text err = "Index out of Range Exception File: ";
  106. err += __FILE__;
  107. err += " Line: ";
  108. err += __LINE__;
  109. throw std::out_of_range( (char *)err );
  110. }
  111. return Iterator( current->next );
  112. }
  113. operator bool()
  114. {
  115. return current != 0;
  116. }
  117. operator TYP()
  118. {
  119. if( !current || !current->set )
  120. {
  121. Text err = "Index out of Range Exception File: ";
  122. err += __FILE__;
  123. err += " Line: ";
  124. err += __LINE__;
  125. throw std::out_of_range( (char *)err );
  126. }
  127. return current->var;
  128. }
  129. Iterator< TYP > &operator++() //! prefix
  130. {
  131. do
  132. {
  133. if( current )
  134. current = current->next;
  135. } while( current && !current->set );
  136. return *this;
  137. }
  138. Iterator< TYP > operator++( int ) //! postfix
  139. {
  140. Iterator< TYP > temp( *this );
  141. do
  142. {
  143. if( current )
  144. current = current->next;
  145. } while( current && !current->set );
  146. return temp;
  147. }
  148. TYP operator->()
  149. {
  150. if( !current || !current->set )
  151. {
  152. Text err = "Index out of Range Exception File: ";
  153. err += __FILE__;
  154. err += " Line: ";
  155. err += __LINE__;
  156. throw std::out_of_range( (char *)err );
  157. }
  158. return current->var;
  159. }
  160. TYP val()
  161. {
  162. if( !current || !current->set )
  163. {
  164. Text err = "Index out of Range Exception File: ";
  165. err += __FILE__;
  166. err += " Line: ";
  167. err += __LINE__;
  168. throw std::out_of_range( (char *)err );
  169. }
  170. return current->var;
  171. }
  172. void set( TYP val )
  173. {
  174. if( current )
  175. {
  176. current->var = val;
  177. current->set = true;
  178. }
  179. else
  180. {
  181. Text err = "Index out of Range Exception File: ";
  182. err += __FILE__;
  183. err += " Line: ";
  184. err += __LINE__;
  185. throw std::out_of_range( (char *)err );
  186. }
  187. }
  188. };
  189. #define _ val()
  190. template< class TYP >
  191. //! Eine Linked List von Klassen, die kein Reference Counting berteiben
  192. class Array : public virtual ReferenceCounter
  193. {
  194. private:
  195. ArrayEintrag< TYP > *entries;
  196. public:
  197. //! Erstellt eine neue Linked List
  198. Array() noexcept
  199. : ReferenceCounter()
  200. {
  201. entries = new ArrayEintrag< TYP >();
  202. entries->set = 0;
  203. entries->next = 0;
  204. }
  205. //! Kopiert eine Linked list
  206. //!
  207. Array( const Array &arr )
  208. : ReferenceCounter()
  209. {
  210. entries = new ArrayEintrag< TYP >();
  211. entries->set = 0;
  212. entries->next = 0;
  213. int anz = arr.getEintragAnzahl();
  214. for( int i = 0; i < anz; i++ )
  215. add( arr.get( i ) );
  216. }
  217. //! Leert und löscht die Linked List
  218. ~Array()
  219. {
  220. leeren();
  221. delete entries;
  222. }
  223. //! Hängt ein Element ans Ende der Liste an
  224. //! \param t Das neue Element
  225. void add( TYP t )
  226. {
  227. for( ArrayEintrag< TYP > *e = entries; 1; e = e->next )
  228. {
  229. if( !e->set && !e->next )
  230. {
  231. e->var = t;
  232. e->set = 1;
  233. break;
  234. }
  235. if( !e->next )
  236. {
  237. e->next = new ArrayEintrag< TYP >();
  238. e->next->set = 0;
  239. e->next->next = 0;
  240. }
  241. }
  242. }
  243. //! Fügt ein Element bei einer bestimmten Position in die Liste ein
  244. //! \param t das neue Element
  245. //! \param i Die Position, wo das Element eingefügt wird (danach der Index des neuen Elementes)
  246. void add( TYP t, int i )
  247. {
  248. if( i < 0 )
  249. return;
  250. ArrayEintrag< TYP > *e = entries;
  251. for( int a = 0; a < i; ++a )
  252. {
  253. if( !e->next )
  254. {
  255. ArrayEintrag< TYP > *ne = new ArrayEintrag< TYP >();
  256. ne->set = 0;
  257. ne->next = 0;
  258. e->next = ne;
  259. }
  260. e = e->next;
  261. }
  262. ArrayEintrag< TYP > *ne = new ArrayEintrag< TYP >();
  263. ne->var = e->var;
  264. ne->set = e->set;
  265. ne->next = e->next;
  266. e->next = ne;
  267. e->var = t;
  268. e->set = 1;
  269. }
  270. //! Setzt den Wert des i-ten Eintrags
  271. //! \param t der Neue Wert
  272. //! \param i Der Index des Eintrages der gesetzt werden soll
  273. void set( TYP t, int i )
  274. {
  275. if( i < 0 )
  276. return;
  277. ArrayEintrag< TYP > *e = entries;
  278. for( int a = 0; a < i; ++a )
  279. {
  280. if( !e->next )
  281. {
  282. ArrayEintrag< TYP > *ne = new ArrayEintrag< TYP >();
  283. ne->set = 0;
  284. ne->next = 0;
  285. e->next = ne;
  286. }
  287. e = e->next;
  288. }
  289. e->var = t;
  290. e->set = 1;
  291. }
  292. //! Verändert die Position des i-ten Elementes in der Liste
  293. //! \param i Der Index des Elementes, welches verschoben werden soll
  294. //! \param p Die Zielposition des Elementes (danach der neue Index des Elementes)
  295. void setPosition( int i, int p )
  296. {
  297. if( i < 0 || p < 0 || i == p )
  298. return;
  299. ArrayEintrag< TYP > *e = entries;
  300. ArrayEintrag< TYP > *ve = 0;
  301. for( int a = 0; a < i; ++a )
  302. {
  303. if( !e->next )
  304. return;
  305. ve = e;
  306. e = e->next;
  307. }
  308. ArrayEintrag< TYP > *e2 = entries == e ? e->next : entries;
  309. ArrayEintrag< TYP > *ve2 = 0;
  310. for( int a = 0; a < p; ++a )
  311. {
  312. if( !e2 )
  313. return;
  314. ve2 = e2;
  315. if( e2->next == e )
  316. e2 = e->next;
  317. else
  318. e2 = e2->next;
  319. }
  320. if( !e )
  321. return;
  322. if( !ve2 )
  323. entries = e;
  324. else
  325. ve2->next = e;
  326. if( ve )
  327. ve->next = e->next;
  328. else
  329. entries = e->next;
  330. e->next = e2;
  331. }
  332. //! Löscht ein Bestimmtes Element
  333. //! \param i Der Index des Elementes das gelöscht werden soll
  334. void remove( int i )
  335. {
  336. if( i < 0 )
  337. return;
  338. ArrayEintrag< TYP > *e = entries;
  339. for( int a = 0; a < i; ++a )
  340. {
  341. if( !e->next )
  342. return;
  343. e = e->next;
  344. }
  345. if( !e )
  346. return;
  347. if( e->next )
  348. {
  349. e->var = e->next->var;
  350. e->set = e->next->set;
  351. }
  352. else
  353. e->set = 0;
  354. ArrayEintrag< TYP > *del = e->next;
  355. if( e->next )
  356. e->next = e->next->next;
  357. else
  358. e->next = 0;
  359. if( del )
  360. {
  361. del->set = 0;
  362. del->next = 0;
  363. delete del;
  364. }
  365. }
  366. //! Löscht ein Bestimmtes Element
  367. //! \param i Der Index des Elementes das gelöscht werden soll
  368. void removeValue( TYP value )
  369. {
  370. ArrayEintrag< TYP > *e = entries;
  371. for( int a = 0; e->var != value; ++a )
  372. {
  373. if( !e->next )
  374. return;
  375. e = e->next;
  376. }
  377. if( !e )
  378. return;
  379. if( e->next )
  380. {
  381. e->var = e->next->var;
  382. e->set = e->next->set;
  383. }
  384. else
  385. e->set = 0;
  386. ArrayEintrag< TYP > *del = e->next;
  387. if( e->next )
  388. e->next = e->next->next;
  389. else
  390. e->next = 0;
  391. if( del )
  392. {
  393. del->set = 0;
  394. del->next = 0;
  395. delete del;
  396. }
  397. }
  398. //! Vertauscht zwei Elemente in der Liste
  399. //! \param vi Der Index des ersten Elementes
  400. //! \param ni Der Index des zweiten Elementes
  401. void tausch( int vi, int ni )
  402. {
  403. if( vi < 0 || ni < 0 )
  404. return;
  405. TYP tmp = get( ni );
  406. set( get( vi ), ni );
  407. set( tmp, vi );
  408. }
  409. //! Löscht alle Elemente der Liste
  410. void leeren()
  411. {
  412. ArrayEintrag< TYP > *e2 = 0;
  413. for( ArrayEintrag< TYP > *e = entries; e; e = e->next )
  414. {
  415. delete e2;
  416. e2 = e;
  417. }
  418. delete e2;
  419. entries = new ArrayEintrag< TYP >();
  420. entries->set = 0;
  421. entries->next = 0;
  422. }
  423. //! Gibt einen Iterator zurück.
  424. //! Mit ++ kann durch die Liste iteriert werden
  425. Iterator< TYP > getIterator() const
  426. {
  427. return Iterator< TYP >( entries );
  428. }
  429. //! Gibt zurück, wie viele Elemente in der Liste sind
  430. int getEintragAnzahl() const
  431. {
  432. int i = 0;
  433. for( auto it = getIterator(); it; it++ )
  434. ++i;
  435. return i;
  436. }
  437. //! Gibt den Wert des i-ten Elementes zurück
  438. //! \param i Der index des gesuchten Elementes
  439. //! throws:
  440. //! \param std:out_of_range wenn i < 0 oder i >= getEintragAnzahl()
  441. TYP get( int i ) const
  442. {
  443. if( i < 0 )
  444. {
  445. Text err = "Index out of Range Exception File: ";
  446. err += __FILE__;
  447. err += " Line: ";
  448. err += __LINE__;
  449. err += " Index: ";
  450. err += i;
  451. throw std::out_of_range( (char *)err );
  452. }
  453. ArrayEintrag< TYP > *e = entries;
  454. for( int a = 0; a < i && e; ++a )
  455. e = e->next;
  456. if( e && e->set )
  457. return e->var;
  458. Text err = "Index out of Range Exception File: ";
  459. err += __FILE__;
  460. err += " Line: ";
  461. err += __LINE__;
  462. err += " Index: ";
  463. err += i;
  464. throw std::out_of_range( (char *)err );
  465. }
  466. //! Überprüft, ob ein Element in der Liste enthalten ist
  467. //! \param i Der Index des gesuchten Elementes
  468. //! \return (true), wenn der Index vorhanden ist. (false) sonnst
  469. bool hat( int i ) const
  470. {
  471. if( i < 0 )
  472. return 0;
  473. ArrayEintrag< TYP > *e = entries;
  474. for( int a = 0; a < i && e; ++a )
  475. e = e->next;
  476. if( e && e->set )
  477. return 1;
  478. return 0;
  479. }
  480. //! Gibt den Index eines Wertes zurück
  481. //! \param t Der Wert, nach dem gesucht werden soll
  482. int getWertIndex( TYP t ) const
  483. {
  484. int ret = 0;
  485. for( ArrayEintrag< TYP > *e = entries; e; e = e->next )
  486. {
  487. if( e->set && e->var == t )
  488. return ret;
  489. ++ret;
  490. }
  491. return -1;
  492. }
  493. Array &operator=( const Array &arr )
  494. {
  495. leeren();
  496. int anz = arr.getEintragAnzahl();
  497. for( int i = 0; i < anz; i++ )
  498. add( arr.get( i ) );
  499. return *this;
  500. }
  501. };
  502. template< class TYP >
  503. //! Eine Linked List von Zeigern auf Zeichnunge, die Reference Counting berteiben
  504. class RCArray : public virtual ReferenceCounter
  505. {
  506. private:
  507. ArrayEintrag< TYP * > *entries;
  508. public:
  509. //! Erstellt eine neue Linked List
  510. RCArray() noexcept
  511. : ReferenceCounter()
  512. {
  513. entries = new ArrayEintrag< TYP * >();
  514. entries->set = 0;
  515. entries->next = 0;
  516. }
  517. //! Kopiert eine Linked list
  518. RCArray( const RCArray &arr )
  519. : ReferenceCounter()
  520. {
  521. entries = new ArrayEintrag< TYP * >();
  522. entries->set = 0;
  523. entries->next = 0;
  524. int anz = arr.getEintragAnzahl();
  525. for( int i = 0; i < anz; i++ )
  526. add( arr.get( i ) );
  527. ref = 1;
  528. }
  529. //! Leert und löscht die Linked List
  530. ~RCArray()
  531. {
  532. leeren();
  533. delete entries;
  534. }
  535. //! Hängt ein Element ans Ende der Liste an
  536. //! \param t Das neue Element
  537. void add( TYP *t )
  538. {
  539. for( ArrayEintrag< TYP * > *e = entries; 1; e = e->next )
  540. {
  541. if( !e->set && !e->next )
  542. {
  543. e->var = t;
  544. e->set = 1;
  545. break;
  546. }
  547. if( !e->next )
  548. {
  549. e->next = new ArrayEintrag< TYP * >();
  550. if( e->next->set && e->next->var )
  551. e->next->var->release();
  552. e->next->set = 0;
  553. e->next->next = 0;
  554. }
  555. }
  556. }
  557. //! Fügt ein Element bei einer bestimmten Position in die Liste ein
  558. //! \param t das neue Element
  559. //! \param i Die Position, wo das Element eingefügt wird (danach der Index des neuen Elementes)
  560. void add( TYP *t, int i )
  561. {
  562. if( i < 0 )
  563. {
  564. if( t )
  565. t->release();
  566. return;
  567. }
  568. ArrayEintrag< TYP * > *e = entries;
  569. for( int a = 0; a < i; ++a )
  570. {
  571. if( !e->next )
  572. {
  573. ArrayEintrag< TYP * > *ne = new ArrayEintrag< TYP * >();
  574. ne->set = 0;
  575. ne->next = 0;
  576. e->next = ne;
  577. }
  578. e = e->next;
  579. }
  580. ArrayEintrag< TYP * > *ne = new ArrayEintrag< TYP * >();
  581. ne->var = e->var;
  582. ne->set = e->set;
  583. ne->next = e->next;
  584. e->next = ne;
  585. e->var = t;
  586. e->set = 1;
  587. }
  588. //! Setzt den Wert des i-ten Eintrags
  589. //! \param t der Neue Wert
  590. //! \param i Der Index des Eintrages der gesetzt werden soll
  591. void set( TYP *t, int i )
  592. {
  593. if( i < 0 )
  594. {
  595. if( t )
  596. t->release();
  597. return;
  598. }
  599. ArrayEintrag< TYP * > *e = entries;
  600. for( int a = 0; a < i; ++a )
  601. {
  602. if( !e->next )
  603. {
  604. ArrayEintrag< TYP * > *ne = new ArrayEintrag< TYP * >();
  605. ne->set = 0;
  606. ne->next = 0;
  607. e->next = ne;
  608. }
  609. e = e->next;
  610. }
  611. if( e->set && e->var )
  612. e->var->release();
  613. e->var = t;
  614. e->set = 1;
  615. }
  616. //! Verändert die Position des i-ten Elementes in der Liste
  617. //! \param i Der Index des Elementes, welches verschoben werden soll
  618. //! \param p Die Zielposition des Elementes (danach der neue Index des Elementes)
  619. void setPosition( int i, int p )
  620. {
  621. if( i < 0 || p < 0 || i == p )
  622. return;
  623. ArrayEintrag< TYP * > *ve = 0;
  624. ArrayEintrag< TYP * > *e = entries;
  625. for( int a = 0; a < i; ++a )
  626. {
  627. if( !e->next )
  628. return;
  629. ve = e;
  630. e = e->next;
  631. }
  632. ArrayEintrag< TYP * > *e2 = entries == e ? e->next : entries;
  633. ArrayEintrag< TYP * > *ve2 = 0;
  634. for( int a = 0; a < p; ++a )
  635. {
  636. if( !e2 )
  637. return;
  638. ve2 = e2;
  639. if( e2->next == e )
  640. e2 = e->next;
  641. else
  642. e2 = e2->next;
  643. }
  644. if( !e )
  645. return;
  646. if( !ve2 )
  647. entries = e;
  648. else
  649. ve2->next = e;
  650. if( ve )
  651. ve->next = e->next;
  652. else
  653. entries = e->next;
  654. e->next = e2;
  655. }
  656. //! Löscht ein Bestimmtes Element
  657. //! \param i Der Index des Elementes das gelöscht werden soll
  658. void remove( int i )
  659. {
  660. if( i < 0 )
  661. return;
  662. ArrayEintrag< TYP * > *e = entries;
  663. for( int a = 0; a < i; ++a )
  664. {
  665. if( !e->next )
  666. return;
  667. e = e->next;
  668. }
  669. if( !e )
  670. return;
  671. if( e->next )
  672. {
  673. if( e->set && e->var )
  674. e->var->release();
  675. e->var = e->next->var;
  676. e->set = e->next->set;
  677. }
  678. else
  679. {
  680. if( e->set && e->var )
  681. e->var->release();
  682. e->set = 0;
  683. }
  684. ArrayEintrag< TYP * > *del = e->next;
  685. if( e->next )
  686. e->next = e->next->next;
  687. else
  688. e->next = 0;
  689. if( del )
  690. {
  691. del->set = 0;
  692. del->next = 0;
  693. delete del;
  694. }
  695. }
  696. //! Vertauscht zwei Elemente in der Liste
  697. //! \param vi Der Index des ersten Elementes
  698. //! \param ni Der Index des zweiten Elementes
  699. void tausch( int vi, int ni )
  700. {
  701. if( vi < 0 || ni < 0 )
  702. return;
  703. TYP *tmp = get( ni );
  704. set( get( vi ), ni );
  705. set( tmp, vi );
  706. }
  707. //! Löscht alle Elemente der Liste
  708. void leeren()
  709. {
  710. ArrayEintrag< TYP * > *e2 = 0;
  711. for( ArrayEintrag< TYP * > *e = entries; e; e = e->next )
  712. {
  713. if( e2 && e2->var && e2->set )
  714. e2->var->release();
  715. delete e2;
  716. e2 = e;
  717. }
  718. if( e2 && e2->var && e2->set )
  719. e2->var->release();
  720. delete e2;
  721. entries = new ArrayEintrag< TYP * >();
  722. entries->set = 0;
  723. entries->next = 0;
  724. }
  725. //! Gibt einen Iterator zurück.
  726. //! Mit ++ kann durch die Liste iteriert werden
  727. Iterator< TYP * > getIterator() const
  728. {
  729. return Iterator< TYP * >( entries );
  730. }
  731. //! Gibt zurück, wie viele Elemente in der Liste sind
  732. int getEintragAnzahl() const
  733. {
  734. int i = 0;
  735. for( auto it = getIterator(); it; it++ )
  736. ++i;
  737. return i;
  738. }
  739. int getLastIndex() const
  740. {
  741. int index = 0;
  742. ArrayEintrag< TYP * > *e = entries;
  743. for( ; e; ++index )
  744. e = e->next;
  745. return index - 1;
  746. }
  747. //! Gibt den Wert des i-ten Elementes zurück mit erhöhtem Reference Counter
  748. //! \param i Der index des gesuchten Elementes, (0) wenn der Index nicht existiert
  749. TYP *get( int i ) const
  750. {
  751. if( i < 0 )
  752. return (TYP *)0;
  753. ArrayEintrag< TYP * > *e = entries;
  754. for( int a = 0; a < i && e; ++a )
  755. e = e->next;
  756. if( e && e->set && e->var )
  757. return dynamic_cast<TYP *>( e->var->getThis() );
  758. return (TYP *)0;
  759. }
  760. //! Gibt den Wert des i-ten Elementes zurück ohne erhöhten Reference Counter
  761. //! \param i Der index des gesuchten Elementes, (0) wenn der Index nicht existiert
  762. TYP *z( int i ) const //! gibt den index - ten T zurück
  763. {
  764. if( i < 0 )
  765. return (TYP *)0;
  766. ArrayEintrag< TYP * > *e = entries;
  767. for( int a = 0; a < i && e; ++a )
  768. e = e->next;
  769. if( e && e->set && e->var )
  770. return (TYP *)e->var;
  771. return (TYP *)0;
  772. }
  773. //! Überprüft, ob ein Element in der Liste enthalten ist
  774. //! \param i Der Index des gesuchten Elementes
  775. //! \return (true), wenn der Index vorhanden ist. (false) sonnst
  776. bool hat( int i ) const
  777. {
  778. if( i < 0 )
  779. return 0;
  780. ArrayEintrag< TYP * > *e = entries;
  781. for( int a = 0; a < i && e; ++a )
  782. e = e->next;
  783. if( e && e->set )
  784. return 1;
  785. return 0;
  786. }
  787. RCArray &operator=( const RCArray &arr )
  788. {
  789. leeren();
  790. int anz = arr.getEintragAnzahl();
  791. for( int i = 0; i < anz; i++ )
  792. add( arr.get( i ) );
  793. return *this;
  794. }
  795. };
  796. }
  797. #endif