[geos-devel] Encounter Segmentation Fault with GEOS 2.2.2

strk at refractions.net strk at refractions.net
Wed Jun 28 09:12:35 EDT 2006


Ops, sorry, I fell in the initGEOS missing call myself.
Actually I can *not* reproduce the error against the 2.2 branch.

Here is my testcase, if you confirm it fails please
send a backtrace, or valgrind output.

----------------------------------------------------------------------

#include <stdlib.h>
#include <stdio.h>
#include <geos_c.h>


int main()
{
        initGEOS(printf, printf);

   GEOSGeom aPolygon1,aPolygon2;

   const char *aString1 = "POLYGON ((125.331 0,3.35823e-06 125.331,-125.331 6.71
646e-06,-1.00747e-05 -125.331,125.331 0))";

   const char *aString2 = "POLYGON ((245.331 120,120 245.331,-5.331 120,120 -5.3
31,245.331 120))";


   aPolygon1 = GEOSGeomFromWKT(aString1);
   aPolygon2 = GEOSGeomFromWKT(aString2);

   GEOSGeom anIntersection = GEOSIntersection(aPolygon1,aPolygon2);

}

----------------------------------------------------------------------

--strk;


On Wed, Jun 28, 2006 at 01:51:59PM +0200, strk at refractions.net wrote:
> Oh, ok, I now remember to have fixed this in HEAD.
> Can you confirm ?
> 
> --strk;
> 
> On Wed, Jun 28, 2006 at 09:15:25AM +0800, Sheng Liang (SH/CBC) wrote:
> > Hi:
> >   Yes. I have called initGEOS() before I create those GEOSGeom.
> > As I said, if I provide some other polygons, there is no fault.
> > The fault just happened to these two specific polygons.
> > 
> >   Regards 
> > 
> > -----Original Message-----
> > From: geos-devel-bounces at geos.refractions.net
> > [mailto:geos-devel-bounces at geos.refractions.net] On Behalf Of
> > strk at refractions.net
> > Sent: Tuesday, June 27, 2006 23:45
> > To: GEOS Development List
> > Subject: Re: [geos-devel] Encounter Segmentation Fault with GEOS 2.2.2
> > 
> > Did you call initGEOS() ?
> > That's currently *required* (might change in the future)
> > 
> > --strk;
> > 
> > On Mon, Jun 26, 2006 at 12:07:48PM +0800, Sheng Liang (SH/CBC) wrote:
> > > HI:
> > >   I have tried aString1.c_str(), but I still get the same error. And I
> > 
> > > even use such code:
> > >    GEOSGeom aPolygon1,aPolygon2;
> > >    const char *aString1 = "POLYGON ((125.331 0,3.35823e-06
> > > 125.331,-125.331 6.71646e-06,-1.00747e-05 -125.331,125.331 0))";
> > > 
> > >    const char *aString2 = "POLYGON ((245.331 120,120 245.331,-5.331 
> > > 120,120 -5.331,245.331 120))";
> > > 
> > >         
> > >    aPolygon1 = GEOSGeomFromWKT(aString1);
> > >    aPolygon2 = GEOSGeomFromWKT(aString2);
> > >         
> > >    GEOSGeom anIntersection = GEOSIntersection(aPolygon1,aPolygon2);
> > > 
> > > And the error is the same.
> > >   Regards
> > > 
> > > -----Original Message-----
> > > From: geos-devel-bounces at geos.refractions.net
> > > [mailto:geos-devel-bounces at geos.refractions.net] On Behalf Of Mateusz 
> > > Loskot
> > > Sent: Monday, June 26, 2006 11:49
> > > To: GEOS Development List
> > > Subject: Re: [geos-devel] Encounter Segmentation Fault with GEOS 2.2.2
> > > 
> > > Sheng Liang (SH/CBC) wrote:
> > > > Hi: I encountered an error of "Segmentation Fault" with GEOS 2.2.2.
> > > > What I am doing is to get intersection of two polygons. The error 
> > > > happens to the specific polygong: POLYGON ((125.331 0,3.35823e-06
> > > > 125.331,-125.331 6.71646e-06,-1.00747e-05 -125.331,125.331 0)) and 
> > > > POLYGON ((245.331 120,120 245.331,-5.331 120,120 -5.331,245.331 
> > > > 120))
> > > 
> > > > There is no error to others polygons. So I think it must be an error
> > 
> > > > of GEOS 2.2.2 code.
> > > > 
> > > > My code is : GEOSGeom aPolygon1,aPolygon2; string aString1("POLYGON
> > > > ((125.331 0,3.35823e-06 125.331,-125.331 6.71646e-06,-1.00747e-05
> > > > -125.331,125.331 0))");
> > > > 
> > > > string aString2("POLYGON ((245.331 120,120 245.331,-5.331 120,120
> > > > -5.331,245.331 120))");
> > > > 
> > > > aPolygon1 = GEOSGeomFromWKT(aString1.data());
> > > > aPolygon2 = GEOSGeomFromWKT(aString2.data());
> > > 
> > > I'm suer in 99% that the problem is in your code above.
> > > You should not access internal buffer of std::string with data() 
> > > member function. It should be used in very rare cases because it 
> > > breaks OOP rule of encapsulation! It's available only for C
> > compatibility.
> > > 
> > > GEOSGeomFromWKT expects to get const char* :
> > > Geometry *GEOSGeomFromWKT(const char *wkt);
> > > 
> > > so, you should call it as follows:
> > > 
> > > aPolygon1 = GEOSGeomFromWKT(aString1.c_str());
> > > 
> > > std::string::c_str() returns const char*.
> > > 
> > > Cheers
> > > --
> > > Mateusz Loskot
> > > http://mateusz.loskot.net
> > > _______________________________________________
> > > geos-devel mailing list
> > > geos-devel at geos.refractions.net
> > > http://geos.refractions.net/mailman/listinfo/geos-devel
> > > _______________________________________________
> > > geos-devel mailing list
> > > geos-devel at geos.refractions.net
> > > http://geos.refractions.net/mailman/listinfo/geos-devel
> > 
> > -- 
> > 
> >  /"\    ASCII Ribbon Campaign
> >  \ /    Respect for low technology.
> >   X     Keep e-mail messages readable by any computer system.
> >  / \    Keep it ASCII. 
> > 
> > _______________________________________________
> > geos-devel mailing list
> > geos-devel at geos.refractions.net
> > http://geos.refractions.net/mailman/listinfo/geos-devel
> > _______________________________________________
> > geos-devel mailing list
> > geos-devel at geos.refractions.net
> > http://geos.refractions.net/mailman/listinfo/geos-devel
> 
> -- 
> 
>  /"\    ASCII Ribbon Campaign
>  \ /    Respect for low technology.
>   X     Keep e-mail messages readable by any computer system.
>  / \    Keep it ASCII. 
> 
> _______________________________________________
> geos-devel mailing list
> geos-devel at geos.refractions.net
> http://geos.refractions.net/mailman/listinfo/geos-devel

-- 

 /"\    ASCII Ribbon Campaign
 \ /    Respect for low technology.
  X     Keep e-mail messages readable by any computer system.
 / \    Keep it ASCII. 




More information about the geos-devel mailing list