/src/PROJ/src/conversions/set.cpp
Line | Count | Source (jump to first uncovered line) |
1 | | |
2 | | |
3 | | #include "proj_internal.h" |
4 | | #include <errno.h> |
5 | | |
6 | | PROJ_HEAD(set, "Set coordinate value"); |
7 | | |
8 | | /* Projection specific elements for the PJ object */ |
9 | | namespace { // anonymous namespace |
10 | | struct Set { |
11 | | bool v1; |
12 | | bool v2; |
13 | | bool v3; |
14 | | bool v4; |
15 | | double v1_val; |
16 | | double v2_val; |
17 | | double v3_val; |
18 | | double v4_val; |
19 | | }; |
20 | | } // anonymous namespace |
21 | | |
22 | 41.6k | static void set_fwd_inv(PJ_COORD &point, PJ *P) { |
23 | | |
24 | 41.6k | struct Set *set = static_cast<struct Set *>(P->opaque); |
25 | | |
26 | 41.6k | if (set->v1) |
27 | 0 | point.v[0] = set->v1_val; |
28 | 41.6k | if (set->v2) |
29 | 0 | point.v[1] = set->v2_val; |
30 | 41.6k | if (set->v3) |
31 | 0 | point.v[2] = set->v3_val; |
32 | 41.6k | if (set->v4) |
33 | 0 | point.v[3] = set->v4_val; |
34 | 41.6k | } |
35 | | |
36 | 1.36k | PJ *OPERATION(set, 0) { |
37 | 1.36k | P->inv4d = set_fwd_inv; |
38 | 1.36k | P->fwd4d = set_fwd_inv; |
39 | | |
40 | 1.36k | auto set = static_cast<struct Set *>(calloc(1, sizeof(struct Set))); |
41 | 1.36k | P->opaque = set; |
42 | 1.36k | if (nullptr == P->opaque) |
43 | 0 | return pj_default_destructor(P, PROJ_ERR_OTHER /*ENOMEM*/); |
44 | | |
45 | 1.36k | if (pj_param_exists(P->params, "v_1")) { |
46 | 25 | set->v1 = true; |
47 | 25 | set->v1_val = pj_param(P->ctx, P->params, "dv_1").f; |
48 | 25 | } |
49 | | |
50 | 1.36k | if (pj_param_exists(P->params, "v_2")) { |
51 | 29 | set->v2 = true; |
52 | 29 | set->v2_val = pj_param(P->ctx, P->params, "dv_2").f; |
53 | 29 | } |
54 | | |
55 | 1.36k | if (pj_param_exists(P->params, "v_3")) { |
56 | 42 | set->v3 = true; |
57 | 42 | set->v3_val = pj_param(P->ctx, P->params, "dv_3").f; |
58 | 42 | } |
59 | | |
60 | 1.36k | if (pj_param_exists(P->params, "v_4")) { |
61 | 51 | set->v4 = true; |
62 | 51 | set->v4_val = pj_param(P->ctx, P->params, "dv_4").f; |
63 | 51 | } |
64 | | |
65 | 1.36k | P->left = PJ_IO_UNITS_WHATEVER; |
66 | 1.36k | P->right = PJ_IO_UNITS_WHATEVER; |
67 | | |
68 | 1.36k | return P; |
69 | 1.36k | } |