source: src/examples/iostream.c@ e56cfdb0

ADT aaron-thesis arm-eh ast-experimental cleanup-dtors ctor deferred_resn demangler enum forall-pointer-decay gc_noraii jacob/cs343-translation jenkins-sandbox memory new-ast new-ast-unique-expr new-env no_list persistent-indexer pthread-emulation qualifiedEnum resolv-new string with_gc
Last change on this file since e56cfdb0 was e56cfdb0, checked in by Peter A. Buhr <pabuhr@…>, 10 years ago

allow nested routines to use type variables in containing scope, fix missing adapters, generalized iostream write

  • Property mode set to 100644
File size: 2.7 KB
Line 
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.c --
8//
9// Author : Richard C. Bilson
10// Created On : Wed May 27 17:56:53 2015
11// Last Modified By : Peter A. Buhr
12// Last Modified On : Thu Nov 19 17:54:38 2015
13// Update Count : 4
14//
15
16#include "iostream.h"
17extern "C" {
18#include <stdio.h>
19//#include <string.h>
20//#include <ctype.h>
21 typedef long unsigned int size_t;
22 size_t strlen(const char *s);
23}
24
25forall( dtype ostype | ostream( ostype ) )
26ostype * ?<<?( ostype *os, char c ) {
27 return write( os, &c, 1 );
28}
29
30forall( dtype ostype | ostream( ostype ) )
31ostype * ?<<?( ostype *os, int i ) {
32 char buffer[32]; // larger than the largest integer
33 sprintf( buffer, "%d", i );
34 return write( os, buffer, strlen( buffer ) );
35}
36
37forall( dtype ostype | ostream( ostype ) )
38ostype * ?<<?( ostype *os, double d ) {
39 char buffer[32]; // larger than the largest double
40 sprintf( buffer, "%g", d );
41 return write( os, buffer, strlen( buffer ) );
42}
43
44forall( dtype ostype | ostream( ostype ) )
45ostype * ?<<?( ostype *os, const char *cp ) {
46 return write( os, cp, strlen( cp ) );
47}
48
49forall( dtype ostype | ostream( ostype ) )
50ostype * ?<<?( ostype *os, const void *p ) {
51 char buffer[32]; // larger than the largest pointer
52 sprintf( buffer, "%p", p );
53 return write( os, buffer, strlen( buffer ) );
54}
55
56forall( type elt_type | writeable( elt_type ),
57 type iterator_type | iterator( iterator_type, elt_type ),
58 dtype os_type | ostream( os_type ) )
59void write( iterator_type begin, iterator_type end, os_type *os ) {
60 void print( elt_type i ) {
61 os << i << ' ';
62 }
63 for_each( begin, end, print );
64}
65
66forall( type elt_type | writeable( elt_type ),
67 type iterator_type | iterator( iterator_type, elt_type ),
68 dtype os_type | ostream( os_type ) )
69void write_reverse( iterator_type begin, iterator_type end, os_type *os ) {
70 void print( elt_type i ) {
71 os << i << ' ';
72 }
73 for_each_reverse( begin, end, print );
74}
75
76
77forall( dtype istype | istream( istype ) )
78istype * ?>>?( istype *is, char *cp ) {
79 return read( is, cp, 1 );
80}
81
82forall( dtype istype | istream( istype ) )
83istype * ?>>?( istype *is, int *ip ) {
84 char cur;
85
86 // skip some whitespace
87 do {
88 is >> &cur;
89 if ( fail( is ) || eof( is ) ) return is;
90 } while ( !( cur >= '0' && cur <= '9' ) );
91
92 // accumulate digits
93 *ip = 0;
94 while ( cur >= '0' && cur <= '9' ) {
95 *ip = *ip * 10 + ( cur - '0' );
96 is >> &cur;
97 if ( fail( is ) || eof( is ) ) return is;
98 }
99
100 unread( is, cur );
101 return is;
102}
103
104// Local Variables: //
105// tab-width: 4 //
106// compile-command: "cfa iostream.c" //
107// End: //
Note: See TracBrowser for help on using the repository browser.