2.11BSD/src/usr.lib/libI77/f77_abort.c

Compare this file to the similar file:
Show the results in this format:

/*
 * Copyright (c) 1980 Regents of the University of California.
 * All rights reserved.  The Berkeley software License Agreement
 * specifies the terms and conditions for redistribution.
 *
 *	@(#)f77_abort.c	5.2.1 (2.11BSD)	1999/10/24
 *
 *	all f77 aborts eventually call f77_abort.
 *	f77_abort cleans up open files and terminates with a dump if needed,
 *	with a message otherwise.	
 *
 */

#include <signal.h>
#include "fio.h"

#ifndef pdp11
char *getenv();
int _lg_flag;	/* _lg_flag is non-zero if -lg was specified to ld */
#endif

f77_abort( nargs, err_val, act_core )
{
	int core_dump;
	sigset_t set;
#ifndef pdp11
	/*
	 * The f77_dump_flag is really unnecessary to begin with and not
	 * implementing it on the PDP-11 saves a little space ...
	 */
	char first_char, *env_var;

	env_var = getenv("f77_dump_flag");
	first_char = (env_var == NULL) ? 0 : *env_var;
#endif

	signal(SIGILL, SIG_DFL);
	(void)sigemptyset(&set);
	(void)sigaddset(&set, SIGILL);
	(void)sigprocmask(SIG_UNBLOCK, &set, NULL);	/* don't block */

#ifdef pdp11
	/*
	 * See if we want a core dump:  don't dump for signals like hangup.
	 */
	core_dump = (nargs != 2) || act_core;
#else
	/* see if we want a core dump:
		first line checks for signals like hangup - don't dump then.
		second line checks if -lg specified to ld (e.g. by saying
			-g to f77) and checks the f77_dump_flag var. */
	core_dump = ((nargs != 2) || act_core) &&
	    ( (_lg_flag && (first_char != 'n')) || first_char == 'y');
#endif

	if( !core_dump )
		fprintf(units[STDERR].ufd,"*** Execution terminated\n");

	f_exit();
	_cleanup();
	if( nargs ) errno = err_val;
	else errno = -2;   /* prior value will be meaningless,
				so set it to undefined value */

	if( core_dump ) abort();
	else  exit( errno );
}