From: David Blaikie Date: Thu, 12 Apr 2012 22:40:54 +0000 (+0000) Subject: Warn on 64-to-32 for source value of x bits where 64 >= x > 32. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=37050841d7b852497b85d5275d9ea92c07ddf059;p=clang Warn on 64-to-32 for source value of x bits where 64 >= x > 32. The codepath already only works for source bits > target bits, it's just that it was testing for the source expr bits to be exactly 64. This meant simple cases (int i = x_long / 2) were missed & ended up under the general -Wconversion warning, which a user might not have enabled. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@154626 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Sema/SemaChecking.cpp b/lib/Sema/SemaChecking.cpp index 1606e336ee..7fabfaf565 100644 --- a/lib/Sema/SemaChecking.cpp +++ b/lib/Sema/SemaChecking.cpp @@ -4233,7 +4233,7 @@ void CheckImplicitConversion(Sema &S, Expr *E, QualType T, if (S.SourceMgr.isInSystemMacro(CC)) return; - if (SourceRange.Width == 64 && TargetRange.Width == 32) + if (TargetRange.Width == 32 && S.Context.getIntWidth(E->getType()) == 64) return DiagnoseImpCast(S, E, T, CC, diag::warn_impcast_integer_64_32, /* pruneControlFlow */ true); return DiagnoseImpCast(S, E, T, CC, diag::warn_impcast_integer_precision); diff --git a/test/Sema/conversion-64-32.c b/test/Sema/conversion-64-32.c index 112e995102..3de20cb0fd 100644 --- a/test/Sema/conversion-64-32.c +++ b/test/Sema/conversion-64-32.c @@ -13,3 +13,7 @@ int4 test1(long2 a) { int4 v127 = a; // no warning. return v127; } + +int test2(long v) { + return v / 2; // expected-warning {{implicit conversion loses integer precision: 'long' to 'int'}} +}