[gtk/transform-fixes: 4/5] Never compare floats for equality
- From: Emmanuele Bassi <ebassi src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk/transform-fixes: 4/5] Never compare floats for equality
- Date: Fri, 22 Mar 2019 14:35:25 +0000 (UTC)
commit 5866b875654c265bfaaabc1bfa8833678de8fe17
Author: Emmanuele Bassi <ebassi gnome org>
Date: Fri Mar 22 12:39:28 2019 +0000
Never compare floats for equality
Floating point values cannot ever be compared for equality. GLib has a
G_APPROX_VALUE macro that lets us compare two value within a provided
precision, so we should use that instead.
gsk/gsktransform.c | 14 +++++++-------
1 file changed, 7 insertions(+), 7 deletions(-)
---
diff --git a/gsk/gsktransform.c b/gsk/gsktransform.c
index 133f5820e5..9608a141ca 100644
--- a/gsk/gsktransform.c
+++ b/gsk/gsktransform.c
@@ -735,7 +735,7 @@ gsk_rotate_transform_equal (GskTransform *first_transform,
GskRotateTransform *first = (GskRotateTransform *) first_transform;
GskRotateTransform *second = (GskRotateTransform *) second_transform;
- return first->angle == second->angle;
+ return G_APPROX_VALUE (first->angle, second->angle, 0.01f);
}
static void
@@ -837,8 +837,8 @@ gsk_rotate3d_transform_equal (GskTransform *first_transform,
GskRotate3dTransform *first = (GskRotate3dTransform *) first_transform;
GskRotate3dTransform *second = (GskRotate3dTransform *) second_transform;
- return first->angle == second->angle
- && graphene_vec3_equal (&first->axis, &second->axis);
+ return G_APPROX_VALUE (first->angle, second->angle, 0.01f) &&
+ graphene_vec3_equal (&first->axis, &second->axis);
}
static void
@@ -996,9 +996,9 @@ gsk_scale_transform_equal (GskTransform *first_transform,
GskScaleTransform *first = (GskScaleTransform *) first_transform;
GskScaleTransform *second = (GskScaleTransform *) second_transform;
- return first->factor_x == second->factor_x
- && first->factor_y == second->factor_y
- && first->factor_z == second->factor_z;
+ return G_APPROX_VALUE (first->factor_x, second->factor_x, 0.01f) &&
+ G_APPROX_VALUE (first->factor_y, second->factor_y, 0.01f) &&
+ G_APPROX_VALUE (first->factor_z, second->factor_z, 0.01f);
}
static void
@@ -1150,7 +1150,7 @@ gsk_perspective_transform_equal (GskTransform *first_transform,
GskPerspectiveTransform *first = (GskPerspectiveTransform *) first_transform;
GskPerspectiveTransform *second = (GskPerspectiveTransform *) second_transform;
- return first->depth == second->depth;
+ return G_APPROX_VALUE (first->depth, second->depth, 0.001f);
}
static void
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]