From: Jonathan Wakely Date: Wed, 29 Jun 2022 22:41:46 +0000 (+0100) Subject: c-family: Add names to diagnostics for known headers X-Git-Tag: releases/gcc-12.2.0~144 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=40ddc305802cb7174e5b3d2e9b31e783b46f3769;p=thirdparty%2Fgcc.git c-family: Add names to diagnostics for known headers gcc/c-family/ChangeLog: * known-headers.cc (get_stdlib_header_for_name): Add names. gcc/testsuite/ChangeLog: * g++.dg/spellcheck-stdlib.C: Check types and functions. (cherry picked from commit d489ec082ea214109ff54071410f8cd00344e654) --- diff --git a/gcc/c-family/known-headers.cc b/gcc/c-family/known-headers.cc index 8ad3eb3f4667..1c08f2c09d72 100644 --- a/gcc/c-family/known-headers.cc +++ b/gcc/c-family/known-headers.cc @@ -200,6 +200,20 @@ get_stdlib_header_for_name (const char *name, enum stdlib lib) {"WINT_MAX", {"", ""} }, {"WINT_MIN", {"", ""} }, + /* . */ + {"asctime", {"", ""} }, + {"clock", {"", ""} }, + {"clock_t", {"", ""} }, + {"ctime", {"", ""} }, + {"difftime", {"", ""} }, + {"gmtime", {"", ""} }, + {"localtime", {"", ""} }, + {"mktime", {"", ""} }, + {"strftime", {"", ""} }, + {"time", {"", ""} }, + {"time_t", {"", ""} }, + {"tm", {"", ""} }, + /* . */ {"WCHAR_MAX", {"", ""} }, {"WCHAR_MIN", {"", ""} } diff --git a/gcc/testsuite/g++.dg/spellcheck-stdlib.C b/gcc/testsuite/g++.dg/spellcheck-stdlib.C index 87736b25e54b..7a70641e3ae1 100644 --- a/gcc/testsuite/g++.dg/spellcheck-stdlib.C +++ b/gcc/testsuite/g++.dg/spellcheck-stdlib.C @@ -158,6 +158,35 @@ void test_cstdlib (void *q) // { dg-message "'#include '" "" { target *-*-* } .-1 } } +/* Missing . */ + +void test_ctime (void *q, long s, double d) +{ + clock_t c; // { dg-error "was not declared" } + // { dg-message "'#include '" "" { target *-*-* } .-1 } + time_t t; // { dg-error "was not declared" } + // { dg-message "'#include '" "" { target *-*-* } .-1 } + tm t2; // { dg-error "was not declared" } + // { dg-message "'#include '" "" { target *-*-* } .-1 } + d = difftime (0, 0); // { dg-error "was not declared" } + // { dg-message "'#include '" "" { target *-*-* } .-1 } + s = mktime (q); // { dg-error "was not declared" } + // { dg-message "'#include '" "" { target *-*-* } .-1 } + s = time (0); // { dg-error "was not declared" } + // { dg-message "'#include '" "" { target *-*-* } .-1 } + q = asctime (0); // { dg-error "was not declared" } + // { dg-message "'#include '" "" { target *-*-* } .-1 } + q = ctime (0); // { dg-error "was not declared" } + // { dg-message "'#include '" "" { target *-*-* } .-1 } + q = gmtime (0); // { dg-error "was not declared" } + // { dg-message "'#include '" "" { target *-*-* } .-1 } + q = localtime (0); // { dg-error "was not declared" } + // { dg-message "'#include '" "" { target *-*-* } .-1 } + char c[2]; + strftime (c, 2, "", 0); // { dg-error "was not declared" } + // { dg-message "'#include '" "" { target *-*-* } .-1 } +} + /* Verify that we don't offer suggestions to stdlib globals names when there's an explicit namespace. */