File Coverage

pp-rgb_to_linear.c
Criterion Covered Total %
statement 34 44 77.2
branch 31 122 25.4
condition n/a
subroutine n/a
pod n/a
total 65 166 39.1


line stmt bran cond sub pod time code
1              
2             #line 453 "lib/PDL/PP.pm"
3             /*
4             * THIS FILE WAS GENERATED BY PDL::PP from color_space.pd! Do not modify!
5             */
6              
7             #define PDL_FREE_CODE(trans, destroy, comp_free_code, ntpriv_free_code) \
8             if (destroy) { \
9             comp_free_code \
10             } \
11             if ((trans)->dims_redone) { \
12             ntpriv_free_code \
13             }
14              
15             #include "EXTERN.h"
16             #include "perl.h"
17             #include "XSUB.h"
18             #include "pdl.h"
19             #include "pdlcore.h"
20             #define PDL PDL_Graphics_ColorSpace
21             extern Core* PDL; /* Structure hold core C functions */
22             #line 23 "pp-rgb_to_linear.c"
23              
24             #include
25             #include "color_space.h" /* Local decs */
26              
27             #line 1857 "lib/PDL/PP.pm"
28             pdl_error pdl_rgb_to_linear_redodims(pdl_trans *__privtrans) {
29             pdl_error PDL_err = {0, NULL, 0};
30             #line 31 "pp-rgb_to_linear.c"
31 1           __privtrans->ind_sizes[0] = 3;
32 1 50         PDL_RETERROR(PDL_err, PDL->redodims_default(__privtrans));
33 1           return PDL_err;
34             }
35              
36              
37             #line 1857 "lib/PDL/PP.pm"
38             pdl_error pdl_rgb_to_linear_readdata(pdl_trans *__privtrans) {
39             pdl_error PDL_err = {0, NULL, 0};
40             #line 41 "pp-rgb_to_linear.c"
41 1           register PDL_Indx __c_size = __privtrans->ind_sizes[0];
42 1 50         if (!__privtrans->broadcast.incs) return PDL->make_error(PDL_EUSERERROR, "Error in rgb_to_linear:" "broadcast.incs NULL");
43             /* broadcastloop declarations */
44             int __brcloopval;
45             register PDL_Indx __tind0,__tind1; /* counters along dim */
46 1           register PDL_Indx __tnpdls = __privtrans->broadcast.npdls;
47             /* dims here are how many steps along those dims */
48 1           register PDL_Indx __tinc0_rgb = PDL_BRC_INC(__privtrans->broadcast.incs,__tnpdls,0,0);
49 1           register PDL_Indx __tinc0_gamma = PDL_BRC_INC(__privtrans->broadcast.incs,__tnpdls,1,0);
50 1           register PDL_Indx __tinc0_out = PDL_BRC_INC(__privtrans->broadcast.incs,__tnpdls,2,0);
51 1           register PDL_Indx __tinc1_rgb = PDL_BRC_INC(__privtrans->broadcast.incs,__tnpdls,0,1);
52 1           register PDL_Indx __tinc1_gamma = PDL_BRC_INC(__privtrans->broadcast.incs,__tnpdls,1,1);
53 1           register PDL_Indx __tinc1_out = PDL_BRC_INC(__privtrans->broadcast.incs,__tnpdls,2,1);
54             #define PDL_BROADCASTLOOP_START_rgb_to_linear_readdata PDL_BROADCASTLOOP_START( \
55             readdata, \
56             __privtrans->broadcast, \
57             __privtrans->vtable, \
58             rgb_datap += __offsp[0]; \
59             gamma_datap += __offsp[1]; \
60             out_datap += __offsp[2]; \
61             , \
62             ( ,rgb_datap += __tinc1_rgb - __tinc0_rgb * __tdims0 \
63             ,gamma_datap += __tinc1_gamma - __tinc0_gamma * __tdims0 \
64             ,out_datap += __tinc1_out - __tinc0_out * __tdims0 \
65             ), \
66             ( ,rgb_datap += __tinc0_rgb \
67             ,gamma_datap += __tinc0_gamma \
68             ,out_datap += __tinc0_out \
69             ) \
70             )
71             #define PDL_BROADCASTLOOP_END_rgb_to_linear_readdata PDL_BROADCASTLOOP_END( \
72             __privtrans->broadcast, \
73             rgb_datap -= __tinc1_rgb * __tdims1 + __offsp[0]; \
74             gamma_datap -= __tinc1_gamma * __tdims1 + __offsp[1]; \
75             out_datap -= __tinc1_out * __tdims1 + __offsp[2]; \
76             )
77 1           register PDL_Indx __inc_out_c = __privtrans->inc_sizes[PDL_INC_ID(__privtrans->vtable,2,0)]; (void)__inc_out_c;
78 1           register PDL_Indx __inc_rgb_c = __privtrans->inc_sizes[PDL_INC_ID(__privtrans->vtable,0,0)]; (void)__inc_rgb_c;
79             #ifndef PDL_DECLARE_PARAMS_rgb_to_linear_1
80             #define PDL_DECLARE_PARAMS_rgb_to_linear_1(PDL_TYPE_OP,PDL_PPSYM_OP) \
81             PDL_DECLARE_PARAMETER_BADVAL(PDL_TYPE_OP, rgb, (__privtrans->pdls[0]), 1, PDL_PPSYM_OP) \
82             PDL_DECLARE_PARAMETER_BADVAL(PDL_TYPE_OP, gamma, (__privtrans->pdls[1]), 1, PDL_PPSYM_OP) \
83             PDL_DECLARE_PARAMETER_BADVAL(PDL_TYPE_OP, out, (__privtrans->pdls[2]), 1, PDL_PPSYM_OP)
84             #endif
85 1 50         if ( __privtrans->bvalflag ) { /* ** do 'bad' Code ** */
86             #define PDL_BAD_CODE
87             #define PDL_IF_BAD(t,f) t
88 0 0         switch (__privtrans->__datatype) { /* Start generic switch */
89 0           case PDL_D: {
90 0 0         PDL_DECLARE_PARAMS_rgb_to_linear_1(PDL_Double,D)
    0          
    0          
    0          
    0          
    0          
    0          
    0          
    0          
    0          
    0          
    0          
91 0 0         PDL_BROADCASTLOOP_START_rgb_to_linear_readdata {
    0          
    0          
    0          
    0          
    0          
    0          
92 0 0         PDL_IF_BAD(if (PDL_ISBAD2((rgb_datap)[0+(__inc_rgb_c*(0))],rgb_badval,D,rgb_badval_isnan) || PDL_ISBAD2((rgb_datap)[0+(__inc_rgb_c*(1))],rgb_badval,D,rgb_badval_isnan) || PDL_ISBAD2((rgb_datap)[0+(__inc_rgb_c*(2))],rgb_badval,D,rgb_badval_isnan)) {
    0          
    0          
    0          
    0          
    0          
    0          
    0          
    0          
    0          
93             {/* Open c */ PDL_EXPAND2(register PDL_Indx c=0, __c_stop=(__c_size)); for(; c<__c_stop; c+=1) { (out_datap)[0+(__inc_out_c*(c))]=out_badval; }} /* Close c */
94             }
95             else,) {
96 0           rgb2linear( rgb_datap, (gamma_datap)[0], out_datap );
97             }
98 0 0         }PDL_BROADCASTLOOP_END_rgb_to_linear_readdata
    0          
99 0           } break;
100 0           default: return PDL->make_error(PDL_EUSERERROR, "PP INTERNAL ERROR in rgb_to_linear: unhandled datatype(%d), only handles (D)! PLEASE MAKE A BUG REPORT\n", __privtrans->__datatype);
101             }
102             #undef PDL_BAD_CODE
103             #undef PDL_IF_BAD
104             } else { /* ** else do 'good' Code ** */
105             #define PDL_IF_BAD(t,f) f
106 1 50         switch (__privtrans->__datatype) { /* Start generic switch */
107 1           case PDL_D: {
108 1 50         PDL_DECLARE_PARAMS_rgb_to_linear_1(PDL_Double,D)
    50          
    50          
    50          
    50          
    50          
    50          
    50          
    50          
    50          
    50          
    50          
109 7 50         PDL_BROADCASTLOOP_START_rgb_to_linear_readdata {
    50          
    50          
    50          
    50          
    100          
    100          
110             PDL_IF_BAD(if (PDL_ISBAD2((rgb_datap)[0+(__inc_rgb_c*(0))],rgb_badval,D,rgb_badval_isnan) || PDL_ISBAD2((rgb_datap)[0+(__inc_rgb_c*(1))],rgb_badval,D,rgb_badval_isnan) || PDL_ISBAD2((rgb_datap)[0+(__inc_rgb_c*(2))],rgb_badval,D,rgb_badval_isnan)) {
111             {/* Open c */ PDL_EXPAND2(register PDL_Indx c=0, __c_stop=(__c_size)); for(; c<__c_stop; c+=1) { (out_datap)[0+(__inc_out_c*(c))]=out_badval; }} /* Close c */
112             }
113             else,) {
114 4           rgb2linear( rgb_datap, (gamma_datap)[0], out_datap );
115             }
116 1 50         }PDL_BROADCASTLOOP_END_rgb_to_linear_readdata
    50          
117 1           } break;
118 0           default: return PDL->make_error(PDL_EUSERERROR, "PP INTERNAL ERROR in rgb_to_linear: unhandled datatype(%d), only handles (D)! PLEASE MAKE A BUG REPORT\n", __privtrans->__datatype);
119             }
120             #undef PDL_IF_BAD
121             }
122 1           return PDL_err;
123             }
124              
125             static pdl_datatypes pdl_rgb_to_linear_vtable_gentypes[] = { PDL_D, -1 };
126             static PDL_Indx pdl_rgb_to_linear_vtable_realdims[] = { 1, 0, 1 };
127             static char *pdl_rgb_to_linear_vtable_parnames[] = { "rgb","gamma","out" };
128             static short pdl_rgb_to_linear_vtable_parflags[] = {
129             PDL_PARAM_ISPHYS,
130             0,
131             PDL_PARAM_ISCREAT|PDL_PARAM_ISOUT|PDL_PARAM_ISPHYS|PDL_PARAM_ISWRITE
132             };
133             static pdl_datatypes pdl_rgb_to_linear_vtable_partypes[] = { -1, -1, -1 };
134             static PDL_Indx pdl_rgb_to_linear_vtable_realdims_starts[] = { 0, 1, 1 };
135             static PDL_Indx pdl_rgb_to_linear_vtable_realdims_ind_ids[] = { 0, 0 };
136             static char *pdl_rgb_to_linear_vtable_indnames[] = { "c" };
137             pdl_transvtable pdl_rgb_to_linear_vtable = {
138             PDL_TRANS_DO_BROADCAST|PDL_TRANS_BADPROCESS, 0, pdl_rgb_to_linear_vtable_gentypes, 2, 3, NULL /*CORE21*/,
139             pdl_rgb_to_linear_vtable_realdims, pdl_rgb_to_linear_vtable_parnames,
140             pdl_rgb_to_linear_vtable_parflags, pdl_rgb_to_linear_vtable_partypes,
141             pdl_rgb_to_linear_vtable_realdims_starts, pdl_rgb_to_linear_vtable_realdims_ind_ids, 2,
142             1, pdl_rgb_to_linear_vtable_indnames,
143             pdl_rgb_to_linear_redodims, pdl_rgb_to_linear_readdata, NULL,
144             NULL,
145             0,"PDL::Graphics::ColorSpace::rgb_to_linear"
146             };
147              
148              
149 1           pdl_error pdl_run_rgb_to_linear(pdl *rgb,pdl *gamma,pdl *out) {
150 1           pdl_error PDL_err = {0, NULL, 0};
151 1 50         if (!PDL) return (pdl_error){PDL_EFATAL, "PDL core struct is NULL, can't continue",0};
152 1           pdl_trans *__privtrans = PDL->create_trans(&pdl_rgb_to_linear_vtable);
153 1 50         if (!__privtrans) return PDL->make_error_simple(PDL_EFATAL, "Couldn't create trans");
154 1           __privtrans->pdls[0] = rgb;
155 1           __privtrans->pdls[1] = gamma;
156 1           __privtrans->pdls[2] = out;
157 1 50         PDL_RETERROR(PDL_err, PDL->type_coerce(__privtrans));
158 1 50         PDL_RETERROR(PDL_err, PDL->make_trans_mutual(__privtrans));
159 1           return PDL_err;
160             }