[Home] [Help]
PACKAGE BODY: APPS.AHL_FMP_MR_INTERVAL_PVT_W
Source
1 package body ahl_fmp_mr_interval_pvt_w as
2 /* $Header: AHLWMITB.pls 120.2 2007/10/30 23:11:21 sikumar ship $ */
3 rosetta_g_mistake_date date := to_date('01/01/+4713', 'MM/DD/SYYYY');
4 rosetta_g_miss_date date := to_date('01/01/-4712', 'MM/DD/SYYYY');
5 rosetta_g_mistake_date_high date := to_date('01/01/+4710', 'MM/DD/SYYYY');
6 rosetta_g_mistake_date_low date := to_date('01/01/-4710', 'MM/DD/SYYYY');
7
8 -- this is to workaround the JDBC bug regarding IN DATE of value GMiss
9 function rosetta_g_miss_date_in_map(d date) return date as
10 begin
11 if d > rosetta_g_mistake_date_high then return fnd_api.g_miss_date; end if;
12 if d < rosetta_g_mistake_date_low then return fnd_api.g_miss_date; end if;
13 return d;
14 end;
15
16 procedure rosetta_table_copy_in_p2(t out nocopy ahl_fmp_mr_interval_pvt.interval_tbl_type, a0 JTF_NUMBER_TABLE
17 , a1 JTF_NUMBER_TABLE
18 , a2 JTF_NUMBER_TABLE
19 , a3 JTF_VARCHAR2_TABLE_100
20 , a4 JTF_NUMBER_TABLE
21 , a5 JTF_NUMBER_TABLE
22 , a6 JTF_NUMBER_TABLE
23 , a7 JTF_NUMBER_TABLE
24 , a8 JTF_DATE_TABLE
25 , a9 JTF_DATE_TABLE
26 , a10 JTF_NUMBER_TABLE
27 , a11 JTF_NUMBER_TABLE
28 , a12 JTF_NUMBER_TABLE
29 , a13 JTF_VARCHAR2_TABLE_100
30 , a14 JTF_VARCHAR2_TABLE_200
31 , a15 JTF_VARCHAR2_TABLE_200
32 , a16 JTF_VARCHAR2_TABLE_200
33 , a17 JTF_VARCHAR2_TABLE_200
34 , a18 JTF_VARCHAR2_TABLE_200
35 , a19 JTF_VARCHAR2_TABLE_200
36 , a20 JTF_VARCHAR2_TABLE_200
37 , a21 JTF_VARCHAR2_TABLE_200
38 , a22 JTF_VARCHAR2_TABLE_200
39 , a23 JTF_VARCHAR2_TABLE_200
40 , a24 JTF_VARCHAR2_TABLE_200
41 , a25 JTF_VARCHAR2_TABLE_200
42 , a26 JTF_VARCHAR2_TABLE_200
43 , a27 JTF_VARCHAR2_TABLE_200
44 , a28 JTF_VARCHAR2_TABLE_200
45 , a29 JTF_DATE_TABLE
46 , a30 JTF_NUMBER_TABLE
47 , a31 JTF_DATE_TABLE
48 , a32 JTF_NUMBER_TABLE
49 , a33 JTF_NUMBER_TABLE
50 , a34 JTF_VARCHAR2_TABLE_100
51 ) as
52 ddindx binary_integer; indx binary_integer;
53 begin
54 if a0 is not null and a0.count > 0 then
55 if a0.count > 0 then
56 indx := a0.first;
57 ddindx := 1;
58 while true loop
59 t(ddindx).mr_interval_id := a0(indx);
60 t(ddindx).object_version_number := a1(indx);
61 t(ddindx).counter_id := a2(indx);
62 t(ddindx).counter_name := a3(indx);
63 t(ddindx).interval_value := a4(indx);
64 t(ddindx).earliest_due_value := a5(indx);
65 t(ddindx).start_value := a6(indx);
66 t(ddindx).stop_value := a7(indx);
67 t(ddindx).start_date := rosetta_g_miss_date_in_map(a8(indx));
68 t(ddindx).stop_date := rosetta_g_miss_date_in_map(a9(indx));
69 t(ddindx).tolerance_before := a10(indx);
70 t(ddindx).tolerance_after := a11(indx);
71 t(ddindx).reset_value := a12(indx);
72 t(ddindx).attribute_category := a13(indx);
73 t(ddindx).attribute1 := a14(indx);
74 t(ddindx).attribute2 := a15(indx);
75 t(ddindx).attribute3 := a16(indx);
76 t(ddindx).attribute4 := a17(indx);
77 t(ddindx).attribute5 := a18(indx);
78 t(ddindx).attribute6 := a19(indx);
79 t(ddindx).attribute7 := a20(indx);
80 t(ddindx).attribute8 := a21(indx);
81 t(ddindx).attribute9 := a22(indx);
82 t(ddindx).attribute10 := a23(indx);
83 t(ddindx).attribute11 := a24(indx);
84 t(ddindx).attribute12 := a25(indx);
85 t(ddindx).attribute13 := a26(indx);
86 t(ddindx).attribute14 := a27(indx);
87 t(ddindx).attribute15 := a28(indx);
88 t(ddindx).last_update_date := rosetta_g_miss_date_in_map(a29(indx));
89 t(ddindx).last_updated_by := a30(indx);
90 t(ddindx).creation_date := rosetta_g_miss_date_in_map(a31(indx));
91 t(ddindx).created_by := a32(indx);
92 t(ddindx).last_update_login := a33(indx);
93 t(ddindx).dml_operation := a34(indx);
94 ddindx := ddindx+1;
95 if a0.last =indx
96 then exit;
97 end if;
98 indx := a0.next(indx);
99 end loop;
100 end if;
101 end if;
102 end rosetta_table_copy_in_p2;
103 procedure rosetta_table_copy_out_p2(t ahl_fmp_mr_interval_pvt.interval_tbl_type, a0 out nocopy JTF_NUMBER_TABLE
104 , a1 out nocopy JTF_NUMBER_TABLE
105 , a2 out nocopy JTF_NUMBER_TABLE
106 , a3 out nocopy JTF_VARCHAR2_TABLE_100
107 , a4 out nocopy JTF_NUMBER_TABLE
108 , a5 out nocopy JTF_NUMBER_TABLE
109 , a6 out nocopy JTF_NUMBER_TABLE
110 , a7 out nocopy JTF_NUMBER_TABLE
111 , a8 out nocopy JTF_DATE_TABLE
112 , a9 out nocopy JTF_DATE_TABLE
113 , a10 out nocopy JTF_NUMBER_TABLE
114 , a11 out nocopy JTF_NUMBER_TABLE
115 , a12 out nocopy JTF_NUMBER_TABLE
116 , a13 out nocopy JTF_VARCHAR2_TABLE_100
117 , a14 out nocopy JTF_VARCHAR2_TABLE_200
118 , a15 out nocopy JTF_VARCHAR2_TABLE_200
119 , a16 out nocopy JTF_VARCHAR2_TABLE_200
120 , a17 out nocopy JTF_VARCHAR2_TABLE_200
121 , a18 out nocopy JTF_VARCHAR2_TABLE_200
122 , a19 out nocopy JTF_VARCHAR2_TABLE_200
123 , a20 out nocopy JTF_VARCHAR2_TABLE_200
124 , a21 out nocopy JTF_VARCHAR2_TABLE_200
125 , a22 out nocopy JTF_VARCHAR2_TABLE_200
126 , a23 out nocopy JTF_VARCHAR2_TABLE_200
127 , a24 out nocopy JTF_VARCHAR2_TABLE_200
128 , a25 out nocopy JTF_VARCHAR2_TABLE_200
129 , a26 out nocopy JTF_VARCHAR2_TABLE_200
130 , a27 out nocopy JTF_VARCHAR2_TABLE_200
131 , a28 out nocopy JTF_VARCHAR2_TABLE_200
132 , a29 out nocopy JTF_DATE_TABLE
133 , a30 out nocopy JTF_NUMBER_TABLE
134 , a31 out nocopy JTF_DATE_TABLE
135 , a32 out nocopy JTF_NUMBER_TABLE
136 , a33 out nocopy JTF_NUMBER_TABLE
137 , a34 out nocopy JTF_VARCHAR2_TABLE_100
138 ) as
139 ddindx binary_integer; indx binary_integer;
140 begin
141 if t is null or t.count = 0 then
142 a0 := JTF_NUMBER_TABLE();
143 a1 := JTF_NUMBER_TABLE();
144 a2 := JTF_NUMBER_TABLE();
145 a3 := JTF_VARCHAR2_TABLE_100();
146 a4 := JTF_NUMBER_TABLE();
147 a5 := JTF_NUMBER_TABLE();
148 a6 := JTF_NUMBER_TABLE();
149 a7 := JTF_NUMBER_TABLE();
150 a8 := JTF_DATE_TABLE();
151 a9 := JTF_DATE_TABLE();
152 a10 := JTF_NUMBER_TABLE();
153 a11 := JTF_NUMBER_TABLE();
154 a12 := JTF_NUMBER_TABLE();
155 a13 := JTF_VARCHAR2_TABLE_100();
156 a14 := JTF_VARCHAR2_TABLE_200();
157 a15 := JTF_VARCHAR2_TABLE_200();
158 a16 := JTF_VARCHAR2_TABLE_200();
159 a17 := JTF_VARCHAR2_TABLE_200();
160 a18 := JTF_VARCHAR2_TABLE_200();
161 a19 := JTF_VARCHAR2_TABLE_200();
162 a20 := JTF_VARCHAR2_TABLE_200();
163 a21 := JTF_VARCHAR2_TABLE_200();
164 a22 := JTF_VARCHAR2_TABLE_200();
165 a23 := JTF_VARCHAR2_TABLE_200();
166 a24 := JTF_VARCHAR2_TABLE_200();
167 a25 := JTF_VARCHAR2_TABLE_200();
168 a26 := JTF_VARCHAR2_TABLE_200();
169 a27 := JTF_VARCHAR2_TABLE_200();
170 a28 := JTF_VARCHAR2_TABLE_200();
171 a29 := JTF_DATE_TABLE();
172 a30 := JTF_NUMBER_TABLE();
173 a31 := JTF_DATE_TABLE();
174 a32 := JTF_NUMBER_TABLE();
175 a33 := JTF_NUMBER_TABLE();
176 a34 := JTF_VARCHAR2_TABLE_100();
177 else
178 a0 := JTF_NUMBER_TABLE();
179 a1 := JTF_NUMBER_TABLE();
180 a2 := JTF_NUMBER_TABLE();
181 a3 := JTF_VARCHAR2_TABLE_100();
182 a4 := JTF_NUMBER_TABLE();
183 a5 := JTF_NUMBER_TABLE();
184 a6 := JTF_NUMBER_TABLE();
185 a7 := JTF_NUMBER_TABLE();
186 a8 := JTF_DATE_TABLE();
187 a9 := JTF_DATE_TABLE();
188 a10 := JTF_NUMBER_TABLE();
189 a11 := JTF_NUMBER_TABLE();
190 a12 := JTF_NUMBER_TABLE();
191 a13 := JTF_VARCHAR2_TABLE_100();
192 a14 := JTF_VARCHAR2_TABLE_200();
193 a15 := JTF_VARCHAR2_TABLE_200();
194 a16 := JTF_VARCHAR2_TABLE_200();
195 a17 := JTF_VARCHAR2_TABLE_200();
196 a18 := JTF_VARCHAR2_TABLE_200();
197 a19 := JTF_VARCHAR2_TABLE_200();
198 a20 := JTF_VARCHAR2_TABLE_200();
199 a21 := JTF_VARCHAR2_TABLE_200();
200 a22 := JTF_VARCHAR2_TABLE_200();
201 a23 := JTF_VARCHAR2_TABLE_200();
202 a24 := JTF_VARCHAR2_TABLE_200();
203 a25 := JTF_VARCHAR2_TABLE_200();
204 a26 := JTF_VARCHAR2_TABLE_200();
205 a27 := JTF_VARCHAR2_TABLE_200();
206 a28 := JTF_VARCHAR2_TABLE_200();
207 a29 := JTF_DATE_TABLE();
208 a30 := JTF_NUMBER_TABLE();
209 a31 := JTF_DATE_TABLE();
210 a32 := JTF_NUMBER_TABLE();
211 a33 := JTF_NUMBER_TABLE();
212 a34 := JTF_VARCHAR2_TABLE_100();
213 if t.count > 0 then
214 a0.extend(t.count);
215 a1.extend(t.count);
216 a2.extend(t.count);
217 a3.extend(t.count);
218 a4.extend(t.count);
219 a5.extend(t.count);
220 a6.extend(t.count);
221 a7.extend(t.count);
222 a8.extend(t.count);
223 a9.extend(t.count);
224 a10.extend(t.count);
225 a11.extend(t.count);
226 a12.extend(t.count);
227 a13.extend(t.count);
228 a14.extend(t.count);
229 a15.extend(t.count);
230 a16.extend(t.count);
231 a17.extend(t.count);
232 a18.extend(t.count);
233 a19.extend(t.count);
234 a20.extend(t.count);
235 a21.extend(t.count);
236 a22.extend(t.count);
237 a23.extend(t.count);
238 a24.extend(t.count);
239 a25.extend(t.count);
240 a26.extend(t.count);
241 a27.extend(t.count);
242 a28.extend(t.count);
243 a29.extend(t.count);
244 a30.extend(t.count);
245 a31.extend(t.count);
246 a32.extend(t.count);
247 a33.extend(t.count);
248 a34.extend(t.count);
249 ddindx := t.first;
250 indx := 1;
251 while true loop
252 a0(indx) := t(ddindx).mr_interval_id;
253 a1(indx) := t(ddindx).object_version_number;
254 a2(indx) := t(ddindx).counter_id;
255 a3(indx) := t(ddindx).counter_name;
256 a4(indx) := t(ddindx).interval_value;
257 a5(indx) := t(ddindx).earliest_due_value;
258 a6(indx) := t(ddindx).start_value;
259 a7(indx) := t(ddindx).stop_value;
260 a8(indx) := t(ddindx).start_date;
261 a9(indx) := t(ddindx).stop_date;
262 a10(indx) := t(ddindx).tolerance_before;
263 a11(indx) := t(ddindx).tolerance_after;
264 a12(indx) := t(ddindx).reset_value;
265 a13(indx) := t(ddindx).attribute_category;
266 a14(indx) := t(ddindx).attribute1;
267 a15(indx) := t(ddindx).attribute2;
268 a16(indx) := t(ddindx).attribute3;
269 a17(indx) := t(ddindx).attribute4;
270 a18(indx) := t(ddindx).attribute5;
271 a19(indx) := t(ddindx).attribute6;
272 a20(indx) := t(ddindx).attribute7;
273 a21(indx) := t(ddindx).attribute8;
274 a22(indx) := t(ddindx).attribute9;
275 a23(indx) := t(ddindx).attribute10;
276 a24(indx) := t(ddindx).attribute11;
277 a25(indx) := t(ddindx).attribute12;
278 a26(indx) := t(ddindx).attribute13;
279 a27(indx) := t(ddindx).attribute14;
280 a28(indx) := t(ddindx).attribute15;
281 a29(indx) := t(ddindx).last_update_date;
282 a30(indx) := t(ddindx).last_updated_by;
283 a31(indx) := t(ddindx).creation_date;
284 a32(indx) := t(ddindx).created_by;
285 a33(indx) := t(ddindx).last_update_login;
286 a34(indx) := t(ddindx).dml_operation;
287 indx := indx+1;
288 if t.last =ddindx
289 then exit;
290 end if;
291 ddindx := t.next(ddindx);
295 end rosetta_table_copy_out_p2;
292 end loop;
293 end if;
294 end if;
296
297 procedure process_interval(p_api_version NUMBER
298 , p_init_msg_list VARCHAR2
299 , p_commit VARCHAR2
300 , p_validation_level NUMBER
301 , p_default VARCHAR2
302 , p_module_type VARCHAR2
303 , x_return_status out nocopy VARCHAR2
304 , x_msg_count out nocopy NUMBER
305 , x_msg_data out nocopy VARCHAR2
306 , p9_a0 in out nocopy JTF_NUMBER_TABLE
307 , p9_a1 in out nocopy JTF_NUMBER_TABLE
308 , p9_a2 in out nocopy JTF_NUMBER_TABLE
309 , p9_a3 in out nocopy JTF_VARCHAR2_TABLE_100
310 , p9_a4 in out nocopy JTF_NUMBER_TABLE
311 , p9_a5 in out nocopy JTF_NUMBER_TABLE
312 , p9_a6 in out nocopy JTF_NUMBER_TABLE
313 , p9_a7 in out nocopy JTF_NUMBER_TABLE
314 , p9_a8 in out nocopy JTF_DATE_TABLE
315 , p9_a9 in out nocopy JTF_DATE_TABLE
316 , p9_a10 in out nocopy JTF_NUMBER_TABLE
317 , p9_a11 in out nocopy JTF_NUMBER_TABLE
318 , p9_a12 in out nocopy JTF_NUMBER_TABLE
319 , p9_a13 in out nocopy JTF_VARCHAR2_TABLE_100
320 , p9_a14 in out nocopy JTF_VARCHAR2_TABLE_200
321 , p9_a15 in out nocopy JTF_VARCHAR2_TABLE_200
322 , p9_a16 in out nocopy JTF_VARCHAR2_TABLE_200
323 , p9_a17 in out nocopy JTF_VARCHAR2_TABLE_200
324 , p9_a18 in out nocopy JTF_VARCHAR2_TABLE_200
325 , p9_a19 in out nocopy JTF_VARCHAR2_TABLE_200
326 , p9_a20 in out nocopy JTF_VARCHAR2_TABLE_200
327 , p9_a21 in out nocopy JTF_VARCHAR2_TABLE_200
328 , p9_a22 in out nocopy JTF_VARCHAR2_TABLE_200
329 , p9_a23 in out nocopy JTF_VARCHAR2_TABLE_200
330 , p9_a24 in out nocopy JTF_VARCHAR2_TABLE_200
331 , p9_a25 in out nocopy JTF_VARCHAR2_TABLE_200
332 , p9_a26 in out nocopy JTF_VARCHAR2_TABLE_200
333 , p9_a27 in out nocopy JTF_VARCHAR2_TABLE_200
334 , p9_a28 in out nocopy JTF_VARCHAR2_TABLE_200
335 , p9_a29 in out nocopy JTF_DATE_TABLE
336 , p9_a30 in out nocopy JTF_NUMBER_TABLE
337 , p9_a31 in out nocopy JTF_DATE_TABLE
338 , p9_a32 in out nocopy JTF_NUMBER_TABLE
339 , p9_a33 in out nocopy JTF_NUMBER_TABLE
340 , p9_a34 in out nocopy JTF_VARCHAR2_TABLE_100
341 , p10_a0 in out nocopy NUMBER
342 , p10_a1 in out nocopy NUMBER
343 , p10_a2 in out nocopy DATE
344 , p10_a3 in out nocopy NUMBER
345 , p10_a4 in out nocopy VARCHAR2
346 , p_mr_header_id NUMBER
347 , p_super_user VARCHAR2
348 )
349
350 as
351 ddp_x_interval_tbl ahl_fmp_mr_interval_pvt.interval_tbl_type;
352 ddp_x_threshold_rec ahl_fmp_mr_interval_pvt.threshold_rec_type;
353 ddindx binary_integer; indx binary_integer;
354 begin
355
356 -- copy data to the local IN or IN-OUT args, if any
357
358
359
360
361
362
363
364
365
366 ahl_fmp_mr_interval_pvt_w.rosetta_table_copy_in_p2(ddp_x_interval_tbl, p9_a0
367 , p9_a1
368 , p9_a2
369 , p9_a3
370 , p9_a4
371 , p9_a5
372 , p9_a6
373 , p9_a7
374 , p9_a8
375 , p9_a9
376 , p9_a10
377 , p9_a11
378 , p9_a12
379 , p9_a13
380 , p9_a14
381 , p9_a15
382 , p9_a16
383 , p9_a17
384 , p9_a18
385 , p9_a19
386 , p9_a20
387 , p9_a21
388 , p9_a22
389 , p9_a23
390 , p9_a24
391 , p9_a25
392 , p9_a26
393 , p9_a27
394 , p9_a28
395 , p9_a29
396 , p9_a30
397 , p9_a31
398 , p9_a32
399 , p9_a33
400 , p9_a34
401 );
402
403 ddp_x_threshold_rec.mr_effectivity_id := p10_a0;
404 ddp_x_threshold_rec.object_version_number := p10_a1;
405 ddp_x_threshold_rec.threshold_date := rosetta_g_miss_date_in_map(p10_a2);
406 ddp_x_threshold_rec.program_duration := p10_a3;
407 ddp_x_threshold_rec.program_duration_uom_code := p10_a4;
408
409
410
411 -- here's the delegated call to the old PL/SQL routine
412 ahl_fmp_mr_interval_pvt.process_interval(p_api_version,
413 p_init_msg_list,
414 p_commit,
415 p_validation_level,
416 p_default,
417 p_module_type,
418 x_return_status,
419 x_msg_count,
420 x_msg_data,
421 ddp_x_interval_tbl,
422 ddp_x_threshold_rec,
423 p_mr_header_id,
424 p_super_user);
425
426 -- copy data back from the local variables to OUT or IN-OUT args, if any
427
428
429
430
431
432
433
434
435
436 ahl_fmp_mr_interval_pvt_w.rosetta_table_copy_out_p2(ddp_x_interval_tbl, p9_a0
437 , p9_a1
438 , p9_a2
439 , p9_a3
440 , p9_a4
441 , p9_a5
442 , p9_a6
443 , p9_a7
444 , p9_a8
445 , p9_a9
446 , p9_a10
447 , p9_a11
448 , p9_a12
449 , p9_a13
450 , p9_a14
451 , p9_a15
452 , p9_a16
453 , p9_a17
454 , p9_a18
455 , p9_a19
456 , p9_a20
457 , p9_a21
458 , p9_a22
459 , p9_a23
460 , p9_a24
461 , p9_a25
462 , p9_a26
463 , p9_a27
464 , p9_a28
465 , p9_a29
466 , p9_a30
467 , p9_a31
468 , p9_a32
469 , p9_a33
470 , p9_a34
471 );
472
473 p10_a0 := ddp_x_threshold_rec.mr_effectivity_id;
474 p10_a1 := ddp_x_threshold_rec.object_version_number;
475 p10_a2 := ddp_x_threshold_rec.threshold_date;
476 p10_a3 := ddp_x_threshold_rec.program_duration;
477 p10_a4 := ddp_x_threshold_rec.program_duration_uom_code;
478
479
480 end;
481
482 end ahl_fmp_mr_interval_pvt_w;