2005-08-11 15:50:13 +02:00
|
|
|
/* Handling of compile-time options that influence the library.
|
2014-01-02 23:25:45 +01:00
|
|
|
Copyright (C) 2005-2014 Free Software Foundation, Inc.
|
2005-08-11 15:50:13 +02:00
|
|
|
|
2010-06-25 21:17:21 +02:00
|
|
|
This file is part of the GNU Fortran runtime library (libgfortran).
|
2005-08-11 15:50:13 +02:00
|
|
|
|
|
|
|
Libgfortran is free software; you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
2009-04-09 17:00:19 +02:00
|
|
|
the Free Software Foundation; either version 3, or (at your option)
|
2005-08-11 15:50:13 +02:00
|
|
|
any later version.
|
|
|
|
|
|
|
|
Libgfortran 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.
|
|
|
|
|
2009-04-09 17:00:19 +02:00
|
|
|
Under Section 7 of GPL version 3, you are granted additional
|
|
|
|
permissions described in the GCC Runtime Library Exception, version
|
|
|
|
3.1, as published by the Free Software Foundation.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License and
|
|
|
|
a copy of the GCC Runtime Library Exception along with this program;
|
|
|
|
see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
|
|
|
|
<http://www.gnu.org/licenses/>. */
|
2005-08-11 15:50:13 +02:00
|
|
|
|
|
|
|
#include "libgfortran.h"
|
2007-08-11 23:52:22 +02:00
|
|
|
#include <signal.h>
|
|
|
|
|
2005-08-11 15:50:13 +02:00
|
|
|
|
|
|
|
/* Useful compile-time options will be stored in here. */
|
|
|
|
compile_options_t compile_options;
|
|
|
|
|
2007-08-11 23:52:22 +02:00
|
|
|
|
2011-05-14 10:44:09 +02:00
|
|
|
volatile sig_atomic_t fatal_error_in_progress = 0;
|
|
|
|
|
2012-01-09 20:53:27 +01:00
|
|
|
|
|
|
|
/* Helper function for backtrace_handler to write information about the
|
|
|
|
received signal to stderr before actually giving the backtrace. */
|
|
|
|
static void
|
|
|
|
show_signal (int signum)
|
|
|
|
{
|
|
|
|
const char * name = NULL, * desc = NULL;
|
|
|
|
|
|
|
|
switch (signum)
|
|
|
|
{
|
2012-01-10 10:32:29 +01:00
|
|
|
#if defined(SIGQUIT)
|
|
|
|
case SIGQUIT:
|
|
|
|
name = "SIGQUIT";
|
|
|
|
desc = "Terminal quit signal";
|
|
|
|
break;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* The following 4 signals are defined by C89. */
|
|
|
|
case SIGILL:
|
|
|
|
name = "SIGILL";
|
|
|
|
desc = "Illegal instruction";
|
|
|
|
break;
|
|
|
|
|
|
|
|
case SIGABRT:
|
|
|
|
name = "SIGABRT";
|
|
|
|
desc = "Process abort signal";
|
|
|
|
break;
|
|
|
|
|
|
|
|
case SIGFPE:
|
|
|
|
name = "SIGFPE";
|
|
|
|
desc = "Floating-point exception - erroneous arithmetic operation";
|
|
|
|
break;
|
|
|
|
|
2012-01-09 20:53:27 +01:00
|
|
|
case SIGSEGV:
|
|
|
|
name = "SIGSEGV";
|
2012-01-10 10:32:29 +01:00
|
|
|
desc = "Segmentation fault - invalid memory reference";
|
2012-01-09 20:53:27 +01:00
|
|
|
break;
|
|
|
|
|
|
|
|
#if defined(SIGBUS)
|
|
|
|
case SIGBUS:
|
|
|
|
name = "SIGBUS";
|
2012-01-10 10:32:29 +01:00
|
|
|
desc = "Access to an undefined portion of a memory object";
|
2012-01-09 20:53:27 +01:00
|
|
|
break;
|
|
|
|
#endif
|
|
|
|
|
2012-01-10 10:32:29 +01:00
|
|
|
#if defined(SIGSYS)
|
|
|
|
case SIGSYS:
|
|
|
|
name = "SIGSYS";
|
|
|
|
desc = "Bad system call";
|
2012-01-09 20:53:27 +01:00
|
|
|
break;
|
|
|
|
#endif
|
|
|
|
|
2012-01-10 10:32:29 +01:00
|
|
|
#if defined(SIGTRAP)
|
|
|
|
case SIGTRAP:
|
|
|
|
name = "SIGTRAP";
|
|
|
|
desc = "Trace/breakpoint trap";
|
|
|
|
break;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(SIGXCPU)
|
|
|
|
case SIGXCPU:
|
|
|
|
name = "SIGXCPU";
|
|
|
|
desc = "CPU time limit exceeded";
|
|
|
|
break;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(SIGXFSZ)
|
|
|
|
case SIGXFSZ:
|
|
|
|
name = "SIGXFSZ";
|
|
|
|
desc = "File size limit exceeded";
|
2012-01-09 20:53:27 +01:00
|
|
|
break;
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
if (name)
|
2012-01-10 10:32:29 +01:00
|
|
|
st_printf ("\nProgram received signal %s: %s.\n", name, desc);
|
2012-01-09 20:53:27 +01:00
|
|
|
else
|
|
|
|
st_printf ("\nProgram received signal %d.\n", signum);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-08-11 23:52:22 +02:00
|
|
|
/* A signal handler to allow us to output a backtrace. */
|
|
|
|
void
|
2011-05-14 10:44:09 +02:00
|
|
|
backtrace_handler (int signum)
|
2007-08-11 23:52:22 +02:00
|
|
|
{
|
2011-05-14 10:44:09 +02:00
|
|
|
/* Since this handler is established for more than one kind of signal,
|
|
|
|
it might still get invoked recursively by delivery of some other kind
|
|
|
|
of signal. Use a static variable to keep track of that. */
|
|
|
|
if (fatal_error_in_progress)
|
|
|
|
raise (signum);
|
|
|
|
fatal_error_in_progress = 1;
|
|
|
|
|
2012-01-09 20:53:27 +01:00
|
|
|
show_signal (signum);
|
2012-12-20 19:15:13 +01:00
|
|
|
estr_write ("\nBacktrace for this error:\n");
|
|
|
|
backtrace ();
|
2011-05-14 10:44:09 +02:00
|
|
|
|
|
|
|
/* Now reraise the signal. We reactivate the signal's
|
|
|
|
default handling, which is to terminate the process.
|
|
|
|
We could just call exit or abort,
|
|
|
|
but reraising the signal sets the return status
|
|
|
|
from the process correctly. */
|
|
|
|
signal (signum, SIG_DFL);
|
|
|
|
raise (signum);
|
2007-08-11 23:52:22 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2011-05-29 22:13:52 +02:00
|
|
|
/* Helper function for set_options because we need to access the
|
|
|
|
global variable options which is not seen in set_options. */
|
|
|
|
static void
|
|
|
|
maybe_find_addr2line (void)
|
|
|
|
{
|
|
|
|
if (options.backtrace == -1)
|
|
|
|
find_addr2line ();
|
|
|
|
}
|
|
|
|
|
2007-07-15 18:26:22 +02:00
|
|
|
/* Set the usual compile-time options. */
|
|
|
|
extern void set_options (int , int []);
|
|
|
|
export_proto(set_options);
|
2005-08-11 15:50:13 +02:00
|
|
|
|
|
|
|
void
|
2007-07-15 18:26:22 +02:00
|
|
|
set_options (int num, int options[])
|
2005-08-11 15:50:13 +02:00
|
|
|
{
|
2007-07-15 18:26:22 +02:00
|
|
|
if (num >= 1)
|
|
|
|
compile_options.warn_std = options[0];
|
|
|
|
if (num >= 2)
|
|
|
|
compile_options.allow_std = options[1];
|
|
|
|
if (num >= 3)
|
|
|
|
compile_options.pedantic = options[2];
|
2011-05-14 10:44:09 +02:00
|
|
|
/* options[3] is the removed -fdump-core option. It's place in the
|
|
|
|
options array is retained due to ABI compatibility. Remove when
|
|
|
|
bumping the library ABI. */
|
2007-07-15 18:26:22 +02:00
|
|
|
if (num >= 5)
|
|
|
|
compile_options.backtrace = options[4];
|
|
|
|
if (num >= 6)
|
|
|
|
compile_options.sign_zero = options[5];
|
2007-07-24 07:52:44 +02:00
|
|
|
if (num >= 7)
|
|
|
|
compile_options.bounds_check = options[6];
|
2012-05-14 21:39:23 +02:00
|
|
|
/* options[7] is the -frange-check option, which no longer affects
|
|
|
|
the library behavior; range checking is now always done when
|
|
|
|
parsing integers. It's place in the options array is retained due
|
|
|
|
to ABI compatibility. Remove when bumping the library ABI. */
|
2013-06-17 09:48:21 +02:00
|
|
|
if (num >= 9)
|
|
|
|
compile_options.fpe_summary = options[8];
|
2007-08-11 23:52:22 +02:00
|
|
|
|
2011-05-14 10:44:09 +02:00
|
|
|
/* If backtrace is required, we set signal handlers on the POSIX
|
|
|
|
2001 signals with core action. */
|
2007-08-11 23:52:22 +02:00
|
|
|
if (compile_options.backtrace)
|
|
|
|
{
|
2011-05-14 10:44:09 +02:00
|
|
|
#if defined(SIGQUIT)
|
|
|
|
signal (SIGQUIT, backtrace_handler);
|
|
|
|
#endif
|
|
|
|
|
2011-11-09 19:25:58 +01:00
|
|
|
/* The following 4 signals are defined by C89. */
|
2011-05-14 10:44:09 +02:00
|
|
|
signal (SIGILL, backtrace_handler);
|
|
|
|
signal (SIGABRT, backtrace_handler);
|
|
|
|
signal (SIGFPE, backtrace_handler);
|
|
|
|
signal (SIGSEGV, backtrace_handler);
|
2007-08-11 23:52:22 +02:00
|
|
|
|
|
|
|
#if defined(SIGBUS)
|
2011-05-14 10:44:09 +02:00
|
|
|
signal (SIGBUS, backtrace_handler);
|
2007-08-11 23:52:22 +02:00
|
|
|
#endif
|
|
|
|
|
2011-05-14 10:44:09 +02:00
|
|
|
#if defined(SIGSYS)
|
|
|
|
signal (SIGSYS, backtrace_handler);
|
2007-08-11 23:52:22 +02:00
|
|
|
#endif
|
|
|
|
|
2011-05-14 10:44:09 +02:00
|
|
|
#if defined(SIGTRAP)
|
|
|
|
signal (SIGTRAP, backtrace_handler);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(SIGXCPU)
|
|
|
|
signal (SIGXCPU, backtrace_handler);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(SIGXFSZ)
|
|
|
|
signal (SIGXFSZ, backtrace_handler);
|
2007-08-11 23:52:22 +02:00
|
|
|
#endif
|
2011-05-29 22:13:52 +02:00
|
|
|
|
|
|
|
maybe_find_addr2line ();
|
2007-08-11 23:52:22 +02:00
|
|
|
}
|
2005-08-11 15:50:13 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* Default values for the compile-time options. Keep in sync with
|
|
|
|
gcc/fortran/options.c (gfc_init_options). */
|
|
|
|
void
|
|
|
|
init_compile_options (void)
|
|
|
|
{
|
2008-09-24 09:08:22 +02:00
|
|
|
compile_options.warn_std = GFC_STD_F95_DEL | GFC_STD_LEGACY;
|
2005-08-11 15:50:13 +02:00
|
|
|
compile_options.allow_std = GFC_STD_F95_OBS | GFC_STD_F95_DEL
|
2008-09-24 09:08:22 +02:00
|
|
|
| GFC_STD_F2003 | GFC_STD_F2008 | GFC_STD_F95 | GFC_STD_F77
|
2010-06-25 21:17:21 +02:00
|
|
|
| GFC_STD_F2008_OBS | GFC_STD_GNU | GFC_STD_LEGACY;
|
2006-02-08 21:54:14 +01:00
|
|
|
compile_options.pedantic = 0;
|
gfortran.h (gfc_option_t): Add flag_backtrace field.
* gfortran.h (gfc_option_t): Add flag_backtrace field.
* lang.opt: Add -fbacktrace option.
* invoke.texi: Document the new option.
* trans-decl.c (gfc_build_builtin_function_decls): Add new
option to the call to set_std.
* options.c (gfc_init_options, gfc_handle_option): Handle the
new option.
* runtime/backtrace.c: New file.
* runtime/environ.c (variable_table): New GFORTRAN_ERROR_BACKTRACE
environment variable.
* runtime/compile_options.c (set_std): Add new argument.
* runtime/main.c (store_exe_path, full_exe_path): New functions.
* runtime/error.c (sys_exit): Add call to show_backtrace.
* libgfortran.h (options_t): New backtrace field.
(store_exe_path, full_exe_path, show_backtrace): New prototypes.
* configure.ac: Add checks for execinfo.h, execvp, pipe, dup2,
close, fdopen, strcasestr, getrlimit, backtrace, backtrace_symbols
and getppid.
* Makefile.am: Add runtime/backtrace.c.
* fmain.c (main): Add call to store_exe_path.
* Makefile.in: Renegerate.
* config.h.in: Renegerate.
* configure: Regenerate.
From-SVN: r122954
2007-03-15 13:39:47 +01:00
|
|
|
compile_options.backtrace = 0;
|
2007-07-15 18:26:22 +02:00
|
|
|
compile_options.sign_zero = 1;
|
2013-06-17 09:48:21 +02:00
|
|
|
compile_options.fpe_summary = 0;
|
2005-08-11 15:50:13 +02:00
|
|
|
}
|
2006-02-06 21:12:44 +01:00
|
|
|
|
|
|
|
/* Function called by the front-end to tell us the
|
|
|
|
default for unformatted data conversion. */
|
|
|
|
|
|
|
|
extern void set_convert (int);
|
|
|
|
export_proto (set_convert);
|
|
|
|
|
|
|
|
void
|
|
|
|
set_convert (int conv)
|
|
|
|
{
|
|
|
|
compile_options.convert = conv;
|
|
|
|
}
|
2006-03-22 20:09:11 +01:00
|
|
|
|
|
|
|
extern void set_record_marker (int);
|
|
|
|
export_proto (set_record_marker);
|
|
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
set_record_marker (int val)
|
|
|
|
{
|
|
|
|
|
|
|
|
switch(val)
|
|
|
|
{
|
|
|
|
case 4:
|
re PR libfortran/29568 (implement unformatted files with subrecords (Intel style))
2006-12-01 Thomas Koenig <Thomas.Koenig@online.de>
PR libfortran/29568
* gfortran.dg/convert_implied_open.f90: Change to
new default record length.
* gfortran.dg/unf_short_record_1.f90: Adapt to
new error message.
* gfortran.dg/unformatted_subrecords_1.f90: New test.
2006-12-01 Thomas Koenig <Thomas.Koenig@online.de>
PR libfortran/29568
* gfortran.h (gfc_option_t): Add max_subrecord_length.
(top level): Define MAX_SUBRECORD_LENGTH.
* lang.opt: Add option -fmax-subrecord-length=.
* trans-decl.c: Add new function set_max_subrecord_length.
(gfc_generate_function_code): If we are within the main
program and max_subrecord_length has been set, call
set_max_subrecord_length.
* options.c (gfc_init_options): Add defaults for
max_subrecord_lenght, convert and record_marker.
(gfc_handle_option): Add handling for
-fmax_subrecord_length.
* invoke.texi: Document the new default for
-frecord-marker=<n>.
2006-12-01 Thomas Koenig <Thomas.Koenig@online.de>
PR libfortran/29568
* libgfortran/libgfortran.h (compile_options_t): Add
record_marker. (top level): Define GFC_MAX_SUBRECORD_LENGTH.
* runtime/compile_options.c (set_record_marker): Change
default to four-byte record marker.
(set_max_subrecord_length): New function.
* runtime/error.c (translate_error): Change error message
for short record on unformatted read.
* io/io.h (gfc_unit): Add recl_subrecord, bytes_left_subrecord
and continued.
* io/file_pos.c (unformatted_backspace): Change default of record
marker size to four bytes. Loop over subrecords.
* io/open.c: Default recl is max_offset. If
compile_options.max_subrecord_length has been set, set set
u->recl_subrecord to its value, to the maximum value otherwise.
* io/transfer.c (top level): Add prototypes for us_read, us_write,
next_record_r_unf and next_record_w_unf.
(read_block_direct): Separate codepaths for unformatted direct
and unformatted sequential. If a recl has been set by the
user, use the number of bytes left for the record if it is smaller
than the read request. Loop over subrecords. Set an error if the
user has set a recl and the read was short.
(write_buf): Separate codepaths for unformatted direct and
unformatted sequential. If a recl has been set by the
user, use the number of bytes left for the record if it is smaller
than the read request. Loop over subrecords. Set an error if the
user has set a recl and the read was short.
(us_read): Add parameter continued (to indicate that bytes_left
should not be intialized). Change default of record marker size
to four bytes. Use subrecord. If the subrecord length is smaller than
zero, this indicates a continuation.
(us_write): Add parameter continued (to indicate that the continued
flag should be set). Use subrecord.
(pre_position): Use 0 for continued on us_write and us_read calls.
(skip_record): New function.
(next_record_r_unf): New function.
(next_record_r): Use next_record_r_unf.
(write_us_marker): Default size for record markers is four bytes.
(next_record_w_unf): New function.
(next_record_w): Use next_record_w_unf.
From-SVN: r119412
2006-12-01 22:04:38 +01:00
|
|
|
compile_options.record_marker = sizeof (GFC_INTEGER_4);
|
2006-03-22 20:09:11 +01:00
|
|
|
break;
|
|
|
|
|
|
|
|
case 8:
|
re PR libfortran/29568 (implement unformatted files with subrecords (Intel style))
2006-12-01 Thomas Koenig <Thomas.Koenig@online.de>
PR libfortran/29568
* gfortran.dg/convert_implied_open.f90: Change to
new default record length.
* gfortran.dg/unf_short_record_1.f90: Adapt to
new error message.
* gfortran.dg/unformatted_subrecords_1.f90: New test.
2006-12-01 Thomas Koenig <Thomas.Koenig@online.de>
PR libfortran/29568
* gfortran.h (gfc_option_t): Add max_subrecord_length.
(top level): Define MAX_SUBRECORD_LENGTH.
* lang.opt: Add option -fmax-subrecord-length=.
* trans-decl.c: Add new function set_max_subrecord_length.
(gfc_generate_function_code): If we are within the main
program and max_subrecord_length has been set, call
set_max_subrecord_length.
* options.c (gfc_init_options): Add defaults for
max_subrecord_lenght, convert and record_marker.
(gfc_handle_option): Add handling for
-fmax_subrecord_length.
* invoke.texi: Document the new default for
-frecord-marker=<n>.
2006-12-01 Thomas Koenig <Thomas.Koenig@online.de>
PR libfortran/29568
* libgfortran/libgfortran.h (compile_options_t): Add
record_marker. (top level): Define GFC_MAX_SUBRECORD_LENGTH.
* runtime/compile_options.c (set_record_marker): Change
default to four-byte record marker.
(set_max_subrecord_length): New function.
* runtime/error.c (translate_error): Change error message
for short record on unformatted read.
* io/io.h (gfc_unit): Add recl_subrecord, bytes_left_subrecord
and continued.
* io/file_pos.c (unformatted_backspace): Change default of record
marker size to four bytes. Loop over subrecords.
* io/open.c: Default recl is max_offset. If
compile_options.max_subrecord_length has been set, set set
u->recl_subrecord to its value, to the maximum value otherwise.
* io/transfer.c (top level): Add prototypes for us_read, us_write,
next_record_r_unf and next_record_w_unf.
(read_block_direct): Separate codepaths for unformatted direct
and unformatted sequential. If a recl has been set by the
user, use the number of bytes left for the record if it is smaller
than the read request. Loop over subrecords. Set an error if the
user has set a recl and the read was short.
(write_buf): Separate codepaths for unformatted direct and
unformatted sequential. If a recl has been set by the
user, use the number of bytes left for the record if it is smaller
than the read request. Loop over subrecords. Set an error if the
user has set a recl and the read was short.
(us_read): Add parameter continued (to indicate that bytes_left
should not be intialized). Change default of record marker size
to four bytes. Use subrecord. If the subrecord length is smaller than
zero, this indicates a continuation.
(us_write): Add parameter continued (to indicate that the continued
flag should be set). Use subrecord.
(pre_position): Use 0 for continued on us_write and us_read calls.
(skip_record): New function.
(next_record_r_unf): New function.
(next_record_r): Use next_record_r_unf.
(write_us_marker): Default size for record markers is four bytes.
(next_record_w_unf): New function.
(next_record_w): Use next_record_w_unf.
From-SVN: r119412
2006-12-01 22:04:38 +01:00
|
|
|
compile_options.record_marker = sizeof (GFC_INTEGER_8);
|
2006-03-22 20:09:11 +01:00
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
runtime_error ("Invalid value for record marker");
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
re PR libfortran/29568 (implement unformatted files with subrecords (Intel style))
2006-12-01 Thomas Koenig <Thomas.Koenig@online.de>
PR libfortran/29568
* gfortran.dg/convert_implied_open.f90: Change to
new default record length.
* gfortran.dg/unf_short_record_1.f90: Adapt to
new error message.
* gfortran.dg/unformatted_subrecords_1.f90: New test.
2006-12-01 Thomas Koenig <Thomas.Koenig@online.de>
PR libfortran/29568
* gfortran.h (gfc_option_t): Add max_subrecord_length.
(top level): Define MAX_SUBRECORD_LENGTH.
* lang.opt: Add option -fmax-subrecord-length=.
* trans-decl.c: Add new function set_max_subrecord_length.
(gfc_generate_function_code): If we are within the main
program and max_subrecord_length has been set, call
set_max_subrecord_length.
* options.c (gfc_init_options): Add defaults for
max_subrecord_lenght, convert and record_marker.
(gfc_handle_option): Add handling for
-fmax_subrecord_length.
* invoke.texi: Document the new default for
-frecord-marker=<n>.
2006-12-01 Thomas Koenig <Thomas.Koenig@online.de>
PR libfortran/29568
* libgfortran/libgfortran.h (compile_options_t): Add
record_marker. (top level): Define GFC_MAX_SUBRECORD_LENGTH.
* runtime/compile_options.c (set_record_marker): Change
default to four-byte record marker.
(set_max_subrecord_length): New function.
* runtime/error.c (translate_error): Change error message
for short record on unformatted read.
* io/io.h (gfc_unit): Add recl_subrecord, bytes_left_subrecord
and continued.
* io/file_pos.c (unformatted_backspace): Change default of record
marker size to four bytes. Loop over subrecords.
* io/open.c: Default recl is max_offset. If
compile_options.max_subrecord_length has been set, set set
u->recl_subrecord to its value, to the maximum value otherwise.
* io/transfer.c (top level): Add prototypes for us_read, us_write,
next_record_r_unf and next_record_w_unf.
(read_block_direct): Separate codepaths for unformatted direct
and unformatted sequential. If a recl has been set by the
user, use the number of bytes left for the record if it is smaller
than the read request. Loop over subrecords. Set an error if the
user has set a recl and the read was short.
(write_buf): Separate codepaths for unformatted direct and
unformatted sequential. If a recl has been set by the
user, use the number of bytes left for the record if it is smaller
than the read request. Loop over subrecords. Set an error if the
user has set a recl and the read was short.
(us_read): Add parameter continued (to indicate that bytes_left
should not be intialized). Change default of record marker size
to four bytes. Use subrecord. If the subrecord length is smaller than
zero, this indicates a continuation.
(us_write): Add parameter continued (to indicate that the continued
flag should be set). Use subrecord.
(pre_position): Use 0 for continued on us_write and us_read calls.
(skip_record): New function.
(next_record_r_unf): New function.
(next_record_r): Use next_record_r_unf.
(write_us_marker): Default size for record markers is four bytes.
(next_record_w_unf): New function.
(next_record_w): Use next_record_w_unf.
From-SVN: r119412
2006-12-01 22:04:38 +01:00
|
|
|
|
|
|
|
extern void set_max_subrecord_length (int);
|
|
|
|
export_proto (set_max_subrecord_length);
|
|
|
|
|
|
|
|
void set_max_subrecord_length(int val)
|
|
|
|
{
|
|
|
|
if (val > GFC_MAX_SUBRECORD_LENGTH || val < 1)
|
|
|
|
{
|
|
|
|
runtime_error ("Invalid value for maximum subrecord length");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
compile_options.max_subrecord_length = val;
|
|
|
|
}
|