-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathAllocatedMatrix.h
65 lines (56 loc) · 1.74 KB
/
AllocatedMatrix.h
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
/**
* @file AllocatedMatrix.h
* Declares and implements the AllocatedMatrix template class.
* @ingroup meshtex-util
*/
/*
* Copyright 2012 Joel Baxter
*
* This file is part of MeshTex.
*
* MeshTex 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 of the License, or
* (at your option) any later version.
*
* MeshTex 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 MeshTex. If not, see <http://www.gnu.org/licenses/>.
*/
#if !defined(INCLUDED_ALLOCATEDMATRIX_H)
#define INCLUDED_ALLOCATEDMATRIX_H
#include "debugging/debugging.h"
#include "ipatch.h"
/**
* Matrix subclass that allocates its data array on construction and
* deallocates it on destruction.
*
* @ingroup meshtex-util
*/
template<typename Element>
class AllocatedMatrix : public Matrix<Element>
{
public: // public methods
/**
* Constructor. Allocates a data array of the appropriate size.
*
* @param x Matrix x dimension.
* @param y Matrix y dimension.
*/
AllocatedMatrix(std::size_t x, std::size_t y) :
Matrix(x, y, (_allocated = new Element[x*y])) {}
/**
* Destructor. Deallocates the data array.
*/
~AllocatedMatrix() { delete [] _allocated; }
private: // private member vars
/**
* Pointer to the data array so that the destructor can find it for deletion.
*/
Element *_allocated;
};
#endif // #if !defined(INCLUDED_ALLOCATEDMATRIX_H)