|
@@ -7,7 +7,7 @@ int rpn_if_argf_default(rpn_if_t *rif, size_t pos, rpn_value_t *args)
|
7
|
7
|
rpn_if_default_data_t *data;
|
8
|
8
|
rpn_value_t *values;
|
9
|
9
|
|
10
|
|
- data = (rpn_if_default_data_t*)rif->params.data;
|
|
10
|
+ data = (rpn_if_default_data_t*)rif->params->data;
|
11
|
11
|
|
12
|
12
|
switch(data->pos_flag)
|
13
|
13
|
{
|
|
@@ -24,7 +24,7 @@ int rpn_if_argf_default(rpn_if_t *rif, size_t pos, rpn_value_t *args)
|
24
|
24
|
cur_arg = *(data->size_lim);
|
25
|
25
|
break;
|
26
|
26
|
}
|
27
|
|
- if(cur_arg > rif->params.rpn_argc)
|
|
27
|
+ if(cur_arg > rif->params->rpn_argc)
|
28
|
28
|
{
|
29
|
29
|
/* Too many arguments for given rif !! */
|
30
|
30
|
return -1;
|
|
@@ -50,7 +50,7 @@ int rpn_if_argf_default(rpn_if_t *rif, size_t pos, rpn_value_t *args)
|
50
|
50
|
}
|
51
|
51
|
break;
|
52
|
52
|
case RPN_IF_RES_XFUN:
|
53
|
|
- for(i=0; i < rif->params.rpn_sz - cur_arg; i++)
|
|
53
|
+ for(i=0; i < rif->params->rpn_sz - cur_arg; i++)
|
54
|
54
|
{
|
55
|
55
|
args[cur_arg+i] = values[i];
|
56
|
56
|
}
|
|
@@ -62,36 +62,38 @@ int rpn_if_argf_default(rpn_if_t *rif, size_t pos, rpn_value_t *args)
|
62
|
62
|
return -1;
|
63
|
63
|
}
|
64
|
64
|
|
65
|
|
-int rpn_if_resf_default(rpn_if_t *rif, size_t *pos, rpn_value_t *data)
|
|
65
|
+int rpn_if_resf_default(rpn_if_t *rif, size_t *pos, rpn_value_t *res)
|
66
|
66
|
{
|
67
|
67
|
rpn_if_default_data_t *data;
|
68
|
68
|
size_t cur_arg, i, rgb_imax;
|
|
69
|
+ rpn_value_t *values;
|
69
|
70
|
|
70
|
|
- data = (rpn_if_default_data_t*)rif->params.data;
|
|
71
|
+ data = (rpn_if_default_data_t*)rif->params->data;
|
71
|
72
|
|
72
|
73
|
switch(data->pos_flag)
|
73
|
74
|
{
|
74
|
75
|
case RPN_IF_POSITION_LINEAR:
|
75
|
|
- rpn_if_resf_linear(rif, pos, data);
|
|
76
|
+ rpn_if_resf_linear(rif, pos, res);
|
76
|
77
|
cur_arg = 1;
|
77
|
78
|
break;
|
78
|
79
|
case RPN_IF_POSITION_XY:
|
79
|
|
- rpn_if_resf_xy(rif, pos, data);
|
|
80
|
+ rpn_if_resf_xy(rif, pos, res);
|
80
|
81
|
cur_arg = 2;
|
81
|
82
|
break;
|
82
|
83
|
case RPN_IF_POSITION_XDIM:
|
83
|
|
- rpn_if_resf_xdim(rif, pos, data);
|
|
84
|
+ rpn_if_resf_xdim(rif, pos, res);
|
84
|
85
|
cur_arg = *(data->size_lim);
|
85
|
86
|
break;
|
86
|
87
|
}
|
87
|
|
- if(cur_arg > rif->params.rpn_argc)
|
|
88
|
+ if(cur_arg > rif->params->rpn_argc)
|
88
|
89
|
{
|
89
|
90
|
/** LOG ERROR ! should never append... */
|
90
|
91
|
return -1;
|
91
|
92
|
}
|
92
|
93
|
rgb_imax = 3; /* rgba */
|
93
|
|
- values = rpn_if_getimtem(rif, pos);
|
94
|
|
- siwtch(data->res-flag)
|
|
94
|
+ values = rpn_if_getitem(rif, *pos);
|
|
95
|
+ /**@todo if(res) set the values in res too ! */
|
|
96
|
+ switch(data->res_flag)
|
95
|
97
|
{
|
96
|
98
|
case RPN_IF_RES_BOOL:
|
97
|
99
|
*values = 1;
|
|
@@ -102,12 +104,12 @@ int rpn_if_resf_default(rpn_if_t *rif, size_t *pos, rpn_value_t *data)
|
102
|
104
|
break;
|
103
|
105
|
|
104
|
106
|
case RPN_IF_RES_COUNT:
|
105
|
|
- *values++;
|
106
|
|
- beak;
|
|
107
|
+ (*values)++;
|
|
108
|
+ break;
|
107
|
109
|
|
108
|
110
|
case RPN_IF_RES_CONST_RGBA:
|
109
|
111
|
rgb_imax = 4;
|
110
|
|
- case RPN_IF_RES_CONST_RGB:
|
|
112
|
+ //case RPN_IF_RES_CONST_RGB:
|
111
|
113
|
for(i=0;i<rgb_imax;i++)
|
112
|
114
|
{
|
113
|
115
|
values[i] = data->const_val[i];
|
|
@@ -124,7 +126,7 @@ int rpn_if_resf_default(rpn_if_t *rif, size_t *pos, rpn_value_t *data)
|
124
|
126
|
break;
|
125
|
127
|
|
126
|
128
|
case RPN_IF_RES_XFUN:
|
127
|
|
- for(i=0; i<rif->params.rpn_sz - cur_arg; i++)
|
|
129
|
+ for(i=0; i<rif->params->rpn_sz - cur_arg; i++)
|
128
|
130
|
{
|
129
|
131
|
values[i] = rif->rpn_res[cur_arg+i];
|
130
|
132
|
}
|
|
@@ -134,12 +136,13 @@ int rpn_if_resf_default(rpn_if_t *rif, size_t *pos, rpn_value_t *data)
|
134
|
136
|
/* LOG ERROR */
|
135
|
137
|
return -1;
|
136
|
138
|
}
|
|
139
|
+ return 0;
|
137
|
140
|
}
|
138
|
141
|
|
139
|
142
|
int rpn_if_argf_linear(rpn_if_t *rif, size_t pos, rpn_value_t *args)
|
140
|
143
|
{
|
141
|
144
|
rpn_if_default_data_t *data;
|
142
|
|
- data = (rpn_if_default_data_t*)rif->params.data;
|
|
145
|
+ data = (rpn_if_default_data_t*)rif->params->data;
|
143
|
146
|
if(data->size_lim && pos >= *data->size_lim)
|
144
|
147
|
{
|
145
|
148
|
if(data->pos_flag & RPN_IF_POSITION_OF_ERR)
|
|
@@ -156,7 +159,7 @@ int rpn_if_resf_linear(rpn_if_t *rif, size_t *pos, rpn_value_t *_data)
|
156
|
159
|
{
|
157
|
160
|
rpn_if_default_data_t *data;
|
158
|
161
|
size_t res;
|
159
|
|
- data = (rpn_if_default_data_t*)rif->params.data;
|
|
162
|
+ data = (rpn_if_default_data_t*)rif->params->data;
|
160
|
163
|
res = rif->rpn_res[0];
|
161
|
164
|
if(data->size_lim && res >= *data->size_lim)
|
162
|
165
|
{
|
|
@@ -174,7 +177,7 @@ int rpn_if_argf_xy(rpn_if_t *rif, size_t pos, rpn_value_t *args)
|
174
|
177
|
{
|
175
|
178
|
rpn_if_default_data_t *data;
|
176
|
179
|
|
177
|
|
- data = (rpn_if_default_data_t*)rif->params.data;
|
|
180
|
+ data = (rpn_if_default_data_t*)rif->params->data;
|
178
|
181
|
if(!data->size_lim)
|
179
|
182
|
{
|
180
|
183
|
return -1;
|
|
@@ -197,7 +200,7 @@ int rpn_if_resf_xy(rpn_if_t *rif, size_t *pos, rpn_value_t *_data)
|
197
|
200
|
rpn_if_default_data_t *data;
|
198
|
201
|
size_t xy[2];
|
199
|
202
|
|
200
|
|
- data = (rpn_if_default_data_t*)rif->params.data;
|
|
203
|
+ data = (rpn_if_default_data_t*)rif->params->data;
|
201
|
204
|
|
202
|
205
|
xy[0] = rif->rpn_res[0];
|
203
|
206
|
xy[1] = rif->rpn_res[1];
|
|
@@ -225,7 +228,7 @@ int rpn_if_argf_xdim(rpn_if_t *rif, size_t pos, rpn_value_t *args)
|
225
|
228
|
rpn_if_default_data_t *data;
|
226
|
229
|
size_t i, curdim_sz, curpos;
|
227
|
230
|
|
228
|
|
- data = (rpn_if_default_data_t*)rif->params.data;
|
|
231
|
+ data = (rpn_if_default_data_t*)rif->params->data;
|
229
|
232
|
|
230
|
233
|
if(!data->size_lim)
|
231
|
234
|
{
|
|
@@ -262,7 +265,7 @@ int rpn_if_resf_xdim(rpn_if_t *rif, size_t *pos, rpn_value_t *_data)
|
262
|
265
|
rpn_if_default_data_t *data;
|
263
|
266
|
size_t i, res, cur, curlim, prevlim;
|
264
|
267
|
|
265
|
|
- data = (rpn_if_default_data_t*)rif->params.data;
|
|
268
|
+ data = (rpn_if_default_data_t*)rif->params->data;
|
266
|
269
|
res = 0;
|
267
|
270
|
|
268
|
271
|
if(!data->size_lim)
|