wpp: Add explicit casts when mixing unsigned and signed integers.

Gerald Pfeifer gerald at pfeifer.com
Sat Feb 26 14:01:02 CST 2011


This is the symmetric case of 
http://www.winehq.org/pipermail/wine-cvs/2011-February/075210.html
that I missed originally.

Gerald

---
 libs/wpp/ppy.y |    6 +++---
 1 files changed, 3 insertions(+), 3 deletions(-)

diff --git a/libs/wpp/ppy.y b/libs/wpp/ppy.y
index a66072d..f2805e1 100644
--- a/libs/wpp/ppy.y
+++ b/libs/wpp/ppy.y
@@ -61,7 +61,7 @@
 	else if(cv_signed(v1) && !cv_signed(v2))	\
 		r.val.si = v1.val.si OP (signed) v2.val.ui; \
 	else if(!cv_signed(v1) && cv_signed(v2))	\
-		r.val.si = v1.val.ui OP v2.val.si;	\
+		r.val.si = (signed) v1.val.ui OP v2.val.si; \
 	else						\
 		r.val.ui = v1.val.ui OP v2.val.ui;
 
@@ -72,7 +72,7 @@
 	else if(cv_signed(v1) && !cv_signed(v2))	\
 		r.val.sl = v1.val.sl OP (signed long) v2.val.ul; \
 	else if(!cv_signed(v1) && cv_signed(v2))	\
-		r.val.sl = v1.val.ul OP v2.val.sl;	\
+		r.val.sl = (signed long) v1.val.ul OP v2.val.sl; \
 	else						\
 		r.val.ul = v1.val.ul OP v2.val.ul;
 
@@ -83,7 +83,7 @@
 	else if(cv_signed(v1) && !cv_signed(v2))	\
 		r.val.sll = v1.val.sll OP (wrc_sll_t) v2.val.ull; \
 	else if(!cv_signed(v1) && cv_signed(v2))	\
-		r.val.sll = v1.val.ull OP v2.val.sll;	\
+		r.val.sll = (wrc_sll_t) v1.val.ull OP v2.val.sll; \
 	else						\
 		r.val.ull = v1.val.ull OP v2.val.ull;
 
-- 
1.7.4.1



More information about the wine-patches mailing list