2023-12-20 11:49:06 +00:00
|
|
|
/*
|
|
|
|
* PROJECT: ReactOS Cicero
|
|
|
|
* LICENSE: LGPL-2.1-or-later (https://spdx.org/licenses/LGPL-2.1-or-later)
|
|
|
|
* PURPOSE: Cicero dynamic array
|
|
|
|
* COPYRIGHT: Copyright 2023 Katayama Hirofumi MZ <katayama.hirofumi.mz@gmail.com>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "cicbase.h"
|
|
|
|
|
2023-12-21 11:17:35 +00:00
|
|
|
class CicArrayBase
|
2023-12-20 11:49:06 +00:00
|
|
|
{
|
2023-12-21 11:17:35 +00:00
|
|
|
protected:
|
2023-12-20 11:49:06 +00:00
|
|
|
LPBYTE m_pb;
|
2023-12-21 11:17:35 +00:00
|
|
|
size_t m_cItems, m_cbItem, m_cCapacity;
|
|
|
|
|
|
|
|
public:
|
|
|
|
CicArrayBase(size_t cbItem);
|
|
|
|
virtual ~CicArrayBase();
|
|
|
|
|
|
|
|
BOOL Insert(size_t iItem, size_t cGrow);
|
|
|
|
LPVOID Append(size_t cGrow);
|
2024-02-09 09:28:24 +00:00
|
|
|
void Remove(size_t iItem, size_t cRemove = 1);
|
2023-12-21 11:17:35 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
template <typename T_ITEM>
|
|
|
|
class CicArray : protected CicArrayBase
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
CicArray() : CicArrayBase(sizeof(T_ITEM)) { }
|
|
|
|
|
|
|
|
T_ITEM* data() const { return (T_ITEM*)m_pb; }
|
|
|
|
size_t size() const { return m_cItems; }
|
|
|
|
bool empty() const { return !size(); }
|
2024-01-23 11:33:43 +00:00
|
|
|
void clear()
|
|
|
|
{
|
|
|
|
cicMemFree(m_pb);
|
|
|
|
m_pb = NULL;
|
|
|
|
m_cItems = m_cCapacity = 0;
|
|
|
|
}
|
2023-12-20 11:49:06 +00:00
|
|
|
|
2023-12-21 11:17:35 +00:00
|
|
|
T_ITEM& operator[](size_t iItem)
|
|
|
|
{
|
|
|
|
return *(T_ITEM*)&m_pb[iItem * m_cbItem];
|
|
|
|
}
|
|
|
|
const T_ITEM& operator[](size_t iItem) const
|
|
|
|
{
|
|
|
|
return *(const T_ITEM*)&m_pb[iItem * m_cbItem];
|
|
|
|
}
|
2023-12-20 11:49:06 +00:00
|
|
|
|
2023-12-21 11:17:35 +00:00
|
|
|
T_ITEM* Append(size_t cGrow)
|
|
|
|
{
|
|
|
|
return (T_ITEM*)CicArrayBase::Append(cGrow);
|
|
|
|
}
|
|
|
|
|
|
|
|
using CicArrayBase::Insert;
|
|
|
|
using CicArrayBase::Remove;
|
2024-01-05 08:43:06 +00:00
|
|
|
|
2024-01-25 03:35:04 +00:00
|
|
|
BOOL Add(const T_ITEM& item)
|
|
|
|
{
|
|
|
|
T_ITEM *pItem = Append(1);
|
|
|
|
if (!pItem)
|
|
|
|
return FALSE;
|
|
|
|
CopyMemory(pItem, &item, sizeof(T_ITEM));
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
2024-02-17 00:53:50 +00:00
|
|
|
ptrdiff_t Find(const T_ITEM& item) const
|
2024-01-05 08:43:06 +00:00
|
|
|
{
|
|
|
|
for (size_t iItem = 0; iItem < m_cItems; ++iItem)
|
|
|
|
{
|
|
|
|
if ((*this)[iItem] == item)
|
|
|
|
return iItem;
|
|
|
|
}
|
|
|
|
return -1;
|
|
|
|
}
|
2023-12-20 11:49:06 +00:00
|
|
|
};
|