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 00043 #include <fbxfilesdk/components/kbaselib/kbaselib_h.h> 00044 00045 #include <fbxfilesdk/fbxfilesdk_nsbegin.h> 00046 00047 struct SSet; 00048 00049 // ************************************************************************* 00050 // 00051 // class KSet 00052 // 00053 // ************************************************************************* 00054 00058 class KFBX_DLL KSet { 00059 public: 00060 enum 00061 { 00062 KFBX_NOT_FOUND = 0x0L, 00063 KFBX_ITEM_PER_BLOCK = 20 00064 }; 00065 00070 00071 00075 KSet( int pItemPerBlock = KFBX_ITEM_PER_BLOCK ); 00076 00080 KSet(const KSet& other); 00081 00083 ~KSet(); 00085 00086 // Add and remove 00093 bool Add ( kReference pReference, kReference pItem ); 00094 00095 00100 bool Remove ( kReference pReference ); 00101 00106 bool RemoveItem ( kReference pItem ); 00107 00113 bool SetItem ( kReference pReference, kReference pItem ); // Change Item Reference, don't Create if doesn't Exist 00114 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