*
  *
  * IDENTIFICATION
- *   $PostgreSQL: pgsql/src/backend/utils/adt/float.c,v 1.106 2004/08/04 21:34:02 tgl Exp $
+ *   $PostgreSQL: pgsql/src/backend/utils/adt/float.c,v 1.107 2004/08/11 17:20:49 tgl Exp $
  *
  *-------------------------------------------------------------------------
  */
                     errmsg("invalid input syntax for type real: \"%s\"",
                            orig_num)));
    }
+#ifdef HAVE_BUGGY_SOLARIS_STRTOD
+   else
+   {
+       /*
+        * Many versions of Solaris have a bug wherein strtod sets endptr
+        * to point one byte beyond the end of the string when given
+        * "inf" or "infinity".
+        */
+       if (endptr != num && endptr[-1] == '\0')
+           endptr--;
+   }
+#endif /* HAVE_BUGGY_SOLARIS_STRTOD */
 
    /* skip trailing whitespace */
    while (*endptr != '\0' && isspace((unsigned char) *endptr))
                     errmsg("invalid input syntax for type double precision: \"%s\"",
                            orig_num)));
    }
+#ifdef HAVE_BUGGY_SOLARIS_STRTOD
+   else
+   {
+       /*
+        * Many versions of Solaris have a bug wherein strtod sets endptr
+        * to point one byte beyond the end of the string when given
+        * "inf" or "infinity".
+        */
+       if (endptr != num && endptr[-1] == '\0')
+           endptr--;
+   }
+#endif /* HAVE_BUGGY_SOLARIS_STRTOD */
 
    /* skip trailing whitespace */
    while (*endptr != '\0' && isspace((unsigned char) *endptr))
 
-/* $PostgreSQL: pgsql/src/include/port/solaris.h,v 1.11 2004/03/15 03:29:22 tgl Exp $ */
+/* $PostgreSQL: pgsql/src/include/port/solaris.h,v 1.12 2004/08/11 17:20:50 tgl Exp $ */
 
 /*
  * Sort this out for all operating systems some time.  The __xxx
 #define         BYTE_ORDER      LITTLE_ENDIAN
 #endif
 #endif
+
+/*
+ * Many versions of Solaris have broken strtod() --- see bug #4751182.
+ * For the moment we just assume they all do; it's probably not worth
+ * the trouble to add a configure test for this.
+ */
+#define HAVE_BUGGY_SOLARIS_STRTOD