| 1 | // | 
|---|
| 2 | // Cforall Version 1.0.0 Copyright (C) 2015 University of Waterloo | 
|---|
| 3 | // | 
|---|
| 4 | // The contents of this file are covered under the licence agreement in the | 
|---|
| 5 | // file "LICENCE" distributed with Cforall. | 
|---|
| 6 | // | 
|---|
| 7 | // iostream -- | 
|---|
| 8 | // | 
|---|
| 9 | // Author           : Peter A. Buhr | 
|---|
| 10 | // Created On       : Wed May 27 17:56:53 2015 | 
|---|
| 11 | // Last Modified By : Peter A. Buhr | 
|---|
| 12 | // Last Modified On : Thu Jan 25 13:08:39 2018 | 
|---|
| 13 | // Update Count     : 149 | 
|---|
| 14 | // | 
|---|
| 15 |  | 
|---|
| 16 | #pragma once | 
|---|
| 17 |  | 
|---|
| 18 | #include "iterator" | 
|---|
| 19 |  | 
|---|
| 20 | trait ostream( dtype ostype ) { | 
|---|
| 21 | // private | 
|---|
| 22 | _Bool sepPrt( ostype & );                                                       // return separator state (on/off) | 
|---|
| 23 | void sepReset( ostype & );                                                      // set separator state to default state | 
|---|
| 24 | void sepReset( ostype &, _Bool );                                       // set separator and default state | 
|---|
| 25 | const char * sepGetCur( ostype & );                                     // get current separator string | 
|---|
| 26 | void sepSetCur( ostype &, const char * );                       // set current separator string | 
|---|
| 27 | _Bool getNL( ostype & );                                                        // check newline | 
|---|
| 28 | void setNL( ostype &, _Bool );                                          // saw newline | 
|---|
| 29 | // public | 
|---|
| 30 | void sepOn( ostype & );                                                         // turn separator state on | 
|---|
| 31 | void sepOff( ostype & );                                                        // turn separator state off | 
|---|
| 32 | _Bool sepDisable( ostype & );                                           // set default state to off, and return previous state | 
|---|
| 33 | _Bool sepEnable( ostype & );                                            // set default state to on, and return previous state | 
|---|
| 34 |  | 
|---|
| 35 | const char * sepGet( ostype & );                                        // get separator string | 
|---|
| 36 | void sepSet( ostype &, const char * );                          // set separator to string (15 character maximum) | 
|---|
| 37 | const char * sepGetTuple( ostype & );                           // get tuple separator string | 
|---|
| 38 | void sepSetTuple( ostype &, const char * );                     // set tuple separator to string (15 character maximum) | 
|---|
| 39 |  | 
|---|
| 40 | int fail( ostype & ); | 
|---|
| 41 | int flush( ostype & ); | 
|---|
| 42 | void open( ostype & os, const char * name, const char * mode ); | 
|---|
| 43 | void close( ostype & os ); | 
|---|
| 44 | ostype & write( ostype &, const char *, unsigned long int ); | 
|---|
| 45 | int fmt( ostype &, const char fmt[], ... ); | 
|---|
| 46 | }; // ostream | 
|---|
| 47 |  | 
|---|
| 48 | // trait writeable( otype T ) { | 
|---|
| 49 | //      forall( dtype ostype | ostream( ostype ) ) ostype & ?|?( ostype &, T ); | 
|---|
| 50 | // }; // writeable | 
|---|
| 51 |  | 
|---|
| 52 | trait writeable( otype T, dtype ostype | ostream( ostype ) ) { | 
|---|
| 53 | ostype & ?|?( ostype &, T ); | 
|---|
| 54 | }; // writeable | 
|---|
| 55 |  | 
|---|
| 56 | // implement writable for intrinsic types | 
|---|
| 57 |  | 
|---|
| 58 | forall( dtype ostype | ostream( ostype ) ) ostype & ?|?( ostype &, _Bool ); | 
|---|
| 59 |  | 
|---|
| 60 | forall( dtype ostype | ostream( ostype ) ) ostype & ?|?( ostype &, char ); | 
|---|
| 61 | forall( dtype ostype | ostream( ostype ) ) ostype & ?|?( ostype &, signed char ); | 
|---|
| 62 | forall( dtype ostype | ostream( ostype ) ) ostype & ?|?( ostype &, unsigned char ); | 
|---|
| 63 |  | 
|---|
| 64 | forall( dtype ostype | ostream( ostype ) ) ostype & ?|?( ostype &, short int ); | 
|---|
| 65 | forall( dtype ostype | ostream( ostype ) ) ostype & ?|?( ostype &, unsigned short int ); | 
|---|
| 66 | forall( dtype ostype | ostream( ostype ) ) ostype & ?|?( ostype &, int ); | 
|---|
| 67 | forall( dtype ostype | ostream( ostype ) ) ostype & ?|?( ostype &, unsigned int ); | 
|---|
| 68 | forall( dtype ostype | ostream( ostype ) ) ostype & ?|?( ostype &, long int ); | 
|---|
| 69 | forall( dtype ostype | ostream( ostype ) ) ostype & ?|?( ostype &, long long int ); | 
|---|
| 70 | forall( dtype ostype | ostream( ostype ) ) ostype & ?|?( ostype &, unsigned long int ); | 
|---|
| 71 | forall( dtype ostype | ostream( ostype ) ) ostype & ?|?( ostype &, unsigned long long int ); | 
|---|
| 72 |  | 
|---|
| 73 | forall( dtype ostype | ostream( ostype ) ) ostype & ?|?( ostype &, float ); // FIX ME: should not be required | 
|---|
| 74 | forall( dtype ostype | ostream( ostype ) ) ostype & ?|?( ostype &, double ); | 
|---|
| 75 | forall( dtype ostype | ostream( ostype ) ) ostype & ?|?( ostype &, long double ); | 
|---|
| 76 |  | 
|---|
| 77 | forall( dtype ostype | ostream( ostype ) ) ostype & ?|?( ostype &, float _Complex ); | 
|---|
| 78 | forall( dtype ostype | ostream( ostype ) ) ostype & ?|?( ostype &, double _Complex ); | 
|---|
| 79 | forall( dtype ostype | ostream( ostype ) ) ostype & ?|?( ostype &, long double _Complex ); | 
|---|
| 80 |  | 
|---|
| 81 | forall( dtype ostype | ostream( ostype ) ) ostype & ?|?( ostype &, const char * ); | 
|---|
| 82 | forall( dtype ostype | ostream( ostype ) ) ostype & ?|?( ostype &, const char16_t * ); | 
|---|
| 83 | #if ! ( __ARM_ARCH_ISA_ARM == 1 && __ARM_32BIT_STATE == 1 ) // char32_t == wchar_t => ambiguous | 
|---|
| 84 | forall( dtype ostype | ostream( ostype ) ) ostype & ?|?( ostype &, const char32_t * ); | 
|---|
| 85 | #endif // ! ( __ARM_ARCH_ISA_ARM == 1 && __ARM_32BIT_STATE == 1 ) | 
|---|
| 86 | forall( dtype ostype | ostream( ostype ) ) ostype & ?|?( ostype &, const wchar_t * ); | 
|---|
| 87 | forall( dtype ostype | ostream( ostype ) ) ostype & ?|?( ostype &, const void * ); | 
|---|
| 88 |  | 
|---|
| 89 | // tuples | 
|---|
| 90 | forall( dtype ostype, otype T, ttype Params | writeable( T, ostype ) | { ostype & ?|?( ostype &, Params ); } ) | 
|---|
| 91 | ostype & ?|?( ostype & os, T arg, Params rest ); | 
|---|
| 92 |  | 
|---|
| 93 | // manipulators | 
|---|
| 94 | forall( dtype ostype | ostream( ostype ) ) ostype & ?|?( ostype &, ostype & (*)( ostype & ) ); | 
|---|
| 95 | forall( dtype ostype | ostream( ostype ) ) ostype & endl( ostype & ); | 
|---|
| 96 | forall( dtype ostype | ostream( ostype ) ) ostype & sep( ostype & ); | 
|---|
| 97 | forall( dtype ostype | ostream( ostype ) ) ostype & sepTuple( ostype & ); | 
|---|
| 98 | forall( dtype ostype | ostream( ostype ) ) ostype & sepOn( ostype & ); | 
|---|
| 99 | forall( dtype ostype | ostream( ostype ) ) ostype & sepOff( ostype & ); | 
|---|
| 100 | forall( dtype ostype | ostream( ostype ) ) ostype & sepDisable( ostype & ); | 
|---|
| 101 | forall( dtype ostype | ostream( ostype ) ) ostype & sepEnable( ostype & ); | 
|---|
| 102 |  | 
|---|
| 103 | // writes the range [begin, end) to the given stream | 
|---|
| 104 | forall( dtype ostype, otype elt_type | writeable( elt_type, ostype ), otype iterator_type | iterator( iterator_type, elt_type ) ) | 
|---|
| 105 | void write( iterator_type begin, iterator_type end, ostype & os ); | 
|---|
| 106 |  | 
|---|
| 107 | forall( dtype ostype, otype elt_type | writeable( elt_type, ostype ), otype iterator_type | iterator( iterator_type, elt_type ) ) | 
|---|
| 108 | void write_reverse( iterator_type begin, iterator_type end, ostype & os ); | 
|---|
| 109 |  | 
|---|
| 110 | //--------------------------------------- | 
|---|
| 111 |  | 
|---|
| 112 | trait istream( dtype istype ) { | 
|---|
| 113 | int fail( istype & ); | 
|---|
| 114 | int eof( istype & ); | 
|---|
| 115 | void open( istype & is, const char * name ); | 
|---|
| 116 | void close( istype & is ); | 
|---|
| 117 | istype & read( istype &, char *, unsigned long int ); | 
|---|
| 118 | istype & ungetc( istype &, char ); | 
|---|
| 119 | int fmt( istype &, const char fmt[], ... ); | 
|---|
| 120 | }; // istream | 
|---|
| 121 |  | 
|---|
| 122 | trait readable( otype T ) { | 
|---|
| 123 | forall( dtype istype | istream( istype ) ) istype & ?|?( istype &, T ); | 
|---|
| 124 | }; // readable | 
|---|
| 125 |  | 
|---|
| 126 | forall( dtype istype | istream( istype ) ) istype & ?|?( istype &, _Bool & ); | 
|---|
| 127 |  | 
|---|
| 128 | forall( dtype istype | istream( istype ) ) istype & ?|?( istype &, char & ); | 
|---|
| 129 | forall( dtype istype | istream( istype ) ) istype & ?|?( istype &, signed char & ); | 
|---|
| 130 | forall( dtype istype | istream( istype ) ) istype & ?|?( istype &, unsigned char & ); | 
|---|
| 131 |  | 
|---|
| 132 | forall( dtype istype | istream( istype ) ) istype & ?|?( istype &, short int & ); | 
|---|
| 133 | forall( dtype istype | istream( istype ) ) istype & ?|?( istype &, unsigned short int & ); | 
|---|
| 134 | forall( dtype istype | istream( istype ) ) istype & ?|?( istype &, int & ); | 
|---|
| 135 | forall( dtype istype | istream( istype ) ) istype & ?|?( istype &, unsigned int & ); | 
|---|
| 136 | forall( dtype istype | istream( istype ) ) istype & ?|?( istype &, long int & ); | 
|---|
| 137 | forall( dtype istype | istream( istype ) ) istype & ?|?( istype &, long long int & ); | 
|---|
| 138 | forall( dtype istype | istream( istype ) ) istype & ?|?( istype &, unsigned long int & ); | 
|---|
| 139 | forall( dtype istype | istream( istype ) ) istype & ?|?( istype &, unsigned long long int & ); | 
|---|
| 140 |  | 
|---|
| 141 | forall( dtype istype | istream( istype ) ) istype & ?|?( istype &, float & ); | 
|---|
| 142 | forall( dtype istype | istream( istype ) ) istype & ?|?( istype &, double & ); | 
|---|
| 143 | forall( dtype istype | istream( istype ) ) istype & ?|?( istype &, long double & ); | 
|---|
| 144 |  | 
|---|
| 145 | forall( dtype istype | istream( istype ) ) istype & ?|?( istype &, float _Complex & ); | 
|---|
| 146 | forall( dtype istype | istream( istype ) ) istype & ?|?( istype &, double _Complex & ); | 
|---|
| 147 | forall( dtype istype | istream( istype ) ) istype & ?|?( istype &, long double _Complex & ); | 
|---|
| 148 |  | 
|---|
| 149 | // manipulators | 
|---|
| 150 | forall( dtype istype | istream( istype ) ) istype & ?|?( istype &, istype & (*)( istype & ) ); | 
|---|
| 151 | forall( dtype istype | istream( istype ) ) istype & endl( istype & is ); | 
|---|
| 152 |  | 
|---|
| 153 | struct _Istream_cstrUC { char * s; }; | 
|---|
| 154 | _Istream_cstrUC cstr( char * ); | 
|---|
| 155 | forall( dtype istype | istream( istype ) ) istype & ?|?( istype &, _Istream_cstrUC ); | 
|---|
| 156 |  | 
|---|
| 157 | struct _Istream_cstrC { char * s; int size; }; | 
|---|
| 158 | _Istream_cstrC cstr( char *, int size ); | 
|---|
| 159 | forall( dtype istype | istream( istype ) ) istype & ?|?( istype &, _Istream_cstrC ); | 
|---|
| 160 |  | 
|---|
| 161 | // Local Variables: // | 
|---|
| 162 | // mode: c // | 
|---|
| 163 | // tab-width: 4 // | 
|---|
| 164 | // End: // | 
|---|