r16363 - lwpoly_construct_circle: Avoid division by zero (Raúl Marín Rodríguez)

Paul Ramsey pramsey at cleverelephant.ca
Fri Jan 26 06:56:52 PST 2018


Author: pramsey
Date: 2018-01-26 06:56:52 -0800 (Fri, 26 Jan 2018)
New Revision: 16363

Modified:
   branches/2.3/NEWS
   branches/2.3/liblwgeom/lwpoly.c
Log:
lwpoly_construct_circle: Avoid division by zero (Raúl Marín Rodríguez)
References #4003


Modified: branches/2.3/NEWS
===================================================================
--- branches/2.3/NEWS	2018-01-26 14:55:44 UTC (rev 16362)
+++ branches/2.3/NEWS	2018-01-26 14:56:52 UTC (rev 16363)
@@ -4,7 +4,9 @@
   * Bug Fixes and Enhancements
 
   - #3978, Fix KNN when upgrading from 2.1 or older (Sandro Santilli)
+  - #4003, lwpoly_construct_circle: Avoid division by zero (Raúl Marín Rodríguez)
 
+
 PostGIS 2.3.6
 2018/01/17
 

Modified: branches/2.3/liblwgeom/lwpoly.c
===================================================================
--- branches/2.3/liblwgeom/lwpoly.c	2018-01-26 14:55:44 UTC (rev 16362)
+++ branches/2.3/liblwgeom/lwpoly.c	2018-01-26 14:56:52 UTC (rev 16363)
@@ -98,13 +98,13 @@
 lwpoly_construct_circle(int srid, double x, double y, double radius, uint32_t segments_per_quarter, char exterior)
 {
 	const int segments = 4*segments_per_quarter;
-	const double theta = 2*M_PI / segments;
+	double theta;
 	LWPOLY *lwpoly;
 	POINTARRAY *pa;
 	POINT4D pt;
 	uint32_t i;
 
-	if (segments_per_quarter < 1)
+	if (segments_per_quarter == 0)
 	{
 		lwerror("Need at least one segment per quarter-circle.");
 		return NULL;
@@ -116,6 +116,8 @@
 		return NULL;
 	}
 
+	theta = 2*M_PI / segments;
+
 	lwpoly = lwpoly_construct_empty(srid, LW_FALSE, LW_FALSE);
 	pa = ptarray_construct_empty(LW_FALSE, LW_FALSE, segments + 1);
 



More information about the postgis-tickets mailing list