source: src/tests/pingpong.c@ 4e66a18

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

add full coroutine tests

  • Property mode set to 100644
File size: 1.3 KB
Line 
1//
2// Cforall Version 1.0.0 Copyright (C) 2017 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// pingpong.c --
8//
9// Author : Peter A. Buhr
10// Created On : Wed Sep 20 11:55:23 2017
11// Last Modified By : Peter A. Buhr
12// Last Modified On : Wed Sep 20 13:41:39 2017
13// Update Count : 26
14//
15
16#include <coroutine>
17#include <fstream>
18
19coroutine PingPong {
20 const char * name;
21 /* const */ unsigned int N;
22 PingPong * part;
23};
24
25void ?{}( PingPong & this, const char * name, unsigned int N, PingPong & part ) {
26 this.name = name;
27 this.N = N;
28 this.part = &part;
29}
30void ?{}( PingPong & this, const char * name, unsigned int N ) {
31 this{ name, N, *(PingPong *)0 };
32}
33void cycle( PingPong & pingpong ) {
34 resume( pingpong );
35}
36void partner( PingPong & this, PingPong & part ) {
37 this.part = &part;
38 resume( this );
39}
40void main( PingPong & pingpong ) { // ping's starter ::main, pong's starter ping
41 for ( unsigned int i = 0; i < pingpong.N; i += 1 ) {
42 sout | pingpong.name | endl;
43 cycle( *pingpong.part );
44 } // for
45}
46int main() {
47 enum { N = 20 };
48 PingPong ping = { "ping", N }, pong = { "pong", N, ping };
49 partner( ping, pong );
50}
51
52// Local Variables: //
53// tab-width: 4 //
54// compile-command: "cfa pingpong.c" //
55// End: //
Note: See TracBrowser for help on using the repository browser.