diff options
author | Tobias Burnus <burnus@net-b.de> | 2009-06-28 19:56:41 +0200 |
---|---|---|
committer | Tobias Burnus <burnus@gcc.gnu.org> | 2009-06-28 19:56:41 +0200 |
commit | 08a6b8e049f9935cc314a669b2120ff07cd7fbeb (patch) | |
tree | 49b09d2f1e0cfee1a1f1901ff04e9da4c8a351d1 /gcc/fortran/symbol.c | |
parent | 0948ccb243a5b2244bef375addc6f1a4b3a2f526 (diff) | |
download | gcc-08a6b8e049f9935cc314a669b2120ff07cd7fbeb.zip gcc-08a6b8e049f9935cc314a669b2120ff07cd7fbeb.tar.gz gcc-08a6b8e049f9935cc314a669b2120ff07cd7fbeb.tar.bz2 |
re PR fortran/34112 (Add $!DEC ATTRIBUTE support for 32bit Windows' STDCALL)
2009-06-28 Tobias Burnus <burnus@net-b.de>
Francois-Xavier Coudert <fxcoudert@gcc.gnu.org>
PR fortran/34112
* symbol.c (gfc_add_ext_attribute): New function.
(gfc_get_sym_tree): New argument allow_subroutine.
(gfc_get_symbol,gfc_get_ha_sym_tree,gen_cptr_param,gen_fptr_param
gen_shape_param,generate_isocbinding_symbol): Use it.
* decl.c (find_special): New argument allow_subroutine.
(add_init_expr_to_sym,add_hidden_procptr_result,attr_decl1,
match_procedure_in_type,gfc_match_final_decl): Use it.
(gfc_match_gcc_attributes): New function.
* gfortran.texi (Mixed-Language Programming): New section
"GNU Fortran Compiler Directives".
* gfortran.h (ext_attr_t): New struct.
(symbol_attributes): Use it.
(gfc_add_ext_attribute): New prototype.
(gfc_get_sym_tree): Update pototype.
* expr.c (gfc_check_pointer_assign): Check whether call
convention is the same.
* module.c (import_iso_c_binding_module, create_int_parameter,
use_iso_fortran_env_module): Update gfc_get_sym_tree call.
* scanner.c (skip_gcc_attribute): New function.
(skip_free_comments,skip_fixed_comments): Use it.
(gfc_next_char_literal): Support !GCC$ lines.
* resolve.c (check_host_association): Update
gfc_get_sym_tree call.
* match.c (gfc_match_sym_tree,gfc_match_call): Update
gfc_get_sym_tree call.
* trans-decl.c (add_attributes_to_decl): New function.
(gfc_get_symbol_decl,get_proc_pointer_decl,
gfc_get_extern_function_decl,build_function_decl: Use it.
* match.h (gfc_match_gcc_attributes): Add prototype.
* parse.c (decode_gcc_attribute): New function.
(next_free,next_fixed): Support !GCC$ lines.
* primary.c (match_actual_arg,check_for_implicit_index,
gfc_match_rvalue,gfc_match_rvalue): Update
gfc_get_sym_tree call.
2009-06-28 Tobias Burnus <burnus@net-b.de>
PR fortran/34112
* gfortran.dg/compiler-directive_1.f90: New test.
* gfortran.dg/compiler-directive_2.f: New test.
Co-Authored-By: Francois-Xavier Coudert <fxcoudert@gcc.gnu.org>
From-SVN: r149036
Diffstat (limited to 'gcc/fortran/symbol.c')
-rw-r--r-- | gcc/fortran/symbol.c | 33 |
1 files changed, 21 insertions, 12 deletions
diff --git a/gcc/fortran/symbol.c b/gcc/fortran/symbol.c index 89cff65..0c1a2fd 100644 --- a/gcc/fortran/symbol.c +++ b/gcc/fortran/symbol.c @@ -809,19 +809,28 @@ duplicate_attr (const char *attr, locus *where) } +gfc_try +gfc_add_ext_attribute (symbol_attribute *attr, unsigned ext_attr, + locus *where ATTRIBUTE_UNUSED) +{ + attr->ext_attr |= 1 << ext_attr; + return SUCCESS; +} + + /* Called from decl.c (attr_decl1) to check attributes, when declared separately. */ gfc_try gfc_add_attribute (symbol_attribute *attr, locus *where) { - if (check_used (attr, NULL, where)) return FAILURE; return check_conflict (attr, NULL, where); } + gfc_try gfc_add_allocatable (symbol_attribute *attr, locus *where) { @@ -2539,7 +2548,8 @@ save_symbol_data (gfc_symbol *sym) So if the return value is nonzero, then an error was issued. */ int -gfc_get_sym_tree (const char *name, gfc_namespace *ns, gfc_symtree **result) +gfc_get_sym_tree (const char *name, gfc_namespace *ns, gfc_symtree **result, + bool allow_subroutine) { gfc_symtree *st; gfc_symbol *p; @@ -2580,11 +2590,10 @@ gfc_get_sym_tree (const char *name, gfc_namespace *ns, gfc_symtree **result) } p = st->n.sym; - if (p->ns != ns && (!p->attr.function || ns->proc_name != p) - && !(ns->proc_name - && ns->proc_name->attr.if_source == IFSRC_IFBODY - && (ns->has_import_set || p->attr.imported))) + && !(allow_subroutine && p->attr.subroutine) + && !(ns->proc_name && ns->proc_name->attr.if_source == IFSRC_IFBODY + && (ns->has_import_set || p->attr.imported))) { /* Symbol is from another namespace. */ gfc_error ("Symbol '%s' at %C has already been host associated", @@ -2609,7 +2618,7 @@ gfc_get_symbol (const char *name, gfc_namespace *ns, gfc_symbol **result) gfc_symtree *st; int i; - i = gfc_get_sym_tree (name, ns, &st); + i = gfc_get_sym_tree (name, ns, &st, false); if (i != 0) return i; @@ -2651,7 +2660,7 @@ gfc_get_ha_sym_tree (const char *name, gfc_symtree **result) } } - return gfc_get_sym_tree (name, gfc_current_ns, result); + return gfc_get_sym_tree (name, gfc_current_ns, result, false); } @@ -3653,7 +3662,7 @@ gen_cptr_param (gfc_formal_arglist **head, c_ptr_in = "gfc_cptr__"; else c_ptr_in = c_ptr_name; - gfc_get_sym_tree (c_ptr_in, ns, ¶m_symtree); + gfc_get_sym_tree (c_ptr_in, ns, ¶m_symtree, false); if (param_symtree != NULL) param_sym = param_symtree->n.sym; else @@ -3719,7 +3728,7 @@ gen_fptr_param (gfc_formal_arglist **head, if (f_ptr_name != NULL) f_ptr_out = f_ptr_name; - gfc_get_sym_tree (f_ptr_out, ns, ¶m_symtree); + gfc_get_sym_tree (f_ptr_out, ns, ¶m_symtree, false); if (param_symtree != NULL) param_sym = param_symtree->n.sym; else @@ -3766,7 +3775,7 @@ gen_shape_param (gfc_formal_arglist **head, if (shape_param_name != NULL) shape_param = shape_param_name; - gfc_get_sym_tree (shape_param, ns, ¶m_symtree); + gfc_get_sym_tree (shape_param, ns, ¶m_symtree, false); if (param_symtree != NULL) param_sym = param_symtree->n.sym; else @@ -4115,7 +4124,7 @@ generate_isocbinding_symbol (const char *mod_name, iso_c_binding_symbol s, return; /* Create the sym tree in the current ns. */ - gfc_get_sym_tree (name, gfc_current_ns, &tmp_symtree); + gfc_get_sym_tree (name, gfc_current_ns, &tmp_symtree, false); if (tmp_symtree) tmp_sym = tmp_symtree->n.sym; else |