summaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authormanu <manu@138bc75d-0d04-0410-961f-82ee72b054a4>2012-05-05 11:32:26 +0000
committermanu <manu@138bc75d-0d04-0410-961f-82ee72b054a4>2012-05-05 11:32:26 +0000
commitbfff5bd71a8cc29d1147627c6c779bbc422c1e81 (patch)
tree5b778fa5063ddd329ba7caa13246cdd6ff76e765 /gcc
parent686369e8bd98a1c4b48984e62cc61e9e4047a1d2 (diff)
downloadgcc-bfff5bd71a8cc29d1147627c6c779bbc422c1e81.tar.gz
2012-05-05 Manuel López-Ibáñez <manu@gcc.gnu.org>
PR c/43772 testsuite/ * c-c++-common/pr43772.c: New. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@187195 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc')
-rw-r--r--gcc/testsuite/c-c++-common/pr43772.c45
1 files changed, 45 insertions, 0 deletions
diff --git a/gcc/testsuite/c-c++-common/pr43772.c b/gcc/testsuite/c-c++-common/pr43772.c
new file mode 100644
index 00000000000..8bf09a420f3
--- /dev/null
+++ b/gcc/testsuite/c-c++-common/pr43772.c
@@ -0,0 +1,45 @@
+/* { dg-do compile } */
+/* { dg-options "-Wlogical-op -Wtype-limits" } */
+#include <limits.h>
+long long
+emacs_lseek (long long offset)
+{
+ return -1-9223372036854775807LL <= offset && offset <= 9223372036854775807LL;
+}
+
+long long
+foo (long long offset)
+{
+ return -1-9223372036854775807LL > offset && offset > 9223372036854775807LL;
+}
+
+long long
+foo3 (long long offset)
+{
+ return -1-9223372036854775807LL > offset && offset < 9223372036854775807LL;
+}
+
+long long
+foo2 (long long offset)
+{
+ if (-1-9223372036854775807LL <= offset) return 0;
+ if (offset <= 9223372036854775807LL) return 0;
+ if (-1-9223372036854775807LL > offset) return 0;
+ if (offset > 9223372036854775807LL) return 0;
+ return 1;
+}
+
+# define BOT INT_MIN
+# define TOP INT_MAX
+
+long long get_intmax(void);
+int get_int(void);
+extern void do_something(void);
+int main(void)
+{
+ int i = get_int();
+ long long x = get_intmax();
+ i = (i > BOT && i < TOP); //OK
+ i = (i >= BOT+1 && i <= TOP-1); //OK
+ i = (i >= BOT && i <= TOP); //Oops!
+}