*
  *
  * IDENTIFICATION
- *       $PostgreSQL: pgsql/src/backend/utils/adt/geo_ops.c,v 1.88.4.2 2008/04/11 22:53:24 tgl Exp $
+ *       $PostgreSQL: pgsql/src/backend/utils/adt/geo_ops.c,v 1.88.4.3 2009/06/23 16:25:28 tgl Exp $
  *
  *-------------------------------------------------------------------------
  */
                                tmpdist;
        Point      *ip;
 
-/*
- * Construct a line perpendicular to the input segment
- * and through the input point
- */
+       /*
+        * Construct a line perpendicular to the input segment
+        * and through the input point
+        */
        if (lseg->p[1].x == lseg->p[0].x)
                m = 0;
        else if (lseg->p[1].y == lseg->p[0].y)
-       {                                                       /* slope is infinite */
-               m = (double) DBL_MAX;
-       }
+               m = (double) DBL_MAX;   /* slope is infinite */
        else
-               m = ((lseg->p[0].y - lseg->p[1].y) / (lseg->p[1].x - lseg->p[0].x));
+               m = (lseg->p[0].x - lseg->p[1].x) / (lseg->p[1].y - lseg->p[0].y);
        ln = line_construct_pm(pt, m);
 
 #ifdef GEODEBUG
 #endif
 
        /*
-        * Calculate distance to the line segment or to the endpoints of the
-        * segment.
+        * Calculate distance to the line segment or to the nearest endpoint of
+        * the segment.
         */
 
        /* intersection is on the line segment? */
        if ((ip = interpt_sl(lseg, ln)) != NULL)
        {
+               /* yes, so use distance to the intersection point */
                result = point_dt(pt, ip);
 #ifdef GEODEBUG
                printf("dist_ps- distance is %f to intersection point is (%f,%f)\n",
        }
        else
        {
-               /* intersection is not on line segment */
+               /* no, so use distance to the nearer endpoint */
                result = point_dt(pt, &lseg->p[0]);
                tmpdist = point_dt(pt, &lseg->p[1]);
                if (tmpdist < result)
                {
                        if (point_inside(&(polyb->p[i]), polya->npts, &(polya->p[0])) == 0)
                        {
-#if GEODEBUG
+#ifdef GEODEBUG
                                printf("poly_contain- point (%f,%f) not in polygon\n", polyb->p[i].x, polyb->p[i].y);
 #endif
                                result = false;
                        {
                                if (point_inside(&(polya->p[i]), polyb->npts, &(polyb->p[0])) == 1)
                                {
-#if GEODEBUG
+#ifdef GEODEBUG
                                        printf("poly_contain- point (%f,%f) in polygon\n", polya->p[i].x, polya->p[i].y);
 #endif
                                        result = false;
        }
        else
        {
-#if GEODEBUG
+#ifdef GEODEBUG
                printf("poly_contain- bound box ((%f,%f),(%f,%f)) not inside ((%f,%f),(%f,%f))\n",
                           polyb->boundbox.low.x, polyb->boundbox.low.y, polyb->boundbox.high.x, polyb->boundbox.high.y,
                           polya->boundbox.low.x, polya->boundbox.low.y, polya->boundbox.high.x, polya->boundbox.high.y);