ftp.nice.ch/pub/next/developer/languages/c/djgpp-NS.s.tar.gz#/djgpp/src/gas-2.3/gas/xmalloc.c

This is xmalloc.c in view mode; [Download] [Up]

/* xmalloc.c - get memory or bust

   Copyright (C) 1987, 1990, 1991, 1992 Free Software Foundation, Inc.

   This file is part of GAS, the GNU Assembler.

   GAS 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.

   GAS 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 GAS; see the file COPYING.  If not, write to
   the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.  */

/*
  NAME
  xmalloc() - get memory or bust
  INDEX
  xmalloc() uses malloc()

  SYNOPSIS
  char *	my_memory;

  my_memory = xmalloc(42); / * my_memory gets address of 42 chars * /

  DESCRIPTION

  Use xmalloc() as an "error-free" malloc(). It does almost the same job.
  When it cannot honour your request for memory it BOMBS your program
  with a "virtual memory exceeded" message. Malloc() returns NULL and
  does not bomb your program.

  SEE ALSO
  malloc()

  */

#include "as.h"

#define error as_fatal

PTR
xmalloc (n)
     unsigned long n;
{
  PTR retval;

  retval = malloc (n);
  if (retval == NULL)
    error ("virtual memory exceeded");
  return (retval);
}

PTR
xrealloc (ptr, n)
     register PTR ptr;
     unsigned long n;
{
  ptr = realloc (ptr, n);
  if (ptr == 0)
    error ("virtual memory exceeded");
  return (ptr);
}
/* end of xmalloc.c */

These are the contents of the former NiCE NeXT User Group NeXTSTEP/OpenStep software archive, currently hosted by Netfuture.ch.