kset.h

Go to the documentation of this file.
00001 
00004 #ifndef FBXFILESDK_COMPONENTS_KBASELIB_KLIB_KSET_H
00005 #define FBXFILESDK_COMPONENTS_KBASELIB_KLIB_KSET_H
00006 
00007 /**************************************************************************************
00008 
00009  Copyright (C) 2001 - 2009 Autodesk, Inc. and/or its licensors.
00010  All Rights Reserved.
00011 
00012  The coded instructions, statements, computer programs, and/or related material 
00013  (collectively the "Data") in these files contain unpublished information 
00014  proprietary to Autodesk, Inc. and/or its licensors, which is protected by 
00015  Canada and United States of America federal copyright law and by international 
00016  treaties. 
00017  
00018  The Data may not be disclosed or distributed to third parties, in whole or in
00019  part, without the prior written consent of Autodesk, Inc. ("Autodesk").
00020 
00021  THE DATA IS PROVIDED "AS IS" AND WITHOUT WARRANTY.
00022  ALL WARRANTIES ARE EXPRESSLY EXCLUDED AND DISCLAIMED. AUTODESK MAKES NO
00023  WARRANTY OF ANY KIND WITH RESPECT TO THE DATA, EXPRESS, IMPLIED OR ARISING
00024  BY CUSTOM OR TRADE USAGE, AND DISCLAIMS ANY IMPLIED WARRANTIES OF TITLE, 
00025  NON-INFRINGEMENT, MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE OR USE. 
00026  WITHOUT LIMITING THE FOREGOING, AUTODESK DOES NOT WARRANT THAT THE OPERATION
00027  OF THE DATA WILL BE UNINTERRUPTED OR ERROR FREE. 
00028  
00029  IN NO EVENT SHALL AUTODESK, ITS AFFILIATES, PARENT COMPANIES, LICENSORS
00030  OR SUPPLIERS ("AUTODESK GROUP") BE LIABLE FOR ANY LOSSES, DAMAGES OR EXPENSES
00031  OF ANY KIND (INCLUDING WITHOUT LIMITATION PUNITIVE OR MULTIPLE DAMAGES OR OTHER
00032  SPECIAL, DIRECT, INDIRECT, EXEMPLARY, INCIDENTAL, LOSS OF PROFITS, REVENUE
00033  OR DATA, COST OF COVER OR CONSEQUENTIAL LOSSES OR DAMAGES OF ANY KIND),
00034  HOWEVER CAUSED, AND REGARDLESS OF THE THEORY OF LIABILITY, WHETHER DERIVED
00035  FROM CONTRACT, TORT (INCLUDING, BUT NOT LIMITED TO, NEGLIGENCE), OR OTHERWISE,
00036  ARISING OUT OF OR RELATING TO THE DATA OR ITS USE OR ANY OTHER PERFORMANCE,
00037  WHETHER OR NOT AUTODESK HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH LOSS
00038  OR DAMAGE. 
00039 
00040 **************************************************************************************/
00041 
00042 #include <fbxfilesdk/fbxfilesdk_def.h>
00043 
00044 #include <fbxfilesdk/fbxfilesdk_nsbegin.h>
00045 
00046     struct SSet;
00047 
00048     // *************************************************************************
00049     //
00050     //  class KSet
00051     //
00052     // ************************************************************************* 
00053 
00057     class KFBX_DLL KSet {
00058     public:
00059         enum
00060         {
00061             KFBX_NOT_FOUND        = 0x0L,
00062             KFBX_ITEM_PER_BLOCK   = 20
00063         };
00064 
00069 
00070         
00074         KSet( int pItemPerBlock = KFBX_ITEM_PER_BLOCK );
00075 
00079         KSet(const KSet& other);
00080 
00082         ~KSet();
00084 
00085         // Add and remove
00092         bool  Add       ( kReference pReference, kReference pItem );
00093 
00094         
00099         bool  Remove        ( kReference pReference );
00100         
00105         bool  RemoveItem    ( kReference pItem );
00106 
00112         bool  SetItem   ( kReference pReference, kReference pItem ); // Change Item Reference, don't Create if doesn't Exist
00113 
00120         kReference Get ( kReference pReference, int* pIndex = NULL ) const;
00121 
00123         void     Clear();
00124 
00125         // Index manipulation
00131         kReference GetFromIndex ( int pIndex, kReference* pReference = NULL )const;
00132 
00137         bool  RemoveFromIndex( int pIndex );
00138 
00139         // Get The Count
00143         int  GetCount ()const       { return mSetCount; }
00144 
00145         // Sorting
00150         bool  Swap()const;
00151 
00152         //The array can be sorted only if the private member:mIsChanged be true.
00156         bool  Sort()const;
00157 
00159         const KSet& operator=(const KSet&);
00160 
00161     private:
00162         // internal functions for Sets manipulation
00163         SSet*   FindEqual( kReference pReference)const;
00164 
00165     private:
00166         SSet*   mSetArray;
00167         int     mSetCount;
00168         int     mBlockCount;
00169         int     mItemPerBlock;
00170         mutable bool    mIsChanged;
00171     };
00172 
00173 #include <fbxfilesdk/fbxfilesdk_nsend.h>
00174 
00175 #endif // FBXFILESDK_COMPONENTS_KBASELIB_KLIB_KSET_H
00176