1 | /* |
2 | * This Source Code Form is subject to the terms of the Mozilla Public |
3 | * License, v. 2.0. If a copy of the MPL was not distributed with this |
4 | * file, You can obtain one at http://mozilla.org/MPL/2.0/. |
5 | * |
6 | * Copyright 1997 - July 2008 CWI, August 2008 - 2019 MonetDB B.V. |
7 | */ |
8 | |
9 | #include "monetdb_config.h" |
10 | #include "projectionpath.h" |
11 | |
12 | str |
13 | ALGprojectionpath(Client cntxt, MalBlkPtr mb, MalStkPtr stk, InstrPtr pci) |
14 | { |
15 | int i; |
16 | bat bid; |
17 | bat *r = getArgReference_bat(stk, pci, 0); |
18 | BAT *b, **joins = (BAT**)GDKzalloc(pci->argc * sizeof(BAT*)); |
19 | |
20 | (void) mb; |
21 | (void) cntxt; |
22 | |
23 | if(pci->argc <= 1) |
24 | throw(MAL, "algebra.projectionpath" , SQLSTATE(HY001) "INTERNAL ERROR" ); |
25 | if ( joins == NULL) |
26 | throw(MAL, "algebra.projectionpath" , SQLSTATE(HY001) MAL_MALLOC_FAIL); |
27 | for (i = pci->retc; i < pci->argc; i++) { |
28 | bid = *getArgReference_bat(stk, pci, i); |
29 | b = BATdescriptor(bid); |
30 | if (b == NULL || (i + 1 < pci->argc && ATOMtype(b->ttype) != TYPE_oid)) { |
31 | while (--i >= pci->retc) |
32 | BBPunfix(joins[i - pci->retc]->batCacheid); |
33 | GDKfree(joins); |
34 | throw(MAL, "algebra.projectionpath" , "%s" , b ? SEMANTIC_TYPE_MISMATCH : INTERNAL_BAT_ACCESS); |
35 | } |
36 | joins[i - pci->retc] = b; |
37 | } |
38 | joins[pci->argc - pci->retc] = NULL; |
39 | b = BATprojectchain(joins); |
40 | for (i = pci->retc; i < pci->argc; i++) |
41 | BBPunfix(joins[i - pci->retc]->batCacheid); |
42 | GDKfree(joins); |
43 | if ( b) |
44 | BBPkeepref( *r = b->batCacheid); |
45 | else |
46 | throw(MAL, "algebra.projectionpath" , INTERNAL_OBJ_CREATE); |
47 | return MAL_SUCCEED; |
48 | } |
49 | |