mirror of
https://github.com/llvm/llvm-project.git
synced 2025-04-29 07:16:08 +00:00

Summary: As noted in PR, we have a poor test coverage for this warning. I think macro support was just overlooked. GCC warns in these cases. Clang missed a real bug in the code I am working with, GCC caught it. Reviewers: aaron.ballman Reviewed By: aaron.ballman Subscribers: cfe-commits Tags: #clang Differential Revision: https://reviews.llvm.org/D70624
30 lines
1.3 KiB
C
30 lines
1.3 KiB
C
// RUN: %clang_cc1 -x c -fsyntax-only -verify %s
|
|
// RUN: %clang_cc1 -x c++ -fsyntax-only -verify %s
|
|
|
|
#define DELIM "/"
|
|
#define DOT "."
|
|
#define NULL (void *)0
|
|
|
|
void test(const char *d) {
|
|
if ("/" != d) // expected-warning {{result of comparison against a string literal is unspecified (use an explicit string comparison function instead)}}
|
|
return;
|
|
if (d == "/") // expected-warning {{result of comparison against a string literal is unspecified (use an explicit string comparison function instead)}}
|
|
return;
|
|
if ("/" != NULL)
|
|
return;
|
|
if (NULL == "/")
|
|
return;
|
|
if ("/" != DELIM) // expected-warning {{result of comparison against a string literal is unspecified (use an explicit string comparison function instead)}}
|
|
return;
|
|
if (DELIM == "/") // expected-warning {{result of comparison against a string literal is unspecified (use an explicit string comparison function instead)}}
|
|
return;
|
|
if (DELIM != NULL)
|
|
return;
|
|
if (NULL == DELIM)
|
|
return;
|
|
if (DOT != DELIM) // expected-warning {{result of comparison against a string literal is unspecified (use an explicit string comparison function instead)}}
|
|
return;
|
|
if (DELIM == DOT) // expected-warning {{result of comparison against a string literal is unspecified (use an explicit string comparison function instead)}}
|
|
return;
|
|
}
|