Ignore:
Timestamp:
May 22, 2018, 2:43:09 PM (5 years ago)
Author:
Thierry Delisle <tdelisle@…>
Branches:
aaron-thesis, arm-eh, cleanup-dtors, deferred_resn, demangler, enum, forall-pointer-decay, jacob/cs343-translation, jenkins-sandbox, master, new-ast, new-ast-unique-expr, new-env, no_list, persistent-indexer, pthread-emulation, qualifiedEnum, with_gc
Children:
a1a17a7
Parents:
cac8a6e
Message:

removed workaround for tuple references

File:
1 edited

Legend:

Unmodified
Added
Removed
  • src/libcfa/bits/containers.h

    rcac8a6e r639991a  
    220220        }
    221221
    222         #define _next .0
    223         #define _prev .1
     222        #define next 0
     223        #define prev 1
    224224        forall(dtype T | sized(T))
    225225        static inline void push_front( __dllist(T) & this, T & node ) with( this ) {
    226226                if ( head ) {
    227                         __get( node )_next = head;
    228                         __get( node )_prev = __get( *head )_prev;
     227                        __get( node ).next = head;
     228                        __get( node ).prev = __get( *head ).prev;
    229229                        // inserted node must be consistent before it is seen
    230230                        // prevent code movement across barrier
    231231                        asm( "" : : : "memory" );
    232                         __get( *head )_prev = &node;
    233                         T & prev = *__get( node )_prev;
    234                         __get( prev )_next = &node;
     232                        __get( *head ).prev = &node;
     233                        T & _prev = *__get( node ).prev;
     234                        __get( _prev ).next = &node;
    235235                }
    236236                else {
    237                         __get( node )_next = &node;
    238                         __get( node )_prev = &node;
     237                        __get( node ).next = &node;
     238                        __get( node ).prev = &node;
    239239                }
    240240
     
    247247        static inline void remove( __dllist(T) & this, T & node ) with( this ) {
    248248                if ( &node == head ) {
    249                         if ( __get( *head )_next == head ) {
     249                        if ( __get( *head ).next == head ) {
    250250                                head = NULL;
    251251                        }
    252252                        else {
    253                                 head = __get( *head )_next;
     253                                head = __get( *head ).next;
    254254                        }
    255255                }
    256                 __get( *__get( node )_next )_prev = __get( node )_prev;
    257                 __get( *__get( node )_prev )_next = __get( node )_next;
    258                 __get( node )_next = NULL;
    259                 __get( node )_prev = NULL;
    260         }
    261         #undef _next
    262         #undef _prev
     256                __get( *__get( node ).next ).prev = __get( node ).prev;
     257                __get( *__get( node ).prev ).next = __get( node ).next;
     258                __get( node ).next = NULL;
     259                __get( node ).prev = NULL;
     260        }
     261        #undef next
     262        #undef prev
    263263#endif
    264264
Note: See TracChangeset for help on using the changeset viewer.