home *** CD-ROM | disk | FTP | other *** search
/ Geek Gadgets 1 / ADE-1.bin / ade-dist / libg++-2.7.1-bin.lha / lib / g++-include / gen / PVec.hP < prev    next >
Text File  |  1996-10-12  |  3KB  |  80 lines

  1. /*  : light weight Vector: This will simply reuse code from  */
  2. /* a VoidP Vec, which was genclassed from the Vec libg++ class.     */
  3. /* The classes generated from this file will all be derived classes */
  4. /* from class VoidVec or intVec.  No .cc file is generated.  So     */
  5. /* it costs nothing to use these type-safe Vectors. Only member     */
  6. /* functions needing type casting are re-defined.                   */
  7. /*  */
  8.  
  9. #ifndef _<T>Vec_h
  10. #define _<T>Vec_h 1
  11.  
  12. #include "VoidP.Vec.h"
  13. #include "<T>.defs.h"
  14.  
  15.  
  16. #ifndef _<T>_typedefs
  17. #define _<T>_typedefs 1
  18. typedef void (*<T>Procedure)(<T> );
  19. typedef <T>  (*<T>Mapper)(<T> );
  20. typedef <T>  (*<T>Combiner)(<T> , <T> );
  21. typedef int  (*<T>Predicate)(<T> );
  22. typedef int  (*<T>Comparator)(<T> , <T> );
  23. #endif
  24.  
  25. class <T>Vec : public VoidPVec
  26. {
  27. protected:
  28.   <T>Vec(int l, <T>* d) : (l, (VoidP*) d) {};
  29. public:
  30.   <T>Vec() {};
  31.   <T>Vec(int l) : (l) {};
  32.   <T>Vec(int l, <T&> fill_value) : (l, fill_value) {};
  33.   <T>Vec(<T>Vec& v) : (v) {};
  34.   <T>Vec(VoidPVec& v) {fake_copy(v, s, len);}
  35.   ~<T>Vec() {};
  36.  
  37.   <T>Vec& operator = (<T>Vec& a)
  38.            {return (<T>Vec&) VoidPVec::operator= (a);}
  39.   <T>Vec  at(int from, int n) {return (<T>Vec) VoidPVec::at(from, n);}
  40.  
  41.   <T>&    operator [] (int n) {return (<T>&)VoidPVec::operator[] (n);}
  42.   <T>&    elem(int n) {return (<T>&)VoidPVec::elem(n);}
  43.  
  44.   friend <T>Vec   concat(<T>Vec& a, <T>Vec& b);
  45.   friend <T>Vec   map(<T>Mapper f, <T>Vec & a);
  46.   friend <T>Vec   merge(<T>Vec & a, <T>Vec & b, <T>Comparator f);
  47.   friend <T>Vec   combine(<T>Combiner f, <T>Vec & a, <T>Vec & b);
  48.   friend <T>Vec   reverse(<T>Vec& a);
  49.  
  50.   void sort(<T>Comparator f);
  51.   void apply(<T>Procedure f);
  52.   <T> reduce(<T>Combiner f, <T> base);
  53. };
  54.  
  55. inline <T>Vec concat(<T>Vec& a, <T>Vec& b)
  56. {return (<T>Vec)concat((VoidPVec&)a, (VoidPVec&)b);}
  57.  
  58. inline <T>Vec   map(<T>Mapper f, <T>Vec & a) {
  59.   return (<T>Vec)map((VoidPMapper)f, (VoidPVec&)a); }
  60.  
  61. inline <T>Vec   merge(<T>Vec & a, <T>Vec & b, <T>Comparator f) {
  62.   return (<T>Vec)merge((VoidPVec&)a, (VoidPVec&)b, (VoidPComparator)f); }
  63.  
  64. inline <T>Vec   combine(<T>Combiner f, <T>Vec & a, <T>Vec & b) {
  65.   return (<T>Vec)combine((VoidPCombiner)f, (VoidPVec&)a, (VoidPVec&)b); }
  66.  
  67. inline <T>Vec reverse(<T>Vec& a) {
  68.   return (<T>Vec)reverse((VoidPVec&)a);}
  69.  
  70. inline void <T>Vec::sort(<T>Comparator f) {
  71.   VoidPVec::sort((VoidPComparator) f); }
  72.  
  73. inline void <T>Vec::apply(<T>Procedure f) {
  74.   VoidPVec::apply((VoidPProcedure) f); }
  75.  
  76. inline <T> <T>Vec::reduce(<T>Combiner f, <T> base) {
  77.   return (<T>)VoidPVec::reduce((VoidPCombiner)f, base);}
  78.  
  79. #endif /* conditional include */
  80.