vcl_list.h

来自「DTMK软件开发包,此为开源软件,是一款很好的医学图像开发资源.」· C头文件 代码 · 共 645 行 · 第 1/2 页

H
645
字号
        (*tmp).prev = (*position.node).prev;
        (*(link_type((*position.node).prev))).next = tmp;
        (*position.node).prev = tmp;
        ++length;
        return tmp;
    }
    iterator insert(iterator position) { return insert(position, T()); }
    inline void insert(iterator position, const T* first, const T* last);
    inline void insert(iterator position, const_iterator first, const_iterator last);
    inline void insert(iterator position, size_type n, const T& x);
    void push_front(const T& x) { insert(begin(), x); }
    void push_back(const T& x) { insert(end(), x); }
    void erase(iterator position) {
        __stl_debug_check(__check_if_owner(node,position));
        __stl_verbose_assert(position.node!=node, __STL_MSG_ERASE_PAST_THE_END);
        (*(link_type((*position.node).prev))).next = (*position.node).next;
        (*(link_type((*position.node).next))).prev = (*position.node).prev;
        vcl_destroy(&(*position.node).data);
        put_node(position.node);
        --length;
        __stl_debug_do(invalidate_iterator(position));
    }
    inline void erase(iterator first, iterator last);
    inline void resize(size_type new_size, const T& x);
    void resize(size_type new_size) { resize(new_size, T()); }
    inline void clear();

    void pop_front() { erase(begin()); }
    void pop_back() {
        iterator tmp = end();
        erase(--tmp);
    }
    explicit vcl_list(size_type n, const T& value) {
        insert(begin(), n, value);
    }
    explicit vcl_list(size_type n) {
        insert(begin(), n, T());
    }
    vcl_list(const T* first, const T* last) {
        insert(begin(), first, last);
    }
    vcl_list(const_iterator first, const_iterator last) {
        insert(begin(), first, last);
    }
    vcl_list(const self& x) {
        insert(begin(), x.begin(), x.end());
    }
    ~vcl_list() {}
    inline self& operator=(const self& x);

protected:
    void transfer(iterator position, iterator first, iterator last) {
      if (position.node != last.node) {
        (*(link_type((*last.node).prev))).next = position.node;
        (*(link_type((*first.node).prev))).next = last.node;
        (*(link_type((*position.node).prev))).next = first.node;
        link_type tmp = link_type((*position.node).prev);
        (*position.node).prev = (*last.node).prev;
        (*last.node).prev = (*first.node).prev;
        (*first.node).prev = tmp;
      }
    }

public:
    void splice(iterator position, vcl_list<T, Alloc>& x) {
        __stl_verbose_assert(&x!=this, __STL_MSG_INVALID_ARGUMENT);
        __stl_debug_check(__check_if_owner(node,position));
        if (!x.empty()) {
            transfer(position, x.begin(), x.end());
            length += x.length;
            x.length = 0;
            __stl_debug_do(x.invalidate_all());
        }
    }
    void splice(iterator position, vcl_list<T, Alloc>& x, iterator i) {
        __stl_debug_check(__check_if_owner(node,position) &&
                          __check_if_owner(x.node ,i));
        __stl_verbose_assert(i.node!=i.owner(), __STL_MSG_NOT_DEREFERENCEABLE);
        iterator j = i;
        if (position == i || position == ++j) return;
        transfer(position, i, j);
        ++length;
        --x.length;
        __stl_debug_do(x.invalidate_iterator(i));
    }
    void splice(iterator position, vcl_list<T, Alloc>& x, iterator first, iterator last) {
        __stl_debug_check(__check_if_owner(node, position));
        __stl_verbose_assert(first.owner()==x.node && last.owner()==x.node,
                             __STL_MSG_NOT_OWNER);
        if (first != last) {
            if (&x != this) {
                difference_type n = 0;
                vcl_distance(first, last, n);
                x.length -= n;
                length += n;
            }
            transfer(position, first, last);
            __stl_debug_do(x.invalidate_all());
        }
    }
    inline void remove(const T& value);
    inline void unique();
    inline void merge(vcl_list<T, Alloc>& x);
    inline void reverse();
    inline void sort();
};

# if defined (__STL_NESTED_TYPE_PARAM_BUG)
#  define iterator       __list_iterator<T>
#  define const_iterator __list_const_iterator<T>
#  define size_type      vcl_size_t
# endif

template <class T, class Alloc>
INLINE_LOOP void vcl_list<T, Alloc>::insert(iterator position, const T* first, const T* last) {
    for (; first != last; ++first) insert(position, *first);
}

template <class T, class Alloc>
INLINE_LOOP void vcl_list<T, Alloc>::insert(iterator position, const_iterator first,
                                            const_iterator last) {
    for (; first != last; ++first) insert(position, *first);
}

template <class T, class Alloc>
INLINE_LOOP void vcl_list<T, Alloc>::insert(iterator position, size_type n, const T& x) {
    while (n--) insert(position, x);
}

template <class T, class Alloc>
INLINE_LOOP void vcl_list<T, Alloc>::erase(iterator first, iterator last) {
    while (first != last) erase(first++);
}

template <class T, class Alloc>
void vcl_list<T, Alloc>::resize(size_type new_size, const T& x)
{
  if (new_size < size()) {
    iterator f;
    if (new_size < size() / 2) {
      f = begin();
      vcl_advance(f, new_size);
    }
    else {
      f = end();
      vcl_advance(f, difference_type(size()) - difference_type(new_size));
    }
    erase(f, end());
  }
  else
    insert(end(), new_size - size(), x);
}

template <class T, class Alloc>
void vcl_list<T, Alloc>::clear()
{
  super::clear();
  node->next = node;
  node->prev = node;
  length = 0;
}

template <class T, class Alloc>
#ifdef __SUNPRO_CC
inline
#endif
vcl_list<T, Alloc>& vcl_list<T, Alloc>::operator=(const vcl_list<T, Alloc>& x) {
    if (this != &x) {
        iterator first1 = begin();
        iterator last1 = end();
        const_iterator first2 = x.begin();
        const_iterator last2 = x.end();
        while (first1 != last1 && first2 != last2) *first1++ = *first2++;
        if (first2 == last2)
            erase(first1, last1);
        else
            insert(last1, first2, last2);
        __stl_debug_do(invalidate_all());
    }
    return *this;
}

template <class T, class Alloc>
void vcl_list<T, Alloc>::remove(const T& value) {
    iterator first = begin();
    iterator last = end();
    while (first != last) {
        iterator next = first;
        ++next;
        if (*first == value) erase(first);
        first = next;
    }
}

template <class T, class Alloc>
void vcl_list<T, Alloc>::unique() {
    iterator first = begin();
    iterator last = end();
    if (first == last) return;
    iterator next = first;
    while (++next != last) {
        if (*first == *next)
            erase(next);
        else
            first = next;
        next = first;
    }
}

template <class T, class Alloc>
void vcl_list<T, Alloc>::merge(vcl_list<T, Alloc>& x) {
    iterator first1 = begin();
    iterator last1 = end();
    iterator first2 = x.begin();
    iterator last2 = x.end();
    while (first1 != last1 && first2 != last2)
        if (*first2 < *first1) {
            iterator next = first2;
            transfer(first1, first2, ++next);
            first2 = next;
        } else
            ++first1;
    if (first2 != last2) transfer(last1, first2, last2);
    length += x.length;
    x.length= 0;
    __stl_debug_do(x.invalidate_all());
}

template <class T, class Alloc>
void vcl_list<T, Alloc>::reverse() {
    if (size() < 2) return;
    iterator first(begin());
    for (++first; first != end();) {
        iterator old = first++;
        transfer(begin(), old, first);
    }
    __stl_debug_do(invalidate_all());
}

template <class T, class Alloc>
void vcl_list<T, Alloc>::sort() {
    if (size() < 2) return;
    vcl_list<T, Alloc> carry;
    vcl_list<T, Alloc> counter[64];
    int fill = 0;
    while (!empty()) {
        carry.splice(carry.begin(), *this, begin());
        int i = 0;
        while (i < fill && !counter[i].empty()) {
            counter[i].merge(carry);
            carry.swap(counter[i++]);
        }
        carry.swap(counter[i]);
        if (i == fill) ++fill;
    }

    for (int i = 1; i < fill; ++i) counter[i].merge(counter[i-1]);
    swap(counter[fill-1]);
    __stl_debug_do(invalidate_all());
}

# if defined ( __STL_NESTED_TYPE_PARAM_BUG )
#  undef  iterator
#  undef  const_iterator
#  undef  size_type
# endif

// do a cleanup
# undef vcl_list
#  define __list__ __FULL_NAME(vcl_list)
__END_STL_FULL_NAMESPACE

#if !defined ( __STL_DEFAULT_TYPE_PARAM )
// provide a "default" vcl_list adaptor
template <class T>
class vcl_list : public __list__<T,vcl_alloc>
{
    typedef vcl_list<T> self;
public:
    typedef __list__<T,vcl_alloc> super;
    __CONTAINER_SUPER_TYPEDEFS
    __IMPORT_SUPER_COPY_ASSIGNMENT(vcl_list)
    typedef super::link_type link_type;
    vcl_list() { }
    explicit vcl_list(size_type n, const T& value) : super(n, value) { }
    explicit vcl_list(size_type n) :  super(n) { }
    vcl_list(const T* first, const T* last) : super(first, last) { }
    vcl_list(const_iterator first, const_iterator last) : super(first, last) { }
};

#  if defined (__STL_BASE_MATCH_BUG)
template <class T>
inline bool operator==(const vcl_list<T>& x, const vcl_list<T>& y) {
    typedef typename vcl_list<T>::super super;
    return operator == ((const super&)x,(const super&)y);
}

template <class T>
inline bool operator<(const vcl_list<T>& x, const vcl_list<T>& y) {
    typedef typename vcl_list<T>::super super;
    return operator < ((const super&)x,(const super&)y);
}
#  endif
# endif /*  __STL_DEFAULT_TYPE_PARAM */

template <class T, class Alloc>
inline bool operator==(const __list__<T, Alloc>& x, const __list__<T, Alloc>& y) {
    return x.size() == y.size() && vcl_equal(x.begin(), x.end(), y.begin());
}

template <class T, class Alloc>
inline bool operator<(const __list__<T, Alloc>& x, const __list__<T, Alloc>& y) {
    return lexicographical_compare(x.begin(), x.end(), y.begin(), y.end());
}

# if defined (__STL_CLASS_PARTIAL_SPECIALIZATION )
template <class T, class Alloc>
inline void vcl_swap(__list__<T,Alloc>& a, __list__<T,Alloc>& b) { a.swap(b); }
# endif

#endif // vcl_emulation_list_h

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?