commit 2025-09-11 12:36 edit codes for ZtCInit<> in ZCppMain/ZtSimList.H etc

This commit is contained in:
2025-09-11 12:37:05 +09:00
parent 5ced8624e6
commit 0c07b0e497
5 changed files with 222 additions and 145 deletions

View File

@ -3628,13 +3628,36 @@ namespace ZNsMain
ZftCopyChars(TTypeCh* ApcDest, TTypeSize AL_DestSize, const TTypeCh* ApcSource) */
/*######################################################################################
■ ZtCInit<>, ZCInit 은 주로 자유 기억 공간을 구현하는 자료 구조에서 사용한다.
1) 자유 기억 공간에서 나오는 data 에 대하여 OnInit() 를 호출한다.
2) 자유 기억 공간으로 가 는 data 에 대하여 OnFini() 를 호출한다.
그런데 2) 는 자료 구조에 따라 호출하지 않을 수도 있다. 다수의 원소가 자유 기억 공간으
로 들어갈 때, 일일이 그 모든 원소에 대해 Onfini() 를 호출하는 것은 낭비일 수 있는 것이
다.
-- 2025-09-11 11:00
■ 주로 container 인 typename TType2 을 인수로 받아, container 와의 활용도롤 높이고 있다.
-- 2025-09-11 11:03
######################################################################################*/
template<typename TType> class ZtCInit
{
public:
void operator()(TType& AR_TypeArg){}
enum{EUseInit=0};
enum{EUseFini=0};
public:
void OnInit(TType& AR_TypeArg){}
void OnFini(TType& AR_TypeArg){}
template<typename TType2>
static void OnInit(TType& AR_TypeArg, TType2& AR_TypeArg2){}
template<typename TType2>
static void OnFini(TType& AR_TypeArg, TType2& AR_TypeArg2){}
public:
};/*
template<typename TType> class ZtCInit*/
@ -3643,12 +3666,13 @@ namespace ZNsMain
class ZCInit
{
public:
template<typename TType> void operator()(TType& AR_TypeArg){}
template<typename TType> void OnInit (TType& AR_TypeArg){}
template<typename TType> void OnFini (TType& AR_TypeArg){}
void OnInit(){}
void OnFini(){}
enum{EUseInit=0};
enum{EUseFini=0};
public:
template<typename TType, typename TType2>
static void OnInit(TType& AR_TypeArg, TType2& AR_TypeArg2){}
template<typename TType, typename TType2>
static void OnFini(TType& AR_TypeArg, TType2& AR_TypeArg2){}
public:
};/*
class ZCInit*/

View File

@ -2422,6 +2422,7 @@ namespace ZNsMain
using ZNsMain::ZtCObjAVL;
namespace ZNsTmplParam
{

View File

@ -12,7 +12,7 @@ namespace ZNsMain
/*/////////////////////////////////////////////////////////////////
■ typename TTypCInit 는 별다른 역할을 하지 않고 있다. 다른 리스트
■ typename TTypeInit 는 별다른 역할을 하지 않고 있다. 다른 리스트
클래스와 템플릿 인수를 비슷하게 맞추기 위해, 그리고 차후의 설계
를 위해 일단 이대로 두자.
@ -20,7 +20,7 @@ namespace ZNsMain
-- 2025-08-11 14:47
ZtCTreeData.H 에서 ZtCObjList<> 에서 TTypCInit 자리에 형을 지정
ZtCTreeData.H 에서 ZtCObjList<> 에서 TTypeInit 자리에 형을 지정
하고 있다. 쓰긴 쓰니까 주석을 해제하자. -- 2025-08-14 13:43
/////////////////////////////////////////////////////////////////*/
@ -29,15 +29,15 @@ namespace ZNsMain
template<typename TypeObjList> class ZtCSortObjList;
template< typename TType ,
typename TTypArgu = const TType&,
typename TTypCAlloc = ZCAllocator ,
typename TTypCInit = ZCInit ,
typename TTypSize = ZTypLong ,
template< typename TType , /////////////////////////////
typename TTypArgu = const TType& ,
typename TTypCAlloc = ZCAllocator ,
typename TTypeInit = ZtCInit<TType>,
typename TTypSize = ZTypLong ,
typename TMoveObj = ZNsMain::
ZtCMoveObj<TType, TTypArgu, true>
>
class ZtCObjList //////////////////////////////
class ZtCObjList ////////////////////////////////////////////////////////////*/
{
public:
template<typename TypeObjList> friend class ZtCSortObjList;
@ -46,7 +46,7 @@ namespace ZNsMain
typedef TType TypeData ;
typedef TTypArgu TypeArg ;
typedef TTypCAlloc TypeAlloc ;
//typedef TTypCInit TypeInit ;
typedef TTypeInit TypeInit ;
typedef TTypSize TypeSize ;
typedef TMoveObj TypeMoveObj;
public:
@ -231,34 +231,53 @@ namespace ZNsMain
TypeSize ml_Size ;
protected:
virtual void OnDelete(
ZCLink* AP_CutHead, TypeSize AI_CutHeadPos,
ZCLink* AP_CutTail, TypeSize AI_CutTailPos
/*//////////*/ )
void OnDelete /*//////////////////////////////////////////////*/
(
ZCLink* AP_CutHead, TypeSize AI_CutHeadPos,
ZCLink* AP_CutTail, TypeSize AI_CutTailPos
)
/*############################################################*/
{
// 상속클래스에서 추가된 멤버 데이타가 링크의 삭제시 변해야 하는 값이라면
// 이 함수를 overload 하여 값을 조종한다.
}/*
virtual void OnDelete(
ZCLink* AP_CutHead, TypeSize AI_CutHeadPos,
ZCLink* AP_CutTail, TypeSize AI_CutTailPos
////////////// ) */
// 상속클래스에서 추가된 멤버 데이타가 링크의 삭제시 변해야
// 하는 값이라면, 이 함수를 overload 하여 값을 조종한다.
if(TypeInit::EUseFini<1) return;
TypeSize VL_LoopCnt = AI_CutTailPos-AI_CutHeadPos+1 ;
ZCLink* VP_NowLink = AP_CutHead ;
__for1(TypeSize, i, VL_LoopCnt)
{
TypeInit::OnFini(VP_NowLink->mo_Data, *this) ;
VP_NowLink = VP_NowLink->mp_NextLink;
}/*
__for1(TypeSize, i, VL_LoopCnt)*/
}
/*############################################################*/
virtual void OnInsert(
TypeSize AI_InsertPos , // 삽입되는 위치
TypeSize AI_InsertSize, // 삽입되는 링크의 갯수
ZCLink* AP_HeadInsert // 삽입되는 첫번째 링크의 포인터
/*//////////*/ )
void OnInsert /*//////////////////////////////////////////////*/
(
TypeSize AI_InsertPos , // 삽입되는 위치
TypeSize AI_InsertSize, // 삽입되는 링크의 갯수
ZCLink* AP_HeadInsert // 삽입되는 첫번째 링크의 포인터
)
/*############################################################*/
{
// 상속클래스에서 추가된 멤버 데이타가 링크의 삽입시 변해야 하는 값이라면
// 이 함수를 overload 하여 값을 조종한다.
}/*
virtual void OnInsert(
TypeSize AI_InsertPos ,
TypeSize AI_InsertSize,
ZCLink* AP_HeadInsert
////////////// ) */
if(TypeInit::EUseInit<1) return;
ZCLink* VP_NowLink = AP_HeadInsert;
__for1(TypeSize, i, AI_InsertSize)
{
TypeInit::OnInit(VP_NowLink->mo_Data, *this);
VP_NowLink = VP_NowLink->mp_NextLink;
}/*
__for1(TypeSize, i, AI_InsertSize)*/
}
/*############################################################*/
void JoinAfter(ZCLink* AP_LinkInsert, ZCLink* AP_LinkStd, TypeSize AL_PosStd)
@ -268,7 +287,7 @@ namespace ZNsMain
if(AP_LinkStd==0)
{
OnInsert(1,1,AP_LinkInsert);
OnInsert(1, 1, AP_LinkInsert);
if(++ml_Size==1)
{
@ -1005,7 +1024,7 @@ namespace ZNsMain
do ////
{
VP_DelLink =mp_HeadLink;
mp_HeadLink=mp_HeadLink->mp_NextLink;
mp_HeadLink=mp_HeadLink->mp_NextLink ;
delete VP_DelLink;
}
@ -2159,15 +2178,15 @@ namespace ZNsMain
public:
};/*
template< typename TType ,
typename TTypArgu = const TType&,
typename TTypCAlloc = ZCAllocator ,
typename TTypCInit = ZCInit ,
typename TTypSize = ZTypLong ,
template< typename TType ,
typename TTypArgu = const TType& ,
typename TTypCAlloc = ZCAllocator ,
typename TTypeInit = ZtCInit<TType>,
typename TTypSize = ZTypLong ,
typename TMoveObj = ZNsMain::
ZtCMoveObj<TType, TTypArg, true>
ZtCMoveObj<TType, TTypArgu, true>
>
class ZtCObjList ////////////////////////////*/
class ZtCObjList ////////////////////////////////////////////////////////////*/
/*/////////////////////////////////////////////////////////////////////////////

View File

@ -15,11 +15,11 @@ namespace ZNsMain
template /*#######################################*/
<
typename TType ,
typename TTypArgu =const TType&,
typename TTypCAlloc=ZCAllocator ,
typename TTypCInit =ZCInit ,
typename TTypSize =ZTypLong ,
typename TType ,
typename TTypArgu = const TType& ,
typename TTypCAlloc= ZCAllocator ,
typename TTypCInit = ZtCInit<TType> ,
typename TTypSize = ZTypLong ,
typename TMoveObj = ZNsMain::
ZtCMoveObj<TType, TTypArgu, true>
>
@ -54,7 +54,7 @@ namespace ZNsMain
private:
ZCLink* mp_NextLink;
TType mo_Type ;
TType mo_Data ;
private:
@ -89,62 +89,62 @@ namespace ZNsMain
{
// TType 의 대입연산자는 반드시 public 영역에 있어야 한다.
mo_Type=rhs.mo_Type;
mo_Data=rhs.mo_Data;
}/*
ZCLink(const ZCLink& rhs)*/
ZCLink(TypeArg AR_Type):mp_NextLink(0)
{
mo_Type=AR_Type;
mo_Data=AR_Type;
}/*
ZCLink(TypeArg AR_Type)*/
operator TType&()
{
return mo_Type;
return mo_Data;
}/*
operator TType&()*/
operator TType()
{
return mo_Type;
return mo_Data;
}/*
operator TType()*/
TType& GetData()
{
return mo_Type;
return mo_Data;
}/*
TType& GetData()*/
const TType& GetData() const
{
return mo_Type;
return mo_Data;
}/*
const TType& GetData() const*/
TType& GetData(TTypSize AL_FarNum) // must AL_FarNum >= 0
{
return GetNextPtr(AL_FarNum)->mo_Type;
return GetNextPtr(AL_FarNum)->mo_Data;
}/*
TType& GetData(TTypSize AL_FarNum)*/
const TType& GetData(TTypSize AL_FarNum) const
{
return GetNextPtr(AL_FarNum)->mo_Type;
return GetNextPtr(AL_FarNum)->mo_Data;
}/*
const TType& GetData(TTypSize AL_FarNum) const*/
TType& operator*()
{
return mo_Type;
return mo_Data;
}/*
TType& operator*()*/
const TType& operator*() const
{
return mo_Type;
return mo_Data;
}/*
const TType& operator*() const*/
@ -199,7 +199,7 @@ namespace ZNsMain
ZCLink& operator=(TypeArg AR_Type)
{
mo_Type=AR_Type; return *this;
mo_Data=AR_Type; return *this;
}/*
ZCLink& operator=(TypeArg AR_Type)*/
@ -222,11 +222,11 @@ namespace ZNsMain
class ZCLink*/
/////////////////////////////////////////////////
//////////////////////////////////////////////////
/*************** end class ZCLink ***************/
/////////////////////////////////////////////////
//////////////////////////////////////////////////
class ZCLinkHeap : public ZCFreeAllocBase
@ -242,8 +242,6 @@ namespace ZNsMain
private:
TypeInit mo_TypeInit;
TTypSize ml_AllSize ;
TTypSize ml_UseSize ;
@ -264,8 +262,16 @@ namespace ZNsMain
#endif //_DEBUG
if(ml_UseSize==0)
return (++ml_AllSize, new ZCLink) ;
/////////////////
{
ZCLink* VP_TempLink = new ZCLink ;
if(TypeInit::EUseInit>0)
TypeInit::OnInit(VP_TempLink->mo_Data, *this);
return (++ml_AllSize, VP_TempLink);
}/*
if(ml_UseSize==0)*/
ZCLink* VP_TempLink=mp_NoUseHeadLink;
@ -305,11 +311,12 @@ namespace ZNsMain
}
else if(AL_LinkSize==ml_UseSize)
{
ZCLink* VP_Temp=mp_NoUseHeadLink;
ZCLink* VP_Temp = mp_NoUseHeadLink;
while(true)
{
mo_TypeInit(VP_Temp->mo_Type);
if(TypeInit::EUseInit>0)
TypeInit::OnInit(VP_Temp->mo_Data, *this);
if(VP_Temp==mp_NoUseTailLink)
{ break; }
@ -328,17 +335,20 @@ namespace ZNsMain
}
else if(AL_LinkSize<ml_UseSize)
{
APR_HeadLink=mp_NoUseHeadLink;
APR_HeadLink = mp_NoUseHeadLink;
mo_TypeInit(mp_NoUseHeadLink->mo_Type);
if(TypeInit::EUseInit>0)
TypeInit::OnInit(mp_NoUseHeadLink->mo_Data, *this);
for(TTypSize VL_Count=2; VL_Count<=AL_LinkSize; ++VL_Count)
{
// VL_Count 가 2 부터 시작함으로 AL_LinkSize-1 번 순환한다.
// 그래야지 AL_LinkSize 개의 링크를 자를 수 있다.
mp_NoUseHeadLink=mp_NoUseHeadLink->mp_NextLink;
mo_TypeInit(mp_NoUseHeadLink->mo_Type);
mp_NoUseHeadLink = mp_NoUseHeadLink->mp_NextLink;
if(TypeInit::EUseInit>0)
TypeInit::OnInit(mp_NoUseHeadLink->mo_Data, *this);
}
//for(TTypSize VL_Count=2; VL_Count<=AL_LinkSize; ++VL_Count)
@ -353,8 +363,6 @@ namespace ZNsMain
while(true)
{
mo_TypeInit(VP_Temp->mo_Type);
if(VP_Temp==mp_NoUseTailLink)
{ break; }
@ -364,6 +372,7 @@ namespace ZNsMain
APR_HeadLink = mp_NoUseHeadLink;
// MakeLink() 에서 TypeInit::OnInit() 가 호출됨.
MakeLink( AL_LinkSize - ml_UseSize ,
mp_NoUseTailLink->mp_NextLink,
APR_TailLink
@ -415,7 +424,7 @@ namespace ZNsMain
{
ml_UseSize -= AL_FarNum+1 ;
mp_NoUseHeadLink->mo_Type = AP_LinkOrgin->mo_Type;
mp_NoUseHeadLink->mo_Data = AP_LinkOrgin->mo_Data;
APR_HeadCopy = mp_NoUseHeadLink ;
while(--AL_FarNum>=0)
@ -423,7 +432,7 @@ namespace ZNsMain
mp_NoUseHeadLink= mp_NoUseHeadLink->mp_NextLink ;
AP_LinkOrgin = AP_LinkOrgin->mp_NextLink ;
mp_NoUseHeadLink->mo_Type = AP_LinkOrgin->mo_Type;
mp_NoUseHeadLink->mo_Data = AP_LinkOrgin->mo_Data;
}
//while(--AL_FarNum>=0)
@ -446,7 +455,7 @@ namespace ZNsMain
}
else // AL_FarNum > ml_UseSize
{
mp_NoUseHeadLink->mo_Type = AP_LinkOrgin->mo_Type ;
mp_NoUseHeadLink->mo_Data = AP_LinkOrgin->mo_Data ;
APR_HeadCopy = mp_NoUseHeadLink ;
while(mp_NoUseHeadLink!=mp_NoUseTailLink)
@ -454,7 +463,7 @@ namespace ZNsMain
mp_NoUseHeadLink=mp_NoUseHeadLink->mp_NextLink;
AP_LinkOrgin =AP_LinkOrgin ->mp_NextLink;
mp_NoUseHeadLink->mo_Type = AP_LinkOrgin->mo_Type;
mp_NoUseHeadLink->mo_Data = AP_LinkOrgin->mo_Data;
}
//while(mp_NoUseHeadLink!=mp_NoUseTailLink)
@ -487,11 +496,11 @@ namespace ZNsMain
)
///////////////////////////////////////////////////*/
{
#ifdef _REENTRANT_MUTEX
#ifdef _REENTRANT_MUTEX
ZNsMain::ZCMutexSmallLock VO_ZCMutexSmallLock(mo_Mutex);
#endif //_REENTRANT_MUTEX
#ifdef _DEBUG
#ifdef _DEBUG
ZNsMain::ZCCheckAlloc::ZCAllowAlloc CAllowAllocObj;
#endif //_DEBUG
@ -505,6 +514,9 @@ namespace ZNsMain
}
//if(APR_HeadLink==0)
if(TypeInit::EUseInit>0)
TypeInit::OnInit(APR_HeadLink->mo_Data, *this);
ml_AllSize += AL_MakeSize;
ZCLink* VP_MakeLink = 0 ;
@ -535,8 +547,11 @@ namespace ZNsMain
}
//if(VP_MakeLink==0)
if(TypeInit::EUseInit>0)
TypeInit::OnInit(VP_MakeLink->mo_Data, *this);
VP_TempLink->mp_NextLink=VP_MakeLink;
VP_TempLink=VP_MakeLink;
VP_TempLink=VP_MakeLink ;
}
//while(--AL_MakeSize>0)
@ -608,7 +623,7 @@ namespace ZNsMain
bool VB_IsHeapOver= false;
VP_TempLink = \
VP_MakeLink = new ZCLink(AP_LinkOrgin->mo_Type);
VP_MakeLink = new ZCLink(AP_LinkOrgin->mo_Data);
ml_AllSize += AL_FarNum+1 ;
@ -628,7 +643,7 @@ namespace ZNsMain
while(--AL_FarNum >= 0)
{
AP_LinkOrgin= AP_LinkOrgin->mp_NextLink;
VP_MakeLink = new ZCLink(AP_LinkOrgin->mo_Type);
VP_MakeLink = new ZCLink(AP_LinkOrgin->mo_Data);
if(VP_MakeLink==0)
{
@ -697,15 +712,33 @@ namespace ZNsMain
mp_NoUseTailLink = AP_Link;
}
//else
if(TypeInit::EUseFini>0)
TypeInit::OnFini(AP_Link->mo_Data, *this);
}
//void ReceiveLink(ZCLink* AP_Link)
void ReceiveLink(ZCLink* AP_HeadLink,ZCLink* AP_TailLink, TTypSize AL_Count)
void ReceiveLink(ZCLink* AP_HeadLink, ZCLink* AP_TailLink, TTypSize AL_Count)
{
#ifdef _REENTRANT_MUTEX
ZNsMain::ZCMutexSmallLock VO_ZCMutexSmallLock(mo_Mutex);
#endif //_REENTRANT_MUTEX
if(TypeInit::EUseFini>0)
{
ZCLink* VP_NowLink = AP_HeadLink;
__for1(TypeSize, i, AL_Count)
{
TypeInit::OnFini(VP_NowLink->mo_Data, *this) ;
VP_NowLink = VP_NowLink->mp_NextLink;
}/*
__for1(TypeSize, i, AL_Count)*/
}/*
if(TypeInit::EUseFini>0)*/
if(ml_UseSize==0)
{
mp_NoUseHeadLink = AP_HeadLink ;
@ -839,12 +872,6 @@ namespace ZNsMain
}
//long GetMemSize() const
TypeInit& GetTypeInit()
{
return mo_TypeInit;
}
//TypeInit& GetTypeInit()
//public:
};
//class ZCLinkHeap
@ -1183,7 +1210,7 @@ namespace ZNsMain
#endif //_DEBUG
return GetLinkPtr(AL_Index)->mo_Type;
return GetLinkPtr(AL_Index)->mo_Data;
}/*
TType& operator[](TTypSize AL_Index)*/
@ -1204,17 +1231,17 @@ namespace ZNsMain
#endif //_DEBUG
return GetLinkPtr(AL_Index)->mo_Type;
return GetLinkPtr(AL_Index)->mo_Data;
}
//const TType& operator[](TTypSize AL_Index) const
operator TType&(){return AddTailDefault()->mo_Type;}
operator TType&(){return AddTailDefault()->mo_Data;}
TType& operator()()
{
return AddTailDefault()->mo_Type;
return AddTailDefault()->mo_Data;
}/*
TType& operator()()*/
@ -1226,11 +1253,11 @@ namespace ZNsMain
#if(_CODE_NEW_)
if(TypeMoveObj::ZEUseMoveObj>0) ////////////////////
{
TypeMoveObj::Exec(VP_AddLink->mo_Type, AR_Type);
TypeMoveObj::Exec(VP_AddLink->mo_Data, AR_Type);
}
else ///////////////////////////////////////////////
#endif
VP_AddLink->mo_Type= AR_Type ;
VP_AddLink->mo_Data= AR_Type ;
if(++ml_Size==1) // ml_Size==0
{
@ -1274,11 +1301,11 @@ namespace ZNsMain
#if(_CODE_NEW_)
if(TypeMoveObj::ZEUseMoveObj>0) ////////////////////
{
TypeMoveObj::Exec(VP_AddLink->mo_Type, AR_Type);
TypeMoveObj::Exec(VP_AddLink->mo_Data, AR_Type);
}
else ///////////////////////////////////////////////
#endif
VP_AddLink->mo_Type= AR_Type ;
VP_AddLink->mo_Data= AR_Type ;
if(++ml_Size==1) // ml_Size==0
{
@ -1348,8 +1375,8 @@ namespace ZNsMain
ZCLink* GetTailIterEasy (){return mp_TailLink;}
IterEasyID GetTailIterEasyID(){return (IterEasyID)mp_TailLink;}
TType& front(){return mp_HeadLink->mo_Type;}
TType& back (){return mp_TailLink->mo_Type;}
TType& front(){return mp_HeadLink->mo_Data;}
TType& back (){return mp_TailLink->mo_Data;}
const ZCLink* GetHeadLinkPtr () const{return mp_HeadLink;}
@ -1360,8 +1387,8 @@ namespace ZNsMain
const ZCLink* GetTailIterEasy () const{return mp_TailLink;}
const IterEasyID GetTailIterEasyID() const{return (IterEasyID)mp_TailLink;}
const TType& front() const{return mp_HeadLink->mo_Type;}
const TType& back () const{return mp_TailLink->mo_Type;}
const TType& front() const{return mp_HeadLink->mo_Data;}
const TType& back () const{return mp_TailLink->mo_Data;}
void pop_back(TypeArg AR_Type)
@ -1394,7 +1421,7 @@ namespace ZNsMain
#endif //_DEBUG
return mp_HeadLink->mo_Type;
return mp_HeadLink->mo_Data;
}/*
TType& GetHeadData()*/
@ -1415,7 +1442,7 @@ namespace ZNsMain
#endif //_DEBUG
return mp_HeadLink->mo_Type;
return mp_HeadLink->mo_Data;
}/*
const TType& GetHeadData() const*/
@ -1437,7 +1464,7 @@ namespace ZNsMain
#endif //_DEBUG
return mp_TailLink->mo_Type ;
return mp_TailLink->mo_Data ;
}/*
TType& GetTailData()*/
@ -1458,7 +1485,7 @@ namespace ZNsMain
#endif //_DEBUG
return mp_TailLink->mo_Type ;
return mp_TailLink->mo_Data ;
}/*
const TType& GetTailData() const*/
@ -1480,7 +1507,7 @@ namespace ZNsMain
#endif //_DEBUG
return GetLinkPtr(AL_Index)->mo_Type;
return GetLinkPtr(AL_Index)->mo_Data;
}/*
TType& GetData(TTypSize AL_Index)*/
@ -1501,7 +1528,7 @@ namespace ZNsMain
#endif //_DEBUG
return GetLinkPtr(AL_Index)->mo_Type;
return GetLinkPtr(AL_Index)->mo_Data;
}/*
TType GetData(TTypSize AL_Index) const*/
@ -1685,8 +1712,15 @@ namespace ZNsMain
if(AL_DelSize>ml_Size) AL_DelSize=ml_Size;
ZtCSimList VO_StoreList; CutLink(
0, mp_HeadLink, 1, mp_HeadLink->GetNextPtr(AL_DelSize-1), AL_DelSize , VO_StoreList).DeleteAll();
ZtCSimList VO_StoreList; CutLink /////////////
(
0, mp_HeadLink
, 1, mp_HeadLink->GetNextPtr(AL_DelSize-1)
, AL_DelSize
, VO_StoreList
)
.DeleteAll();
////////////////////////////////////////////////
}/*
void DeleteHead(TTypSize AL_DelSize)*/
@ -1884,13 +1918,13 @@ namespace ZNsMain
do //////
{
if(VP_TempLink==AP_pSearchLink)
{return VL_FindIndex;}
{ return VL_FindIndex; }
/*+++++++++++++++++++++++++++*/
if(VL_FindIndex==ml_Size){return 0; }
VP_TempLink= VP_TempLink->mp_NextLink ;
++VL_FindIndex ;
VP_TempLink = VP_TempLink->mp_NextLink;
VL_FindIndex= VL_FindIndex + 1 ;
}
while(true);
}/*
@ -1917,8 +1951,8 @@ namespace ZNsMain
if(VL_FindIndex==ml_Size){return 0; }
VP_TempLink=VP_TempLink->mp_NextLink;
++VL_FindIndex ;
VP_TempLink = VP_TempLink->mp_NextLink;
VL_FindIndex= VL_FindIndex + 1 ;
}
while(true);
}/*
@ -2026,7 +2060,7 @@ namespace ZNsMain
__for1(TTypSize, VL_Index, ml_Size)
{
ZtCTypeData<TFunctor>::
GetObjRef(AO_Functor)(VP_LoopLink->mo_Type);
GetObjRef(AO_Functor)(VP_LoopLink->mo_Data);
VP_LoopLink = VP_LoopLink->mp_NextLink;
}/*
@ -2047,7 +2081,7 @@ namespace ZNsMain
{
ZtCTypeData<TFunctor>::GetObjRef(AO_Functor)
(
VP_LoopLink->mo_Type, ZCCheckRef::PassData(AO_TypeHelp)
VP_LoopLink->mo_Data, ZCCheckRef::PassData(AO_TypeHelp)
);
////////////////////////////////////////////
@ -2072,7 +2106,7 @@ namespace ZNsMain
{
ZtCTypeData<TFunctor>::GetObjRef(AO_Functor)
(
VP_LoopLink->mo_Type ,
VP_LoopLink->mo_Data ,
ZCCheckRef1::PassData(AO_TypeHelp1),
ZCCheckRef2::PassData(AO_TypeHelp2)
);
@ -2109,7 +2143,7 @@ namespace ZNsMain
VP_TempLink=VP_TempLink->mp_NextLink;
const bool CB_IsTrue = ZtCTypeData<TFunctor>::
GetObjRef(AO_Functor)( VP_TempBefore->mo_Type );
GetObjRef(AO_Functor)( VP_TempBefore->mo_Data );
if(CB_IsTrue)
{
@ -2322,11 +2356,11 @@ namespace ZNsMain
};/*
template ###########################################
<
typename TType ,
typename TTypArgu =const TType&,
typename TTypCAlloc=ZCAllocator ,
typename TTypCInit =ZCInit ,
typename TTypSize =ZTypLong ,
typename TType ,
typename TTypArgu = const TType& ,
typename TTypCAlloc= ZCAllocator ,
typename TTypCInit = ZtCInit<TType> ,
typename TTypSize = ZTypLong ,
typename TMoveObj = ZNsMain::
ZtCMoveObj<TType, TTypArgu, true>
>

View File

@ -122,8 +122,7 @@ namespace ZNsMain
namespace ZNsType*/
template< typename TType ,
typename TTypeInit =ZNsMain::ZtCInit<TType>,
template< typename TType ,
typename TTypeTreeData=ZNsType::ZtCTypeTreeData<long>
>
class ZtCTreeData /*###########################################*/
@ -131,9 +130,8 @@ namespace ZNsMain
public:
class ZCNode1; class ZCNode2; class ZCNodeInfo;
public:
typedef TType TypeData ;
typedef TTypeInit ZCTypeInit ;
typedef TTypeTreeData ZCTypeTreeData;
typedef TType TypeData ;
typedef TTypeTreeData TypeTreeData;
public:
typedef typename TTypeTreeData::TypeSize TypeSize ;
typedef typename TTypeTreeData::template
@ -148,7 +146,8 @@ namespace ZNsMain
typedef typename ZCNodeList::iterator IterOfNode;
public:
class ZCNode1 : public ZCTypeInit
class ZCNode1 :
{
public :
friend class ZCNodeInfo;
@ -160,13 +159,13 @@ namespace ZNsMain
ZCNode1()
{
mp_HighNode=0; this->ZCTypeInit::OnInit(mo_TypeData);
mp_HighNode=0;
}/*
ZCNode1()*/
~ZCNode1()
{
mp_HighNode=0; this->ZCTypeInit::OnFini(mo_TypeData);
mp_HighNode=0;
}/*
~ZCNode1()*/
@ -325,7 +324,8 @@ namespace ZNsMain
};/*
class ZCNode1*/
class ZCNode2 : public ZCTypeInit
class ZCNode2
{
public :
friend class ZCNodeInfo;
@ -337,12 +337,12 @@ namespace ZNsMain
ZCNode2()
{
mp_HighNode=0; this->ZCTypeInit::OnInit(mo_TypeData);
mp_HighNode=0;
}/*
ZCNode2()*/
~ZCNode2()
{
mp_HighNode=0; this->ZCTypeInit::OnFini(mo_TypeData);
mp_HighNode=0;
}/*
~ZCNode2()*/
@ -458,8 +458,7 @@ namespace ZNsMain
public:
};/*
template< typename TType ,
typename TTypeInit =ZNsMain::ZtCInit<TType>,
template< typename TType ,
typename TTypeTreeData=ZNsType::ZtCTypeTreeData<long>
>
class ZtCTreeData #############################################*/