File Coverage

pp-rgb_to_cmyk.c
Criterion Covered Total %
statement 40 42 95.2
branch 57 106 53.7
condition n/a
subroutine n/a
pod n/a
total 97 148 65.5


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_cmyk.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_cmyk_redodims(pdl_trans *__privtrans) {
29             pdl_error PDL_err = {0, NULL, 0};
30             #line 31 "pp-rgb_to_cmyk.c"
31 2           __privtrans->ind_sizes[0] = 3;
32 2           __privtrans->ind_sizes[1] = 4;
33 2 50         PDL_RETERROR(PDL_err, PDL->redodims_default(__privtrans));
34 2           return PDL_err;
35             }
36              
37              
38             #line 1857 "lib/PDL/PP.pm"
39             pdl_error pdl_rgb_to_cmyk_readdata(pdl_trans *__privtrans) {
40             pdl_error PDL_err = {0, NULL, 0};
41             #line 42 "pp-rgb_to_cmyk.c"
42 2           register PDL_Indx __d_size = __privtrans->ind_sizes[1];
43 2 50         if (!__privtrans->broadcast.incs) return PDL->make_error(PDL_EUSERERROR, "Error in rgb_to_cmyk:" "broadcast.incs NULL");
44             /* broadcastloop declarations */
45             int __brcloopval;
46             register PDL_Indx __tind0,__tind1; /* counters along dim */
47 2           register PDL_Indx __tnpdls = __privtrans->broadcast.npdls;
48             /* dims here are how many steps along those dims */
49 2           register PDL_Indx __tinc0_rgb = PDL_BRC_INC(__privtrans->broadcast.incs,__tnpdls,0,0);
50 2           register PDL_Indx __tinc0_cmyk = PDL_BRC_INC(__privtrans->broadcast.incs,__tnpdls,1,0);
51 2           register PDL_Indx __tinc1_rgb = PDL_BRC_INC(__privtrans->broadcast.incs,__tnpdls,0,1);
52 2           register PDL_Indx __tinc1_cmyk = PDL_BRC_INC(__privtrans->broadcast.incs,__tnpdls,1,1);
53             #define PDL_BROADCASTLOOP_START_rgb_to_cmyk_readdata PDL_BROADCASTLOOP_START( \
54             readdata, \
55             __privtrans->broadcast, \
56             __privtrans->vtable, \
57             rgb_datap += __offsp[0]; \
58             cmyk_datap += __offsp[1]; \
59             , \
60             ( ,rgb_datap += __tinc1_rgb - __tinc0_rgb * __tdims0 \
61             ,cmyk_datap += __tinc1_cmyk - __tinc0_cmyk * __tdims0 \
62             ), \
63             ( ,rgb_datap += __tinc0_rgb \
64             ,cmyk_datap += __tinc0_cmyk \
65             ) \
66             )
67             #define PDL_BROADCASTLOOP_END_rgb_to_cmyk_readdata PDL_BROADCASTLOOP_END( \
68             __privtrans->broadcast, \
69             rgb_datap -= __tinc1_rgb * __tdims1 + __offsp[0]; \
70             cmyk_datap -= __tinc1_cmyk * __tdims1 + __offsp[1]; \
71             )
72 2           register PDL_Indx __inc_cmyk_d = __privtrans->inc_sizes[PDL_INC_ID(__privtrans->vtable,1,0)]; (void)__inc_cmyk_d;
73 2           register PDL_Indx __inc_rgb_c = __privtrans->inc_sizes[PDL_INC_ID(__privtrans->vtable,0,0)]; (void)__inc_rgb_c;
74             #ifndef PDL_DECLARE_PARAMS_rgb_to_cmyk_1
75             #define PDL_DECLARE_PARAMS_rgb_to_cmyk_1(PDL_TYPE_OP,PDL_PPSYM_OP) \
76             PDL_DECLARE_PARAMETER_BADVAL(PDL_TYPE_OP, rgb, (__privtrans->pdls[0]), 1, PDL_PPSYM_OP) \
77             PDL_DECLARE_PARAMETER_BADVAL(PDL_TYPE_OP, cmyk, (__privtrans->pdls[1]), 1, PDL_PPSYM_OP)
78             #endif
79 2 100         if ( __privtrans->bvalflag ) { /* ** do 'bad' Code ** */
80             #define PDL_BAD_CODE
81             #define PDL_IF_BAD(t,f) t
82 1 50         switch (__privtrans->__datatype) { /* Start generic switch */
83 1           case PDL_D: {
84 1 50         PDL_DECLARE_PARAMS_rgb_to_cmyk_1(PDL_Double,D)
    50          
    50          
    50          
    50          
    50          
    50          
    50          
85 7 50         PDL_BROADCASTLOOP_START_rgb_to_cmyk_readdata {
    50          
    50          
    50          
    50          
    100          
    100          
86             /* First check for bad values */
87 8 50         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          
    50          
    50          
    0          
    100          
    50          
    0          
    50          
    100          
88             {/* Open d */ PDL_EXPAND2(register PDL_Indx d=0, __d_stop=(__d_size)); for(; d<__d_stop; d+=1) {
89             (cmyk_datap)[0+(__inc_cmyk_d*(d))]=cmyk_badval;
90             }} /* Close d */
91             /* skip to the next cmyk triple */
92             }
93             else,) {
94 3           rgb2cmyk(rgb_datap, cmyk_datap);
95             }
96 1 50         }PDL_BROADCASTLOOP_END_rgb_to_cmyk_readdata
    50          
97 1           } break;
98 0           default: return PDL->make_error(PDL_EUSERERROR, "PP INTERNAL ERROR in rgb_to_cmyk: unhandled datatype(%d), only handles (D)! PLEASE MAKE A BUG REPORT\n", __privtrans->__datatype);
99             }
100             #undef PDL_BAD_CODE
101             #undef PDL_IF_BAD
102             } else { /* ** else do 'good' Code ** */
103             #define PDL_IF_BAD(t,f) f
104 1 50         switch (__privtrans->__datatype) { /* Start generic switch */
105 1           case PDL_D: {
106 1 50         PDL_DECLARE_PARAMS_rgb_to_cmyk_1(PDL_Double,D)
    50          
    50          
    50          
    50          
    50          
    50          
    50          
107 7 50         PDL_BROADCASTLOOP_START_rgb_to_cmyk_readdata {
    50          
    50          
    50          
    50          
    100          
    100          
108             /* First check for bad values */
109             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)) {
110             {/* Open d */ PDL_EXPAND2(register PDL_Indx d=0, __d_stop=(__d_size)); for(; d<__d_stop; d+=1) {
111             (cmyk_datap)[0+(__inc_cmyk_d*(d))]=cmyk_badval;
112             }} /* Close d */
113             /* skip to the next cmyk triple */
114             }
115             else,) {
116 4           rgb2cmyk(rgb_datap, cmyk_datap);
117             }
118 1 50         }PDL_BROADCASTLOOP_END_rgb_to_cmyk_readdata
    50          
119 1           } break;
120 0           default: return PDL->make_error(PDL_EUSERERROR, "PP INTERNAL ERROR in rgb_to_cmyk: unhandled datatype(%d), only handles (D)! PLEASE MAKE A BUG REPORT\n", __privtrans->__datatype);
121             }
122             #undef PDL_IF_BAD
123             }
124 2           return PDL_err;
125             }
126              
127             static pdl_datatypes pdl_rgb_to_cmyk_vtable_gentypes[] = { PDL_D, -1 };
128             static PDL_Indx pdl_rgb_to_cmyk_vtable_realdims[] = { 1, 1 };
129             static char *pdl_rgb_to_cmyk_vtable_parnames[] = { "rgb","cmyk" };
130             static short pdl_rgb_to_cmyk_vtable_parflags[] = {
131             PDL_PARAM_ISPHYS,
132             PDL_PARAM_ISCREAT|PDL_PARAM_ISOUT|PDL_PARAM_ISPHYS|PDL_PARAM_ISWRITE
133             };
134             static pdl_datatypes pdl_rgb_to_cmyk_vtable_partypes[] = { -1, -1 };
135             static PDL_Indx pdl_rgb_to_cmyk_vtable_realdims_starts[] = { 0, 1 };
136             static PDL_Indx pdl_rgb_to_cmyk_vtable_realdims_ind_ids[] = { 0, 1 };
137             static char *pdl_rgb_to_cmyk_vtable_indnames[] = { "c","d" };
138             pdl_transvtable pdl_rgb_to_cmyk_vtable = {
139             PDL_TRANS_DO_BROADCAST|PDL_TRANS_BADPROCESS, 0, pdl_rgb_to_cmyk_vtable_gentypes, 1, 2, NULL /*CORE21*/,
140             pdl_rgb_to_cmyk_vtable_realdims, pdl_rgb_to_cmyk_vtable_parnames,
141             pdl_rgb_to_cmyk_vtable_parflags, pdl_rgb_to_cmyk_vtable_partypes,
142             pdl_rgb_to_cmyk_vtable_realdims_starts, pdl_rgb_to_cmyk_vtable_realdims_ind_ids, 2,
143             2, pdl_rgb_to_cmyk_vtable_indnames,
144             pdl_rgb_to_cmyk_redodims, pdl_rgb_to_cmyk_readdata, NULL,
145             NULL,
146             0,"PDL::Graphics::ColorSpace::rgb_to_cmyk"
147             };
148              
149              
150 2           pdl_error pdl_run_rgb_to_cmyk(pdl *rgb,pdl *cmyk) {
151 2           pdl_error PDL_err = {0, NULL, 0};
152 2 50         if (!PDL) return (pdl_error){PDL_EFATAL, "PDL core struct is NULL, can't continue",0};
153 2           pdl_trans *__privtrans = PDL->create_trans(&pdl_rgb_to_cmyk_vtable);
154 2 50         if (!__privtrans) return PDL->make_error_simple(PDL_EFATAL, "Couldn't create trans");
155 2           __privtrans->pdls[0] = rgb;
156 2           __privtrans->pdls[1] = cmyk;
157 2 50         PDL_RETERROR(PDL_err, PDL->type_coerce(__privtrans));
158 2 50         PDL_RETERROR(PDL_err, PDL->make_trans_mutual(__privtrans));
159 2           return PDL_err;
160             }