Ignore:
Timestamp:
Jan 27, 2025, 9:23:35 PM (10 days ago)
Author:
kyoung <lseo@…>
Branches:
master
Children:
2e0bb92, 71ca5b9
Parents:
11f92fac
git-author:
kyoung <lseo@…> (01/27/25 14:34:28)
git-committer:
kyoung <lseo@…> (01/27/25 21:23:35)
Message:

plan9 inline ordering for concurrency keywords.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • libcfa/src/concurrency/future.hfa

    r11f92fac rc3d0182a  
    99// Author           : Thierry Delisle & Peiran Hong & Colby Parsons
    1010// Created On       : Wed Jan 06 17:33:18 2021
    11 // Last Modified By : Peter A. Buhr
    12 // Last Modified On : Fri Nov 29 16:07:34 2024
    13 // Update Count     : 30
     11// Last Modified By : Kyoung Seo
     12// Last Modified On : Mon Jan 27 20:35:00 2025
     13// Update Count     : 3
    1414//
    1515
     
    260260                        if( this.has_first != false) abort("Attempting to reset a multi_future with at least one blocked threads");
    261261                        if( !is_empty(this.blocked) ) abort("Attempting to reset a multi_future with multiple blocked threads");
    262                         reset( (future_t&)this );
     262                        reset( (future_t&)*(&this+sizeof(monitor$)) );
    263263                }
    264264
     
    266266                bool fulfil( multi_future(T) & this, T result ) {
    267267                        this.result = result;
    268                         return fulfil( (future_t&)this ) != 0p;
     268                        return fulfil( (future_t&)*(&this+sizeof(monitor$)) ) != 0p;
    269269                }
    270270
     
    275275                        bool w = !sw;
    276276                        if ( sw ) {
    277                                 w = wait( (future_t&)this );
     277                                w = wait( (future_t&)*(&this+sizeof(monitor$)) );
    278278                                $first_done( this );
    279279                        }
Note: See TracChangeset for help on using the changeset viewer.