Welcome to mirror list, hosted at ThFree Co, Russian Federation.

Array.h « libssf « subtitles « src - github.com/mpc-hc/mpc-hc.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 90d61c004621e6bc116475b874fe031d56108415 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
/* 
 *	Copyright (C) 2003-2006 Gabest
 *	http://www.gabest.org
 *
 *  This Program is free software; you can redistribute it and/or modify
 *  it under the terms of the GNU General Public License as published by
 *  the Free Software Foundation; either version 2, or (at your option)
 *  any later version.
 *   
 *  This Program is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
 *  GNU General Public License for more details.
 *   
 *  You should have received a copy of the GNU General Public License
 *  along with GNU Make; see the file COPYING.  If not, write to
 *  the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. 
 *  http://www.gnu.org/copyleft/gpl.html
 *
 */

#pragma once

namespace ssf
{
	// simple array class for simple types without constructors, 
	// and it doesn't free its reserves on SetCount(0)

	template<class T> 
	class Array
	{
		T* m_pData;
		size_t m_nSize;
		size_t m_nMaxSize;
		size_t m_nGrowBy;

	public:
		Array() {m_pData = NULL; m_nSize = m_nMaxSize = 0; m_nGrowBy = 4096;}
		virtual ~Array() {if(m_pData) _aligned_free(m_pData);}

		void SetCount(size_t nSize, size_t nGrowBy = 0)
		{
			if(nGrowBy > 0)
			{
				m_nGrowBy = nGrowBy;
			}

			if(nSize > m_nMaxSize)
			{
				m_nMaxSize = nSize + max(m_nGrowBy, m_nSize);
				size_t nBytes = m_nMaxSize * sizeof(T);
				m_pData = m_pData ? (T*)_aligned_realloc(m_pData, nBytes, 16) : (T*)_aligned_malloc(nBytes, 16);
			}

			m_nSize = nSize;
		}

		size_t GetCount() const {return m_nSize;}

		void RemoveAll() {m_nSize = 0;}
		bool IsEmpty() const {return m_nSize == 0;}

		T* GetData() {return m_pData;}

		void Add(const T& t)
		{
			size_t nPos = m_nSize;
			SetCount(m_nSize+1);
			m_pData[nPos] = t;
		}

		void Append(const Array& a, size_t nGrowBy = 0)
		{
			Append(a.m_pData, a.m_nSize, nGrowBy);
		}

		void Append(const T* ptr, size_t nSize, size_t nGrowBy = 0)
		{
			if(!nSize) return;
			size_t nOldSize = m_nSize;
			SetCount(nOldSize + nSize);
			memcpy(m_pData + nOldSize, ptr, nSize * sizeof(T));
		}

		const T& operator [] (size_t i) const {return m_pData[i];}
		T& operator [] (size_t i) {return m_pData[i];}

		void Copy(const Array& v)
		{
			SetCount(v.GetCount());
			memcpy(m_pData, v.m_pData, m_nSize * sizeof(T));
		}

		void Move(Array& v)
		{
			Swap(v);
			v.SetCount(0);
		}

		void Swap(Array& v)
		{
			T* pData = m_pData; m_pData = v.m_pData; v.m_pData = pData;
			size_t nSize = m_nSize; m_nSize = v.m_nSize; v.m_nSize = nSize;
			size_t nMaxSize = m_nMaxSize; m_nMaxSize = v.m_nMaxSize; v.m_nMaxSize = nMaxSize;
			size_t nGrowBy = m_nGrowBy; m_nGrowBy = v.m_nGrowBy; v.m_nGrowBy = nGrowBy;
		}
	};
}