source: tests/concurrency/actors/pingpong.cfa @ 50be8af

Last change on this file since 50be8af was 50be8af, checked in by Peter A. Buhr <pabuhr@…>, 10 months ago

clean up command-line handling and I/O

  • Property mode set to 100644
File size: 1.2 KB
Line 
1#include <fstream.hfa>
2#include <stdlib.hfa>
3#include <string.h>
4#include <stdio.h>
5#include <mutex_stmt.hfa>
6#include <actor.hfa>
7
8struct ping { inline actor; };
9struct pong { inline actor; };
10
11struct p_msg {
12    inline message;
13    size_t count;
14};
15static inline void ?{}( p_msg & this ) { ((message &)this){}; this.count = 0; }
16
17ping * pi;
18pong * po;
19size_t times = 100000;
20
21allocation receive( ping & receiver, p_msg & msg ) {
22    msg.count++;
23    if ( msg.count > times ) return Finished;
24
25    allocation retval = Nodelete;
26    if ( msg.count == times ) retval = Finished;
27    *po | msg;
28    return retval;
29}
30
31allocation receive( pong & receiver, p_msg & msg ) {
32    msg.count++;
33    if ( msg.count > times ) return Finished;
34   
35    allocation retval = Nodelete;
36    if ( msg.count == times ) retval = Finished;
37    *pi | msg;
38    return retval;
39}
40
41size_t Processors = 2;
42
43int main( int argc, char * argv[] ) {
44    sout | "start";
45
46    processor p[Processors - 1];
47
48    start_actor_system( Processors ); // test passing number of processors
49
50    ping pi_actor;
51    pong po_actor;
52    po = &po_actor;
53    pi = &pi_actor;
54    p_msg m;
55    pi_actor | m;
56    stop_actor_system();
57
58    sout | "end";
59}
Note: See TracBrowser for help on using the repository browser.