亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? bags.h

?? 小程序
?? H
字號:
/*------------------------------------------------------------------------*/
/*                                                                        */
/*  BAGS.H                                                                */
/*                                                                        */
/*  Copyright Borland International 1991                                  */
/*  All Rights Reserved                                                   */
/*                                                                        */
/*------------------------------------------------------------------------*/

#if !defined( __BAGS_H )
#define __BAGS_H

#if !defined( __CHECKS_H )
#include <Checks.h>
#endif	// __CHECKS_H

#if !defined( __SHDDEL_H )
#include <ShdDel.h>
#endif	// __SHDDEL_H

#if !defined( __VECTIMP_H )
#include <VectImp.h>
#endif	// __VECTIMP_H

#if !defined( __RESOURCE_H )
#include <Resource.h>
#endif	// __RESOURCE_H

#if !defined( __COLLECT_H )
#include <Collect.h>
#endif	// __COLLECT_H

/*------------------------------------------------------------------------*/
/*                                                                        */
/*  template <class Vect, class T> class BI_BagAsVectorImp                */
/*                                                                        */
/*  Implements a bag, using a vector as the underlying implementation.    */
/*  The type Vect specifies the form of the vector, either a              */
/*  BI_CVectorImp<T0> or a BI_ICVectorImp<T0>.  The type T specifies the  */
/*  type of the objects to be put in the bag.  When using                 */
/*  BI_VectorImp<T0>, T should be the same as T0. When using              */
/*  BI_IVectorImp<T0>, T should be of type pointer to T0.  See            */
/*  BI_BagAsVector and BI_IBagAsVector for examples.                      */
/*                                                                        */
/*------------------------------------------------------------------------*/

template <class Vect, class T> class _CLASSTYPE BI_BagAsVectorImp
{

public:

    BI_BagAsVectorImp( unsigned sz = DEFAULT_BAG_SIZE ) :
        data(sz,1)
        {
        }

    void add( T t )
        {
        data.add( t );
        }

    void detach( T t, TShouldDelete::DeleteType = TShouldDelete::NoDelete )
        {
        data.detach( t );
        }

    void flush( TShouldDelete::DeleteType = TShouldDelete::DefDelete )
        {
        data.flush();
        }

    int hasMember( T t ) const
        {
        return data.find(t) != UINT_MAX;
        }

    T findMember( T t ) const
        {
        PRECONDITION( hasMember(t) );
        return data[data.find(t)];
        }

    int isEmpty() const
        {
        return data.isEmpty();
        }

    int isFull() const
        { return 0;
        }

    int getItemsInContainer() const
        {
        return data.top();
        }

protected:

    Vect data;

};

/*------------------------------------------------------------------------*/
/*                                                                        */
/*  template <class T> class BI_BagAsVector                               */
/*                                                                        */
/*  Implements a bag of objects of type T, using a vector as              */
/*  the underlying implementation.                                        */
/*                                                                        */
/*------------------------------------------------------------------------*/

template <class T> class _CLASSTYPE BI_BagAsVector :
    public BI_BagAsVectorImp<BI_CVectorImp<T>,T>
{

public:

    friend class _CLASSTYPE BI_BagAsVectorIterator<T>;

    BI_BagAsVector( unsigned sz = DEFAULT_BAG_SIZE ) :
        BI_BagAsVectorImp<BI_CVectorImp<T>,T>( sz )
        {
        }

    void forEach( void (_FAR *f)(T _FAR &, void _FAR *), void _FAR *args )
        {
        data.forEach( f, args, 0, data.top() );
        }

    T _FAR *firstThat( int (_FAR *f)(const T _FAR &, void _FAR *),
                       void _FAR *args
                     ) const
        {
        return data.firstThat( f, args, 0, data.top() );
        }

    T _FAR *lastThat( int (_FAR *f)(const T _FAR &, void _FAR *),
                      void _FAR *args
                    ) const
        {
        return data.lastThat( f, args, 0, data.top() );
        }

protected:

    virtual T _FAR *find( T ) const;

};

template <class T> T _FAR *BI_BagAsVector<T>::find( T t ) const
{
    if( isEmpty() )
        return 0;
    for( int index = 0; index < data.top(); index++ )
        if( data[index] == t )
            return &(data[index]);
    return 0;
}

template <class T> class _CLASSTYPE BI_BagAsVectorIterator :
    public BI_VectorIteratorImp<T>
{

public:

    BI_BagAsVectorIterator( const BI_BagAsVector<T> _FAR & b ) :
        BI_VectorIteratorImp<T>(b.data,0,b.data.top()) {}

};

/*------------------------------------------------------------------------*/
/*                                                                        */
/*  template <class T> class BI_IBagAsVector                              */
/*                                                                        */
/*  Implements a bag of pointers to objects of type T,                    */
/*  using a vector as the underlying implementation.                      */
/*                                                                        */
/*------------------------------------------------------------------------*/

template <class T> class _CLASSTYPE BI_IBagAsVector :
    public BI_BagAsVectorImp<BI_ICVectorImp<T>,T _FAR *>,
    public virtual TShouldDelete
{

public:

    friend class _CLASSTYPE BI_IBagAsVectorIterator<T>;

    BI_IBagAsVector( unsigned sz = DEFAULT_BAG_SIZE ) :
        BI_BagAsVectorImp<BI_ICVectorImp<T>,T _FAR *>(sz)
        {
        }

    ~BI_IBagAsVector()
        {
        flush();
        }

    void add( T _FAR *t )
        {
        BI_BagAsVectorImp<BI_ICVectorImp<T>,T _FAR *>::add(t);
        }

    void detach( T _FAR *t, DeleteType dt = NoDelete )
        {
        data.detach( t, delObj(dt) );
        }

    void flush( TShouldDelete::DeleteType dt = TShouldDelete::DefDelete )
        {
        data.flush( delObj(dt), data.top(), 0 );
        }

    T _FAR *findMember( T _FAR *t ) const
        {
        unsigned loc = data.find(t);
        return (T _FAR *)( loc == UINT_MAX ? 0 : data[loc] );
        }

    void forEach( void (_FAR *f)(T _FAR &, void _FAR *), void _FAR *args )
        {
        data.forEach( f, args, 0, data.top() );
        }

    T _FAR *firstThat( int (_FAR *f)(const T _FAR &, void _FAR *),
                       void _FAR *args
                     ) const
        {
        return data.firstThat( f, args, 0, data.top() );
        }

    T _FAR *lastThat( int (_FAR *f)(const T _FAR &, void _FAR *),
                      void _FAR *args
                    ) const
        {
        return data.lastThat( f, args, 0, data.top() );
        }

};

template <class T> class _CLASSTYPE BI_IBagAsVectorIterator :
    public BI_IVectorIteratorImp<T>
{

public:

    BI_IBagAsVectorIterator( const BI_IBagAsVector<T> _FAR & s ) :
        BI_IVectorIteratorImp<T>(s.data,0,s.data.top()) {}

};

/*------------------------------------------------------------------------*/
/*                                                                        */
/*  class BI_OBagAsVector                                                 */
/*                                                                        */
/*  Implements a bag of pointers to Object,                               */
/*  using a vector as the underlying implementation.                      */
/*                                                                        */
/*------------------------------------------------------------------------*/

class _CLASSTYPE BI_OBagAsVector
{

public:

    friend class _CLASSTYPE BI_OBagAsVectorIterator;

    BI_OBagAsVector( unsigned sz = DEFAULT_BAG_SIZE ) :
        obag( sz )
        {
        }

    void add( Object _FAR *o )
        {
        obag.add(o);
        }

    void detach( Object _FAR *o,
                 TShouldDelete::DeleteType dt = TShouldDelete::NoDelete
               )
        {
        obag.detach( o, dt );
        }

    void flush( TShouldDelete::DeleteType dt = TShouldDelete::DefDelete )
        {
        obag.flush( dt );
        }

    int hasMember( Object _FAR *o ) const
        {
        return obag.hasMember(o);
        }

    Object _FAR *findMember( Object _FAR *o ) const
        {
        Object _FAR *obj = obag.findMember( o );
        return obj != 0 ? obj : 0;
        }

    int isEmpty() const
        {
        return obag.isEmpty();
        }

    int isFull() const
        {
        return obag.isFull();
        }

    void forEach( void (_FAR*f)(Object _FAR &, void _FAR*), void _FAR*args )
        {
        obag.forEach( f, args );
        }

    Object _FAR *firstThat( int (_FAR *f)(const Object _FAR &, void _FAR *),
                            void _FAR *args
                          ) const
        {
        return obag.firstThat( f, args );
        }

    Object _FAR *lastThat( int (_FAR *f)(const Object _FAR &, void _FAR *),
                           void _FAR *args
                         ) const
        {
        return obag.lastThat( f, args );
        }

    int getItemsInContainer() const
        {
        return obag.getItemsInContainer();
        }

    int ownsElements()
        {
        return obag.ownsElements();
        }

    void ownsElements( int del )
        {
        obag.ownsElements( del );
        }

protected:

    BI_IBagAsVector<Object> obag;

};

class _CLASSTYPE BI_OBagAsVectorIterator :
    public BI_IBagAsVectorIterator<Object>
{

public:

    BI_OBagAsVectorIterator( const BI_OBagAsVector _FAR & b ) :
        BI_IBagAsVectorIterator<Object>(b.obag)
        {
        }

};

/*------------------------------------------------------------------------*/
/*                                                                        */
/*  class BI_TCBagAsVector                                                */
/*                                                                        */
/*  Implements an Object bag, with the full semantics of                  */
/*  the BC 2.0 style Bag, using a vector as the underlying                */
/*  implementation.                                                       */
/*                                                                        */
/*------------------------------------------------------------------------*/

class _CLASSTYPE BI_TCBagAsVector : public Collection
{

public:

    friend class _CLASSTYPE BI_TCBagAsVectorIterator;

    BI_TCBagAsVector( int sz = DEFAULT_BAG_SIZE ) :
        bag(sz)
        {
        }

    virtual void add( Object _FAR & o )
        {
        bag.add( &o );
        }

    virtual void detach( Object _FAR & o,
                    TShouldDelete::DeleteType dt = TShouldDelete::NoDelete )
        {
        bag.detach( &o, dt );
        }

    virtual void flush(TShouldDelete::DeleteType dt=TShouldDelete::DefDelete )
        {
        bag.flush( dt );
        }

    virtual int isEmpty() const
        {
        return bag.isEmpty();
        }

    virtual countType getItemsInContainer() const
        {
        return bag.getItemsInContainer();
        }

    void forEach( void (_FAR*f)(Object _FAR &, void _FAR*), void _FAR*args )
        {
        bag.forEach( f, args );
        }

    Object _FAR & firstThat( int (_FAR *f)(const Object _FAR &, void _FAR *),
                             void _FAR *args
                           ) const
        {
        return ptrToRef(bag.firstThat( f, args ));
        }

    Object _FAR & lastThat( int (_FAR *f)(const Object _FAR &, void _FAR *),
                            void _FAR *args
                          ) const
        {
        return ptrToRef(bag.lastThat( f, args ));
        }

    virtual int hasMember( Object _FAR & o ) const
        {
        return bag.hasMember( &o );
        }

    virtual Object _FAR & findMember( Object _FAR & o ) const
        {
        return ptrToRef(bag.findMember(&o));
        }

    virtual ContainerIterator _FAR & initIterator() const;

    virtual classType isA() const
        {
        return bagClass;
        }

    virtual char _FAR *nameOf() const
        {
        return "BI_TCBagAsVector";
        }

    int ownsElements()
        {
        return bag.ownsElements();
        }

    void ownsElements( int del )
        {
        bag.ownsElements( del );
        }

protected:

    BI_OBagAsVector bag;

};

class _CLASSTYPE BI_TCBagAsVectorIterator : public ContainerIterator
{

public:

    BI_TCBagAsVectorIterator( const BI_TCBagAsVector _FAR &b ) :
        iter(b.bag)
        {
        }

    virtual operator int()
        {
        return int(iter);
        }

    virtual Object _FAR & current()
        {
        return Object::ptrToRef(iter.current());
        }

    virtual Object _FAR & operator ++ ( int )
        {
        return Object::ptrToRef(iter++);
        }

    virtual Object _FAR & operator ++ ()
        {
        return Object::ptrToRef(++iter);
        }

    virtual void restart()
        {
        iter.restart();
        }

private:

    BI_OBagAsVectorIterator iter;

};

inline ContainerIterator _FAR & BI_TCBagAsVector::initIterator() const
{
    return *new BI_TCBagAsVectorIterator( *this );
}

#endif  // __BAGS_H

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲免费av在线| 精品一区二区三区久久| 中文字幕一区在线观看视频| 久久这里只有精品视频网| 日韩一级欧美一级| 精品sm在线观看| 久久综合九色综合97婷婷| 精品国产3级a| 久久精品欧美一区二区三区不卡| 久久久亚洲高清| 国产精品久久久久影院| 亚洲欧美日韩人成在线播放| 一区二区三区四区高清精品免费观看| 亚洲黄网站在线观看| 一个色综合av| 日韩不卡一二三区| 九色|91porny| 国产成人精品亚洲午夜麻豆| 成人免费高清在线| 色成年激情久久综合| 欧美色网一区二区| 日韩精品一区二区在线观看| 久久九九全国免费| 亚洲精品高清在线| 日韩激情视频网站| 国产成人av在线影院| 色94色欧美sute亚洲线路二| 51午夜精品国产| 久久久一区二区| 亚洲欧美成aⅴ人在线观看| 亚洲五码中文字幕| 激情欧美一区二区| 99精品在线观看视频| 欧美精品第1页| 久久人人爽人人爽| 亚洲欧美激情在线| 美女一区二区久久| 99re免费视频精品全部| 69久久夜色精品国产69蝌蚪网| 精品国产免费一区二区三区香蕉| 午夜欧美大尺度福利影院在线看| 轻轻草成人在线| 国产成a人无v码亚洲福利| 欧美日韩中文一区| 久久婷婷国产综合精品青草| 亚洲精品videosex极品| 精品一区二区三区免费视频| 99精品久久只有精品| 欧美一区二区三区免费在线看| 国产精品国产三级国产普通话蜜臀| 亚洲超碰97人人做人人爱| 国产成人99久久亚洲综合精品| 欧美日韩一本到| 日本一区二区免费在线| 爽爽淫人综合网网站 | 91网站在线播放| 69成人精品免费视频| 中文字幕日韩欧美一区二区三区| 日韩国产一二三区| 色视频成人在线观看免| 久久久久9999亚洲精品| 亚洲成人综合网站| av一二三不卡影片| 精品久久久久久亚洲综合网| 亚洲最大成人网4388xx| 国产999精品久久久久久| 91精品国产日韩91久久久久久| 亚洲天堂中文字幕| 国产精品白丝av| 日韩区在线观看| 亚洲一区二区三区小说| 成人av在线网站| 久久综合精品国产一区二区三区| 亚洲二区在线观看| 色综合中文字幕国产 | 色呦呦一区二区三区| 久久综合九色欧美综合狠狠| 日本午夜一本久久久综合| 欧洲精品视频在线观看| 中文字幕一区二区三区蜜月| 国产成人精品影院| 久久久久久**毛片大全| 美女任你摸久久| 欧美精品久久天天躁| 亚洲午夜av在线| 在线一区二区观看| 一区精品在线播放| 欧美久久一二三四区| 亚洲综合色区另类av| 97久久久精品综合88久久| 中文欧美字幕免费| 国产精品一级黄| 久久这里只有精品视频网| 久久av中文字幕片| 日韩欧美美女一区二区三区| 天堂资源在线中文精品| 成人18视频在线播放| 亚洲一区二区三区视频在线| 成人午夜电影网站| 久久久天堂av| 国产精品一二三在| 国产亚洲欧洲一区高清在线观看| 精品一区二区免费在线观看| 日韩欧美久久久| 久久成人免费网站| 精品99999| 国产精品66部| 国产精品麻豆欧美日韩ww| 不卡一区在线观看| 亚洲三级小视频| 在线免费视频一区二区| 亚洲一区二区综合| 777奇米四色成人影色区| 麻豆专区一区二区三区四区五区| 日韩三级.com| 国产不卡视频在线观看| 日韩美女精品在线| 欧美视频一区在线| 日本午夜精品一区二区三区电影| 精品人在线二区三区| 国产福利一区二区三区视频在线| 中文字幕+乱码+中文字幕一区| 99国产精品久| 亚洲电影视频在线| 精品日韩一区二区| 亚洲国产精品高清| 国产成人在线看| 1024国产精品| 91久久精品一区二区三区| 性做久久久久久久久| 日韩欧美高清dvd碟片| 国产69精品久久777的优势| **欧美大码日韩| 欧美挠脚心视频网站| 国内精品视频666| 国产精品成人免费| 欧美成人猛片aaaaaaa| 成人晚上爱看视频| 一区二区免费在线| 日韩美女一区二区三区四区| 成人动漫视频在线| 日日摸夜夜添夜夜添精品视频| 久久色在线视频| 91网页版在线| 久久99国产精品免费| 亚洲欧洲韩国日本视频| 91麻豆精品国产自产在线| 国产成人精品影院| 午夜久久久久久久久| 中日韩免费视频中文字幕| 欧美肥大bbwbbw高潮| 丁香婷婷综合网| 日韩精品电影一区亚洲| 国产蜜臀av在线一区二区三区| 日韩免费视频一区| 国产成人综合亚洲91猫咪| 亚洲女人的天堂| 久久综合给合久久狠狠狠97色69| 99国内精品久久| 韩国v欧美v日本v亚洲v| 亚洲一区在线看| 日本一区免费视频| 日韩欧美激情四射| 一本色道久久综合亚洲精品按摩| 国产主播一区二区| 日韩精品亚洲一区| 亚洲图片激情小说| 国产亚洲成aⅴ人片在线观看| 欧美日韩精品一区二区天天拍小说| 高清免费成人av| 美腿丝袜亚洲色图| 亚洲电影在线播放| 综合久久久久久| 久久久精品人体av艺术| 4438x亚洲最大成人网| 91老师片黄在线观看| 国产成人亚洲综合a∨婷婷图片| 日韩精品久久久久久| 亚洲精品中文字幕在线观看| 国产欧美精品一区aⅴ影院| 日韩你懂的在线播放| 宅男噜噜噜66一区二区66| 色婷婷久久久亚洲一区二区三区| 国产成人av福利| 韩日精品视频一区| 免费观看在线综合色| 偷偷要91色婷婷| 亚洲国产精品一区二区尤物区| 中文字幕中文乱码欧美一区二区| 国产三级三级三级精品8ⅰ区| 欧美xxxx老人做受| 日韩一区二区三区在线| 欧美人与性动xxxx| 在线观看91视频| 色噜噜狠狠成人网p站| 91免费版在线| 色综合视频在线观看| 91小视频在线| 色狠狠综合天天综合综合| 色屁屁一区二区|