<div dir="ltr"><div></div><div>I think Paul is right to frame this as a question about handling all errors from GEOS, which is broader than just GEOS errors caused by invalid geometry.<br></div><div><br class="gmail-Apple-interchange-newline">I haven't seen anything documented about the design of the autofix system, which is part of why I'd like to revert the auto-fix changes introduced in 2.5 and discuss the topic at the sprint.</div><div><br></div><div>(PR to revert: <a href="https://github.com/postgis/postgis/pull/268">https://github.com/postgis/postgis/pull/268</a>)</div><div><br></div><div>If we don't revert this, we may be left supporting/explaining with three different systems for handling invalid geometry (2.4, 2.5, 3.0).</div><div><br></div><div>With regard to the suggestion that processes with invalid geometries should "just work," any software must specify its acceptable inputs, and the OGC/ISO standards do this for geometry validity. We shouldn't expect non-conforming data to "just work" any more than we should expect invalid JSON or XML to be "autofixed" by tools operating on that data. Unlike invalid JSON, we don't block import of invalid geometry into PostGIS (and we shouldn't), so we're left with the more difficult task of delineating which parts of the system require valid geometry, and what we do when they don't get it. I would lean towards some combination of a lazy validity flag, validity-checking of inputs, and function parameters for error handling, but the topic is an important enough one that we should probably sketch out several prototypes before committing anything.</div><div><br></div><div>Dan</div><div><br></div><div><br></div></div><br><div class="gmail_quote"><div dir="ltr">On Tue, Jul 24, 2018 at 9:54 AM Paul Ramsey <<a href="mailto:pramsey@cleverelephant.ca">pramsey@cleverelephant.ca</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Just trolling tickets and reading/thinking, was thinking that the<br>
autofix question falls into two parts:<br>
<br>
- having a whole query interrupted by a single row problem is<br>
sometimes not desired<br>
- what *is* desired in that case is quite variable<br>
<br>
This is something for discussion perhaps at the sprint, but the<br>
problem of "policy" is going to keep coming up...<br>
<br>
- is a given behaviour a policy or a parameter?<br>
<br>
For example, does it make more sense to have<br>
<br>
set postgis.geos_exception_action = return_null;<br>
set postgis.geos_exception_action = attempt_repair;<br>
set postgis.geos_exception_action = fatal_error;<br>
<br>
Or, should that kind of thing be a parameter to each effected function?<br>
The same question will obtain for things like tolerance. If we add a<br>
tolerance module, is it a global setting, or is it a function<br>
parameter? Or, heaven help us, is it both?<br>
The whole question is further complicated by the issues we have had in<br>
the past with interactions between GUC and upgrades.<br>
<br>
Anyways, I feel like this stuff needs to be written out a little bit<br>
more, but maybe I'm just ignorant and it's already written out.<br>
<br>
P.<br>
_______________________________________________<br>
postgis-devel mailing list<br>
<a href="mailto:postgis-devel@lists.osgeo.org" target="_blank">postgis-devel@lists.osgeo.org</a><br>
<a href="https://lists.osgeo.org/mailman/listinfo/postgis-devel" rel="noreferrer" target="_blank">https://lists.osgeo.org/mailman/listinfo/postgis-devel</a></blockquote></div>