diff options
| author | Even Rouault <even.rouault@spatialys.com> | 2019-03-15 23:17:03 +0100 |
|---|---|---|
| committer | Even Rouault <even.rouault@spatialys.com> | 2019-03-16 10:10:02 +0100 |
| commit | 1c4988d6be1cce93c866df98786d2eca3a244816 (patch) | |
| tree | 8dbb2289dd90d691dfb228809b46a43691b9f0b7 /src | |
| parent | ed2b26a09b407f7b580297d8a2cc516f786cbcc6 (diff) | |
| download | PROJ-1c4988d6be1cce93c866df98786d2eca3a244816.tar.gz PROJ-1c4988d6be1cce93c866df98786d2eca3a244816.zip | |
sterea: fix lat_0 = -90
A division by zero caused NaN values to be returned.
Fixes https://bugs.chromium.org/p/oss-fuzz/issues/detail?id=12062
Credit to OSS Fuzz
Diffstat (limited to 'src')
| -rw-r--r-- | src/gauss.cpp | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/src/gauss.cpp b/src/gauss.cpp index b7a27191..49ccfa1c 100644 --- a/src/gauss.cpp +++ b/src/gauss.cpp @@ -65,9 +65,14 @@ void *pj_gauss_ini(double e, double phi0, double *chi, double *rc) { } *chi = asin(sphi / en->C); en->ratexp = 0.5 * en->C * e; - en->K = tan(.5 * *chi + M_FORTPI) / ( - pow(tan(.5 * phi0 + M_FORTPI), en->C) * - srat(en->e * sphi, en->ratexp) ); + if( .5 * phi0 + M_FORTPI < 1e-10 ) { + en->K = 1.0 / srat(en->e * sphi, en->ratexp); + } + else { + en->K = tan(.5 * *chi + M_FORTPI) / ( + pow(tan(.5 * phi0 + M_FORTPI), en->C) * + srat(en->e * sphi, en->ratexp) ); + } return ((void *)en); } |
