2011-06-20 Tobias Burnus <burnus@net-b.de> PR fortran/18918 * gfortran.h (gfc_check_vardef_context): Update prototype. (iso_fortran_env_symbol): Handle derived types. (symbol_attribute): Add lock_comp. * expr.c (gfc_check_vardef_context): Add LOCK_TYPE check. * interface.c (compare_parameter, gfc_procedure_use): Handle LOCK_TYPE. (compare_actual_formal): Update gfc_check_vardef_context call. * check.c (gfc_check_atomic_def, gfc_check_atomic_ref): Ditto. * intrinsic.c (check_arglist): Ditto. * io.c (resolve_tag, gfc_resolve_dt, gfc_resolve_inquire): * Ditto. * iso-fortran-env.def (ISOFORTRAN_LOCK_TYPE): Add. * intrinsic.texi (ISO_FORTRAN_ENV): Document LOCK_TYPE. * module.c (mio_symbol_attribute): Handle lock_comp. (create_derived_type): New function. (use_iso_fortran_env_module): Call it to handle LOCK_TYPE. * parse.c (parse_derived): Add constraint check for LOCK_TYPE. * resolve.c (resolve_symbol, resolve_lock_unlock): Add * constraint checks for LOCK_TYPE. (gfc_resolve_iterator, resolve_deallocate_expr, resolve_allocate_expr, resolve_code, resolve_transfer): Update gfc_check_vardef_context call. * trans-stmt.h (gfc_trans_lock_unlock): New prototype. * trans-stmt.c (gfc_trans_lock_unlock): New function. * trans.c (trans_code): Handle LOCK and UNLOCK. 2011-06-20 Tobias Burnus <burnus@net-b.de> PR fortran/18918 * gfortran.dg/coarray_lock_1.f90: Update dg-error. * gfortran.dg/coarray_lock_3.f90: New. * gfortran.dg/coarray/lock_1.f90: New. From-SVN: r175228
124 lines
5.2 KiB
Modula-2
124 lines
5.2 KiB
Modula-2
/* Copyright (C) 2006, 2007, 2008, 2009, 2010 Free Software Foundation, Inc.
|
|
|
|
This file is part of GCC.
|
|
|
|
GCC 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.
|
|
|
|
GCC 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 GCC; see the file COPYING3. If not see
|
|
<http://www.gnu.org/licenses/>. */
|
|
|
|
/* This file contains the definition of the named integer constants provided
|
|
by the Fortran 2003 ISO_FORTRAN_ENV intrinsic module. */
|
|
|
|
#ifndef NAMED_INTCST
|
|
# define NAMED_INTCST(a,b,c,d)
|
|
#endif
|
|
|
|
#ifndef NAMED_KINDARRAY
|
|
# define NAMED_KINDARRAY(a,b,c,d)
|
|
#endif
|
|
|
|
#ifndef NAMED_FUNCTION
|
|
# define NAMED_FUNCTION(a,b,c,d)
|
|
#endif
|
|
|
|
/* The arguments to NAMED_INTCST are:
|
|
-- an internal name
|
|
-- the symbol name in the module, as seen by Fortran code
|
|
-- the value it has
|
|
-- the standard that supports this type */
|
|
|
|
NAMED_INTCST (ISOFORTRANENV_FILE_ATOMIC_INT_KIND, "atomic_int_kind", \
|
|
gfc_atomic_int_kind, GFC_STD_F2008)
|
|
NAMED_INTCST (ISOFORTRANENV_FILE_ATOMIC_LOGICAL_KIND, "atomic_logical_kind", \
|
|
gfc_atomic_logical_kind, GFC_STD_F2008)
|
|
NAMED_INTCST (ISOFORTRANENV_CHARACTER_STORAGE_SIZE, "character_storage_size", \
|
|
gfc_character_storage_size, GFC_STD_F2003)
|
|
NAMED_INTCST (ISOFORTRANENV_ERROR_UNIT, "error_unit", GFC_STDERR_UNIT_NUMBER, \
|
|
GFC_STD_F2003)
|
|
NAMED_INTCST (ISOFORTRANENV_FILE_STORAGE_SIZE, "file_storage_size", 8, \
|
|
GFC_STD_F2003)
|
|
NAMED_INTCST (ISOFORTRANENV_INPUT_UNIT, "input_unit", GFC_STDIN_UNIT_NUMBER, \
|
|
GFC_STD_F2003)
|
|
NAMED_INTCST (ISOFORTRANENV_INT8, "int8", \
|
|
gfc_get_int_kind_from_width_isofortranenv (8), GFC_STD_F2008)
|
|
NAMED_INTCST (ISOFORTRANENV_INT16, "int16", \
|
|
gfc_get_int_kind_from_width_isofortranenv (16), GFC_STD_F2008)
|
|
NAMED_INTCST (ISOFORTRANENV_INT32, "int32", \
|
|
gfc_get_int_kind_from_width_isofortranenv (32), GFC_STD_F2008)
|
|
NAMED_INTCST (ISOFORTRANENV_INT64, "int64", \
|
|
gfc_get_int_kind_from_width_isofortranenv (64), GFC_STD_F2008)
|
|
NAMED_INTCST (ISOFORTRANENV_IOSTAT_END, "iostat_end", LIBERROR_END, \
|
|
GFC_STD_F2003)
|
|
NAMED_INTCST (ISOFORTRANENV_IOSTAT_EOR, "iostat_eor", LIBERROR_EOR, \
|
|
GFC_STD_F2003)
|
|
NAMED_INTCST (ISOFORTRANENV_IOSTAT_INQUIRE_INTERNAL_UNIT, \
|
|
"iostat_inquire_internal_unit", LIBERROR_INQUIRE_INTERNAL_UNIT, \
|
|
GFC_STD_F2008)
|
|
NAMED_INTCST (ISOFORTRANENV_NUMERIC_STORAGE_SIZE, "numeric_storage_size", \
|
|
gfc_numeric_storage_size, GFC_STD_F2003)
|
|
NAMED_INTCST (ISOFORTRANENV_OUTPUT_UNIT, "output_unit", GFC_STDOUT_UNIT_NUMBER, \
|
|
GFC_STD_F2003)
|
|
NAMED_INTCST (ISOFORTRANENV_REAL32, "real32", \
|
|
gfc_get_real_kind_from_width_isofortranenv (32), GFC_STD_F2008)
|
|
NAMED_INTCST (ISOFORTRANENV_REAL64, "real64", \
|
|
gfc_get_real_kind_from_width_isofortranenv (64), GFC_STD_F2008)
|
|
NAMED_INTCST (ISOFORTRANENV_REAL128, "real128", \
|
|
gfc_get_real_kind_from_width_isofortranenv (128), GFC_STD_F2008)
|
|
NAMED_INTCST (ISOFORTRANENV_FILE_STAT_LOCKED, "stat_locked", \
|
|
GFC_STAT_LOCKED, GFC_STD_F2008)
|
|
NAMED_INTCST (ISOFORTRANENV_FILE_STAT_LOCKED_OTHER_IMAGE, \
|
|
"stat_locked_other_image", \
|
|
GFC_STAT_LOCKED_OTHER_IMAGE, GFC_STD_F2008)
|
|
NAMED_INTCST (ISOFORTRANENV_FILE_STAT_STOPPED_IMAGE, "stat_stopped_image", \
|
|
GFC_STAT_STOPPED_IMAGE, GFC_STD_F2008)
|
|
NAMED_INTCST (ISOFORTRANENV_FILE_STAT_UNLOCKED, "stat_unlocked", \
|
|
GFC_STAT_UNLOCKED, GFC_STD_F2008)
|
|
|
|
|
|
/* The arguments to NAMED_KINDARRAY are:
|
|
-- an internal name
|
|
-- the symbol name in the module, as seen by Fortran code
|
|
-- the gfortran variable containing the information
|
|
-- the Fortran standard */
|
|
|
|
NAMED_KINDARRAY (ISOFORTRAN_CHARACTER_KINDS, "character_kinds", \
|
|
gfc_character_kinds, GFC_STD_F2008)
|
|
NAMED_KINDARRAY (ISOFORTRAN_INTEGER_KINDS, "integer_kinds", \
|
|
gfc_integer_kinds, GFC_STD_F2008)
|
|
NAMED_KINDARRAY (ISOFORTRAN_LOGICAL_KINDS, "logical_kinds", \
|
|
gfc_logical_kinds, GFC_STD_F2008)
|
|
NAMED_KINDARRAY (ISOFORTRAN_REAL_KINDS, "real_kinds", \
|
|
gfc_real_kinds, GFC_STD_F2008)
|
|
|
|
/* The arguments to NAMED_FUNCTIONS are:
|
|
-- the ISYM
|
|
-- the symbol name in the module, as seen by Fortran code
|
|
-- the Fortran standard */
|
|
|
|
NAMED_FUNCTION (ISOFORTRAN_COMPILER_OPTIONS, "compiler_options", \
|
|
GFC_ISYM_COMPILER_OPTIONS, GFC_STD_F2008)
|
|
NAMED_FUNCTION (ISOFORTRAN_COMPILER_VERSION, "compiler_version", \
|
|
GFC_ISYM_COMPILER_VERSION, GFC_STD_F2008)
|
|
|
|
#ifndef NAMED_DERIVED_TYPE
|
|
# define NAMED_DERIVED_TYPE(a,b,c,d)
|
|
#endif
|
|
|
|
NAMED_DERIVED_TYPE (ISOFORTRAN_LOCK_TYPE, "lock_type", \
|
|
get_int_kind_from_node (ptr_type_node), GFC_STD_F2008)
|
|
|
|
#undef NAMED_INTCST
|
|
#undef NAMED_KINDARRAY
|
|
#undef NAMED_FUNCTION
|
|
#undef NAMED_DERIVED_TYPE
|