summaryrefslogtreecommitdiffstats
path: root/mymalloc/mymalloc_svc.cc
blob: 3324fb71d95cd7f5aed620c850753cdb49faff41 (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
/*
* This file is part of rasdaman community.
*
* Rasdaman community 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 3 of the License, or
* (at your option) any later version.
*
* Rasdaman community 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 rasdaman community.  If not, see <http://www.gnu.org/licenses/>.
*
* Copyright 2003, 2004, 2005, 2006, 2007, 2008, 2009 Peter Baumann /
rasdaman GmbH.
*
* For more information please see <http://www.rasdaman.org>
* or contact Peter Baumann via <baumann@rasdaman.com>.
*/

//
//	wrapper for malloc on server side - throw bad_alloc if malloc fails
//
#include "mymalloc/mymalloc.h"
#include "reladminif/objectbroker.hh"
#include "raslib/rmdebug.hh"
#include <stdlib.h>
#include <new>

using namespace std;

// try to allocate requested memory;
// if impossible, try to free some, then retry allocation (by recursion)
// if nothing can be freed & allocated, give up & throw exception

void* mymalloc(size_t size) // throw(bad_alloc)	// FIXME: gcc3 doesn't like it, & can't do that unless other places are adapted too
{
	void* p = malloc(size);

#ifdef OLD_VERSION
// replaced this weird coding by the following below which should be semantically equivalent -- PB 2005-feb-01
	// ...except for more detailed error messages
	// FIXME: And SITF resolve this totally screwed up recursion to a while loop.
	if(!p) 
		if(!ObjectBroker::freeMemory() || !(p = mymalloc(size))) {
			RMInit::logOut << "mymalloc: memory allocation failed." << endl;
			throw bad_alloc();				
		}
#else	// improved structure, same logic:
	if (p == (void*) NULL) 
	{
		bool freePossible = ObjectBroker::freeMemory();
		if (freePossible)
		{
			p = mymalloc(size);
			if (p == (void*) NULL)
			{
				RMInit::logOut << "Error: mymalloc(): memory allocation failed." << endl;
				throw bad_alloc();				
			}
			else
			{
				// all went fine, nothing to do, return p
			}
		}
		else	// mem full, according to ObjectBroker, so throw alloc exception
		{
			RMInit::logOut << "Error: mymalloc(): ObjectBroker::freeMemory() failed." << endl;
			throw bad_alloc();				
		}
	}
#endif OLD_VERSION

	return p;
}