summaryrefslogtreecommitdiff
path: root/gcc/fortran/intrinsic.c
diff options
context:
space:
mode:
authorpbrook <pbrook@138bc75d-0d04-0410-961f-82ee72b054a4>2004-11-02 00:27:13 +0000
committerpbrook <pbrook@138bc75d-0d04-0410-961f-82ee72b054a4>2004-11-02 00:27:13 +0000
commit9b65953f5e51a077fe930987b4687d531d0d5e02 (patch)
treea195e9ab84866f6c0e2c542126ddc68982be8389 /gcc/fortran/intrinsic.c
parent3df10a0bd31d6a68473f14f0219b0ee4c30a731f (diff)
downloadgcc-9b65953f5e51a077fe930987b4687d531d0d5e02.tar.gz
* intrinsic.c (check_intrinsic_standard): Include error locus.
Remove VLA. (gfc_intrinsic_func_interface, gfc_intrinsic_sub_interface): Pass locus to check_intrinsic_standard. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@89971 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/fortran/intrinsic.c')
-rw-r--r--gcc/fortran/intrinsic.c15
1 files changed, 5 insertions, 10 deletions
diff --git a/gcc/fortran/intrinsic.c b/gcc/fortran/intrinsic.c
index 1c1698fdd2e..b0a1d189753 100644
--- a/gcc/fortran/intrinsic.c
+++ b/gcc/fortran/intrinsic.c
@@ -2670,18 +2670,13 @@ gfc_init_expr_extensions (gfc_intrinsic_sym *isym)
has chosen. */
static void
-check_intrinsic_standard (const char *name, int standard)
+check_intrinsic_standard (const char *name, int standard, locus * where)
{
- int name_len;
- char msgstr[name_len + 53];
-
if (!gfc_option.warn_nonstd_intrinsics)
return;
- name_len = strlen (name);
- strncpy (msgstr, name, name_len + 1);
- strncat (msgstr, " intrinsic is not included in the selected standard.", 53);
- gfc_notify_std (standard, msgstr);
+ gfc_notify_std (standard, "Intrinsic '%s' at %L is not included"
+ "in the selected standard", name, where);
}
@@ -2794,7 +2789,7 @@ got_specific:
}
}
- check_intrinsic_standard (name, isym->standard);
+ check_intrinsic_standard (name, isym->standard, &expr->where);
return MATCH_YES;
}
@@ -2851,7 +2846,7 @@ gfc_intrinsic_sub_interface (gfc_code * c, int error_flag)
return MATCH_ERROR;
}
- check_intrinsic_standard (name, isym->standard);
+ check_intrinsic_standard (name, isym->standard, &c->loc);
return MATCH_YES;