⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 qvaluelist.h

📁 著名的A780系列,E680系列的SDK开发包
💻 H
字号:
/****************************************************************************** $Id: qt/src/tools/qvaluelist.h   2.3.6   edited 2002-12-09 $**** Definition of QValueList class**** Created : 990406**** Copyright (C) 1992-2000 Trolltech AS.  All rights reserved.**** This file is part of the tools module of the Qt GUI Toolkit.**** This file may be distributed under the terms of the Q Public License** as defined by Trolltech AS of Norway and appearing in the file** LICENSE.QPL included in the packaging of this file.**** This file may be distributed and/or modified under the terms of the** GNU General Public License version 2 as published by the Free Software** Foundation and appearing in the file LICENSE.GPL included in the** packaging of this file.**** Licensees holding valid Qt Enterprise Edition or Qt Professional Edition** licenses may use this file in accordance with the Qt Commercial License** Agreement provided with the Software.**** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.**** See http://www.trolltech.com/pricing.html or email sales@trolltech.com for**   information about Qt Commercial License Agreements.** See http://www.trolltech.com/qpl/ for QPL licensing information.** See http://www.trolltech.com/gpl/ for GPL licensing information.**** Contact info@trolltech.com if any conditions of this licensing are** not clear to you.************************************************************************/#ifndef QVALUELIST_H#define QVALUELIST_H#ifndef QT_H#include "qshared.h"#include "qdatastream.h"#endif // QT_H#if defined(_CC_MSVC_)#pragma warning(disable:4284) // "return type for operator -> is not a UDT"#endiftemplate <class T>class Q_EXPORT QValueListNode{public:    QValueListNode( const T& t ) : data( t ) { }    QValueListNode() { }#if defined(Q_TEMPLATEDLL)    // Workaround MS bug in memory de/allocation in DLL vs. EXE     virtual ~QValueListNode() { }#endif    QValueListNode<T>* next;    QValueListNode<T>* prev;    T data;};template<class T>class Q_EXPORT QValueListIterator{ public:    /**     * Typedefs     */    typedef QValueListNode<T>* NodePtr;    /**     * Variables     */    NodePtr node;    /**     * Functions     */    QValueListIterator() : node( 0 ) {}    QValueListIterator( NodePtr p ) : node( p ) {}    QValueListIterator( const QValueListIterator<T>& it ) : node( it.node ) {}    bool operator==( const QValueListIterator<T>& it ) const { return node == it.node; }    bool operator!=( const QValueListIterator<T>& it ) const { return node != it.node; }    const T& operator*() const { return node->data; }    T& operator*() { return node->data; }    // Compilers are too dumb to understand this for QValueList<int>    //T* operator->() const { return &(node->data); }    QValueListIterator<T>& operator++() {	node = node->next;	return *this;    }    QValueListIterator<T> operator++(int) {	QValueListIterator<T> tmp = *this;	node = node->next;	return tmp;    }    QValueListIterator<T>& operator--() {	node = node->prev;	return *this;    }    QValueListIterator<T> operator--(int) {	QValueListIterator<T> tmp = *this;	node = node->prev;	return tmp;    }};template<class T>class Q_EXPORT QValueListConstIterator{ public:    /**     * Typedefs     */    typedef QValueListNode<T>* NodePtr;    /**     * Variables     */    NodePtr node;    /**     * Functions     */    QValueListConstIterator() : node( 0 ) {}    QValueListConstIterator( NodePtr p ) : node( p ) {}    QValueListConstIterator( const QValueListConstIterator<T>& it ) : node( it.node ) {}    QValueListConstIterator( const QValueListIterator<T>& it ) : node( it.node ) {}    bool operator==( const QValueListConstIterator<T>& it ) const { return node == it.node; }    bool operator!=( const QValueListConstIterator<T>& it ) const { return node != it.node; }    const T& operator*() const { return node->data; }    // Compilers are too dumb to understand this for QValueList<int>    //const T* operator->() const { return &(node->data); }    QValueListConstIterator<T>& operator++() {	node = node->next;	return *this;    }    QValueListConstIterator<T> operator++(int) {	QValueListConstIterator<T> tmp = *this;	node = node->next;	return tmp;    }    QValueListConstIterator<T>& operator--() {	node = node->prev;	return *this;    }    QValueListConstIterator<T> operator--(int) {	QValueListConstIterator<T> tmp = *this;	node = node->prev;	return tmp;    }};template <class T>class Q_EXPORT QValueListPrivate : public QShared{public:    /**     * Typedefs     */    typedef QValueListIterator<T> Iterator;    typedef QValueListConstIterator<T> ConstIterator;    typedef QValueListNode<T> Node;    typedef QValueListNode<T>* NodePtr;    /**     * Functions     */    QValueListPrivate() { node = new Node; node->next = node->prev = node; nodes = 0; }    QValueListPrivate( const QValueListPrivate<T>& _p ) : QShared() {	node = new Node; node->next = node->prev = node; nodes = 0;	Iterator b( _p.node->next );	Iterator e( _p.node );	Iterator i( node );	while( b != e )	    insert( i, *b++ );    }    void derefAndDelete() // ### hack to get around hp-cc brain damage    {	if ( deref() )	    delete this;    }#if defined(Q_TEMPLATEDLL)    // Workaround MS bug in memory de/allocation in DLL vs. EXE     virtual#endif    ~QValueListPrivate() {	NodePtr p = node->next;	while( p != node ) {	    NodePtr x = p->next;	    delete p;	    p = x;	}	delete node;    }    Iterator insert( Iterator it, const T& x ) {	NodePtr p = new Node( x );	p->next = it.node;	p->prev = it.node->prev;	it.node->prev->next = p;	it.node->prev = p;	nodes++;	return p;    }    Iterator remove( Iterator it ) {	ASSERT ( it.node != node );	NodePtr next = it.node->next;	NodePtr prev = it.node->prev;	prev->next = next;	next->prev = prev;	delete it.node;	nodes--;	return Iterator( next );    }    NodePtr find( NodePtr start, const T& x ) const {	ConstIterator first( start );	ConstIterator last( node );	while( first != last) {	    if ( *first == x )		return first.node;	    ++first;	}	return last.node;    }    int findIndex( NodePtr start, const T& x ) const {	ConstIterator first( start );	ConstIterator last( node );	int pos = 0;	while( first != last) {	    if ( *first == x )		return pos;	    ++first;	    ++pos;	}	return -1;    }    uint contains( const T& x ) const {	uint result = 0;	Iterator first = Iterator( node->next );	Iterator last = Iterator( node );	while( first != last) {	    if ( *first == x )		++result;	    ++first;	}	return result;    }    void remove( const T& x ) {	Iterator first = Iterator( node->next );	Iterator last = Iterator( node );	while( first != last) {	    if ( *first == x )		first = remove( first );	    else		++first;	}    }    NodePtr at( uint i ) const {	ASSERT( i <= nodes );	NodePtr p = node->next;	for( uint x = 0; x < i; ++x )	    p = p->next;	return p;    }    void clear() {	nodes = 0;	NodePtr p = node->next;	while( p != node ) {	    NodePtr next = p->next;	    delete p;	    p = next;	}	node->next = node->prev = node;    }    NodePtr node;    uint nodes;};template <class T>class Q_EXPORT QValueList{public:    /**     * Typedefs     */    typedef QValueListIterator<T> Iterator;    typedef QValueListConstIterator<T> ConstIterator;    typedef T ValueType;    /**     * API     */    QValueList() { sh = new QValueListPrivate<T>; }    QValueList( const QValueList<T>& l ) { sh = l.sh; sh->ref(); }    ~QValueList() { sh->derefAndDelete(); }    QValueList<T>& operator= ( const QValueList<T>& l )    {	l.sh->ref();	sh->derefAndDelete();	sh = l.sh;	return *this;    }    QValueList<T> operator+ ( const QValueList<T>& l ) const    {	QValueList<T> l2( *this );	for( ConstIterator it = l.begin(); it != l.end(); ++it )	    l2.append( *it );	return l2;    }    QValueList<T>& operator+= ( const QValueList<T>& l )    {	for( ConstIterator it = l.begin(); it != l.end(); ++it )	    append( *it );	return *this;    }    bool operator== ( const QValueList<T>& l ) const    {	if ( count() != l.count() )	    return FALSE;	ConstIterator it2 = begin();	ConstIterator it = l.begin();	for( ; it != l.end(); ++it, ++it2 )	    if ( !( *it == *it2 ) )		return FALSE;	return TRUE;    }    bool operator!= ( const QValueList<T>& l ) const { return !( *this == l ); }    Iterator begin() { detach(); return Iterator( sh->node->next ); }    ConstIterator begin() const { return ConstIterator( sh->node->next ); }    Iterator end() { detach(); return Iterator( sh->node ); }    ConstIterator end() const { return ConstIterator( sh->node ); }    Iterator fromLast() { detach(); return Iterator( sh->node->prev ); }    ConstIterator fromLast() const { return ConstIterator( sh->node->prev ); }    bool isEmpty() const { return ( sh->nodes == 0 ); }    Iterator insert( Iterator it, const T& x ) { detach(); return sh->insert( it, x ); }    Iterator append( const T& x ) { detach(); return sh->insert( end(), x ); }    Iterator prepend( const T& x ) { detach(); return sh->insert( begin(), x ); }    Iterator remove( Iterator it ) { detach(); return sh->remove( it ); }    void remove( const T& x ) { detach(); sh->remove( x ); }    T& first() { detach(); return sh->node->next->data; }    const T& first() const { return sh->node->next->data; }    T& last() { detach(); return sh->node->prev->data; }    const T& last() const { return sh->node->prev->data; }    T& operator[] ( uint i ) { detach(); return sh->at(i)->data; }    const T& operator[] ( uint i ) const { return sh->at(i)->data; }    Iterator at( uint i ) { detach(); return Iterator( sh->at(i) ); }    ConstIterator at( uint i ) const { return ConstIterator( sh->at(i) ); }    Iterator find ( const T& x ) { detach(); return Iterator( sh->find( sh->node->next, x) ); }    ConstIterator find ( const T& x ) const { return ConstIterator( sh->find( sh->node->next, x) ); }    Iterator find ( Iterator it, const T& x ) { detach(); return Iterator( sh->find( it.node, x ) ); }    ConstIterator find ( ConstIterator it, const T& x ) const { return ConstIterator( sh->find( it.node, x ) ); }    int findIndex( const T& x ) const { return sh->findIndex( sh->node->next, x) ; }    uint contains( const T& x ) const { return sh->contains( x ); }    uint count() const { return sh->nodes; }    void clear() { if ( sh->count == 1 ) sh->clear(); else { sh->deref(); sh = new QValueListPrivate<T>; } }    QValueList<T>& operator+= ( const T& x )    {	append( x );	return *this;    }    QValueList<T>& operator<< ( const T& x )    {	append( x );	return *this;    }protected:    /**     * Helpers     */    void detach() { if ( sh->count > 1 ) { sh->deref(); sh = new QValueListPrivate<T>( *sh ); } }    /**     * Variables     */    QValueListPrivate<T>* sh;};#if defined(Q_TEMPLATEDLL)template class Q_EXPORT QValueList<int>;#endif#ifndef QT_NO_DATASTREAMtemplate<class T>inline QDataStream& operator>>( QDataStream& s, QValueList<T>& l ){    l.clear();    Q_UINT32 c;    s >> c;    for( Q_UINT32 i = 0; i < c; ++i )    {	T t;	s >> t;	l.append( t );	if ( s.atEnd() )	    break;    }    return s;}template<class T>inline QDataStream& operator<<( QDataStream& s, const QValueList<T>& l ){    s << (Q_UINT32)l.count();    QValueListConstIterator<T> it = l.begin();    for( ; it != l.end(); ++it )	s << *it;    return s;}#endif // QT_NO_DATASTREAM#endif // QVALUELIST_H

⌨️ 快捷键说明

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