Coverage Report

Created: 2025-08-29 07:11

/src/PROJ/src/proj_internal.h
Line
Count
Source (jump to first uncovered line)
1
/******************************************************************************
2
 * Project:  PROJ.4
3
 * Purpose:  Internal plumbing for the PROJ.4 library.
4
 *
5
 * Author:   Thomas Knudsen, <thokn@sdfe.dk>
6
 *
7
 ******************************************************************************
8
 * Copyright (c) 2016, 2017, Thomas Knudsen / SDFE
9
 *
10
 * Permission is hereby granted, free of charge, to any person obtaining a
11
 * copy of this software and associated documentation files (the "Software"),
12
 * to deal in the Software without restriction, including without limitation
13
 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
14
 * and/or sell copies of the Software, and to permit persons to whom the
15
 * Software is furnished to do so, subject to the following conditions:
16
 *
17
 * The above copyright notice and this permission notice shall be included
18
 * in all copies or substantial portions of the Software.
19
 *
20
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
21
 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
22
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO COORD SHALL
23
 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
24
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
25
 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
26
 * DEALINGS IN THE SOFTWARE.
27
 *****************************************************************************/
28
29
#ifndef PROJ_INTERNAL_H
30
#define PROJ_INTERNAL_H
31
32
#ifndef __cplusplus
33
#error "proj_internal.h can only be included from a C++ file"
34
#endif
35
36
#ifdef _MSC_VER
37
#ifndef _CRT_SECURE_NO_DEPRECATE
38
#define _CRT_SECURE_NO_DEPRECATE
39
#endif
40
#ifndef _CRT_NONSTDC_NO_DEPRECATE
41
#define _CRT_NONSTDC_NO_DEPRECATE
42
#endif
43
#endif
44
45
/* enable predefined math constants M_* for MS Visual Studio */
46
#if defined(_MSC_VER) || defined(_WIN32)
47
#ifndef _USE_MATH_DEFINES
48
#define _USE_MATH_DEFINES
49
#endif
50
#endif
51
52
// Use "PROJ_FALLTHROUGH;" to annotate deliberate fall-through in switches,
53
// use it analogously to "break;".  The trailing semi-colon is required.
54
#if !defined(PROJ_FALLTHROUGH) && defined(__has_cpp_attribute)
55
#if __cplusplus >= 201703L && __has_cpp_attribute(fallthrough)
56
1.03M
#define PROJ_FALLTHROUGH [[fallthrough]]
57
#elif __cplusplus >= 201103L && __has_cpp_attribute(gnu::fallthrough)
58
#define PROJ_FALLTHROUGH [[gnu::fallthrough]]
59
#elif __cplusplus >= 201103L && __has_cpp_attribute(clang::fallthrough)
60
#define PROJ_FALLTHROUGH [[clang::fallthrough]]
61
#endif
62
#endif
63
64
#ifndef PROJ_FALLTHROUGH
65
#define PROJ_FALLTHROUGH ((void)0)
66
#endif
67
68
/* standard inclusions */
69
#include <limits.h>
70
#include <math.h>
71
#include <stddef.h>
72
#include <stdio.h>
73
#include <stdlib.h>
74
#include <string.h>
75
76
#include "proj/common.hpp"
77
#include "proj/coordinateoperation.hpp"
78
79
#include <cmath>
80
#include <string>
81
#include <vector>
82
83
#include "proj.h"
84
85
#ifdef PROJ_RENAME_SYMBOLS
86
#include "proj_symbol_rename.h"
87
#endif
88
89
#define STATIC_ASSERT(COND) ((void)sizeof(char[(COND) ? 1 : -1]))
90
91
#ifndef PJ_TODEG
92
8.00k
#define PJ_TODEG(rad) ((rad)*180.0 / M_PI)
93
#endif
94
#ifndef PJ_TORAD
95
11
#define PJ_TORAD(deg) ((deg)*M_PI / 180.0)
96
#endif
97
98
/* Maximum latitudinal overshoot accepted */
99
1.52M
#define PJ_EPS_LAT 1e-12
100
101
#define C_NAMESPACE extern "C"
102
#define C_NAMESPACE_VAR extern "C"
103
104
#ifndef NULL
105
#define NULL 0
106
#endif
107
108
#ifndef FALSE
109
353k
#define FALSE 0
110
#endif
111
112
#ifndef TRUE
113
13.3k
#define TRUE 1
114
#endif
115
116
#ifndef MAX
117
0
#define MIN(a, b) ((a < b) ? a : b)
118
0
#define MAX(a, b) ((a > b) ? a : b)
119
#endif
120
121
#ifndef ABS
122
1.35k
#define ABS(x) ((x < 0) ? (-1 * (x)) : x)
123
#endif
124
125
/* maximum path/filename */
126
#ifndef MAX_PATH_FILENAME
127
1.10k
#define MAX_PATH_FILENAME 1024
128
#endif
129
130
/* If we still haven't got M_PI*, we rely on our own defines.
131
 * For example, this is necessary when compiling with gcc and
132
 * the -ansi flag.
133
 */
134
#ifndef M_PI
135
#define M_PI 3.14159265358979323846
136
#endif
137
138
#ifndef M_1_PI
139
#define M_1_PI 0.318309886183790671538
140
#endif
141
142
#ifndef M_PI_2
143
#define M_PI_2 1.57079632679489661923
144
#endif
145
146
#ifndef M_PI_4
147
#define M_PI_4 0.78539816339744830962
148
#endif
149
150
#ifndef M_2_PI
151
#define M_2_PI 0.63661977236758134308
152
#endif
153
154
/* M_SQRT2 might be missing */
155
#ifndef M_SQRT2
156
#define M_SQRT2 1.41421356237309504880
157
#endif
158
159
/* some more useful math constants and aliases */
160
993k
#define M_FORTPI M_PI_4                    /* pi/4 */
161
5.51M
#define M_HALFPI M_PI_2                    /* pi/2 */
162
588
#define M_PI_HALFPI 4.71238898038468985769 /* 1.5*pi */
163
164
#ifndef M_TWOPI
165
49.5k
#define M_TWOPI 6.28318530717958647693 /* 2*pi */
166
#endif
167
168
15.8k
#define M_TWO_D_PI M_2_PI                     /* 2/pi */
169
11.0k
#define M_TWOPI_HALFPI 7.85398163397448309616 /* 2.5*pi */
170
171
/* maximum tag id length for +init and default files */
172
#ifndef ID_TAG_MAX
173
1.10k
#define ID_TAG_MAX 50
174
#endif
175
176
/* Use WIN32 as a standard windows 32 bit declaration */
177
#if defined(_WIN32) && !defined(WIN32)
178
#define WIN32
179
#endif
180
181
#if defined(_WINDOWS) && !defined(WIN32)
182
#define WIN32
183
#endif
184
185
/* directory delimiter for DOS support */
186
#ifdef WIN32
187
#define DIR_CHAR '\\'
188
#else
189
131k
#define DIR_CHAR '/'
190
#endif
191
192
enum pj_io_units {
193
    PJ_IO_UNITS_WHATEVER =
194
        0, /* Doesn't matter (or depends on pipeline neighbours) */
195
    PJ_IO_UNITS_CLASSIC = 1,   /* Scaled meters (right), projected system */
196
    PJ_IO_UNITS_PROJECTED = 2, /* Meters, projected system */
197
    PJ_IO_UNITS_CARTESIAN = 3, /* Meters, 3D cartesian system */
198
    PJ_IO_UNITS_RADIANS = 4,   /* Radians */
199
    PJ_IO_UNITS_DEGREES = 5,   /* Degrees */
200
201
};
202
enum pj_io_units pj_left(PJ *P);
203
enum pj_io_units pj_right(PJ *P);
204
205
PJ_COORD PROJ_DLL proj_coord_error(void);
206
207
void proj_context_errno_set(PJ_CONTEXT *ctx, int err);
208
void PROJ_DLL proj_context_set(PJ *P, PJ_CONTEXT *ctx);
209
void proj_context_inherit(PJ *parent, PJ *child);
210
211
struct projCppContext;
212
/* not sure why we need to export it, but mingw needs it */
213
void PROJ_DLL
214
proj_context_delete_cpp_context(struct projCppContext *cppContext);
215
216
bool pj_fwd4d(PJ_COORD &coo, PJ *P);
217
bool pj_inv4d(PJ_COORD &coo, PJ *P);
218
219
PJ_COORD PROJ_DLL pj_approx_2D_trans(PJ *P, PJ_DIRECTION direction,
220
                                     PJ_COORD coo);
221
PJ_COORD PROJ_DLL pj_approx_3D_trans(PJ *P, PJ_DIRECTION direction,
222
                                     PJ_COORD coo);
223
224
/* Provision for gettext translatable strings */
225
39.3k
#define _(str) (str)
226
227
void PROJ_DLL proj_log_error(const PJ *P, const char *fmt, ...);
228
void proj_log_debug(PJ *P, const char *fmt, ...);
229
void proj_log_trace(PJ *P, const char *fmt, ...);
230
231
void proj_context_log_debug(PJ_CONTEXT *ctx, const char *fmt, ...);
232
233
int pj_ellipsoid(PJ *);
234
void pj_inherit_ellipsoid_def(const PJ *src, PJ *dst);
235
int pj_calc_ellipsoid_params(PJ *P, double a, double es);
236
237
/* Geographical to geocentric latitude - another of the "simple, but useful" */
238
PJ_COORD pj_geocentric_latitude(const PJ *P, PJ_DIRECTION direction,
239
                                PJ_COORD coord);
240
241
char PROJ_DLL *pj_chomp(char *c);
242
char PROJ_DLL *pj_shrink(char *c);
243
size_t pj_trim_argc(char *args);
244
char **pj_trim_argv(size_t argc, char *args);
245
char *pj_make_args(size_t argc, char **argv);
246
247
typedef struct {
248
    double r, i;
249
} COMPLEX;
250
251
/* Forward declarations and typedefs for stuff needed inside the PJ object */
252
struct PJconsts;
253
254
union PJ_COORD;
255
struct geod_geodesic;
256
struct ARG_list;
257
struct PJ_REGION_S;
258
typedef struct PJ_REGION_S PJ_Region;
259
typedef struct ARG_list paralist; /* parameter list */
260
261
#ifndef PROJ_H
262
typedef struct PJconsts PJ; /* the PJ object herself */
263
typedef union PJ_COORD PJ_COORD;
264
#endif
265
266
struct PJ_REGION_S {
267
    double ll_long; /* lower left corner coordinates (radians) */
268
    double ll_lat;
269
    double ur_long; /* upper right corner coordinates (radians) */
270
    double ur_lat;
271
};
272
273
struct PJ_AREA {
274
    bool bbox_set = false;
275
    double west_lon_degree = 0;
276
    double south_lat_degree = 0;
277
    double east_lon_degree = 0;
278
    double north_lat_degree = 0;
279
    std::string name{};
280
};
281
282
/*****************************************************************************
283
284
    Some function types that are especially useful when working with PJs
285
286
******************************************************************************
287
288
PJ_CONSTRUCTOR:
289
290
    A function taking a pointer-to-PJ as arg, and returning a pointer-to-PJ.
291
    Historically called twice: First with a 0 argument, to allocate memory,
292
    second with the first return value as argument, for actual setup.
293
294
PJ_DESTRUCTOR:
295
296
    A function taking a pointer-to-PJ and an integer as args, then first
297
    handling the deallocation of the PJ, afterwards handing the integer over
298
    to the error reporting subsystem, and finally returning a null pointer in
299
    support of the "return free (P)" (aka "get the hell out of here") idiom.
300
301
PJ_OPERATOR:
302
303
    A function taking a reference to a PJ_COORD and a pointer-to-PJ as args,
304
applying the PJ to the PJ_COORD, and modifying in-place the passed PJ_COORD.
305
306
*****************************************************************************/
307
typedef PJ *(*PJ_CONSTRUCTOR)(PJ *);
308
typedef PJ *(*PJ_DESTRUCTOR)(PJ *, int);
309
typedef void (*PJ_OPERATOR)(PJ_COORD &, PJ *);
310
/****************************************************************************/
311
312
/* datum_type values */
313
207k
#define PJD_UNKNOWN 0
314
509k
#define PJD_3PARAM 1
315
1.35k
#define PJD_7PARAM 2
316
6.71k
#define PJD_GRIDSHIFT 3
317
933
#define PJD_WGS84 4 /* WGS84 (or anything considered equivalent) */
318
319
struct PJCoordOperation {
320
  public:
321
    int idxInOriginalList;
322
323
    // [min|max][x|y]Src define the bounding box of the area of validity of
324
    // the transformation, expressed in the source CRS. Except if the source
325
    // CRS is a geocentric one, in which case the bounding box is defined in
326
    // a geographic lon,lat CRS (pjSrcGeocentricToLonLat will have to be used
327
    // on input coordinates in the forward direction)
328
    double minxSrc = 0.0;
329
    double minySrc = 0.0;
330
    double maxxSrc = 0.0;
331
    double maxySrc = 0.0;
332
333
    // [min|max][x|y]Dst define the bounding box of the area of validity of
334
    // the transformation, expressed in the target CRS. Except if the target
335
    // CRS is a geocentric one, in which case the bounding box is defined in
336
    // a geographic lon,lat CRS (pjDstGeocentricToLonLat will have to be used
337
    // on input coordinates in the inverse direction)
338
    double minxDst = 0.0;
339
    double minyDst = 0.0;
340
    double maxxDst = 0.0;
341
    double maxyDst = 0.0;
342
343
    PJ *pj = nullptr;
344
    std::string name{};
345
    double accuracy = -1.0;
346
    double pseudoArea = 0.0;
347
    std::string areaName{};
348
    bool isOffshore = false;
349
    bool isUnknownAreaName = false;
350
    bool isPriorityOp = false;
351
    bool srcIsLonLatDegree = false;
352
    bool srcIsLatLonDegree = false;
353
    bool dstIsLonLatDegree = false;
354
    bool dstIsLatLonDegree = false;
355
356
    // pjSrcGeocentricToLonLat is defined if the source CRS of pj is geocentric
357
    // and in that case it transforms from those geocentric coordinates to
358
    // geographic ones in lon, lat order
359
    PJ *pjSrcGeocentricToLonLat = nullptr;
360
361
    // pjDstGeocentricToLonLat is defined if the target CRS of pj is geocentric
362
    // and in that case it transforms from those geocentric coordinates to
363
    // geographic ones in lon, lat order
364
    PJ *pjDstGeocentricToLonLat = nullptr;
365
366
    PJCoordOperation(int idxInOriginalListIn, double minxSrcIn,
367
                     double minySrcIn, double maxxSrcIn, double maxySrcIn,
368
                     double minxDstIn, double minyDstIn, double maxxDstIn,
369
                     double maxyDstIn, PJ *pjIn, const std::string &nameIn,
370
                     double accuracyIn, double pseudoAreaIn,
371
                     const char *areaName, const PJ *pjSrcGeocentricToLonLatIn,
372
                     const PJ *pjDstGeocentricToLonLatIn);
373
374
    PJCoordOperation(const PJCoordOperation &) = delete;
375
376
    PJCoordOperation(PJ_CONTEXT *ctx, const PJCoordOperation &other)
377
0
        : idxInOriginalList(other.idxInOriginalList), minxSrc(other.minxSrc),
378
0
          minySrc(other.minySrc), maxxSrc(other.maxxSrc),
379
0
          maxySrc(other.maxySrc), minxDst(other.minxDst),
380
0
          minyDst(other.minyDst), maxxDst(other.maxxDst),
381
0
          maxyDst(other.maxyDst), pj(proj_clone(ctx, other.pj)),
382
0
          name(std::move(other.name)), accuracy(other.accuracy),
383
0
          pseudoArea(other.pseudoArea), areaName(other.areaName),
384
0
          isOffshore(other.isOffshore),
385
0
          isUnknownAreaName(other.isUnknownAreaName),
386
0
          isPriorityOp(other.isPriorityOp),
387
0
          srcIsLonLatDegree(other.srcIsLonLatDegree),
388
0
          srcIsLatLonDegree(other.srcIsLatLonDegree),
389
0
          dstIsLonLatDegree(other.dstIsLonLatDegree),
390
0
          dstIsLatLonDegree(other.dstIsLatLonDegree),
391
          pjSrcGeocentricToLonLat(
392
0
              other.pjSrcGeocentricToLonLat
393
0
                  ? proj_clone(ctx, other.pjSrcGeocentricToLonLat)
394
0
                  : nullptr),
395
          pjDstGeocentricToLonLat(
396
0
              other.pjDstGeocentricToLonLat
397
0
                  ? proj_clone(ctx, other.pjDstGeocentricToLonLat)
398
0
                  : nullptr) {}
399
400
    PJCoordOperation(PJCoordOperation &&other)
401
10.1k
        : idxInOriginalList(other.idxInOriginalList), minxSrc(other.minxSrc),
402
10.1k
          minySrc(other.minySrc), maxxSrc(other.maxxSrc),
403
10.1k
          maxySrc(other.maxySrc), minxDst(other.minxDst),
404
10.1k
          minyDst(other.minyDst), maxxDst(other.maxxDst),
405
10.1k
          maxyDst(other.maxyDst), name(std::move(other.name)),
406
10.1k
          accuracy(other.accuracy), pseudoArea(other.pseudoArea),
407
10.1k
          areaName(std::move(other.areaName)), isOffshore(other.isOffshore),
408
10.1k
          isUnknownAreaName(other.isUnknownAreaName),
409
10.1k
          isPriorityOp(other.isPriorityOp),
410
10.1k
          srcIsLonLatDegree(other.srcIsLonLatDegree),
411
10.1k
          srcIsLatLonDegree(other.srcIsLatLonDegree),
412
10.1k
          dstIsLonLatDegree(other.dstIsLonLatDegree),
413
10.1k
          dstIsLatLonDegree(other.dstIsLatLonDegree) {
414
10.1k
        pj = other.pj;
415
10.1k
        other.pj = nullptr;
416
10.1k
        pjSrcGeocentricToLonLat = other.pjSrcGeocentricToLonLat;
417
10.1k
        other.pjSrcGeocentricToLonLat = nullptr;
418
10.1k
        pjDstGeocentricToLonLat = other.pjDstGeocentricToLonLat;
419
10.1k
        other.pjDstGeocentricToLonLat = nullptr;
420
10.1k
    }
421
422
    PJCoordOperation &operator=(const PJCoordOperation &) = delete;
423
424
0
    bool operator==(const PJCoordOperation &other) const {
425
0
        return idxInOriginalList == other.idxInOriginalList &&
426
0
               minxSrc == other.minxSrc && minySrc == other.minySrc &&
427
0
               maxxSrc == other.maxxSrc && maxySrc == other.maxySrc &&
428
0
               minxDst == other.minxDst && minyDst == other.minyDst &&
429
0
               maxxDst == other.maxxDst && maxyDst == other.maxyDst &&
430
0
               name == other.name &&
431
0
               proj_is_equivalent_to(pj, other.pj, PJ_COMP_STRICT) &&
432
0
               accuracy == other.accuracy && areaName == other.areaName;
433
0
    }
434
435
0
    bool operator!=(const PJCoordOperation &other) const {
436
0
        return !(operator==(other));
437
0
    }
438
439
    ~PJCoordOperation();
440
441
    bool isInstantiable() const;
442
443
  private:
444
    static constexpr int INSTANTIABLE_STATUS_UNKNOWN =
445
        -1; // must be different from 0(=false) and 1(=true)
446
    mutable int isInstantiableCached = INSTANTIABLE_STATUS_UNKNOWN;
447
};
448
449
enum class TMercAlgo {
450
    AUTO, // Poder/Engsager if far from central meridian, otherwise
451
          // Evenden/Snyder
452
    EVENDEN_SNYDER,
453
    PODER_ENGSAGER,
454
};
455
456
enum class AuxLat {
457
    GEOGRAPHIC, // 0
458
    PARAMETRIC,
459
    GEOCENTRIC,
460
    RECTIFYING,
461
    CONFORMAL,
462
    AUTHALIC,
463
    NUMBER, // The number of auxiliary latitudes = 6
464
    // The order of the expansion in n (ACCIDENTALLY equal to AUXNUMBER)
465
    ORDER = 6,
466
};
467
468
/* base projection data structure */
469
struct PJconsts {
470
471
    /*************************************************************************************
472
473
                         G E N E R A L   P A R A M E T E R   S T R U C T
474
475
    **************************************************************************************
476
477
        TODO: Need some description here - especially about the thread
478
    context... This is the struct behind the PJ typedef
479
480
    **************************************************************************************/
481
482
    PJ_CONTEXT *ctx = nullptr;
483
    const char *short_name = nullptr; /* From pj_list.h */
484
    const char *descr = nullptr; /* From pj_list.h or individual PJ_*.c file */
485
    paralist *params = nullptr;  /* Parameter list */
486
    char *def_full =
487
        nullptr; /* Full textual definition (usually 0 - set by proj_pj_info) */
488
    PJconsts *parent = nullptr; /* Parent PJ of pipeline steps - nullptr if not
489
                                   a pipeline step */
490
491
    /* For debugging / logging purposes */
492
    char *def_size =
493
        nullptr; /* Shape and size parameters extracted from params */
494
    char *def_shape = nullptr;
495
    char *def_spherification = nullptr;
496
    char *def_ellps = nullptr;
497
498
    struct geod_geodesic *geod = nullptr; /* For geodesic computations */
499
    void *opaque =
500
        nullptr;      /* Projection specific parameters, Defined in PJ_*.c */
501
    int inverted = 0; /* Tell high level API functions to swap inv/fwd */
502
503
    /*************************************************************************************
504
505
                          F U N C T I O N    P O I N T E R S
506
507
    **************************************************************************************
508
509
        For projection xxx, these are pointers to functions in the corresponding
510
        PJ_xxx.c file.
511
512
        pj_init() delegates the setup of these to
513
    pj_projection_specific_setup_xxx(), a name which is currently hidden behind
514
    the magic curtain of the PROJECTION macro.
515
516
    **************************************************************************************/
517
518
    PJ_XY (*fwd)(PJ_LP, PJ *) = nullptr;
519
    PJ_LP (*inv)(PJ_XY, PJ *) = nullptr;
520
    PJ_XYZ (*fwd3d)(PJ_LPZ, PJ *) = nullptr;
521
    PJ_LPZ (*inv3d)(PJ_XYZ, PJ *) = nullptr;
522
    PJ_OPERATOR fwd4d = nullptr;
523
    PJ_OPERATOR inv4d = nullptr;
524
525
    PJ_DESTRUCTOR destructor = nullptr;
526
    void (*reassign_context)(PJ *, PJ_CONTEXT *) = nullptr;
527
528
    /*************************************************************************************
529
530
                          E L L I P S O I D     P A R A M E T E R S
531
532
    **************************************************************************************
533
534
        Despite YAGNI, we add a large number of ellipsoidal shape parameters,
535
    which are not yet set up in pj_init. They are, however, inexpensive to
536
    compute, compared to the overall time taken for setting up the complex PJ
537
    object (cf. e.g. https://en.wikipedia.org/wiki/Angular_eccentricity).
538
539
        But during single point projections it will often be a useful thing to
540
    have these readily available without having to recompute at every pj_fwd /
541
    pj_inv call.
542
543
        With this wide selection, we should be ready for quite a number of
544
    geodetic algorithms, without having to incur further ABI breakage.
545
546
    **************************************************************************************/
547
548
    /* The linear parameters */
549
550
    double a = 0.0;  /* semimajor axis (radius if eccentricity==0) */
551
    double b = 0.0;  /* semiminor axis */
552
    double ra = 0.0; /* 1/a */
553
    double rb = 0.0; /* 1/b */
554
555
    /* The eccentricities */
556
557
    double alpha = 0.0;   /* angular eccentricity */
558
    double e = 0.0;       /* first  eccentricity */
559
    double es = 0.0;      /* first  eccentricity squared */
560
    double e2 = 0.0;      /* second eccentricity */
561
    double e2s = 0.0;     /* second eccentricity squared */
562
    double e3 = 0.0;      /* third  eccentricity */
563
    double e3s = 0.0;     /* third  eccentricity squared */
564
    double one_es = 0.0;  /* 1 - e^2 */
565
    double rone_es = 0.0; /* 1/one_es */
566
567
    /* The flattenings */
568
    double f = 0.0;   /* first  flattening */
569
    double f2 = 0.0;  /* second flattening */
570
    double n = 0.0;   /* third  flattening */
571
    double rf = 0.0;  /* 1/f  */
572
    double rf2 = 0.0; /* 1/f2 */
573
    double rn = 0.0;  /* 1/n  */
574
575
    /* This one's for GRS80 */
576
    double J = 0.0; /* "Dynamic form factor" */
577
578
    double es_orig = 0.0; /* es and a before any +proj related adjustment */
579
    double a_orig = 0.0;
580
581
    /*************************************************************************************
582
583
                          C O O R D I N A T E   H A N D L I N G
584
585
    **************************************************************************************/
586
587
    int over = 0;       /* Over-range flag */
588
    int geoc = 0;       /* Geocentric latitude flag */
589
    int is_latlong = 0; /* proj=latlong ... not really a projection at all */
590
    int is_geocent = 0; /* proj=geocent ... not really a projection at all */
591
    int need_ellps = 0; /* 0 for operations that are purely cartesian */
592
    int skip_fwd_prepare = 0;
593
    int skip_fwd_finalize = 0;
594
    int skip_inv_prepare = 0;
595
    int skip_inv_finalize = 0;
596
597
    enum pj_io_units left =
598
        PJ_IO_UNITS_WHATEVER; /* Flags for input/output coordinate types */
599
    enum pj_io_units right = PJ_IO_UNITS_WHATEVER;
600
601
    /* These PJs are used for implementing cs2cs style coordinate handling in
602
     * the 4D API */
603
    PJ *axisswap = nullptr;
604
    PJ *cart = nullptr;
605
    PJ *cart_wgs84 = nullptr;
606
    PJ *helmert = nullptr;
607
    PJ *hgridshift = nullptr;
608
    PJ *vgridshift = nullptr;
609
610
    /*************************************************************************************
611
612
                       C A R T O G R A P H I C       O F F S E T S
613
614
    **************************************************************************************/
615
616
    double lam0 = 0.0; /* central meridian */
617
    double phi0 = 0.0; /* central parallel */
618
    double x0 = 0.0;   /* false easting */
619
    double y0 = 0.0;   /* false northing  */
620
    double z0 = 0.0;   /* height origin */
621
    double t0 = 0.0;   /* time origin */
622
623
    /*************************************************************************************
624
625
                                    S C A L I N G
626
627
    **************************************************************************************/
628
629
    double k0 = 0.0; /* General scaling factor - e.g. the 0.9996 of UTM */
630
    double to_meter = 0.0,
631
           fr_meter = 0.0; /* Plane coordinate scaling. Internal unit [m] */
632
    double vto_meter = 0.0,
633
           vfr_meter = 0.0; /* Vertical scaling. Internal unit [m] */
634
635
    /*************************************************************************************
636
637
                  D A T U M S   A N D   H E I G H T   S Y S T E M S
638
639
    **************************************************************************************
640
641
        It may be possible, and meaningful, to move the list parts of this up to
642
    the PJ_CONTEXT level.
643
644
    **************************************************************************************/
645
646
    int datum_type =
647
        PJD_UNKNOWN; /* PJD_UNKNOWN/3PARAM/7PARAM/GRIDSHIFT/WGS84 */
648
    double datum_params[7] = {0, 0, 0, 0,
649
                              0, 0, 0}; /* Parameters for 3PARAM and 7PARAM */
650
651
    int has_geoid_vgrids = 0;      /* used by legacy transform.cpp */
652
    void *hgrids_legacy = nullptr; /* used by legacy transform.cpp. Is a pointer
653
                                      to a ListOfHGrids* */
654
    void *vgrids_legacy = nullptr; /* used by legacy transform.cpp. Is a pointer
655
                                      to a ListOfVGrids* */
656
657
    double from_greenwich = 0.0;   /* prime meridian offset (in radians) */
658
    double long_wrap_center = 0.0; /* 0.0 for -180 to 180, actually in radians*/
659
    int is_long_wrap_set = 0;
660
    char axis[4] = {0, 0, 0, 0}; /* Axis order, pj_transform/pj_adjust_axis */
661
662
    /*************************************************************************************
663
     ISO-19111 interface
664
    **************************************************************************************/
665
666
    NS_PROJ::util::BaseObjectPtr iso_obj{};
667
    bool iso_obj_is_coordinate_operation = false;
668
    double coordinateEpoch = 0;
669
    bool hasCoordinateEpoch = false;
670
671
    // cached results
672
    mutable std::string lastWKT{};
673
    mutable std::string lastPROJString{};
674
    mutable std::string lastJSONString{};
675
    mutable bool gridsNeededAsked = false;
676
    mutable std::vector<NS_PROJ::operation::GridDescription> gridsNeeded{};
677
678
    // cache pj_get_type() result to help for repeated calls to proj_factors()
679
    mutable PJ_TYPE type = PJ_TYPE_UNKNOWN;
680
681
    /*************************************************************************************
682
     proj_create_crs_to_crs() alternative coordinate operations
683
    **************************************************************************************/
684
    std::vector<PJCoordOperation> alternativeCoordinateOperations{};
685
    int iCurCoordOp = -1;
686
    bool errorIfBestTransformationNotAvailable = false;
687
    bool warnIfBestTransformationNotAvailable =
688
        true; /* to remove in PROJ 10? */
689
    bool skipNonInstantiable = true;
690
691
    // Used internally by proj_factors()
692
    PJ *cached_op_for_proj_factors = nullptr;
693
694
    /*************************************************************************************
695
696
                 E N D   O F    G E N E R A L   P A R A M E T E R   S T R U C T
697
698
    **************************************************************************************/
699
700
    PJconsts();
701
    PJconsts(const PJconsts &) = delete;
702
    PJconsts &operator=(const PJconsts &) = delete;
703
704
    void copyStateFrom(const PJconsts &);
705
};
706
707
/* Parameter list (a copy of the +proj=... etc. parameters) */
708
struct ARG_list {
709
    paralist *next;
710
    char used;
711
#if (defined(__GNUC__) && __GNUC__ >= 8) ||                                    \
712
    (defined(__clang__) && __clang_major__ >= 9)
713
    char param[]; /* variable-length member */
714
    /* Safer to use [] for gcc 8. See https://github.com/OSGeo/proj.4/pull/1087
715
     */
716
    /* and https://gcc.gnu.org/bugzilla/show_bug.cgi?id=86914 */
717
#else
718
    char param[1]; /* variable-length member */
719
#endif
720
};
721
722
typedef union {
723
    double f;
724
    int i;
725
    char *s;
726
} PROJVALUE;
727
728
struct PJ_DATUMS {
729
    const char *id;         /* datum keyword */
730
    const char *defn;       /* ie. "to_wgs84=..." */
731
    const char *ellipse_id; /* ie from ellipse table */
732
    const char *comments;   /* EPSG code, etc */
733
};
734
735
struct DERIVS {
736
    double x_l, x_p; /* derivatives of x for lambda-phi */
737
    double y_l, y_p; /* derivatives of y for lambda-phi */
738
};
739
740
struct FACTORS {
741
    struct DERIVS der;
742
    double h, k;          /* meridional, parallel scales */
743
    double omega, thetap; /* angular distortion, theta prime */
744
    double conv;          /* convergence */
745
    double s;             /* areal scale factor */
746
    double a, b;          /* max-min scale error */
747
    int code;             /* always 0 */
748
};
749
750
// Legacy
751
struct projFileAPI_t;
752
753
struct projCppContext;
754
755
struct projNetworkCallbacksAndData {
756
    bool enabled = false;
757
    proj_network_open_cbk_type open = nullptr;
758
    proj_network_close_cbk_type close = nullptr;
759
    proj_network_get_header_value_cbk_type get_header_value = nullptr;
760
    proj_network_read_range_type read_range = nullptr;
761
    void *user_data = nullptr;
762
};
763
764
struct projGridChunkCache {
765
    bool enabled = true;
766
    std::string filename{};
767
    long long max_size = 300 * 1024 * 1024;
768
    int ttl = 86400; // 1 day
769
};
770
771
struct projFileApiCallbackAndData {
772
    PROJ_FILE_HANDLE *(*open_cbk)(PJ_CONTEXT *ctx, const char *filename,
773
                                  PROJ_OPEN_ACCESS access,
774
                                  void *user_data) = nullptr;
775
    size_t (*read_cbk)(PJ_CONTEXT *ctx, PROJ_FILE_HANDLE *, void *buffer,
776
                       size_t size, void *user_data) = nullptr;
777
    size_t (*write_cbk)(PJ_CONTEXT *ctx, PROJ_FILE_HANDLE *, const void *buffer,
778
                        size_t size, void *user_data) = nullptr;
779
    int (*seek_cbk)(PJ_CONTEXT *ctx, PROJ_FILE_HANDLE *, long long offset,
780
                    int whence, void *user_data) = nullptr;
781
    unsigned long long (*tell_cbk)(PJ_CONTEXT *ctx, PROJ_FILE_HANDLE *,
782
                                   void *user_data) = nullptr;
783
    void (*close_cbk)(PJ_CONTEXT *ctx, PROJ_FILE_HANDLE *,
784
                      void *user_data) = nullptr;
785
786
    int (*exists_cbk)(PJ_CONTEXT *ctx, const char *filename,
787
                      void *user_data) = nullptr;
788
    int (*mkdir_cbk)(PJ_CONTEXT *ctx, const char *filename,
789
                     void *user_data) = nullptr;
790
    int (*unlink_cbk)(PJ_CONTEXT *ctx, const char *filename,
791
                      void *user_data) = nullptr;
792
    int (*rename_cbk)(PJ_CONTEXT *ctx, const char *oldPath, const char *newPath,
793
                      void *user_data) = nullptr;
794
795
    void *user_data = nullptr;
796
};
797
798
/* proj thread context */
799
struct PROJ_GCC_DLL pj_ctx {
800
    std::string lastFullErrorMessage{}; // used by proj_context_errno_string
801
    int last_errno = 0;
802
    int debug_level = PJ_LOG_ERROR;
803
    bool errorIfBestTransformationNotAvailableDefault = false;
804
    bool warnIfBestTransformationNotAvailableDefault = true;
805
    void (*logger)(void *, int, const char *) = nullptr;
806
    void *logger_app_data = nullptr;
807
    struct projCppContext *cpp_context =
808
        nullptr;                   /* internal context for C++ code */
809
    int use_proj4_init_rules = -1; /* -1 = unknown, 0 = no, 1 = yes */
810
    bool forceOver = false;
811
    int epsg_file_exists = -1; /* -1 = unknown, 0 = no, 1 = yes */
812
813
    std::string
814
        env_var_proj_data{}; // content of PROJ_DATA (or legacy PROJ_LIB)
815
                             // environment variable. Use
816
                             // Filemanager::getProjDataEnvVar() to access
817
    std::vector<std::string> search_paths{};
818
    const char **c_compat_paths = nullptr; // same, but for projinfo usage
819
820
    const char *(*file_finder)(PJ_CONTEXT *, const char *,
821
                               void *user_data) = nullptr;
822
    void *file_finder_user_data = nullptr;
823
824
    // Cache result of pj_find_file()
825
    std::map<std::string, std::string> lookupedFiles{};
826
827
    bool defer_grid_opening = false; // set transiently by pj_obj_create()
828
829
    projFileApiCallbackAndData fileApi{};
830
    std::string custom_sqlite3_vfs_name{};
831
    std::string user_writable_directory{};
832
833
    // BEGIN ini file settings
834
    bool iniFileLoaded = false;
835
    std::string endpoint{};
836
    projNetworkCallbacksAndData networking{};
837
    std::string ca_bundle_path{};
838
    bool native_ca = false;
839
    projGridChunkCache gridChunkCache{};
840
    TMercAlgo defaultTmercAlgo =
841
        TMercAlgo::PODER_ENGSAGER; // can be overridden by content of proj.ini
842
    // END ini file settings
843
844
    int projStringParserCreateFromPROJStringRecursionCounter =
845
        0; // to avoid potential infinite recursion in
846
           // PROJStringParser::createFromPROJString()
847
    int pipelineInitRecursiongCounter =
848
        0; // to avoid potential infinite recursion in pipeline.cpp
849
850
1
    pj_ctx() = default;
851
    pj_ctx(const pj_ctx &);
852
    ~pj_ctx();
853
854
    pj_ctx &operator=(const pj_ctx &) = delete;
855
856
    projCppContext PROJ_FOR_TEST *get_cpp_context();
857
    void set_search_paths(const std::vector<std::string> &search_paths_in);
858
    void set_ca_bundle_path(const std::string &ca_bundle_path_in);
859
860
    static pj_ctx createDefault();
861
};
862
863
#ifndef DO_NOT_DEFINE_PROJ_HEAD
864
#define PROJ_HEAD(name, desc) static const char des_##name[] = desc
865
866
#define OPERATION(name, NEED_ELLPS)                                            \
867
                                                                               \
868
    pj_projection_specific_setup_##name(PJ *P);                                \
869
    C_NAMESPACE PJ *pj_##name(PJ *P);                                          \
870
                                                                               \
871
    C_NAMESPACE_VAR const char *const pj_s_##name = des_##name;                \
872
                                                                               \
873
471k
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
471k
        if (P)                                                                 \
875
471k
            return pj_projection_specific_setup_##name(P);                     \
876
471k
        P = pj_new();                                                          \
877
235k
        if (nullptr == P)                                                      \
878
235k
            return nullptr;                                                    \
879
235k
        P->short_name = #name;                                                 \
880
235k
        P->descr = des_##name;                                                 \
881
235k
        P->need_ellps = NEED_ELLPS;                                            \
882
235k
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
235k
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
235k
        return P;                                                              \
885
235k
    }                                                                          \
pj_geoc
Line
Count
Source
873
31
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
31
        if (P)                                                                 \
875
31
            return pj_projection_specific_setup_##name(P);                     \
876
31
        P = pj_new();                                                          \
877
16
        if (nullptr == P)                                                      \
878
16
            return nullptr;                                                    \
879
16
        P->short_name = #name;                                                 \
880
16
        P->descr = des_##name;                                                 \
881
16
        P->need_ellps = NEED_ELLPS;                                            \
882
16
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
16
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
16
        return P;                                                              \
885
16
    }                                                                          \
pj_gridshift
Line
Count
Source
873
1.34k
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
1.34k
        if (P)                                                                 \
875
1.34k
            return pj_projection_specific_setup_##name(P);                     \
876
1.34k
        P = pj_new();                                                          \
877
674
        if (nullptr == P)                                                      \
878
674
            return nullptr;                                                    \
879
674
        P->short_name = #name;                                                 \
880
674
        P->descr = des_##name;                                                 \
881
674
        P->need_ellps = NEED_ELLPS;                                            \
882
674
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
674
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
674
        return P;                                                              \
885
674
    }                                                                          \
pj_hgridshift
Line
Count
Source
873
9.60k
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
9.60k
        if (P)                                                                 \
875
9.60k
            return pj_projection_specific_setup_##name(P);                     \
876
9.60k
        P = pj_new();                                                          \
877
4.80k
        if (nullptr == P)                                                      \
878
4.80k
            return nullptr;                                                    \
879
4.80k
        P->short_name = #name;                                                 \
880
4.80k
        P->descr = des_##name;                                                 \
881
4.80k
        P->need_ellps = NEED_ELLPS;                                            \
882
4.80k
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
4.80k
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
4.80k
        return P;                                                              \
885
4.80k
    }                                                                          \
pj_vgridshift
Line
Count
Source
873
24.3k
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
24.3k
        if (P)                                                                 \
875
24.3k
            return pj_projection_specific_setup_##name(P);                     \
876
24.3k
        P = pj_new();                                                          \
877
12.1k
        if (nullptr == P)                                                      \
878
12.1k
            return nullptr;                                                    \
879
12.1k
        P->short_name = #name;                                                 \
880
12.1k
        P->descr = des_##name;                                                 \
881
12.1k
        P->need_ellps = NEED_ELLPS;                                            \
882
12.1k
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
12.1k
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
12.1k
        return P;                                                              \
885
12.1k
    }                                                                          \
pj_pipeline
Line
Count
Source
873
51.4k
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
51.4k
        if (P)                                                                 \
875
51.4k
            return pj_projection_specific_setup_##name(P);                     \
876
51.4k
        P = pj_new();                                                          \
877
25.7k
        if (nullptr == P)                                                      \
878
25.7k
            return nullptr;                                                    \
879
25.7k
        P->short_name = #name;                                                 \
880
25.7k
        P->descr = des_##name;                                                 \
881
25.7k
        P->need_ellps = NEED_ELLPS;                                            \
882
25.7k
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
25.7k
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
25.7k
        return P;                                                              \
885
25.7k
    }                                                                          \
pj_push
Line
Count
Source
873
23.1k
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
23.1k
        if (P)                                                                 \
875
23.1k
            return pj_projection_specific_setup_##name(P);                     \
876
23.1k
        P = pj_new();                                                          \
877
11.5k
        if (nullptr == P)                                                      \
878
11.5k
            return nullptr;                                                    \
879
11.5k
        P->short_name = #name;                                                 \
880
11.5k
        P->descr = des_##name;                                                 \
881
11.5k
        P->need_ellps = NEED_ELLPS;                                            \
882
11.5k
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
11.5k
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
11.5k
        return P;                                                              \
885
11.5k
    }                                                                          \
pj_pop
Line
Count
Source
873
23.8k
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
23.8k
        if (P)                                                                 \
875
23.8k
            return pj_projection_specific_setup_##name(P);                     \
876
23.8k
        P = pj_new();                                                          \
877
11.9k
        if (nullptr == P)                                                      \
878
11.9k
            return nullptr;                                                    \
879
11.9k
        P->short_name = #name;                                                 \
880
11.9k
        P->descr = des_##name;                                                 \
881
11.9k
        P->need_ellps = NEED_ELLPS;                                            \
882
11.9k
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
11.9k
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
11.9k
        return P;                                                              \
885
11.9k
    }                                                                          \
pj_axisswap
Line
Count
Source
873
6.19k
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
6.19k
        if (P)                                                                 \
875
6.19k
            return pj_projection_specific_setup_##name(P);                     \
876
6.19k
        P = pj_new();                                                          \
877
3.09k
        if (nullptr == P)                                                      \
878
3.09k
            return nullptr;                                                    \
879
3.09k
        P->short_name = #name;                                                 \
880
3.09k
        P->descr = des_##name;                                                 \
881
3.09k
        P->need_ellps = NEED_ELLPS;                                            \
882
3.09k
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
3.09k
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
3.09k
        return P;                                                              \
885
3.09k
    }                                                                          \
pj_cart
Line
Count
Source
873
148k
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
148k
        if (P)                                                                 \
875
148k
            return pj_projection_specific_setup_##name(P);                     \
876
148k
        P = pj_new();                                                          \
877
74.4k
        if (nullptr == P)                                                      \
878
74.4k
            return nullptr;                                                    \
879
74.4k
        P->short_name = #name;                                                 \
880
74.4k
        P->descr = des_##name;                                                 \
881
74.4k
        P->need_ellps = NEED_ELLPS;                                            \
882
74.4k
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
74.4k
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
74.4k
        return P;                                                              \
885
74.4k
    }                                                                          \
pj_geocent
Line
Count
Source
873
104
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
104
        if (P)                                                                 \
875
104
            return pj_projection_specific_setup_##name(P);                     \
876
104
        P = pj_new();                                                          \
877
52
        if (nullptr == P)                                                      \
878
52
            return nullptr;                                                    \
879
52
        P->short_name = #name;                                                 \
880
52
        P->descr = des_##name;                                                 \
881
52
        P->need_ellps = NEED_ELLPS;                                            \
882
52
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
52
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
52
        return P;                                                              \
885
52
    }                                                                          \
pj_noop
Line
Count
Source
873
1.11k
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
1.11k
        if (P)                                                                 \
875
1.11k
            return pj_projection_specific_setup_##name(P);                     \
876
1.11k
        P = pj_new();                                                          \
877
558
        if (nullptr == P)                                                      \
878
558
            return nullptr;                                                    \
879
558
        P->short_name = #name;                                                 \
880
558
        P->descr = des_##name;                                                 \
881
558
        P->need_ellps = NEED_ELLPS;                                            \
882
558
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
558
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
558
        return P;                                                              \
885
558
    }                                                                          \
pj_topocentric
Line
Count
Source
873
98
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
98
        if (P)                                                                 \
875
98
            return pj_projection_specific_setup_##name(P);                     \
876
98
        P = pj_new();                                                          \
877
50
        if (nullptr == P)                                                      \
878
50
            return nullptr;                                                    \
879
50
        P->short_name = #name;                                                 \
880
50
        P->descr = des_##name;                                                 \
881
50
        P->need_ellps = NEED_ELLPS;                                            \
882
50
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
50
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
50
        return P;                                                              \
885
50
    }                                                                          \
pj_set
Line
Count
Source
873
2.33k
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
2.33k
        if (P)                                                                 \
875
2.33k
            return pj_projection_specific_setup_##name(P);                     \
876
2.33k
        P = pj_new();                                                          \
877
1.16k
        if (nullptr == P)                                                      \
878
1.16k
            return nullptr;                                                    \
879
1.16k
        P->short_name = #name;                                                 \
880
1.16k
        P->descr = des_##name;                                                 \
881
1.16k
        P->need_ellps = NEED_ELLPS;                                            \
882
1.16k
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
1.16k
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
1.16k
        return P;                                                              \
885
1.16k
    }                                                                          \
pj_unitconvert
Line
Count
Source
873
25.0k
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
25.0k
        if (P)                                                                 \
875
25.0k
            return pj_projection_specific_setup_##name(P);                     \
876
25.0k
        P = pj_new();                                                          \
877
12.5k
        if (nullptr == P)                                                      \
878
12.5k
            return nullptr;                                                    \
879
12.5k
        P->short_name = #name;                                                 \
880
12.5k
        P->descr = des_##name;                                                 \
881
12.5k
        P->need_ellps = NEED_ELLPS;                                            \
882
12.5k
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
12.5k
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
12.5k
        return P;                                                              \
885
12.5k
    }                                                                          \
Unexecuted instantiation: pj_airocean
pj_aeqd
Line
Count
Source
873
506
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
506
        if (P)                                                                 \
875
506
            return pj_projection_specific_setup_##name(P);                     \
876
506
        P = pj_new();                                                          \
877
255
        if (nullptr == P)                                                      \
878
255
            return nullptr;                                                    \
879
255
        P->short_name = #name;                                                 \
880
255
        P->descr = des_##name;                                                 \
881
255
        P->need_ellps = NEED_ELLPS;                                            \
882
255
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
255
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
255
        return P;                                                              \
885
255
    }                                                                          \
pj_guyou
Line
Count
Source
873
10
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
10
        if (P)                                                                 \
875
10
            return pj_projection_specific_setup_##name(P);                     \
876
10
        P = pj_new();                                                          \
877
5
        if (nullptr == P)                                                      \
878
5
            return nullptr;                                                    \
879
5
        P->short_name = #name;                                                 \
880
5
        P->descr = des_##name;                                                 \
881
5
        P->need_ellps = NEED_ELLPS;                                            \
882
5
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
5
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
5
        return P;                                                              \
885
5
    }                                                                          \
pj_peirce_q
Line
Count
Source
873
167
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
167
        if (P)                                                                 \
875
167
            return pj_projection_specific_setup_##name(P);                     \
876
167
        P = pj_new();                                                          \
877
84
        if (nullptr == P)                                                      \
878
84
            return nullptr;                                                    \
879
84
        P->short_name = #name;                                                 \
880
84
        P->descr = des_##name;                                                 \
881
84
        P->need_ellps = NEED_ELLPS;                                            \
882
84
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
84
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
84
        return P;                                                              \
885
84
    }                                                                          \
pj_adams_hemi
Line
Count
Source
873
106
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
106
        if (P)                                                                 \
875
106
            return pj_projection_specific_setup_##name(P);                     \
876
106
        P = pj_new();                                                          \
877
54
        if (nullptr == P)                                                      \
878
54
            return nullptr;                                                    \
879
54
        P->short_name = #name;                                                 \
880
54
        P->descr = des_##name;                                                 \
881
54
        P->need_ellps = NEED_ELLPS;                                            \
882
54
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
54
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
54
        return P;                                                              \
885
54
    }                                                                          \
pj_adams_ws1
Line
Count
Source
873
8
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
8
        if (P)                                                                 \
875
8
            return pj_projection_specific_setup_##name(P);                     \
876
8
        P = pj_new();                                                          \
877
4
        if (nullptr == P)                                                      \
878
4
            return nullptr;                                                    \
879
4
        P->short_name = #name;                                                 \
880
4
        P->descr = des_##name;                                                 \
881
4
        P->need_ellps = NEED_ELLPS;                                            \
882
4
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
4
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
4
        return P;                                                              \
885
4
    }                                                                          \
pj_adams_ws2
Line
Count
Source
873
36
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
36
        if (P)                                                                 \
875
36
            return pj_projection_specific_setup_##name(P);                     \
876
36
        P = pj_new();                                                          \
877
18
        if (nullptr == P)                                                      \
878
18
            return nullptr;                                                    \
879
18
        P->short_name = #name;                                                 \
880
18
        P->descr = des_##name;                                                 \
881
18
        P->need_ellps = NEED_ELLPS;                                            \
882
18
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
18
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
18
        return P;                                                              \
885
18
    }                                                                          \
pj_gnom
Line
Count
Source
873
305
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
305
        if (P)                                                                 \
875
305
            return pj_projection_specific_setup_##name(P);                     \
876
305
        P = pj_new();                                                          \
877
153
        if (nullptr == P)                                                      \
878
153
            return nullptr;                                                    \
879
153
        P->short_name = #name;                                                 \
880
153
        P->descr = des_##name;                                                 \
881
153
        P->need_ellps = NEED_ELLPS;                                            \
882
153
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
153
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
153
        return P;                                                              \
885
153
    }                                                                          \
pj_laea
Line
Count
Source
873
705
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
705
        if (P)                                                                 \
875
705
            return pj_projection_specific_setup_##name(P);                     \
876
705
        P = pj_new();                                                          \
877
353
        if (nullptr == P)                                                      \
878
353
            return nullptr;                                                    \
879
353
        P->short_name = #name;                                                 \
880
353
        P->descr = des_##name;                                                 \
881
353
        P->need_ellps = NEED_ELLPS;                                            \
882
353
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
353
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
353
        return P;                                                              \
885
353
    }                                                                          \
pj_mil_os
Line
Count
Source
873
4
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
4
        if (P)                                                                 \
875
4
            return pj_projection_specific_setup_##name(P);                     \
876
4
        P = pj_new();                                                          \
877
2
        if (nullptr == P)                                                      \
878
2
            return nullptr;                                                    \
879
2
        P->short_name = #name;                                                 \
880
2
        P->descr = des_##name;                                                 \
881
2
        P->need_ellps = NEED_ELLPS;                                            \
882
2
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
2
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
2
        return P;                                                              \
885
2
    }                                                                          \
pj_lee_os
Line
Count
Source
873
69
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
69
        if (P)                                                                 \
875
69
            return pj_projection_specific_setup_##name(P);                     \
876
69
        P = pj_new();                                                          \
877
35
        if (nullptr == P)                                                      \
878
35
            return nullptr;                                                    \
879
35
        P->short_name = #name;                                                 \
880
35
        P->descr = des_##name;                                                 \
881
35
        P->need_ellps = NEED_ELLPS;                                            \
882
35
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
35
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
35
        return P;                                                              \
885
35
    }                                                                          \
pj_gs48
Line
Count
Source
873
40
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
40
        if (P)                                                                 \
875
40
            return pj_projection_specific_setup_##name(P);                     \
876
40
        P = pj_new();                                                          \
877
20
        if (nullptr == P)                                                      \
878
20
            return nullptr;                                                    \
879
20
        P->short_name = #name;                                                 \
880
20
        P->descr = des_##name;                                                 \
881
20
        P->need_ellps = NEED_ELLPS;                                            \
882
20
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
20
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
20
        return P;                                                              \
885
20
    }                                                                          \
pj_alsk
Line
Count
Source
873
290
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
290
        if (P)                                                                 \
875
290
            return pj_projection_specific_setup_##name(P);                     \
876
290
        P = pj_new();                                                          \
877
145
        if (nullptr == P)                                                      \
878
145
            return nullptr;                                                    \
879
145
        P->short_name = #name;                                                 \
880
145
        P->descr = des_##name;                                                 \
881
145
        P->need_ellps = NEED_ELLPS;                                            \
882
145
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
145
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
145
        return P;                                                              \
885
145
    }                                                                          \
pj_gs50
Line
Count
Source
873
25
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
25
        if (P)                                                                 \
875
25
            return pj_projection_specific_setup_##name(P);                     \
876
25
        P = pj_new();                                                          \
877
13
        if (nullptr == P)                                                      \
878
13
            return nullptr;                                                    \
879
13
        P->short_name = #name;                                                 \
880
13
        P->descr = des_##name;                                                 \
881
13
        P->need_ellps = NEED_ELLPS;                                            \
882
13
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
13
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
13
        return P;                                                              \
885
13
    }                                                                          \
pj_nsper
Line
Count
Source
873
42
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
42
        if (P)                                                                 \
875
42
            return pj_projection_specific_setup_##name(P);                     \
876
42
        P = pj_new();                                                          \
877
21
        if (nullptr == P)                                                      \
878
21
            return nullptr;                                                    \
879
21
        P->short_name = #name;                                                 \
880
21
        P->descr = des_##name;                                                 \
881
21
        P->need_ellps = NEED_ELLPS;                                            \
882
21
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
21
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
21
        return P;                                                              \
885
21
    }                                                                          \
Unexecuted instantiation: pj_tpers
pj_nzmg
Line
Count
Source
873
33
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
33
        if (P)                                                                 \
875
33
            return pj_projection_specific_setup_##name(P);                     \
876
33
        P = pj_new();                                                          \
877
18
        if (nullptr == P)                                                      \
878
18
            return nullptr;                                                    \
879
18
        P->short_name = #name;                                                 \
880
18
        P->descr = des_##name;                                                 \
881
18
        P->need_ellps = NEED_ELLPS;                                            \
882
18
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
18
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
18
        return P;                                                              \
885
18
    }                                                                          \
pj_ortho
Line
Count
Source
873
333
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
333
        if (P)                                                                 \
875
333
            return pj_projection_specific_setup_##name(P);                     \
876
333
        P = pj_new();                                                          \
877
168
        if (nullptr == P)                                                      \
878
168
            return nullptr;                                                    \
879
168
        P->short_name = #name;                                                 \
880
168
        P->descr = des_##name;                                                 \
881
168
        P->need_ellps = NEED_ELLPS;                                            \
882
168
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
168
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
168
        return P;                                                              \
885
168
    }                                                                          \
pj_stere
Line
Count
Source
873
1.43k
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
1.43k
        if (P)                                                                 \
875
1.43k
            return pj_projection_specific_setup_##name(P);                     \
876
1.43k
        P = pj_new();                                                          \
877
719
        if (nullptr == P)                                                      \
878
719
            return nullptr;                                                    \
879
719
        P->short_name = #name;                                                 \
880
719
        P->descr = des_##name;                                                 \
881
719
        P->need_ellps = NEED_ELLPS;                                            \
882
719
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
719
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
719
        return P;                                                              \
885
719
    }                                                                          \
pj_ups
Line
Count
Source
873
457
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
457
        if (P)                                                                 \
875
457
            return pj_projection_specific_setup_##name(P);                     \
876
457
        P = pj_new();                                                          \
877
230
        if (nullptr == P)                                                      \
878
230
            return nullptr;                                                    \
879
230
        P->short_name = #name;                                                 \
880
230
        P->descr = des_##name;                                                 \
881
230
        P->need_ellps = NEED_ELLPS;                                            \
882
230
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
230
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
230
        return P;                                                              \
885
230
    }                                                                          \
pj_sterea
Line
Count
Source
873
22
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
22
        if (P)                                                                 \
875
22
            return pj_projection_specific_setup_##name(P);                     \
876
22
        P = pj_new();                                                          \
877
11
        if (nullptr == P)                                                      \
878
11
            return nullptr;                                                    \
879
11
        P->short_name = #name;                                                 \
880
11
        P->descr = des_##name;                                                 \
881
11
        P->need_ellps = NEED_ELLPS;                                            \
882
11
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
11
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
11
        return P;                                                              \
885
11
    }                                                                          \
pj_aea
Line
Count
Source
873
81
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
81
        if (P)                                                                 \
875
81
            return pj_projection_specific_setup_##name(P);                     \
876
81
        P = pj_new();                                                          \
877
41
        if (nullptr == P)                                                      \
878
41
            return nullptr;                                                    \
879
41
        P->short_name = #name;                                                 \
880
41
        P->descr = des_##name;                                                 \
881
41
        P->need_ellps = NEED_ELLPS;                                            \
882
41
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
41
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
41
        return P;                                                              \
885
41
    }                                                                          \
pj_leac
Line
Count
Source
873
4
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
4
        if (P)                                                                 \
875
4
            return pj_projection_specific_setup_##name(P);                     \
876
4
        P = pj_new();                                                          \
877
2
        if (nullptr == P)                                                      \
878
2
            return nullptr;                                                    \
879
2
        P->short_name = #name;                                                 \
880
2
        P->descr = des_##name;                                                 \
881
2
        P->need_ellps = NEED_ELLPS;                                            \
882
2
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
2
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
2
        return P;                                                              \
885
2
    }                                                                          \
pj_bipc
Line
Count
Source
873
41
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
41
        if (P)                                                                 \
875
41
            return pj_projection_specific_setup_##name(P);                     \
876
41
        P = pj_new();                                                          \
877
21
        if (nullptr == P)                                                      \
878
21
            return nullptr;                                                    \
879
21
        P->short_name = #name;                                                 \
880
21
        P->descr = des_##name;                                                 \
881
21
        P->need_ellps = NEED_ELLPS;                                            \
882
21
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
21
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
21
        return P;                                                              \
885
21
    }                                                                          \
pj_bonne
Line
Count
Source
873
140
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
140
        if (P)                                                                 \
875
140
            return pj_projection_specific_setup_##name(P);                     \
876
140
        P = pj_new();                                                          \
877
70
        if (nullptr == P)                                                      \
878
70
            return nullptr;                                                    \
879
70
        P->short_name = #name;                                                 \
880
70
        P->descr = des_##name;                                                 \
881
70
        P->need_ellps = NEED_ELLPS;                                            \
882
70
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
70
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
70
        return P;                                                              \
885
70
    }                                                                          \
pj_eqdc
Line
Count
Source
873
129
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
129
        if (P)                                                                 \
875
129
            return pj_projection_specific_setup_##name(P);                     \
876
129
        P = pj_new();                                                          \
877
65
        if (nullptr == P)                                                      \
878
65
            return nullptr;                                                    \
879
65
        P->short_name = #name;                                                 \
880
65
        P->descr = des_##name;                                                 \
881
65
        P->need_ellps = NEED_ELLPS;                                            \
882
65
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
65
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
65
        return P;                                                              \
885
65
    }                                                                          \
pj_isea
Line
Count
Source
873
584
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
584
        if (P)                                                                 \
875
584
            return pj_projection_specific_setup_##name(P);                     \
876
584
        P = pj_new();                                                          \
877
293
        if (nullptr == P)                                                      \
878
293
            return nullptr;                                                    \
879
293
        P->short_name = #name;                                                 \
880
293
        P->descr = des_##name;                                                 \
881
293
        P->need_ellps = NEED_ELLPS;                                            \
882
293
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
293
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
293
        return P;                                                              \
885
293
    }                                                                          \
pj_ccon
Line
Count
Source
873
26
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
26
        if (P)                                                                 \
875
26
            return pj_projection_specific_setup_##name(P);                     \
876
26
        P = pj_new();                                                          \
877
13
        if (nullptr == P)                                                      \
878
13
            return nullptr;                                                    \
879
13
        P->short_name = #name;                                                 \
880
13
        P->descr = des_##name;                                                 \
881
13
        P->need_ellps = NEED_ELLPS;                                            \
882
13
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
13
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
13
        return P;                                                              \
885
13
    }                                                                          \
pj_imw_p
Line
Count
Source
873
307
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
307
        if (P)                                                                 \
875
307
            return pj_projection_specific_setup_##name(P);                     \
876
307
        P = pj_new();                                                          \
877
154
        if (nullptr == P)                                                      \
878
154
            return nullptr;                                                    \
879
154
        P->short_name = #name;                                                 \
880
154
        P->descr = des_##name;                                                 \
881
154
        P->need_ellps = NEED_ELLPS;                                            \
882
154
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
154
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
154
        return P;                                                              \
885
154
    }                                                                          \
pj_krovak
Line
Count
Source
873
2.12k
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
2.12k
        if (P)                                                                 \
875
2.12k
            return pj_projection_specific_setup_##name(P);                     \
876
2.12k
        P = pj_new();                                                          \
877
1.06k
        if (nullptr == P)                                                      \
878
1.06k
            return nullptr;                                                    \
879
1.06k
        P->short_name = #name;                                                 \
880
1.06k
        P->descr = des_##name;                                                 \
881
1.06k
        P->need_ellps = NEED_ELLPS;                                            \
882
1.06k
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
1.06k
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
1.06k
        return P;                                                              \
885
1.06k
    }                                                                          \
pj_mod_krovak
Line
Count
Source
873
689
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
689
        if (P)                                                                 \
875
689
            return pj_projection_specific_setup_##name(P);                     \
876
689
        P = pj_new();                                                          \
877
345
        if (nullptr == P)                                                      \
878
345
            return nullptr;                                                    \
879
345
        P->short_name = #name;                                                 \
880
345
        P->descr = des_##name;                                                 \
881
345
        P->need_ellps = NEED_ELLPS;                                            \
882
345
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
345
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
345
        return P;                                                              \
885
345
    }                                                                          \
pj_lcc
Line
Count
Source
873
539
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
539
        if (P)                                                                 \
875
539
            return pj_projection_specific_setup_##name(P);                     \
876
539
        P = pj_new();                                                          \
877
271
        if (nullptr == P)                                                      \
878
271
            return nullptr;                                                    \
879
271
        P->short_name = #name;                                                 \
880
271
        P->descr = des_##name;                                                 \
881
271
        P->need_ellps = NEED_ELLPS;                                            \
882
271
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
271
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
271
        return P;                                                              \
885
271
    }                                                                          \
pj_poly
Line
Count
Source
873
334
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
334
        if (P)                                                                 \
875
334
            return pj_projection_specific_setup_##name(P);                     \
876
334
        P = pj_new();                                                          \
877
167
        if (nullptr == P)                                                      \
878
167
            return nullptr;                                                    \
879
167
        P->short_name = #name;                                                 \
880
167
        P->descr = des_##name;                                                 \
881
167
        P->need_ellps = NEED_ELLPS;                                            \
882
167
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
167
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
167
        return P;                                                              \
885
167
    }                                                                          \
pj_rpoly
Line
Count
Source
873
4
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
4
        if (P)                                                                 \
875
4
            return pj_projection_specific_setup_##name(P);                     \
876
4
        P = pj_new();                                                          \
877
2
        if (nullptr == P)                                                      \
878
2
            return nullptr;                                                    \
879
2
        P->short_name = #name;                                                 \
880
2
        P->descr = des_##name;                                                 \
881
2
        P->need_ellps = NEED_ELLPS;                                            \
882
2
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
2
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
2
        return P;                                                              \
885
2
    }                                                                          \
pj_euler
Line
Count
Source
873
21
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
21
        if (P)                                                                 \
875
21
            return pj_projection_specific_setup_##name(P);                     \
876
21
        P = pj_new();                                                          \
877
11
        if (nullptr == P)                                                      \
878
11
            return nullptr;                                                    \
879
11
        P->short_name = #name;                                                 \
880
11
        P->descr = des_##name;                                                 \
881
11
        P->need_ellps = NEED_ELLPS;                                            \
882
11
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
11
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
11
        return P;                                                              \
885
11
    }                                                                          \
pj_tissot
Line
Count
Source
873
7
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
7
        if (P)                                                                 \
875
7
            return pj_projection_specific_setup_##name(P);                     \
876
7
        P = pj_new();                                                          \
877
4
        if (nullptr == P)                                                      \
878
4
            return nullptr;                                                    \
879
4
        P->short_name = #name;                                                 \
880
4
        P->descr = des_##name;                                                 \
881
4
        P->need_ellps = NEED_ELLPS;                                            \
882
4
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
4
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
4
        return P;                                                              \
885
4
    }                                                                          \
pj_murd1
Line
Count
Source
873
5
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
5
        if (P)                                                                 \
875
5
            return pj_projection_specific_setup_##name(P);                     \
876
5
        P = pj_new();                                                          \
877
3
        if (nullptr == P)                                                      \
878
3
            return nullptr;                                                    \
879
3
        P->short_name = #name;                                                 \
880
3
        P->descr = des_##name;                                                 \
881
3
        P->need_ellps = NEED_ELLPS;                                            \
882
3
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
3
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
3
        return P;                                                              \
885
3
    }                                                                          \
pj_murd2
Line
Count
Source
873
6
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
6
        if (P)                                                                 \
875
6
            return pj_projection_specific_setup_##name(P);                     \
876
6
        P = pj_new();                                                          \
877
3
        if (nullptr == P)                                                      \
878
3
            return nullptr;                                                    \
879
3
        P->short_name = #name;                                                 \
880
3
        P->descr = des_##name;                                                 \
881
3
        P->need_ellps = NEED_ELLPS;                                            \
882
3
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
3
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
3
        return P;                                                              \
885
3
    }                                                                          \
pj_murd3
Line
Count
Source
873
26
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
26
        if (P)                                                                 \
875
26
            return pj_projection_specific_setup_##name(P);                     \
876
26
        P = pj_new();                                                          \
877
13
        if (nullptr == P)                                                      \
878
13
            return nullptr;                                                    \
879
13
        P->short_name = #name;                                                 \
880
13
        P->descr = des_##name;                                                 \
881
13
        P->need_ellps = NEED_ELLPS;                                            \
882
13
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
13
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
13
        return P;                                                              \
885
13
    }                                                                          \
pj_pconic
Line
Count
Source
873
2
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
2
        if (P)                                                                 \
875
2
            return pj_projection_specific_setup_##name(P);                     \
876
2
        P = pj_new();                                                          \
877
1
        if (nullptr == P)                                                      \
878
1
            return nullptr;                                                    \
879
1
        P->short_name = #name;                                                 \
880
1
        P->descr = des_##name;                                                 \
881
1
        P->need_ellps = NEED_ELLPS;                                            \
882
1
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
1
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
1
        return P;                                                              \
885
1
    }                                                                          \
pj_vitk1
Line
Count
Source
873
23
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
23
        if (P)                                                                 \
875
23
            return pj_projection_specific_setup_##name(P);                     \
876
23
        P = pj_new();                                                          \
877
12
        if (nullptr == P)                                                      \
878
12
            return nullptr;                                                    \
879
12
        P->short_name = #name;                                                 \
880
12
        P->descr = des_##name;                                                 \
881
12
        P->need_ellps = NEED_ELLPS;                                            \
882
12
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
12
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
12
        return P;                                                              \
885
12
    }                                                                          \
pj_rouss
Line
Count
Source
873
163
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
163
        if (P)                                                                 \
875
163
            return pj_projection_specific_setup_##name(P);                     \
876
163
        P = pj_new();                                                          \
877
84
        if (nullptr == P)                                                      \
878
84
            return nullptr;                                                    \
879
84
        P->short_name = #name;                                                 \
880
84
        P->descr = des_##name;                                                 \
881
84
        P->need_ellps = NEED_ELLPS;                                            \
882
84
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
84
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
84
        return P;                                                              \
885
84
    }                                                                          \
pj_cass
Line
Count
Source
873
102
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
102
        if (P)                                                                 \
875
102
            return pj_projection_specific_setup_##name(P);                     \
876
102
        P = pj_new();                                                          \
877
52
        if (nullptr == P)                                                      \
878
52
            return nullptr;                                                    \
879
52
        P->short_name = #name;                                                 \
880
52
        P->descr = des_##name;                                                 \
881
52
        P->need_ellps = NEED_ELLPS;                                            \
882
52
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
52
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
52
        return P;                                                              \
885
52
    }                                                                          \
pj_cc
Line
Count
Source
873
873
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
873
        if (P)                                                                 \
875
873
            return pj_projection_specific_setup_##name(P);                     \
876
873
        P = pj_new();                                                          \
877
437
        if (nullptr == P)                                                      \
878
437
            return nullptr;                                                    \
879
437
        P->short_name = #name;                                                 \
880
437
        P->descr = des_##name;                                                 \
881
437
        P->need_ellps = NEED_ELLPS;                                            \
882
437
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
437
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
437
        return P;                                                              \
885
437
    }                                                                          \
pj_cea
Line
Count
Source
873
384
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
384
        if (P)                                                                 \
875
384
            return pj_projection_specific_setup_##name(P);                     \
876
384
        P = pj_new();                                                          \
877
193
        if (nullptr == P)                                                      \
878
193
            return nullptr;                                                    \
879
193
        P->short_name = #name;                                                 \
880
193
        P->descr = des_##name;                                                 \
881
193
        P->need_ellps = NEED_ELLPS;                                            \
882
193
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
193
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
193
        return P;                                                              \
885
193
    }                                                                          \
pj_eqc
Line
Count
Source
873
191
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
191
        if (P)                                                                 \
875
191
            return pj_projection_specific_setup_##name(P);                     \
876
191
        P = pj_new();                                                          \
877
96
        if (nullptr == P)                                                      \
878
96
            return nullptr;                                                    \
879
96
        P->short_name = #name;                                                 \
880
96
        P->descr = des_##name;                                                 \
881
96
        P->need_ellps = NEED_ELLPS;                                            \
882
96
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
96
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
96
        return P;                                                              \
885
96
    }                                                                          \
pj_gall
Line
Count
Source
873
75
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
75
        if (P)                                                                 \
875
75
            return pj_projection_specific_setup_##name(P);                     \
876
75
        P = pj_new();                                                          \
877
38
        if (nullptr == P)                                                      \
878
38
            return nullptr;                                                    \
879
38
        P->short_name = #name;                                                 \
880
38
        P->descr = des_##name;                                                 \
881
38
        P->need_ellps = NEED_ELLPS;                                            \
882
38
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
38
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
38
        return P;                                                              \
885
38
    }                                                                          \
pj_labrd
Line
Count
Source
873
25
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
25
        if (P)                                                                 \
875
25
            return pj_projection_specific_setup_##name(P);                     \
876
25
        P = pj_new();                                                          \
877
13
        if (nullptr == P)                                                      \
878
13
            return nullptr;                                                    \
879
13
        P->short_name = #name;                                                 \
880
13
        P->descr = des_##name;                                                 \
881
13
        P->need_ellps = NEED_ELLPS;                                            \
882
13
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
13
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
13
        return P;                                                              \
885
13
    }                                                                          \
pj_som
Line
Count
Source
873
346
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
346
        if (P)                                                                 \
875
346
            return pj_projection_specific_setup_##name(P);                     \
876
346
        P = pj_new();                                                          \
877
175
        if (nullptr == P)                                                      \
878
175
            return nullptr;                                                    \
879
175
        P->short_name = #name;                                                 \
880
175
        P->descr = des_##name;                                                 \
881
175
        P->need_ellps = NEED_ELLPS;                                            \
882
175
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
175
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
175
        return P;                                                              \
885
175
    }                                                                          \
pj_misrsom
Line
Count
Source
873
7
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
7
        if (P)                                                                 \
875
7
            return pj_projection_specific_setup_##name(P);                     \
876
7
        P = pj_new();                                                          \
877
4
        if (nullptr == P)                                                      \
878
4
            return nullptr;                                                    \
879
4
        P->short_name = #name;                                                 \
880
4
        P->descr = des_##name;                                                 \
881
4
        P->need_ellps = NEED_ELLPS;                                            \
882
4
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
4
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
4
        return P;                                                              \
885
4
    }                                                                          \
pj_lsat
Line
Count
Source
873
33
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
33
        if (P)                                                                 \
875
33
            return pj_projection_specific_setup_##name(P);                     \
876
33
        P = pj_new();                                                          \
877
17
        if (nullptr == P)                                                      \
878
17
            return nullptr;                                                    \
879
17
        P->short_name = #name;                                                 \
880
17
        P->descr = des_##name;                                                 \
881
17
        P->need_ellps = NEED_ELLPS;                                            \
882
17
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
17
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
17
        return P;                                                              \
885
17
    }                                                                          \
pj_merc
Line
Count
Source
873
542
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
542
        if (P)                                                                 \
875
542
            return pj_projection_specific_setup_##name(P);                     \
876
542
        P = pj_new();                                                          \
877
272
        if (nullptr == P)                                                      \
878
272
            return nullptr;                                                    \
879
272
        P->short_name = #name;                                                 \
880
272
        P->descr = des_##name;                                                 \
881
272
        P->need_ellps = NEED_ELLPS;                                            \
882
272
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
272
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
272
        return P;                                                              \
885
272
    }                                                                          \
pj_webmerc
Line
Count
Source
873
36
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
36
        if (P)                                                                 \
875
36
            return pj_projection_specific_setup_##name(P);                     \
876
36
        P = pj_new();                                                          \
877
18
        if (nullptr == P)                                                      \
878
18
            return nullptr;                                                    \
879
18
        P->short_name = #name;                                                 \
880
18
        P->descr = des_##name;                                                 \
881
18
        P->need_ellps = NEED_ELLPS;                                            \
882
18
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
18
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
18
        return P;                                                              \
885
18
    }                                                                          \
pj_mill
Line
Count
Source
873
231
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
231
        if (P)                                                                 \
875
231
            return pj_projection_specific_setup_##name(P);                     \
876
231
        P = pj_new();                                                          \
877
117
        if (nullptr == P)                                                      \
878
117
            return nullptr;                                                    \
879
117
        P->short_name = #name;                                                 \
880
117
        P->descr = des_##name;                                                 \
881
117
        P->need_ellps = NEED_ELLPS;                                            \
882
117
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
117
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
117
        return P;                                                              \
885
117
    }                                                                          \
pj_ocea
Line
Count
Source
873
43
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
43
        if (P)                                                                 \
875
43
            return pj_projection_specific_setup_##name(P);                     \
876
43
        P = pj_new();                                                          \
877
22
        if (nullptr == P)                                                      \
878
22
            return nullptr;                                                    \
879
22
        P->short_name = #name;                                                 \
880
22
        P->descr = des_##name;                                                 \
881
22
        P->need_ellps = NEED_ELLPS;                                            \
882
22
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
22
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
22
        return P;                                                              \
885
22
    }                                                                          \
pj_omerc
Line
Count
Source
873
399
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
399
        if (P)                                                                 \
875
399
            return pj_projection_specific_setup_##name(P);                     \
876
399
        P = pj_new();                                                          \
877
201
        if (nullptr == P)                                                      \
878
201
            return nullptr;                                                    \
879
201
        P->short_name = #name;                                                 \
880
201
        P->descr = des_##name;                                                 \
881
201
        P->need_ellps = NEED_ELLPS;                                            \
882
201
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
201
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
201
        return P;                                                              \
885
201
    }                                                                          \
pj_somerc
Line
Count
Source
873
218
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
218
        if (P)                                                                 \
875
218
            return pj_projection_specific_setup_##name(P);                     \
876
218
        P = pj_new();                                                          \
877
110
        if (nullptr == P)                                                      \
878
110
            return nullptr;                                                    \
879
110
        P->short_name = #name;                                                 \
880
110
        P->descr = des_##name;                                                 \
881
110
        P->need_ellps = NEED_ELLPS;                                            \
882
110
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
110
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
110
        return P;                                                              \
885
110
    }                                                                          \
pj_tcc
Line
Count
Source
873
20
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
20
        if (P)                                                                 \
875
20
            return pj_projection_specific_setup_##name(P);                     \
876
20
        P = pj_new();                                                          \
877
10
        if (nullptr == P)                                                      \
878
10
            return nullptr;                                                    \
879
10
        P->short_name = #name;                                                 \
880
10
        P->descr = des_##name;                                                 \
881
10
        P->need_ellps = NEED_ELLPS;                                            \
882
10
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
10
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
10
        return P;                                                              \
885
10
    }                                                                          \
pj_tcea
Line
Count
Source
873
90
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
90
        if (P)                                                                 \
875
90
            return pj_projection_specific_setup_##name(P);                     \
876
90
        P = pj_new();                                                          \
877
46
        if (nullptr == P)                                                      \
878
46
            return nullptr;                                                    \
879
46
        P->short_name = #name;                                                 \
880
46
        P->descr = des_##name;                                                 \
881
46
        P->need_ellps = NEED_ELLPS;                                            \
882
46
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
46
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
46
        return P;                                                              \
885
46
    }                                                                          \
pj_times
Line
Count
Source
873
29
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
29
        if (P)                                                                 \
875
29
            return pj_projection_specific_setup_##name(P);                     \
876
29
        P = pj_new();                                                          \
877
16
        if (nullptr == P)                                                      \
878
16
            return nullptr;                                                    \
879
16
        P->short_name = #name;                                                 \
880
16
        P->descr = des_##name;                                                 \
881
16
        P->need_ellps = NEED_ELLPS;                                            \
882
16
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
16
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
16
        return P;                                                              \
885
16
    }                                                                          \
pj_tmerc
Line
Count
Source
873
6.35k
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
6.35k
        if (P)                                                                 \
875
6.35k
            return pj_projection_specific_setup_##name(P);                     \
876
6.35k
        P = pj_new();                                                          \
877
3.17k
        if (nullptr == P)                                                      \
878
3.17k
            return nullptr;                                                    \
879
3.17k
        P->short_name = #name;                                                 \
880
3.17k
        P->descr = des_##name;                                                 \
881
3.17k
        P->need_ellps = NEED_ELLPS;                                            \
882
3.17k
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
3.17k
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
3.17k
        return P;                                                              \
885
3.17k
    }                                                                          \
pj_etmerc
Line
Count
Source
873
16
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
16
        if (P)                                                                 \
875
16
            return pj_projection_specific_setup_##name(P);                     \
876
16
        P = pj_new();                                                          \
877
8
        if (nullptr == P)                                                      \
878
8
            return nullptr;                                                    \
879
8
        P->short_name = #name;                                                 \
880
8
        P->descr = des_##name;                                                 \
881
8
        P->need_ellps = NEED_ELLPS;                                            \
882
8
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
8
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
8
        return P;                                                              \
885
8
    }                                                                          \
pj_utm
Line
Count
Source
873
725
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
725
        if (P)                                                                 \
875
725
            return pj_projection_specific_setup_##name(P);                     \
876
725
        P = pj_new();                                                          \
877
363
        if (nullptr == P)                                                      \
878
363
            return nullptr;                                                    \
879
363
        P->short_name = #name;                                                 \
880
363
        P->descr = des_##name;                                                 \
881
363
        P->need_ellps = NEED_ELLPS;                                            \
882
363
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
363
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
363
        return P;                                                              \
885
363
    }                                                                          \
pj_tobmerc
Line
Count
Source
873
21
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
21
        if (P)                                                                 \
875
21
            return pj_projection_specific_setup_##name(P);                     \
876
21
        P = pj_new();                                                          \
877
11
        if (nullptr == P)                                                      \
878
11
            return nullptr;                                                    \
879
11
        P->short_name = #name;                                                 \
880
11
        P->descr = des_##name;                                                 \
881
11
        P->need_ellps = NEED_ELLPS;                                            \
882
11
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
11
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
11
        return P;                                                              \
885
11
    }                                                                          \
pj_airy
Line
Count
Source
873
170
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
170
        if (P)                                                                 \
875
170
            return pj_projection_specific_setup_##name(P);                     \
876
170
        P = pj_new();                                                          \
877
85
        if (nullptr == P)                                                      \
878
85
            return nullptr;                                                    \
879
85
        P->short_name = #name;                                                 \
880
85
        P->descr = des_##name;                                                 \
881
85
        P->need_ellps = NEED_ELLPS;                                            \
882
85
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
85
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
85
        return P;                                                              \
885
85
    }                                                                          \
pj_aitoff
Line
Count
Source
873
133
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
133
        if (P)                                                                 \
875
133
            return pj_projection_specific_setup_##name(P);                     \
876
133
        P = pj_new();                                                          \
877
68
        if (nullptr == P)                                                      \
878
68
            return nullptr;                                                    \
879
68
        P->short_name = #name;                                                 \
880
68
        P->descr = des_##name;                                                 \
881
68
        P->need_ellps = NEED_ELLPS;                                            \
882
68
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
68
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
68
        return P;                                                              \
885
68
    }                                                                          \
pj_wintri
Line
Count
Source
873
26
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
26
        if (P)                                                                 \
875
26
            return pj_projection_specific_setup_##name(P);                     \
876
26
        P = pj_new();                                                          \
877
13
        if (nullptr == P)                                                      \
878
13
            return nullptr;                                                    \
879
13
        P->short_name = #name;                                                 \
880
13
        P->descr = des_##name;                                                 \
881
13
        P->need_ellps = NEED_ELLPS;                                            \
882
13
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
13
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
13
        return P;                                                              \
885
13
    }                                                                          \
pj_august
Line
Count
Source
873
25
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
25
        if (P)                                                                 \
875
25
            return pj_projection_specific_setup_##name(P);                     \
876
25
        P = pj_new();                                                          \
877
14
        if (nullptr == P)                                                      \
878
14
            return nullptr;                                                    \
879
14
        P->short_name = #name;                                                 \
880
14
        P->descr = des_##name;                                                 \
881
14
        P->need_ellps = NEED_ELLPS;                                            \
882
14
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
14
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
14
        return P;                                                              \
885
14
    }                                                                          \
pj_bacon
Line
Count
Source
873
4
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
4
        if (P)                                                                 \
875
4
            return pj_projection_specific_setup_##name(P);                     \
876
4
        P = pj_new();                                                          \
877
2
        if (nullptr == P)                                                      \
878
2
            return nullptr;                                                    \
879
2
        P->short_name = #name;                                                 \
880
2
        P->descr = des_##name;                                                 \
881
2
        P->need_ellps = NEED_ELLPS;                                            \
882
2
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
2
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
2
        return P;                                                              \
885
2
    }                                                                          \
pj_apian
Line
Count
Source
873
28
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
28
        if (P)                                                                 \
875
28
            return pj_projection_specific_setup_##name(P);                     \
876
28
        P = pj_new();                                                          \
877
15
        if (nullptr == P)                                                      \
878
15
            return nullptr;                                                    \
879
15
        P->short_name = #name;                                                 \
880
15
        P->descr = des_##name;                                                 \
881
15
        P->need_ellps = NEED_ELLPS;                                            \
882
15
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
15
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
15
        return P;                                                              \
885
15
    }                                                                          \
pj_ortel
Line
Count
Source
873
13
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
13
        if (P)                                                                 \
875
13
            return pj_projection_specific_setup_##name(P);                     \
876
13
        P = pj_new();                                                          \
877
7
        if (nullptr == P)                                                      \
878
7
            return nullptr;                                                    \
879
7
        P->short_name = #name;                                                 \
880
7
        P->descr = des_##name;                                                 \
881
7
        P->need_ellps = NEED_ELLPS;                                            \
882
7
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
7
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
7
        return P;                                                              \
885
7
    }                                                                          \
pj_bertin1953
Line
Count
Source
873
4
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
4
        if (P)                                                                 \
875
4
            return pj_projection_specific_setup_##name(P);                     \
876
4
        P = pj_new();                                                          \
877
2
        if (nullptr == P)                                                      \
878
2
            return nullptr;                                                    \
879
2
        P->short_name = #name;                                                 \
880
2
        P->descr = des_##name;                                                 \
881
2
        P->need_ellps = NEED_ELLPS;                                            \
882
2
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
2
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
2
        return P;                                                              \
885
2
    }                                                                          \
pj_chamb
Line
Count
Source
873
38
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
38
        if (P)                                                                 \
875
38
            return pj_projection_specific_setup_##name(P);                     \
876
38
        P = pj_new();                                                          \
877
19
        if (nullptr == P)                                                      \
878
19
            return nullptr;                                                    \
879
19
        P->short_name = #name;                                                 \
880
19
        P->descr = des_##name;                                                 \
881
19
        P->need_ellps = NEED_ELLPS;                                            \
882
19
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
19
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
19
        return P;                                                              \
885
19
    }                                                                          \
pj_hammer
Line
Count
Source
873
117
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
117
        if (P)                                                                 \
875
117
            return pj_projection_specific_setup_##name(P);                     \
876
117
        P = pj_new();                                                          \
877
60
        if (nullptr == P)                                                      \
878
60
            return nullptr;                                                    \
879
60
        P->short_name = #name;                                                 \
880
60
        P->descr = des_##name;                                                 \
881
60
        P->need_ellps = NEED_ELLPS;                                            \
882
60
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
60
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
60
        return P;                                                              \
885
60
    }                                                                          \
pj_lagrng
Line
Count
Source
873
85
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
85
        if (P)                                                                 \
875
85
            return pj_projection_specific_setup_##name(P);                     \
876
85
        P = pj_new();                                                          \
877
44
        if (nullptr == P)                                                      \
878
44
            return nullptr;                                                    \
879
44
        P->short_name = #name;                                                 \
880
44
        P->descr = des_##name;                                                 \
881
44
        P->need_ellps = NEED_ELLPS;                                            \
882
44
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
44
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
44
        return P;                                                              \
885
44
    }                                                                          \
pj_larr
Line
Count
Source
873
10
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
10
        if (P)                                                                 \
875
10
            return pj_projection_specific_setup_##name(P);                     \
876
10
        P = pj_new();                                                          \
877
5
        if (nullptr == P)                                                      \
878
5
            return nullptr;                                                    \
879
5
        P->short_name = #name;                                                 \
880
5
        P->descr = des_##name;                                                 \
881
5
        P->need_ellps = NEED_ELLPS;                                            \
882
5
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
5
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
5
        return P;                                                              \
885
5
    }                                                                          \
pj_lask
Line
Count
Source
873
31
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
31
        if (P)                                                                 \
875
31
            return pj_projection_specific_setup_##name(P);                     \
876
31
        P = pj_new();                                                          \
877
16
        if (nullptr == P)                                                      \
878
16
            return nullptr;                                                    \
879
16
        P->short_name = #name;                                                 \
880
16
        P->descr = des_##name;                                                 \
881
16
        P->need_ellps = NEED_ELLPS;                                            \
882
16
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
16
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
16
        return P;                                                              \
885
16
    }                                                                          \
pj_latlong
Line
Count
Source
873
40
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
40
        if (P)                                                                 \
875
40
            return pj_projection_specific_setup_##name(P);                     \
876
40
        P = pj_new();                                                          \
877
20
        if (nullptr == P)                                                      \
878
20
            return nullptr;                                                    \
879
20
        P->short_name = #name;                                                 \
880
20
        P->descr = des_##name;                                                 \
881
20
        P->need_ellps = NEED_ELLPS;                                            \
882
20
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
20
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
20
        return P;                                                              \
885
20
    }                                                                          \
pj_longlat
Line
Count
Source
873
5.37k
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
5.37k
        if (P)                                                                 \
875
5.37k
            return pj_projection_specific_setup_##name(P);                     \
876
5.37k
        P = pj_new();                                                          \
877
2.69k
        if (nullptr == P)                                                      \
878
2.69k
            return nullptr;                                                    \
879
2.69k
        P->short_name = #name;                                                 \
880
2.69k
        P->descr = des_##name;                                                 \
881
2.69k
        P->need_ellps = NEED_ELLPS;                                            \
882
2.69k
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
2.69k
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
2.69k
        return P;                                                              \
885
2.69k
    }                                                                          \
pj_latlon
Line
Count
Source
873
82
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
82
        if (P)                                                                 \
875
82
            return pj_projection_specific_setup_##name(P);                     \
876
82
        P = pj_new();                                                          \
877
41
        if (nullptr == P)                                                      \
878
41
            return nullptr;                                                    \
879
41
        P->short_name = #name;                                                 \
880
41
        P->descr = des_##name;                                                 \
881
41
        P->need_ellps = NEED_ELLPS;                                            \
882
41
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
41
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
41
        return P;                                                              \
885
41
    }                                                                          \
pj_lonlat
Line
Count
Source
873
23.5k
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
23.5k
        if (P)                                                                 \
875
23.5k
            return pj_projection_specific_setup_##name(P);                     \
876
23.5k
        P = pj_new();                                                          \
877
11.8k
        if (nullptr == P)                                                      \
878
11.8k
            return nullptr;                                                    \
879
11.8k
        P->short_name = #name;                                                 \
880
11.8k
        P->descr = des_##name;                                                 \
881
11.8k
        P->need_ellps = NEED_ELLPS;                                            \
882
11.8k
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
11.8k
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
11.8k
        return P;                                                              \
885
11.8k
    }                                                                          \
pj_nicol
Line
Count
Source
873
11
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
11
        if (P)                                                                 \
875
11
            return pj_projection_specific_setup_##name(P);                     \
876
11
        P = pj_new();                                                          \
877
6
        if (nullptr == P)                                                      \
878
6
            return nullptr;                                                    \
879
6
        P->short_name = #name;                                                 \
880
6
        P->descr = des_##name;                                                 \
881
6
        P->need_ellps = NEED_ELLPS;                                            \
882
6
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
6
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
6
        return P;                                                              \
885
6
    }                                                                          \
pj_ob_tran
Line
Count
Source
873
12.8k
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
12.8k
        if (P)                                                                 \
875
12.8k
            return pj_projection_specific_setup_##name(P);                     \
876
12.8k
        P = pj_new();                                                          \
877
6.45k
        if (nullptr == P)                                                      \
878
6.45k
            return nullptr;                                                    \
879
6.45k
        P->short_name = #name;                                                 \
880
6.45k
        P->descr = des_##name;                                                 \
881
6.45k
        P->need_ellps = NEED_ELLPS;                                            \
882
6.45k
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
6.45k
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
6.45k
        return P;                                                              \
885
6.45k
    }                                                                          \
pj_oea
Line
Count
Source
873
22
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
22
        if (P)                                                                 \
875
22
            return pj_projection_specific_setup_##name(P);                     \
876
22
        P = pj_new();                                                          \
877
12
        if (nullptr == P)                                                      \
878
12
            return nullptr;                                                    \
879
12
        P->short_name = #name;                                                 \
880
12
        P->descr = des_##name;                                                 \
881
12
        P->need_ellps = NEED_ELLPS;                                            \
882
12
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
12
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
12
        return P;                                                              \
885
12
    }                                                                          \
pj_tpeqd
Line
Count
Source
873
174
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
174
        if (P)                                                                 \
875
174
            return pj_projection_specific_setup_##name(P);                     \
876
174
        P = pj_new();                                                          \
877
87
        if (nullptr == P)                                                      \
878
87
            return nullptr;                                                    \
879
87
        P->short_name = #name;                                                 \
880
87
        P->descr = des_##name;                                                 \
881
87
        P->need_ellps = NEED_ELLPS;                                            \
882
87
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
87
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
87
        return P;                                                              \
885
87
    }                                                                          \
pj_vandg
Line
Count
Source
873
237
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
237
        if (P)                                                                 \
875
237
            return pj_projection_specific_setup_##name(P);                     \
876
237
        P = pj_new();                                                          \
877
119
        if (nullptr == P)                                                      \
878
119
            return nullptr;                                                    \
879
119
        P->short_name = #name;                                                 \
880
119
        P->descr = des_##name;                                                 \
881
119
        P->need_ellps = NEED_ELLPS;                                            \
882
119
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
119
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
119
        return P;                                                              \
885
119
    }                                                                          \
pj_vandg2
Line
Count
Source
873
188
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
188
        if (P)                                                                 \
875
188
            return pj_projection_specific_setup_##name(P);                     \
876
188
        P = pj_new();                                                          \
877
94
        if (nullptr == P)                                                      \
878
94
            return nullptr;                                                    \
879
94
        P->short_name = #name;                                                 \
880
94
        P->descr = des_##name;                                                 \
881
94
        P->need_ellps = NEED_ELLPS;                                            \
882
94
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
94
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
94
        return P;                                                              \
885
94
    }                                                                          \
pj_vandg3
Line
Count
Source
873
78
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
78
        if (P)                                                                 \
875
78
            return pj_projection_specific_setup_##name(P);                     \
876
78
        P = pj_new();                                                          \
877
39
        if (nullptr == P)                                                      \
878
39
            return nullptr;                                                    \
879
39
        P->short_name = #name;                                                 \
880
39
        P->descr = des_##name;                                                 \
881
39
        P->need_ellps = NEED_ELLPS;                                            \
882
39
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
39
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
39
        return P;                                                              \
885
39
    }                                                                          \
pj_vandg4
Line
Count
Source
873
108
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
108
        if (P)                                                                 \
875
108
            return pj_projection_specific_setup_##name(P);                     \
876
108
        P = pj_new();                                                          \
877
55
        if (nullptr == P)                                                      \
878
55
            return nullptr;                                                    \
879
55
        P->short_name = #name;                                                 \
880
55
        P->descr = des_##name;                                                 \
881
55
        P->need_ellps = NEED_ELLPS;                                            \
882
55
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
55
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
55
        return P;                                                              \
885
55
    }                                                                          \
pj_wag7
Line
Count
Source
873
1.15k
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
1.15k
        if (P)                                                                 \
875
1.15k
            return pj_projection_specific_setup_##name(P);                     \
876
1.15k
        P = pj_new();                                                          \
877
577
        if (nullptr == P)                                                      \
878
577
            return nullptr;                                                    \
879
577
        P->short_name = #name;                                                 \
880
577
        P->descr = des_##name;                                                 \
881
577
        P->need_ellps = NEED_ELLPS;                                            \
882
577
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
577
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
577
        return P;                                                              \
885
577
    }                                                                          \
pj_lcca
Line
Count
Source
873
16
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
16
        if (P)                                                                 \
875
16
            return pj_projection_specific_setup_##name(P);                     \
876
16
        P = pj_new();                                                          \
877
8
        if (nullptr == P)                                                      \
878
8
            return nullptr;                                                    \
879
8
        P->short_name = #name;                                                 \
880
8
        P->descr = des_##name;                                                 \
881
8
        P->need_ellps = NEED_ELLPS;                                            \
882
8
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
8
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
8
        return P;                                                              \
885
8
    }                                                                          \
pj_geos
Line
Count
Source
873
99
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
99
        if (P)                                                                 \
875
99
            return pj_projection_specific_setup_##name(P);                     \
876
99
        P = pj_new();                                                          \
877
50
        if (nullptr == P)                                                      \
878
50
            return nullptr;                                                    \
879
50
        P->short_name = #name;                                                 \
880
50
        P->descr = des_##name;                                                 \
881
50
        P->need_ellps = NEED_ELLPS;                                            \
882
50
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
50
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
50
        return P;                                                              \
885
50
    }                                                                          \
pj_boggs
Line
Count
Source
873
25
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
25
        if (P)                                                                 \
875
25
            return pj_projection_specific_setup_##name(P);                     \
876
25
        P = pj_new();                                                          \
877
13
        if (nullptr == P)                                                      \
878
13
            return nullptr;                                                    \
879
13
        P->short_name = #name;                                                 \
880
13
        P->descr = des_##name;                                                 \
881
13
        P->need_ellps = NEED_ELLPS;                                            \
882
13
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
13
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
13
        return P;                                                              \
885
13
    }                                                                          \
pj_collg
Line
Count
Source
873
8
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
8
        if (P)                                                                 \
875
8
            return pj_projection_specific_setup_##name(P);                     \
876
8
        P = pj_new();                                                          \
877
4
        if (nullptr == P)                                                      \
878
4
            return nullptr;                                                    \
879
4
        P->short_name = #name;                                                 \
880
4
        P->descr = des_##name;                                                 \
881
4
        P->need_ellps = NEED_ELLPS;                                            \
882
4
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
4
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
4
        return P;                                                              \
885
4
    }                                                                          \
pj_comill
Line
Count
Source
873
60
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
60
        if (P)                                                                 \
875
60
            return pj_projection_specific_setup_##name(P);                     \
876
60
        P = pj_new();                                                          \
877
32
        if (nullptr == P)                                                      \
878
32
            return nullptr;                                                    \
879
32
        P->short_name = #name;                                                 \
880
32
        P->descr = des_##name;                                                 \
881
32
        P->need_ellps = NEED_ELLPS;                                            \
882
32
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
32
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
32
        return P;                                                              \
885
32
    }                                                                          \
pj_crast
Line
Count
Source
873
146
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
146
        if (P)                                                                 \
875
146
            return pj_projection_specific_setup_##name(P);                     \
876
146
        P = pj_new();                                                          \
877
73
        if (nullptr == P)                                                      \
878
73
            return nullptr;                                                    \
879
73
        P->short_name = #name;                                                 \
880
73
        P->descr = des_##name;                                                 \
881
73
        P->need_ellps = NEED_ELLPS;                                            \
882
73
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
73
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
73
        return P;                                                              \
885
73
    }                                                                          \
pj_denoy
Line
Count
Source
873
222
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
222
        if (P)                                                                 \
875
222
            return pj_projection_specific_setup_##name(P);                     \
876
222
        P = pj_new();                                                          \
877
111
        if (nullptr == P)                                                      \
878
111
            return nullptr;                                                    \
879
111
        P->short_name = #name;                                                 \
880
111
        P->descr = des_##name;                                                 \
881
111
        P->need_ellps = NEED_ELLPS;                                            \
882
111
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
111
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
111
        return P;                                                              \
885
111
    }                                                                          \
pj_eck1
Line
Count
Source
873
739
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
739
        if (P)                                                                 \
875
739
            return pj_projection_specific_setup_##name(P);                     \
876
739
        P = pj_new();                                                          \
877
370
        if (nullptr == P)                                                      \
878
370
            return nullptr;                                                    \
879
370
        P->short_name = #name;                                                 \
880
370
        P->descr = des_##name;                                                 \
881
370
        P->need_ellps = NEED_ELLPS;                                            \
882
370
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
370
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
370
        return P;                                                              \
885
370
    }                                                                          \
pj_eck2
Line
Count
Source
873
145
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
145
        if (P)                                                                 \
875
145
            return pj_projection_specific_setup_##name(P);                     \
876
145
        P = pj_new();                                                          \
877
73
        if (nullptr == P)                                                      \
878
73
            return nullptr;                                                    \
879
73
        P->short_name = #name;                                                 \
880
73
        P->descr = des_##name;                                                 \
881
73
        P->need_ellps = NEED_ELLPS;                                            \
882
73
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
73
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
73
        return P;                                                              \
885
73
    }                                                                          \
pj_eck3
Line
Count
Source
873
97
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
97
        if (P)                                                                 \
875
97
            return pj_projection_specific_setup_##name(P);                     \
876
97
        P = pj_new();                                                          \
877
49
        if (nullptr == P)                                                      \
878
49
            return nullptr;                                                    \
879
49
        P->short_name = #name;                                                 \
880
49
        P->descr = des_##name;                                                 \
881
49
        P->need_ellps = NEED_ELLPS;                                            \
882
49
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
49
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
49
        return P;                                                              \
885
49
    }                                                                          \
pj_kav7
Line
Count
Source
873
94
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
94
        if (P)                                                                 \
875
94
            return pj_projection_specific_setup_##name(P);                     \
876
94
        P = pj_new();                                                          \
877
47
        if (nullptr == P)                                                      \
878
47
            return nullptr;                                                    \
879
47
        P->short_name = #name;                                                 \
880
47
        P->descr = des_##name;                                                 \
881
47
        P->need_ellps = NEED_ELLPS;                                            \
882
47
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
47
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
47
        return P;                                                              \
885
47
    }                                                                          \
pj_wag6
Line
Count
Source
873
970
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
970
        if (P)                                                                 \
875
970
            return pj_projection_specific_setup_##name(P);                     \
876
970
        P = pj_new();                                                          \
877
485
        if (nullptr == P)                                                      \
878
485
            return nullptr;                                                    \
879
485
        P->short_name = #name;                                                 \
880
485
        P->descr = des_##name;                                                 \
881
485
        P->need_ellps = NEED_ELLPS;                                            \
882
485
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
485
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
485
        return P;                                                              \
885
485
    }                                                                          \
pj_putp1
Line
Count
Source
873
17
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
17
        if (P)                                                                 \
875
17
            return pj_projection_specific_setup_##name(P);                     \
876
17
        P = pj_new();                                                          \
877
10
        if (nullptr == P)                                                      \
878
10
            return nullptr;                                                    \
879
10
        P->short_name = #name;                                                 \
880
10
        P->descr = des_##name;                                                 \
881
10
        P->need_ellps = NEED_ELLPS;                                            \
882
10
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
10
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
10
        return P;                                                              \
885
10
    }                                                                          \
pj_eck4
Line
Count
Source
873
875
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
875
        if (P)                                                                 \
875
875
            return pj_projection_specific_setup_##name(P);                     \
876
875
        P = pj_new();                                                          \
877
441
        if (nullptr == P)                                                      \
878
441
            return nullptr;                                                    \
879
441
        P->short_name = #name;                                                 \
880
441
        P->descr = des_##name;                                                 \
881
441
        P->need_ellps = NEED_ELLPS;                                            \
882
441
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
441
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
441
        return P;                                                              \
885
441
    }                                                                          \
pj_eck5
Line
Count
Source
873
839
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
839
        if (P)                                                                 \
875
839
            return pj_projection_specific_setup_##name(P);                     \
876
839
        P = pj_new();                                                          \
877
420
        if (nullptr == P)                                                      \
878
420
            return nullptr;                                                    \
879
420
        P->short_name = #name;                                                 \
880
420
        P->descr = des_##name;                                                 \
881
420
        P->need_ellps = NEED_ELLPS;                                            \
882
420
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
420
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
420
        return P;                                                              \
885
420
    }                                                                          \
pj_fahey
Line
Count
Source
873
8
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
8
        if (P)                                                                 \
875
8
            return pj_projection_specific_setup_##name(P);                     \
876
8
        P = pj_new();                                                          \
877
4
        if (nullptr == P)                                                      \
878
4
            return nullptr;                                                    \
879
4
        P->short_name = #name;                                                 \
880
4
        P->descr = des_##name;                                                 \
881
4
        P->need_ellps = NEED_ELLPS;                                            \
882
4
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
4
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
4
        return P;                                                              \
885
4
    }                                                                          \
pj_fouc_s
Line
Count
Source
873
132
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
132
        if (P)                                                                 \
875
132
            return pj_projection_specific_setup_##name(P);                     \
876
132
        P = pj_new();                                                          \
877
66
        if (nullptr == P)                                                      \
878
66
            return nullptr;                                                    \
879
66
        P->short_name = #name;                                                 \
880
66
        P->descr = des_##name;                                                 \
881
66
        P->need_ellps = NEED_ELLPS;                                            \
882
66
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
66
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
66
        return P;                                                              \
885
66
    }                                                                          \
pj_gins8
Line
Count
Source
873
20
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
20
        if (P)                                                                 \
875
20
            return pj_projection_specific_setup_##name(P);                     \
876
20
        P = pj_new();                                                          \
877
10
        if (nullptr == P)                                                      \
878
10
            return nullptr;                                                    \
879
10
        P->short_name = #name;                                                 \
880
10
        P->descr = des_##name;                                                 \
881
10
        P->need_ellps = NEED_ELLPS;                                            \
882
10
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
10
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
10
        return P;                                                              \
885
10
    }                                                                          \
pj_gstmerc
Line
Count
Source
873
150
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
150
        if (P)                                                                 \
875
150
            return pj_projection_specific_setup_##name(P);                     \
876
150
        P = pj_new();                                                          \
877
75
        if (nullptr == P)                                                      \
878
75
            return nullptr;                                                    \
879
75
        P->short_name = #name;                                                 \
880
75
        P->descr = des_##name;                                                 \
881
75
        P->need_ellps = NEED_ELLPS;                                            \
882
75
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
75
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
75
        return P;                                                              \
885
75
    }                                                                          \
pj_sinu
Line
Count
Source
873
1.63k
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
1.63k
        if (P)                                                                 \
875
1.63k
            return pj_projection_specific_setup_##name(P);                     \
876
1.63k
        P = pj_new();                                                          \
877
817
        if (nullptr == P)                                                      \
878
817
            return nullptr;                                                    \
879
817
        P->short_name = #name;                                                 \
880
817
        P->descr = des_##name;                                                 \
881
817
        P->need_ellps = NEED_ELLPS;                                            \
882
817
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
817
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
817
        return P;                                                              \
885
817
    }                                                                          \
pj_eck6
Line
Count
Source
873
64
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
64
        if (P)                                                                 \
875
64
            return pj_projection_specific_setup_##name(P);                     \
876
64
        P = pj_new();                                                          \
877
33
        if (nullptr == P)                                                      \
878
33
            return nullptr;                                                    \
879
33
        P->short_name = #name;                                                 \
880
33
        P->descr = des_##name;                                                 \
881
33
        P->need_ellps = NEED_ELLPS;                                            \
882
33
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
33
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
33
        return P;                                                              \
885
33
    }                                                                          \
pj_mbtfps
Line
Count
Source
873
4
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
4
        if (P)                                                                 \
875
4
            return pj_projection_specific_setup_##name(P);                     \
876
4
        P = pj_new();                                                          \
877
2
        if (nullptr == P)                                                      \
878
2
            return nullptr;                                                    \
879
2
        P->short_name = #name;                                                 \
880
2
        P->descr = des_##name;                                                 \
881
2
        P->need_ellps = NEED_ELLPS;                                            \
882
2
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
2
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
2
        return P;                                                              \
885
2
    }                                                                          \
pj_gn_sinu
Line
Count
Source
873
10
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
10
        if (P)                                                                 \
875
10
            return pj_projection_specific_setup_##name(P);                     \
876
10
        P = pj_new();                                                          \
877
6
        if (nullptr == P)                                                      \
878
6
            return nullptr;                                                    \
879
6
        P->short_name = #name;                                                 \
880
6
        P->descr = des_##name;                                                 \
881
6
        P->need_ellps = NEED_ELLPS;                                            \
882
6
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
6
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
6
        return P;                                                              \
885
6
    }                                                                          \
pj_goode
Line
Count
Source
873
8
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
8
        if (P)                                                                 \
875
8
            return pj_projection_specific_setup_##name(P);                     \
876
8
        P = pj_new();                                                          \
877
4
        if (nullptr == P)                                                      \
878
4
            return nullptr;                                                    \
879
4
        P->short_name = #name;                                                 \
880
4
        P->descr = des_##name;                                                 \
881
4
        P->need_ellps = NEED_ELLPS;                                            \
882
4
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
4
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
4
        return P;                                                              \
885
4
    }                                                                          \
pj_igh
Line
Count
Source
873
125
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
125
        if (P)                                                                 \
875
125
            return pj_projection_specific_setup_##name(P);                     \
876
125
        P = pj_new();                                                          \
877
63
        if (nullptr == P)                                                      \
878
63
            return nullptr;                                                    \
879
63
        P->short_name = #name;                                                 \
880
63
        P->descr = des_##name;                                                 \
881
63
        P->need_ellps = NEED_ELLPS;                                            \
882
63
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
63
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
63
        return P;                                                              \
885
63
    }                                                                          \
pj_igh_o
Line
Count
Source
873
147
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
147
        if (P)                                                                 \
875
147
            return pj_projection_specific_setup_##name(P);                     \
876
147
        P = pj_new();                                                          \
877
74
        if (nullptr == P)                                                      \
878
74
            return nullptr;                                                    \
879
74
        P->short_name = #name;                                                 \
880
74
        P->descr = des_##name;                                                 \
881
74
        P->need_ellps = NEED_ELLPS;                                            \
882
74
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
74
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
74
        return P;                                                              \
885
74
    }                                                                          \
pj_imoll
Line
Count
Source
873
143
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
143
        if (P)                                                                 \
875
143
            return pj_projection_specific_setup_##name(P);                     \
876
143
        P = pj_new();                                                          \
877
72
        if (nullptr == P)                                                      \
878
72
            return nullptr;                                                    \
879
72
        P->short_name = #name;                                                 \
880
72
        P->descr = des_##name;                                                 \
881
72
        P->need_ellps = NEED_ELLPS;                                            \
882
72
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
72
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
72
        return P;                                                              \
885
72
    }                                                                          \
pj_imoll_o
Line
Count
Source
873
14
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
14
        if (P)                                                                 \
875
14
            return pj_projection_specific_setup_##name(P);                     \
876
14
        P = pj_new();                                                          \
877
7
        if (nullptr == P)                                                      \
878
7
            return nullptr;                                                    \
879
7
        P->short_name = #name;                                                 \
880
7
        P->descr = des_##name;                                                 \
881
7
        P->need_ellps = NEED_ELLPS;                                            \
882
7
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
7
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
7
        return P;                                                              \
885
7
    }                                                                          \
pj_hatano
Line
Count
Source
873
5
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
5
        if (P)                                                                 \
875
5
            return pj_projection_specific_setup_##name(P);                     \
876
5
        P = pj_new();                                                          \
877
3
        if (nullptr == P)                                                      \
878
3
            return nullptr;                                                    \
879
3
        P->short_name = #name;                                                 \
880
3
        P->descr = des_##name;                                                 \
881
3
        P->need_ellps = NEED_ELLPS;                                            \
882
3
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
3
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
3
        return P;                                                              \
885
3
    }                                                                          \
pj_loxim
Line
Count
Source
873
43
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
43
        if (P)                                                                 \
875
43
            return pj_projection_specific_setup_##name(P);                     \
876
43
        P = pj_new();                                                          \
877
22
        if (nullptr == P)                                                      \
878
22
            return nullptr;                                                    \
879
22
        P->short_name = #name;                                                 \
880
22
        P->descr = des_##name;                                                 \
881
22
        P->need_ellps = NEED_ELLPS;                                            \
882
22
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
22
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
22
        return P;                                                              \
885
22
    }                                                                          \
pj_mbt_fps
Line
Count
Source
873
6
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
6
        if (P)                                                                 \
875
6
            return pj_projection_specific_setup_##name(P);                     \
876
6
        P = pj_new();                                                          \
877
3
        if (nullptr == P)                                                      \
878
3
            return nullptr;                                                    \
879
3
        P->short_name = #name;                                                 \
880
3
        P->descr = des_##name;                                                 \
881
3
        P->need_ellps = NEED_ELLPS;                                            \
882
3
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
3
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
3
        return P;                                                              \
885
3
    }                                                                          \
pj_mbtfpp
Line
Count
Source
873
4
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
4
        if (P)                                                                 \
875
4
            return pj_projection_specific_setup_##name(P);                     \
876
4
        P = pj_new();                                                          \
877
2
        if (nullptr == P)                                                      \
878
2
            return nullptr;                                                    \
879
2
        P->short_name = #name;                                                 \
880
2
        P->descr = des_##name;                                                 \
881
2
        P->need_ellps = NEED_ELLPS;                                            \
882
2
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
2
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
2
        return P;                                                              \
885
2
    }                                                                          \
pj_mbtfpq
Line
Count
Source
873
4
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
4
        if (P)                                                                 \
875
4
            return pj_projection_specific_setup_##name(P);                     \
876
4
        P = pj_new();                                                          \
877
2
        if (nullptr == P)                                                      \
878
2
            return nullptr;                                                    \
879
2
        P->short_name = #name;                                                 \
880
2
        P->descr = des_##name;                                                 \
881
2
        P->need_ellps = NEED_ELLPS;                                            \
882
2
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
2
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
2
        return P;                                                              \
885
2
    }                                                                          \
pj_moll
Line
Count
Source
873
2.56k
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
2.56k
        if (P)                                                                 \
875
2.56k
            return pj_projection_specific_setup_##name(P);                     \
876
2.56k
        P = pj_new();                                                          \
877
1.28k
        if (nullptr == P)                                                      \
878
1.28k
            return nullptr;                                                    \
879
1.28k
        P->short_name = #name;                                                 \
880
1.28k
        P->descr = des_##name;                                                 \
881
1.28k
        P->need_ellps = NEED_ELLPS;                                            \
882
1.28k
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
1.28k
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
1.28k
        return P;                                                              \
885
1.28k
    }                                                                          \
pj_wag4
Line
Count
Source
873
193
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
193
        if (P)                                                                 \
875
193
            return pj_projection_specific_setup_##name(P);                     \
876
193
        P = pj_new();                                                          \
877
97
        if (nullptr == P)                                                      \
878
97
            return nullptr;                                                    \
879
97
        P->short_name = #name;                                                 \
880
97
        P->descr = des_##name;                                                 \
881
97
        P->need_ellps = NEED_ELLPS;                                            \
882
97
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
97
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
97
        return P;                                                              \
885
97
    }                                                                          \
pj_wag5
Line
Count
Source
873
103
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
103
        if (P)                                                                 \
875
103
            return pj_projection_specific_setup_##name(P);                     \
876
103
        P = pj_new();                                                          \
877
52
        if (nullptr == P)                                                      \
878
52
            return nullptr;                                                    \
879
52
        P->short_name = #name;                                                 \
880
52
        P->descr = des_##name;                                                 \
881
52
        P->need_ellps = NEED_ELLPS;                                            \
882
52
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
52
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
52
        return P;                                                              \
885
52
    }                                                                          \
pj_nell
Line
Count
Source
873
150
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
150
        if (P)                                                                 \
875
150
            return pj_projection_specific_setup_##name(P);                     \
876
150
        P = pj_new();                                                          \
877
75
        if (nullptr == P)                                                      \
878
75
            return nullptr;                                                    \
879
75
        P->short_name = #name;                                                 \
880
75
        P->descr = des_##name;                                                 \
881
75
        P->need_ellps = NEED_ELLPS;                                            \
882
75
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
75
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
75
        return P;                                                              \
885
75
    }                                                                          \
pj_nell_h
Line
Count
Source
873
14
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
14
        if (P)                                                                 \
875
14
            return pj_projection_specific_setup_##name(P);                     \
876
14
        P = pj_new();                                                          \
877
7
        if (nullptr == P)                                                      \
878
7
            return nullptr;                                                    \
879
7
        P->short_name = #name;                                                 \
880
7
        P->descr = des_##name;                                                 \
881
7
        P->need_ellps = NEED_ELLPS;                                            \
882
7
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
7
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
7
        return P;                                                              \
885
7
    }                                                                          \
pj_patterson
Line
Count
Source
873
13
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
13
        if (P)                                                                 \
875
13
            return pj_projection_specific_setup_##name(P);                     \
876
13
        P = pj_new();                                                          \
877
7
        if (nullptr == P)                                                      \
878
7
            return nullptr;                                                    \
879
7
        P->short_name = #name;                                                 \
880
7
        P->descr = des_##name;                                                 \
881
7
        P->need_ellps = NEED_ELLPS;                                            \
882
7
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
7
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
7
        return P;                                                              \
885
7
    }                                                                          \
pj_putp2
Line
Count
Source
873
40
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
40
        if (P)                                                                 \
875
40
            return pj_projection_specific_setup_##name(P);                     \
876
40
        P = pj_new();                                                          \
877
21
        if (nullptr == P)                                                      \
878
21
            return nullptr;                                                    \
879
21
        P->short_name = #name;                                                 \
880
21
        P->descr = des_##name;                                                 \
881
21
        P->need_ellps = NEED_ELLPS;                                            \
882
21
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
21
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
21
        return P;                                                              \
885
21
    }                                                                          \
pj_putp3
Line
Count
Source
873
36
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
36
        if (P)                                                                 \
875
36
            return pj_projection_specific_setup_##name(P);                     \
876
36
        P = pj_new();                                                          \
877
19
        if (nullptr == P)                                                      \
878
19
            return nullptr;                                                    \
879
19
        P->short_name = #name;                                                 \
880
19
        P->descr = des_##name;                                                 \
881
19
        P->need_ellps = NEED_ELLPS;                                            \
882
19
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
19
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
19
        return P;                                                              \
885
19
    }                                                                          \
pj_putp3p
Line
Count
Source
873
87
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
87
        if (P)                                                                 \
875
87
            return pj_projection_specific_setup_##name(P);                     \
876
87
        P = pj_new();                                                          \
877
45
        if (nullptr == P)                                                      \
878
45
            return nullptr;                                                    \
879
45
        P->short_name = #name;                                                 \
880
45
        P->descr = des_##name;                                                 \
881
45
        P->need_ellps = NEED_ELLPS;                                            \
882
45
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
45
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
45
        return P;                                                              \
885
45
    }                                                                          \
pj_putp4p
Line
Count
Source
873
19
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
19
        if (P)                                                                 \
875
19
            return pj_projection_specific_setup_##name(P);                     \
876
19
        P = pj_new();                                                          \
877
10
        if (nullptr == P)                                                      \
878
10
            return nullptr;                                                    \
879
10
        P->short_name = #name;                                                 \
880
10
        P->descr = des_##name;                                                 \
881
10
        P->need_ellps = NEED_ELLPS;                                            \
882
10
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
10
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
10
        return P;                                                              \
885
10
    }                                                                          \
pj_weren
Line
Count
Source
873
37
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
37
        if (P)                                                                 \
875
37
            return pj_projection_specific_setup_##name(P);                     \
876
37
        P = pj_new();                                                          \
877
20
        if (nullptr == P)                                                      \
878
20
            return nullptr;                                                    \
879
20
        P->short_name = #name;                                                 \
880
20
        P->descr = des_##name;                                                 \
881
20
        P->need_ellps = NEED_ELLPS;                                            \
882
20
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
20
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
20
        return P;                                                              \
885
20
    }                                                                          \
pj_putp5
Line
Count
Source
873
31
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
31
        if (P)                                                                 \
875
31
            return pj_projection_specific_setup_##name(P);                     \
876
31
        P = pj_new();                                                          \
877
16
        if (nullptr == P)                                                      \
878
16
            return nullptr;                                                    \
879
16
        P->short_name = #name;                                                 \
880
16
        P->descr = des_##name;                                                 \
881
16
        P->need_ellps = NEED_ELLPS;                                            \
882
16
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
16
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
16
        return P;                                                              \
885
16
    }                                                                          \
pj_putp5p
Line
Count
Source
873
143
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
143
        if (P)                                                                 \
875
143
            return pj_projection_specific_setup_##name(P);                     \
876
143
        P = pj_new();                                                          \
877
72
        if (nullptr == P)                                                      \
878
72
            return nullptr;                                                    \
879
72
        P->short_name = #name;                                                 \
880
72
        P->descr = des_##name;                                                 \
881
72
        P->need_ellps = NEED_ELLPS;                                            \
882
72
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
72
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
72
        return P;                                                              \
885
72
    }                                                                          \
pj_putp6
Line
Count
Source
873
27
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
27
        if (P)                                                                 \
875
27
            return pj_projection_specific_setup_##name(P);                     \
876
27
        P = pj_new();                                                          \
877
14
        if (nullptr == P)                                                      \
878
14
            return nullptr;                                                    \
879
14
        P->short_name = #name;                                                 \
880
14
        P->descr = des_##name;                                                 \
881
14
        P->need_ellps = NEED_ELLPS;                                            \
882
14
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
14
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
14
        return P;                                                              \
885
14
    }                                                                          \
pj_putp6p
Line
Count
Source
873
702
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
702
        if (P)                                                                 \
875
702
            return pj_projection_specific_setup_##name(P);                     \
876
702
        P = pj_new();                                                          \
877
351
        if (nullptr == P)                                                      \
878
351
            return nullptr;                                                    \
879
351
        P->short_name = #name;                                                 \
880
351
        P->descr = des_##name;                                                 \
881
351
        P->need_ellps = NEED_ELLPS;                                            \
882
351
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
351
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
351
        return P;                                                              \
885
351
    }                                                                          \
pj_qsc
Line
Count
Source
873
3.31k
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
3.31k
        if (P)                                                                 \
875
3.31k
            return pj_projection_specific_setup_##name(P);                     \
876
3.31k
        P = pj_new();                                                          \
877
1.65k
        if (nullptr == P)                                                      \
878
1.65k
            return nullptr;                                                    \
879
1.65k
        P->short_name = #name;                                                 \
880
1.65k
        P->descr = des_##name;                                                 \
881
1.65k
        P->need_ellps = NEED_ELLPS;                                            \
882
1.65k
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
1.65k
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
1.65k
        return P;                                                              \
885
1.65k
    }                                                                          \
pj_robin
Line
Count
Source
873
32
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
32
        if (P)                                                                 \
875
32
            return pj_projection_specific_setup_##name(P);                     \
876
32
        P = pj_new();                                                          \
877
16
        if (nullptr == P)                                                      \
878
16
            return nullptr;                                                    \
879
16
        P->short_name = #name;                                                 \
880
16
        P->descr = des_##name;                                                 \
881
16
        P->need_ellps = NEED_ELLPS;                                            \
882
16
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
16
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
16
        return P;                                                              \
885
16
    }                                                                          \
pj_s2
Line
Count
Source
873
1.58k
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
1.58k
        if (P)                                                                 \
875
1.58k
            return pj_projection_specific_setup_##name(P);                     \
876
1.58k
        P = pj_new();                                                          \
877
793
        if (nullptr == P)                                                      \
878
793
            return nullptr;                                                    \
879
793
        P->short_name = #name;                                                 \
880
793
        P->descr = des_##name;                                                 \
881
793
        P->need_ellps = NEED_ELLPS;                                            \
882
793
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
793
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
793
        return P;                                                              \
885
793
    }                                                                          \
Unexecuted instantiation: pj_sch
pj_fouc
Line
Count
Source
873
42
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
42
        if (P)                                                                 \
875
42
            return pj_projection_specific_setup_##name(P);                     \
876
42
        P = pj_new();                                                          \
877
23
        if (nullptr == P)                                                      \
878
23
            return nullptr;                                                    \
879
23
        P->short_name = #name;                                                 \
880
23
        P->descr = des_##name;                                                 \
881
23
        P->need_ellps = NEED_ELLPS;                                            \
882
23
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
23
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
23
        return P;                                                              \
885
23
    }                                                                          \
pj_kav5
Line
Count
Source
873
14
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
14
        if (P)                                                                 \
875
14
            return pj_projection_specific_setup_##name(P);                     \
876
14
        P = pj_new();                                                          \
877
8
        if (nullptr == P)                                                      \
878
8
            return nullptr;                                                    \
879
8
        P->short_name = #name;                                                 \
880
8
        P->descr = des_##name;                                                 \
881
8
        P->need_ellps = NEED_ELLPS;                                            \
882
8
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
8
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
8
        return P;                                                              \
885
8
    }                                                                          \
pj_qua_aut
Line
Count
Source
873
97
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
97
        if (P)                                                                 \
875
97
            return pj_projection_specific_setup_##name(P);                     \
876
97
        P = pj_new();                                                          \
877
49
        if (nullptr == P)                                                      \
878
49
            return nullptr;                                                    \
879
49
        P->short_name = #name;                                                 \
880
49
        P->descr = des_##name;                                                 \
881
49
        P->need_ellps = NEED_ELLPS;                                            \
882
49
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
49
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
49
        return P;                                                              \
885
49
    }                                                                          \
pj_mbt_s
Line
Count
Source
873
13
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
13
        if (P)                                                                 \
875
13
            return pj_projection_specific_setup_##name(P);                     \
876
13
        P = pj_new();                                                          \
877
7
        if (nullptr == P)                                                      \
878
7
            return nullptr;                                                    \
879
7
        P->short_name = #name;                                                 \
880
7
        P->descr = des_##name;                                                 \
881
7
        P->need_ellps = NEED_ELLPS;                                            \
882
7
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
7
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
7
        return P;                                                              \
885
7
    }                                                                          \
pj_urm5
Line
Count
Source
873
18
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
18
        if (P)                                                                 \
875
18
            return pj_projection_specific_setup_##name(P);                     \
876
18
        P = pj_new();                                                          \
877
9
        if (nullptr == P)                                                      \
878
9
            return nullptr;                                                    \
879
9
        P->short_name = #name;                                                 \
880
9
        P->descr = des_##name;                                                 \
881
9
        P->need_ellps = NEED_ELLPS;                                            \
882
9
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
9
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
9
        return P;                                                              \
885
9
    }                                                                          \
pj_urmfps
Line
Count
Source
873
7
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
7
        if (P)                                                                 \
875
7
            return pj_projection_specific_setup_##name(P);                     \
876
7
        P = pj_new();                                                          \
877
4
        if (nullptr == P)                                                      \
878
4
            return nullptr;                                                    \
879
4
        P->short_name = #name;                                                 \
880
4
        P->descr = des_##name;                                                 \
881
4
        P->need_ellps = NEED_ELLPS;                                            \
882
4
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
4
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
4
        return P;                                                              \
885
4
    }                                                                          \
pj_wag1
Line
Count
Source
873
234
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
234
        if (P)                                                                 \
875
234
            return pj_projection_specific_setup_##name(P);                     \
876
234
        P = pj_new();                                                          \
877
117
        if (nullptr == P)                                                      \
878
117
            return nullptr;                                                    \
879
117
        P->short_name = #name;                                                 \
880
117
        P->descr = des_##name;                                                 \
881
117
        P->need_ellps = NEED_ELLPS;                                            \
882
117
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
117
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
117
        return P;                                                              \
885
117
    }                                                                          \
pj_wag2
Line
Count
Source
873
129
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
129
        if (P)                                                                 \
875
129
            return pj_projection_specific_setup_##name(P);                     \
876
129
        P = pj_new();                                                          \
877
65
        if (nullptr == P)                                                      \
878
65
            return nullptr;                                                    \
879
65
        P->short_name = #name;                                                 \
880
65
        P->descr = des_##name;                                                 \
881
65
        P->need_ellps = NEED_ELLPS;                                            \
882
65
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
65
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
65
        return P;                                                              \
885
65
    }                                                                          \
pj_wag3
Line
Count
Source
873
2.32k
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
2.32k
        if (P)                                                                 \
875
2.32k
            return pj_projection_specific_setup_##name(P);                     \
876
2.32k
        P = pj_new();                                                          \
877
1.16k
        if (nullptr == P)                                                      \
878
1.16k
            return nullptr;                                                    \
879
1.16k
        P->short_name = #name;                                                 \
880
1.16k
        P->descr = des_##name;                                                 \
881
1.16k
        P->need_ellps = NEED_ELLPS;                                            \
882
1.16k
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
1.16k
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
1.16k
        return P;                                                              \
885
1.16k
    }                                                                          \
pj_wink1
Line
Count
Source
873
42
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
42
        if (P)                                                                 \
875
42
            return pj_projection_specific_setup_##name(P);                     \
876
42
        P = pj_new();                                                          \
877
21
        if (nullptr == P)                                                      \
878
21
            return nullptr;                                                    \
879
21
        P->short_name = #name;                                                 \
880
21
        P->descr = des_##name;                                                 \
881
21
        P->need_ellps = NEED_ELLPS;                                            \
882
21
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
21
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
21
        return P;                                                              \
885
21
    }                                                                          \
pj_wink2
Line
Count
Source
873
93
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
93
        if (P)                                                                 \
875
93
            return pj_projection_specific_setup_##name(P);                     \
876
93
        P = pj_new();                                                          \
877
47
        if (nullptr == P)                                                      \
878
47
            return nullptr;                                                    \
879
47
        P->short_name = #name;                                                 \
880
47
        P->descr = des_##name;                                                 \
881
47
        P->need_ellps = NEED_ELLPS;                                            \
882
47
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
47
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
47
        return P;                                                              \
885
47
    }                                                                          \
pj_healpix
Line
Count
Source
873
18
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
18
        if (P)                                                                 \
875
18
            return pj_projection_specific_setup_##name(P);                     \
876
18
        P = pj_new();                                                          \
877
9
        if (nullptr == P)                                                      \
878
9
            return nullptr;                                                    \
879
9
        P->short_name = #name;                                                 \
880
9
        P->descr = des_##name;                                                 \
881
9
        P->need_ellps = NEED_ELLPS;                                            \
882
9
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
9
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
9
        return P;                                                              \
885
9
    }                                                                          \
pj_rhealpix
Line
Count
Source
873
6
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
6
        if (P)                                                                 \
875
6
            return pj_projection_specific_setup_##name(P);                     \
876
6
        P = pj_new();                                                          \
877
3
        if (nullptr == P)                                                      \
878
3
            return nullptr;                                                    \
879
3
        P->short_name = #name;                                                 \
880
3
        P->descr = des_##name;                                                 \
881
3
        P->need_ellps = NEED_ELLPS;                                            \
882
3
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
3
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
3
        return P;                                                              \
885
3
    }                                                                          \
pj_natearth
Line
Count
Source
873
29
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
29
        if (P)                                                                 \
875
29
            return pj_projection_specific_setup_##name(P);                     \
876
29
        P = pj_new();                                                          \
877
15
        if (nullptr == P)                                                      \
878
15
            return nullptr;                                                    \
879
15
        P->short_name = #name;                                                 \
880
15
        P->descr = des_##name;                                                 \
881
15
        P->need_ellps = NEED_ELLPS;                                            \
882
15
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
15
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
15
        return P;                                                              \
885
15
    }                                                                          \
pj_natearth2
Line
Count
Source
873
295
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
295
        if (P)                                                                 \
875
295
            return pj_projection_specific_setup_##name(P);                     \
876
295
        P = pj_new();                                                          \
877
148
        if (nullptr == P)                                                      \
878
148
            return nullptr;                                                    \
879
148
        P->short_name = #name;                                                 \
880
148
        P->descr = des_##name;                                                 \
881
148
        P->need_ellps = NEED_ELLPS;                                            \
882
148
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
148
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
148
        return P;                                                              \
885
148
    }                                                                          \
pj_calcofi
Line
Count
Source
873
35
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
35
        if (P)                                                                 \
875
35
            return pj_projection_specific_setup_##name(P);                     \
876
35
        P = pj_new();                                                          \
877
18
        if (nullptr == P)                                                      \
878
18
            return nullptr;                                                    \
879
18
        P->short_name = #name;                                                 \
880
18
        P->descr = des_##name;                                                 \
881
18
        P->need_ellps = NEED_ELLPS;                                            \
882
18
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
18
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
18
        return P;                                                              \
885
18
    }                                                                          \
pj_eqearth
Line
Count
Source
873
64
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
64
        if (P)                                                                 \
875
64
            return pj_projection_specific_setup_##name(P);                     \
876
64
        P = pj_new();                                                          \
877
33
        if (nullptr == P)                                                      \
878
33
            return nullptr;                                                    \
879
33
        P->short_name = #name;                                                 \
880
33
        P->descr = des_##name;                                                 \
881
33
        P->need_ellps = NEED_ELLPS;                                            \
882
33
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
33
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
33
        return P;                                                              \
885
33
    }                                                                          \
pj_col_urban
Line
Count
Source
873
68
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
68
        if (P)                                                                 \
875
68
            return pj_projection_specific_setup_##name(P);                     \
876
68
        P = pj_new();                                                          \
877
34
        if (nullptr == P)                                                      \
878
34
            return nullptr;                                                    \
879
34
        P->short_name = #name;                                                 \
880
34
        P->descr = des_##name;                                                 \
881
34
        P->need_ellps = NEED_ELLPS;                                            \
882
34
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
34
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
34
        return P;                                                              \
885
34
    }                                                                          \
pj_spilhaus
Line
Count
Source
873
6
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
6
        if (P)                                                                 \
875
6
            return pj_projection_specific_setup_##name(P);                     \
876
6
        P = pj_new();                                                          \
877
3
        if (nullptr == P)                                                      \
878
3
            return nullptr;                                                    \
879
3
        P->short_name = #name;                                                 \
880
3
        P->descr = des_##name;                                                 \
881
3
        P->need_ellps = NEED_ELLPS;                                            \
882
3
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
3
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
3
        return P;                                                              \
885
3
    }                                                                          \
pj_affine
Line
Count
Source
873
178
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
178
        if (P)                                                                 \
875
178
            return pj_projection_specific_setup_##name(P);                     \
876
178
        P = pj_new();                                                          \
877
89
        if (nullptr == P)                                                      \
878
89
            return nullptr;                                                    \
879
89
        P->short_name = #name;                                                 \
880
89
        P->descr = des_##name;                                                 \
881
89
        P->need_ellps = NEED_ELLPS;                                            \
882
89
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
89
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
89
        return P;                                                              \
885
89
    }                                                                          \
pj_geogoffset
Line
Count
Source
873
284
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
284
        if (P)                                                                 \
875
284
            return pj_projection_specific_setup_##name(P);                     \
876
284
        P = pj_new();                                                          \
877
142
        if (nullptr == P)                                                      \
878
142
            return nullptr;                                                    \
879
142
        P->short_name = #name;                                                 \
880
142
        P->descr = des_##name;                                                 \
881
142
        P->need_ellps = NEED_ELLPS;                                            \
882
142
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
142
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
142
        return P;                                                              \
885
142
    }                                                                          \
pj_deformation
Line
Count
Source
873
215
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
215
        if (P)                                                                 \
875
215
            return pj_projection_specific_setup_##name(P);                     \
876
215
        P = pj_new();                                                          \
877
108
        if (nullptr == P)                                                      \
878
108
            return nullptr;                                                    \
879
108
        P->short_name = #name;                                                 \
880
108
        P->descr = des_##name;                                                 \
881
108
        P->need_ellps = NEED_ELLPS;                                            \
882
108
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
108
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
108
        return P;                                                              \
885
108
    }                                                                          \
pj_helmert
Line
Count
Source
873
67.2k
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
67.2k
        if (P)                                                                 \
875
67.2k
            return pj_projection_specific_setup_##name(P);                     \
876
67.2k
        P = pj_new();                                                          \
877
33.6k
        if (nullptr == P)                                                      \
878
33.6k
            return nullptr;                                                    \
879
33.6k
        P->short_name = #name;                                                 \
880
33.6k
        P->descr = des_##name;                                                 \
881
33.6k
        P->need_ellps = NEED_ELLPS;                                            \
882
33.6k
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
33.6k
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
33.6k
        return P;                                                              \
885
33.6k
    }                                                                          \
pj_molobadekas
Line
Count
Source
873
60
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
60
        if (P)                                                                 \
875
60
            return pj_projection_specific_setup_##name(P);                     \
876
60
        P = pj_new();                                                          \
877
31
        if (nullptr == P)                                                      \
878
31
            return nullptr;                                                    \
879
31
        P->short_name = #name;                                                 \
880
31
        P->descr = des_##name;                                                 \
881
31
        P->need_ellps = NEED_ELLPS;                                            \
882
31
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
31
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
31
        return P;                                                              \
885
31
    }                                                                          \
pj_horner
Line
Count
Source
873
16
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
16
        if (P)                                                                 \
875
16
            return pj_projection_specific_setup_##name(P);                     \
876
16
        P = pj_new();                                                          \
877
8
        if (nullptr == P)                                                      \
878
8
            return nullptr;                                                    \
879
8
        P->short_name = #name;                                                 \
880
8
        P->descr = des_##name;                                                 \
881
8
        P->need_ellps = NEED_ELLPS;                                            \
882
8
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
8
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
8
        return P;                                                              \
885
8
    }                                                                          \
pj_molodensky
Line
Count
Source
873
9
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
9
        if (P)                                                                 \
875
9
            return pj_projection_specific_setup_##name(P);                     \
876
9
        P = pj_new();                                                          \
877
5
        if (nullptr == P)                                                      \
878
5
            return nullptr;                                                    \
879
5
        P->short_name = #name;                                                 \
880
5
        P->descr = des_##name;                                                 \
881
5
        P->need_ellps = NEED_ELLPS;                                            \
882
5
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
5
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
5
        return P;                                                              \
885
5
    }                                                                          \
pj_xyzgridshift
Line
Count
Source
873
422
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
422
        if (P)                                                                 \
875
422
            return pj_projection_specific_setup_##name(P);                     \
876
422
        P = pj_new();                                                          \
877
211
        if (nullptr == P)                                                      \
878
211
            return nullptr;                                                    \
879
211
        P->short_name = #name;                                                 \
880
211
        P->descr = des_##name;                                                 \
881
211
        P->need_ellps = NEED_ELLPS;                                            \
882
211
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
211
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
211
        return P;                                                              \
885
211
    }                                                                          \
pj_defmodel
Line
Count
Source
873
21
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
21
        if (P)                                                                 \
875
21
            return pj_projection_specific_setup_##name(P);                     \
876
21
        P = pj_new();                                                          \
877
11
        if (nullptr == P)                                                      \
878
11
            return nullptr;                                                    \
879
11
        P->short_name = #name;                                                 \
880
11
        P->descr = des_##name;                                                 \
881
11
        P->need_ellps = NEED_ELLPS;                                            \
882
11
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
11
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
11
        return P;                                                              \
885
11
    }                                                                          \
pj_tinshift
Line
Count
Source
873
9
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
9
        if (P)                                                                 \
875
9
            return pj_projection_specific_setup_##name(P);                     \
876
9
        P = pj_new();                                                          \
877
5
        if (nullptr == P)                                                      \
878
5
            return nullptr;                                                    \
879
5
        P->short_name = #name;                                                 \
880
5
        P->descr = des_##name;                                                 \
881
5
        P->need_ellps = NEED_ELLPS;                                            \
882
5
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
5
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
5
        return P;                                                              \
885
5
    }                                                                          \
pj_vertoffset
Line
Count
Source
873
593
    C_NAMESPACE PJ *pj_##name(PJ *P) {                                         \
874
593
        if (P)                                                                 \
875
593
            return pj_projection_specific_setup_##name(P);                     \
876
593
        P = pj_new();                                                          \
877
297
        if (nullptr == P)                                                      \
878
297
            return nullptr;                                                    \
879
297
        P->short_name = #name;                                                 \
880
297
        P->descr = des_##name;                                                 \
881
297
        P->need_ellps = NEED_ELLPS;                                            \
882
297
        P->left = PJ_IO_UNITS_RADIANS;                                         \
883
297
        P->right = PJ_IO_UNITS_CLASSIC;                                        \
884
297
        return P;                                                              \
885
297
    }                                                                          \
886
                                                                               \
887
    PJ *pj_projection_specific_setup_##name(PJ *P)
888
889
/* In ISO19000 lingo, an operation is either a conversion or a transformation */
890
#define PJ_CONVERSION(name, need_ellps) OPERATION(name, need_ellps)
891
#define PJ_TRANSFORMATION(name, need_ellps) OPERATION(name, need_ellps)
892
893
/* In PROJ.4 a projection is a conversion taking angular input and giving scaled
894
 * linear output */
895
#define PJ_PROJECTION(name) PJ_CONVERSION(name, 1)
896
897
#endif /* DO_NOT_DEFINE_PROJ_HEAD */
898
899
/* procedure prototypes */
900
double PROJ_DLL dmstor(const char *, char **);
901
double dmstor_ctx(PJ_CONTEXT *ctx, const char *, char **);
902
void PROJ_DLL set_rtodms(int, int);
903
char PROJ_DLL *rtodms(char *, size_t, double, int, int);
904
double PROJ_DLL adjlon(double);
905
double aacos(PJ_CONTEXT *, double);
906
double aasin(PJ_CONTEXT *, double);
907
double asqrt(double);
908
double aatan2(double, double);
909
910
PROJVALUE PROJ_DLL pj_param(PJ_CONTEXT *ctx, paralist *, const char *);
911
paralist PROJ_DLL *pj_param_exists(paralist *list, const char *parameter);
912
paralist PROJ_DLL *pj_mkparam(const char *);
913
paralist *pj_mkparam_ws(const char *str, const char **next_str);
914
915
int PROJ_DLL pj_ell_set(PJ_CONTEXT *ctx, paralist *, double *, double *);
916
int pj_datum_set(PJ_CONTEXT *, paralist *, PJ *);
917
int pj_angular_units_set(paralist *, PJ *);
918
919
paralist *pj_clone_paralist(const paralist *);
920
paralist *pj_search_initcache(const char *filekey);
921
void pj_insert_initcache(const char *filekey, const paralist *list);
922
paralist *pj_expand_init(PJ_CONTEXT *ctx, paralist *init);
923
924
void *free_params(PJ_CONTEXT *ctx, paralist *start, int errlev);
925
926
double *pj_enfn(double);
927
double pj_mlfn(double, double, double, const double *);
928
double pj_inv_mlfn(double, const double *);
929
double pj_tsfn(double, double, double);
930
double pj_msfn(double, double, double);
931
double PROJ_DLL pj_phi2(PJ_CONTEXT *, const double, const double);
932
double pj_sinhpsi2tanphi(PJ_CONTEXT *, const double, const double);
933
934
// From latitudes.cpp
935
double pj_conformal_lat(double phi, const PJ *P);
936
double pj_conformal_lat_inverse(double chi, const PJ *P);
937
938
double *pj_authalic_lat_compute_coeffs(double n);
939
double pj_authalic_lat_q(double sinphi, const PJ *P);
940
double pj_authalic_lat(double phi, double sinphi, double cosphi,
941
                       const double *APA, const PJ *P, double qp);
942
double pj_authalic_lat_inverse(double beta, const double *APA, const PJ *P,
943
                               double qp);
944
void pj_auxlat_coeffs(double n, AuxLat auxin, AuxLat auxout, double F[]);
945
double pj_polyval(double x, const double p[], int N);
946
double pj_clenshaw(double szeta, double czeta, const double F[], int K);
947
double pj_auxlat_convert(double phi, double sphi, double cphi, const double F[],
948
                         int K = int(AuxLat::ORDER));
949
double pj_auxlat_convert(double phi, const double F[],
950
                         int K = int(AuxLat::ORDER));
951
void pj_auxlat_convert(double sphi, double cphi, double &saux, double &caux,
952
                       const double F[], int K = int(AuxLat::ORDER));
953
double pj_rectifying_radius(double n);
954
955
COMPLEX pj_zpoly1(COMPLEX, const COMPLEX *, int);
956
COMPLEX pj_zpolyd1(COMPLEX, const COMPLEX *, int, COMPLEX *);
957
958
int pj_deriv(PJ_LP, double, const PJ *, struct DERIVS *);
959
int pj_factors(PJ_LP, PJ *toplevel, const PJ *internal, double,
960
               struct FACTORS *);
961
962
void *proj_mdist_ini(double);
963
double proj_mdist(double, double, double, const void *);
964
double proj_inv_mdist(PJ_CONTEXT *ctx, double, const void *);
965
void *pj_gauss_ini(double, double, double *, double *);
966
PJ_LP pj_gauss(PJ_CONTEXT *, PJ_LP, const void *);
967
PJ_LP pj_inv_gauss(PJ_CONTEXT *, PJ_LP, const void *);
968
969
const struct PJ_DATUMS PROJ_DLL *pj_get_datums_ref(void);
970
971
PJ *pj_new(void);
972
PJ *pj_default_destructor(PJ *P, int errlev);
973
974
double PROJ_DLL pj_atof(const char *nptr);
975
double pj_strtod(const char *nptr, char **endptr);
976
void pj_freeup_plain(PJ *P);
977
978
PJ *pj_init_ctx_with_allow_init_epsg(PJ_CONTEXT *ctx, int argc, char **argv,
979
                                     int allow_init_epsg);
980
981
std::string PROJ_DLL pj_add_type_crs_if_needed(const std::string &str);
982
std::string pj_double_quote_string_param_if_needed(const std::string &str);
983
984
PJ *pj_create_internal(PJ_CONTEXT *ctx, const char *definition);
985
PJ *pj_create_argv_internal(PJ_CONTEXT *ctx, int argc, char **argv);
986
987
// For use by projinfo
988
void pj_load_ini(PJ_CONTEXT *ctx);
989
990
// Exported for testing purposes only
991
std::string PROJ_DLL pj_context_get_grid_cache_filename(PJ_CONTEXT *ctx);
992
993
// For use by projsync
994
std::string PROJ_DLL pj_get_relative_share_proj(PJ_CONTEXT *ctx);
995
996
std::vector<PJCoordOperation>
997
pj_create_prepared_operations(PJ_CONTEXT *ctx, const PJ *source_crs,
998
                              const PJ *target_crs, PJ_OBJ_LIST *op_list);
999
1000
int pj_get_suggested_operation(PJ_CONTEXT *ctx,
1001
                               const std::vector<PJCoordOperation> &opList,
1002
                               const int iExcluded[2], bool skipNonInstantiable,
1003
                               PJ_DIRECTION direction, PJ_COORD coord);
1004
1005
const PJ_UNITS *pj_list_linear_units();
1006
const PJ_UNITS *pj_list_angular_units();
1007
1008
void pj_clear_hgridshift_knowngrids_cache();
1009
void pj_clear_vgridshift_knowngrids_cache();
1010
void pj_clear_gridshift_knowngrids_cache();
1011
1012
void pj_clear_sqlite_cache();
1013
1014
PJ_LP pj_generic_inverse_2d(PJ_XY xy, PJ *P, PJ_LP lpInitial,
1015
                            double deltaXYTolerance);
1016
1017
PJ *pj_obj_create(PJ_CONTEXT *ctx, const NS_PROJ::util::BaseObjectNNPtr &objIn);
1018
1019
PJ_DIRECTION pj_opposite_direction(PJ_DIRECTION dir);
1020
1021
void pj_warn_about_missing_grid(PJ *P);
1022
1023
/*****************************************************************************/
1024
/*                                                                           */
1025
/*                              proj_api.h                                   */
1026
/*                                                                           */
1027
/*    The rest of this header file includes what used to be "proj_api.h"     */
1028
/*                                                                           */
1029
/*****************************************************************************/
1030
1031
/* pj_init() and similar functions can be used with a non-C locale */
1032
/* Can be detected too at runtime if the symbol pj_atof exists */
1033
#define PJ_LOCALE_SAFE 1
1034
1035
5.24k
#define RAD_TO_DEG 57.295779513082321
1036
78.2k
#define DEG_TO_RAD .017453292519943296
1037
1038
extern char const PROJ_DLL pj_release[]; /* global release id string */
1039
1040
/* procedure prototypes */
1041
1042
PJ_CONTEXT PROJ_DLL *pj_get_default_ctx(void);
1043
PJ_CONTEXT *pj_get_ctx(PJ *);
1044
1045
PJ_XY PROJ_DLL pj_fwd(PJ_LP, PJ *);
1046
PJ_LP PROJ_DLL pj_inv(PJ_XY, PJ *);
1047
1048
PJ_XYZ pj_fwd3d(PJ_LPZ, PJ *);
1049
PJ_LPZ pj_inv3d(PJ_XYZ, PJ *);
1050
1051
void pj_clear_initcache(void);
1052
void PROJ_DLL pj_pr_list(PJ *); /* used by proj.cpp */
1053
char *pj_get_def(const PJ *, int);
1054
int pj_has_inverse(PJ *);
1055
1056
char *pj_strdup(const char *str);
1057
const char PROJ_DLL *pj_get_release(void);
1058
void pj_acquire_lock(void);
1059
void pj_release_lock(void);
1060
1061
bool pj_log_active(PJ_CONTEXT *ctx, int level);
1062
void pj_log(PJ_CONTEXT *ctx, int level, const char *fmt, ...);
1063
void pj_stderr_logger(void *, int, const char *);
1064
1065
// PROJ_DLL for tests
1066
int PROJ_DLL pj_find_file(PJ_CONTEXT *ctx, const char *short_filename,
1067
                          char *out_full_filename,
1068
                          size_t out_full_filename_size);
1069
1070
// To remove when PROJ_LIB definitely goes away
1071
void PROJ_DLL pj_stderr_proj_lib_deprecation_warning();
1072
1073
#endif /* ndef PROJ_INTERNAL_H */