ADT
        arm-eh
        ast-experimental
        enum
        forall-pointer-decay
        jacob/cs343-translation
        new-ast-unique-expr
        pthread-emulation
        qualifiedEnum
      
      
        
          | 
            Last change
 on this file since c08c3cf was             fd54fef, checked in by Michael Brooks <mlbrooks@…>, 5 years ago           | 
        
        
          | 
             
Converting the project to use the new syntax for otype, dtype and ttytpe. 
 
Changed prelude (gen), libcfa and test suite to use it.  Added a simple deprecation rule of the old syntax to the parser; we might wish to support both syntaxes "officially," like with an extra CLI switch, but this measure should serve as a simple reminder for our team to try the new syntax. 
 
           | 
        
        
          
            
              - 
Property                 mode
 set to                 
100644
               
             
           | 
        
        
          | 
            File size:
            1.2 KB
           | 
        
      
      
| Rev | Line |   | 
|---|
| [73abe95] | 1 | #include <fstream.hfa>
 | 
|---|
 | 2 | #include <kernel.hfa>
 | 
|---|
 | 3 | #include <monitor.hfa>
 | 
|---|
 | 4 | #include <thread.hfa>
 | 
|---|
| [2781e65] | 5 | 
 | 
|---|
 | 6 | static int global12, global23, global13;
 | 
|---|
 | 7 | 
 | 
|---|
| [bcda04c] | 8 | monitor monitor_t {};
 | 
|---|
| [ef42b143] | 9 | 
 | 
|---|
 | 10 | static monitor_t m1, m2, m3;
 | 
|---|
| [2781e65] | 11 | 
 | 
|---|
| [83a071f9] | 12 | void increment( monitor_t & mutex p1, monitor_t & mutex p2, int & value ) {
 | 
|---|
| [3381ed7] | 13 |         assert(active_thread() == get_monitor(p1)->owner);
 | 
|---|
 | 14 |         assert(active_thread() == get_monitor(p2)->owner);
 | 
|---|
| [83a071f9] | 15 |         value += 1;
 | 
|---|
| [3381ed7] | 16 |         assert(active_thread() == get_monitor(p1)->owner);
 | 
|---|
 | 17 |         assert(active_thread() == get_monitor(p2)->owner);
 | 
|---|
| [2781e65] | 18 | }
 | 
|---|
 | 19 | 
 | 
|---|
| [83a071f9] | 20 | thread MyThread {
 | 
|---|
| [2781e65] | 21 |         int target;
 | 
|---|
 | 22 | };
 | 
|---|
 | 23 | 
 | 
|---|
| [00e80b6] | 24 | void ?{}( MyThread & this, int target ) {
 | 
|---|
 | 25 |         this.target = target;
 | 
|---|
| [2781e65] | 26 | }
 | 
|---|
 | 27 | 
 | 
|---|
| [00e80b6] | 28 | void ^?{}( MyThread & mutex this ) {}
 | 
|---|
| [cb0e6de] | 29 | 
 | 
|---|
| [83a071f9] | 30 | void main( MyThread & this ) {
 | 
|---|
| [2781e65] | 31 |         for(int i = 0; i < 1000000; i++) {
 | 
|---|
| [83a071f9] | 32 |                 choose(this.target) {
 | 
|---|
 | 33 |                         case 0: increment( m1, m2, global12 );
 | 
|---|
 | 34 |                         case 1: increment( m2, m3, global23 );
 | 
|---|
 | 35 |                         case 2: increment( m1, m3, global13 );
 | 
|---|
| [2781e65] | 36 |                 }
 | 
|---|
 | 37 |         }
 | 
|---|
 | 38 | }
 | 
|---|
 | 39 | 
 | 
|---|
| [fd54fef] | 40 | forall(T & | sized(T) | { void ^?{}(T & mutex); })
 | 
|---|
| [83a071f9] | 41 | void delete_mutex(T * x) {
 | 
|---|
 | 42 |         ^(*x){};
 | 
|---|
 | 43 |         free(x);
 | 
|---|
 | 44 | }
 | 
|---|
 | 45 | 
 | 
|---|
| [2781e65] | 46 | int main(int argc, char* argv[]) {
 | 
|---|
 | 47 |         processor p;
 | 
|---|
 | 48 |         {
 | 
|---|
| [83a071f9] | 49 |                 MyThread * f[6];
 | 
|---|
| [2781e65] | 50 |                 for(int i = 0; i < 6; i++) {
 | 
|---|
| [83a071f9] | 51 |                         f[i] = new(i % 3);
 | 
|---|
| [2781e65] | 52 |                 }
 | 
|---|
 | 53 | 
 | 
|---|
 | 54 |                 for(int i = 0; i < 6; i++) {
 | 
|---|
| [83a071f9] | 55 |                         delete_mutex( f[i] );
 | 
|---|
| [2781e65] | 56 |                 }
 | 
|---|
 | 57 |         }
 | 
|---|
| [200fcb3] | 58 |         sout | global12 | global23 | global13;
 | 
|---|
| [00e80b6] | 59 | }
 | 
|---|
       
      
  Note:
 See   
TracBrowser
 for help on using the repository browser.