1
0
mirror of https://github.com/NGSolve/netgen.git synced 2025-01-18 08:50:33 +05:00
netgen/libsrc/general/array.cpp

76 lines
1.6 KiB
C++
Raw Normal View History

2009-01-25 17:35:25 +05:00
#ifndef FILE_NGSTD_ArrayCPP
#define FILE_NGSTD_ArrayCPP
2009-01-13 04:40:13 +05:00
// necessary for SGI ????
/**************************************************************************/
/* File: array.cpp */
/* Author: Joachim Schoeberl */
/* Date: 01. Jun. 95 */
/**************************************************************************/
/*
2009-01-25 17:35:25 +05:00
Abstract data type Array
2009-01-13 04:40:13 +05:00
*/
#include <mystdlib.h>
#include <myadt.hpp>
#include <assert.h>
namespace netgen
{
//using namespace netgen;
#ifdef NONE
2009-01-25 17:35:25 +05:00
void BASE_Array :: ReSize (int minsize, int elementsize)
2009-01-13 04:40:13 +05:00
{
cout << "resize, minsize = " << minsize << endl;
if (inc == -1)
throw Exception ("Try to resize fixed size array");
void * p;
int nsize = (inc) ? allocsize + inc : 2 * allocsize;
if (nsize < minsize) nsize = minsize;
if (data)
{
p = new char [nsize * elementsize];
int mins = (nsize < actsize) ? nsize : actsize;
memcpy (p, data, mins * elementsize);
delete [] static_cast<char*> (data);
data = p;
}
else
{
data = new char[nsize * elementsize];
}
allocsize = nsize;
cout << "resize done" << endl;
}
2009-01-25 17:35:25 +05:00
void BASE_Array :: RangeCheck (int i) const
2009-01-13 04:40:13 +05:00
{
if (i < 0 || i >= actsize)
throw ArrayRangeException ();
}
2009-01-25 17:35:25 +05:00
void BASE_Array :: CheckNonEmpty () const
2009-01-13 04:40:13 +05:00
{
if (!actsize)
{
throw Exception ("Array should not be empty");
// cerr << "Array souldn't be empty";
}
}
#endif
}
#endif