Use glib's malloc functions when compiled with LIBGTOP_ENABLE_DEBUG.
1999-10-24 Martin Baulig <martin@home-of-linux.org> * xmalloc.c: Use glib's malloc functions when compiled with LIBGTOP_ENABLE_DEBUG. * xmalloc_suid.c: New file.
This commit is contained in:
committed by
Martin Baulig
parent
17627bab9f
commit
eeaa766456
7
sysdeps/common/ChangeLog
Normal file
7
sysdeps/common/ChangeLog
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
1999-10-24 Martin Baulig <martin@home-of-linux.org>
|
||||||
|
|
||||||
|
* xmalloc.c: Use glib's malloc functions when compiled
|
||||||
|
with LIBGTOP_ENABLE_DEBUG.
|
||||||
|
|
||||||
|
* xmalloc_suid.c: New file.
|
||||||
|
|
@@ -21,7 +21,7 @@ libgtop_common_la_SOURCES = xmalloc.c error.c gnuslib.c \
|
|||||||
libgtop_common_la_LDFLAGS = $(LT_VERSION_INFO)
|
libgtop_common_la_LDFLAGS = $(LT_VERSION_INFO)
|
||||||
libgtop_common_la_LIBADD = $(LIBGTOP_EXTRA_LIBS)
|
libgtop_common_la_LIBADD = $(LIBGTOP_EXTRA_LIBS)
|
||||||
|
|
||||||
libgtop_suid_common_la_SOURCES = xmalloc.c error.c sysdeps_suid.c
|
libgtop_suid_common_la_SOURCES = xmalloc_suid.c error.c sysdeps_suid.c
|
||||||
|
|
||||||
libgtop_suid_common_la_LDFLAGS = $(LT_VERSION_INFO)
|
libgtop_suid_common_la_LDFLAGS = $(LT_VERSION_INFO)
|
||||||
|
|
||||||
|
@@ -23,22 +23,33 @@
|
|||||||
|
|
||||||
#include <glibtop/xmalloc.h>
|
#include <glibtop/xmalloc.h>
|
||||||
|
|
||||||
|
#if LIBGTOP_ENABLE_DEBUG
|
||||||
|
#include <glib.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Wrappers to malloc, calloc, realloc ... */
|
/* Wrappers to malloc, calloc, realloc ... */
|
||||||
|
|
||||||
void *
|
void *
|
||||||
glibtop_malloc_r (glibtop *server, size_t size)
|
glibtop_malloc_r (glibtop *server, size_t size)
|
||||||
{
|
{
|
||||||
|
#if LIBGTOP_ENABLE_DEBUG
|
||||||
|
return g_malloc0 (size);
|
||||||
|
#else
|
||||||
void *buf = malloc (size);
|
void *buf = malloc (size);
|
||||||
|
|
||||||
if (!buf)
|
if (!buf)
|
||||||
glibtop_error_io_r (server, "malloc %d bytes", size);
|
glibtop_error_io_r (server, "malloc %d bytes", size);
|
||||||
|
|
||||||
return buf;
|
return buf;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void *
|
void *
|
||||||
glibtop_calloc_r (glibtop *server, size_t nmemb, size_t size)
|
glibtop_calloc_r (glibtop *server, size_t nmemb, size_t size)
|
||||||
{
|
{
|
||||||
|
#if LIBGTOP_ENABLE_DEBUG
|
||||||
|
return g_malloc0 (size * nmemb);
|
||||||
|
#else
|
||||||
void *buf = calloc (nmemb, size);
|
void *buf = calloc (nmemb, size);
|
||||||
|
|
||||||
if (!buf)
|
if (!buf)
|
||||||
@@ -46,27 +57,40 @@ glibtop_calloc_r (glibtop *server, size_t nmemb, size_t size)
|
|||||||
nmemb, size);
|
nmemb, size);
|
||||||
|
|
||||||
return buf;
|
return buf;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void *
|
void *
|
||||||
glibtop_realloc_r (glibtop *server, void *ptr, size_t size)
|
glibtop_realloc_r (glibtop *server, void *ptr, size_t size)
|
||||||
{
|
{
|
||||||
|
#if LIBGTOP_ENABLE_DEBUG
|
||||||
|
return g_realloc (ptr, size);
|
||||||
|
#else
|
||||||
void *buf = realloc (ptr, size);
|
void *buf = realloc (ptr, size);
|
||||||
|
|
||||||
if (!buf)
|
if (!buf)
|
||||||
glibtop_error_io_r (server, "realloc %d bytes", size);
|
glibtop_error_io_r (server, "realloc %d bytes", size);
|
||||||
|
|
||||||
return buf;
|
return buf;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
char *
|
char *
|
||||||
glibtop_strdup_r (glibtop *server, const char *string)
|
glibtop_strdup_r (glibtop *server, const char *string)
|
||||||
{
|
{
|
||||||
|
#if LIBGTOP_DEBUG
|
||||||
|
return g_strdup (string);
|
||||||
|
#else
|
||||||
return strcpy (glibtop_malloc_r (server, strlen (string) + 1), string);
|
return strcpy (glibtop_malloc_r (server, strlen (string) + 1), string);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
glibtop_free_r (glibtop *server, const void *ptr)
|
glibtop_free_r (glibtop *server, const void *ptr)
|
||||||
{
|
{
|
||||||
|
#if LIBGTOP_DEBUG
|
||||||
|
g_free (ptr);
|
||||||
|
#else
|
||||||
if (ptr) free ((void *) ptr);
|
if (ptr) free ((void *) ptr);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
72
sysdeps/common/xmalloc_suid.c
Normal file
72
sysdeps/common/xmalloc_suid.c
Normal file
@@ -0,0 +1,72 @@
|
|||||||
|
/* $Id$ */
|
||||||
|
|
||||||
|
/* Copyright (C) 1998-99 Martin Baulig
|
||||||
|
This file is part of LibGTop 1.0.
|
||||||
|
|
||||||
|
Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
|
||||||
|
|
||||||
|
LibGTop 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.
|
||||||
|
|
||||||
|
LibGTop 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 LibGTop; see the file COPYING. If not, write to the
|
||||||
|
Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
||||||
|
Boston, MA 02111-1307, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <glibtop/xmalloc.h>
|
||||||
|
|
||||||
|
/* Wrappers to malloc, calloc, realloc ... */
|
||||||
|
|
||||||
|
void *
|
||||||
|
glibtop_malloc_r (glibtop *server, size_t size)
|
||||||
|
{
|
||||||
|
void *buf = malloc (size);
|
||||||
|
|
||||||
|
if (!buf)
|
||||||
|
glibtop_error_io_r (server, "malloc %d bytes", size);
|
||||||
|
|
||||||
|
return buf;
|
||||||
|
}
|
||||||
|
|
||||||
|
void *
|
||||||
|
glibtop_calloc_r (glibtop *server, size_t nmemb, size_t size)
|
||||||
|
{
|
||||||
|
void *buf = calloc (nmemb, size);
|
||||||
|
|
||||||
|
if (!buf)
|
||||||
|
glibtop_error_io_r (server, "calloc %d blocks (%d bytes each)",
|
||||||
|
nmemb, size);
|
||||||
|
|
||||||
|
return buf;
|
||||||
|
}
|
||||||
|
|
||||||
|
void *
|
||||||
|
glibtop_realloc_r (glibtop *server, void *ptr, size_t size)
|
||||||
|
{
|
||||||
|
void *buf = realloc (ptr, size);
|
||||||
|
|
||||||
|
if (!buf)
|
||||||
|
glibtop_error_io_r (server, "realloc %d bytes", size);
|
||||||
|
|
||||||
|
return buf;
|
||||||
|
}
|
||||||
|
|
||||||
|
char *
|
||||||
|
glibtop_strdup_r (glibtop *server, const char *string)
|
||||||
|
{
|
||||||
|
return strcpy (glibtop_malloc_r (server, strlen (string) + 1), string);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
glibtop_free_r (glibtop *server, const void *ptr)
|
||||||
|
{
|
||||||
|
if (ptr) free ((void *) ptr);
|
||||||
|
}
|
Reference in New Issue
Block a user