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