summaryrefslogtreecommitdiff
path: root/gcc/fortran
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
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')
-rw-r--r--gcc/fortran/ChangeLog7
-rw-r--r--gcc/fortran/intrinsic.c15
2 files changed, 12 insertions, 10 deletions
diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog
index a0590809595..2ce462b08d0 100644
--- a/gcc/fortran/ChangeLog
+++ b/gcc/fortran/ChangeLog
@@ -1,3 +1,10 @@
+2004-11-02 Paul Brook <paul@codesourcery.com>
+
+ * intrinsic.c (check_intrinsic_standard): Include error locus.
+ Remove VLA.
+ (gfc_intrinsic_func_interface, gfc_intrinsic_sub_interface): Pass
+ locus to check_intrinsic_standard.
+
2004-10-31 Janne Blomqvist <jblomqvi@cc.hut.fi>
PR fortran/17590
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;