0ef33d4462
gcc/fortran/ * gfortran.texi: Document. * frontend-passes.c (gfc_code_walker): Add SHARE and CARRIAGECONTROL. * io.c (gfc_free_open, gfc_resolve_open, gfc_match_open): Ditto. * gfortran.h (gfc_open): Add SHARE, CARRIAGECONTROL, and READONLY. * io.c (io_tag, match_open_element): Ditto. * ioparm.def: Ditto. * trans-io.c (gfc_trans_open): Ditto. * io.c (match_dec_etag, match_dec_ftag): New functions. libgfortran/io/ * libgfortran.h (IOPARM_OPEN_HAS_READONLY, IOPARM_OPEN_HAS_SHARE, IOPARM_OPEN_HAS_CC): New for READONLY, SHARE, and CARRIAGECONTROL. * close.c (st_close): Support READONLY. * io.h (st_parameter_open, unit_flags): Support SHARE, CARRIAGECONTROL, and READONLY. * open.c (st_open): Ditto. * transfer.c (data_transfer_init): Ditto. * io.h (st_parameter_dt): New member 'cc' for CARRIAGECONTROL. * write.c (write_check_cc, write_cc): New functions for CARRIAGECONTROL. * transfer.c (next_record_cc): Ditto. * file_pos.c (st_endfile): Support SHARE and CARRIAGECONTROL. * io.h (st_parameter_inquire): Ditto. * open.c (edit_modes, new_unit): Ditto. * inquire.c (inquire_via_unit, inquire_via_filename): Ditto. * io.h (unit_share, unit_cc, cc_fortran, IOPARM_INQUIRE_HAS_SHARE, IOPARM_INQUIRE_HAS_CC): New for SHARE and CARRIAGECONTROL. * open.c (share_opt, cc_opt): Ditto. * read.c (read_x): Support CARRIAGECONTROL. * transfer.c (read_sf, next_record_r, next_record_w): Ditto. * write.c (list_formatted_write_scalar, write_a): Ditto. * unix.h (close_share): New prototype. * unix.c (open_share, close_share): New functions to handle SHARE. * unix.c (open_external): Handle READONLY. Call open_share. * close.c (st_close): Call close_share. gcc/testsuite/ * dec_io_1.f90: New test. * dec_io_2.f90: New test. * dec_io_3.f90: New test. * dec_io_4.f90: New test. * dec_io_5.f90: New test. * dec_io_6.f90: New test. From-SVN: r241550
112 lines
2.7 KiB
C
112 lines
2.7 KiB
C
/* Copyright (C) 2002-2016 Free Software Foundation, Inc.
|
|
Contributed by Andy Vaught
|
|
|
|
This file is part of the GNU Fortran 95 runtime library (libgfortran).
|
|
|
|
Libgfortran 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, or (at your option)
|
|
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.
|
|
|
|
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/>. */
|
|
|
|
#include "io.h"
|
|
#include "unix.h"
|
|
#include <limits.h>
|
|
|
|
typedef enum
|
|
{ CLOSE_DELETE, CLOSE_KEEP, CLOSE_UNSPECIFIED }
|
|
close_status;
|
|
|
|
static const st_option status_opt[] = {
|
|
{"keep", CLOSE_KEEP},
|
|
{"delete", CLOSE_DELETE},
|
|
{NULL, 0}
|
|
};
|
|
|
|
|
|
extern void st_close (st_parameter_close *);
|
|
export_proto(st_close);
|
|
|
|
void
|
|
st_close (st_parameter_close *clp)
|
|
{
|
|
close_status status;
|
|
gfc_unit *u;
|
|
#if !HAVE_UNLINK_OPEN_FILE
|
|
char * path;
|
|
|
|
path = NULL;
|
|
#endif
|
|
|
|
library_start (&clp->common);
|
|
|
|
status = !(clp->common.flags & IOPARM_CLOSE_HAS_STATUS) ? CLOSE_UNSPECIFIED :
|
|
find_option (&clp->common, clp->status, clp->status_len,
|
|
status_opt, "Bad STATUS parameter in CLOSE statement");
|
|
|
|
if ((clp->common.flags & IOPARM_LIBRETURN_MASK) != IOPARM_LIBRETURN_OK)
|
|
{
|
|
library_end ();
|
|
return;
|
|
}
|
|
|
|
u = find_unit (clp->common.unit);
|
|
if (u != NULL)
|
|
{
|
|
if (close_share (u) < 0)
|
|
generate_error (&clp->common, LIBERROR_OS, "Problem in CLOSE");
|
|
if (u->flags.status == STATUS_SCRATCH)
|
|
{
|
|
if (status == CLOSE_KEEP)
|
|
generate_error (&clp->common, LIBERROR_BAD_OPTION,
|
|
"Can't KEEP a scratch file on CLOSE");
|
|
#if !HAVE_UNLINK_OPEN_FILE
|
|
path = strdup (u->filename);
|
|
#endif
|
|
}
|
|
else
|
|
{
|
|
if (status == CLOSE_DELETE)
|
|
{
|
|
if (u->flags.readonly)
|
|
generate_warning (&clp->common, "STATUS set to DELETE on CLOSE"
|
|
" but file protected by READONLY specifier");
|
|
else
|
|
{
|
|
#if HAVE_UNLINK_OPEN_FILE
|
|
remove (u->filename);
|
|
#else
|
|
path = strdup (u->filename);
|
|
#endif
|
|
}
|
|
}
|
|
}
|
|
|
|
close_unit (u);
|
|
|
|
#if !HAVE_UNLINK_OPEN_FILE
|
|
if (path != NULL)
|
|
{
|
|
remove (path);
|
|
free (path);
|
|
}
|
|
#endif
|
|
}
|
|
|
|
/* CLOSE on unconnected unit is legal and a no-op: F95 std., 9.3.5. */
|
|
library_end ();
|
|
}
|