LCOV - code coverage report
Current view: top level - sql/server - sql_symbol.c (source / functions) Hit Total Coverage
Test: coverage.info Lines: 144 144 100.0 %
Date: 2024-11-15 19:37:45 Functions: 17 17 100.0 %

          Line data    Source code
       1             : /*
       2             :  * SPDX-License-Identifier: MPL-2.0
       3             :  *
       4             :  * This Source Code Form is subject to the terms of the Mozilla Public
       5             :  * License, v. 2.0.  If a copy of the MPL was not distributed with this
       6             :  * file, You can obtain one at http://mozilla.org/MPL/2.0/.
       7             :  *
       8             :  * Copyright 2024 MonetDB Foundation;
       9             :  * Copyright August 2008 - 2023 MonetDB B.V.;
      10             :  * Copyright 1997 - July 2008 CWI.
      11             :  */
      12             : 
      13             : #include "monetdb_config.h"
      14             : #include "sql_mem.h"
      15             : #include "sql_symbol.h"
      16             : #include "sql_parser.h"
      17             : 
      18             : static symbol *
      19    10688278 : symbol_init(symbol *s, tokens token, symtype type )
      20             : {
      21    10688278 :         s->token = token;
      22    10688278 :         s->type = type;
      23    10688278 :         return s;
      24             : }
      25             : 
      26             : symbol *
      27      270737 : symbol_create(allocator *sa, tokens token, char *data)
      28             : {
      29      270737 :         symbol *s = SA_NEW(sa, symbol);
      30             : 
      31      270737 :         if (s) {
      32      270737 :                 symbol_init(s, token, type_string);
      33      270737 :                 s->data.sval = data;
      34             :         }
      35      270737 :         return s;
      36             : }
      37             : 
      38             : symbol *
      39     7755556 : symbol_create_list(allocator *sa, tokens token, dlist *data)
      40             : {
      41     7755556 :         symbol *s = SA_NEW(sa, symbol);
      42             : 
      43     7755684 :         if (s) {
      44     7755684 :                 symbol_init(s, token, type_list);
      45     7755684 :                 s->data.lval = data;
      46             :         }
      47     7755684 :         return s;
      48             : }
      49             : 
      50             : symbol *
      51        6387 : symbol_create_int(allocator *sa, tokens token, int data)
      52             : {
      53        6387 :         symbol *s = SA_NEW(sa, symbol);
      54             : 
      55        6387 :         if (s) {
      56        6387 :                 symbol_init(s, token, type_int);
      57        6387 :                 s->data.i_val = data;
      58             :         }
      59        6387 :         return s;
      60             : }
      61             : 
      62             : symbol *
      63         172 : symbol_create_lng(allocator *sa, tokens token, lng data)
      64             : {
      65         172 :         symbol *s = SA_NEW(sa, symbol);
      66             : 
      67         172 :         if (s) {
      68         172 :                 symbol_init(s, token, type_lng);
      69         172 :                 s->data.l_val = data;
      70             :         }
      71         172 :         return s;
      72             : }
      73             : 
      74             : symbol *
      75       96077 : symbol_create_symbol(allocator *sa, tokens token, symbol *data)
      76             : {
      77       96077 :         symbol *s = SA_NEW(sa, symbol);
      78             : 
      79       96077 :         if (s) {
      80       96077 :                 symbol_init(s, token, type_symbol);
      81       96077 :                 s->data.sym = data;
      82             :         }
      83       96077 :         return s;
      84             : }
      85             : 
      86             : static dnode *
      87    29642148 : dnode_create(allocator *sa )
      88             : {
      89    29642148 :         dnode *n = SA_NEW(sa, dnode);
      90             : 
      91    29642356 :         if (n)
      92    29642356 :                 n->next = NULL;
      93    29642356 :         return n;
      94             : }
      95             : 
      96             : static dnode *
      97     9127714 : dnode_create_string(allocator *sa, const char *data)
      98             : {
      99    18255476 :         dnode *n = dnode_create(sa);
     100             : 
     101     9127762 :         if (n) {
     102     9127762 :                 n->data.sval = (char*)data;
     103     9127762 :                 n->type = type_string;
     104             :         }
     105     9127762 :         return n;
     106             : }
     107             : static dnode *
     108     4614434 : dnode_create_list(allocator *sa, dlist *data)
     109             : {
     110     9229601 :         dnode *n = dnode_create(sa);
     111             : 
     112     4615167 :         if (n) {
     113     4615167 :                 n->data.lval = data;
     114     4615167 :                 n->type = type_list;
     115             :         }
     116     4615167 :         return n;
     117             : }
     118             : static dnode *
     119     3170698 : dnode_create_int(allocator *sa, int data)
     120             : {
     121     6341402 :         dnode *n = dnode_create(sa);
     122             : 
     123     3170704 :         if (n) {
     124     3170704 :                 n->data.i_val = data;
     125     3170704 :                 n->type = type_int;
     126             :         }
     127     3170704 :         return n;
     128             : }
     129             : static dnode *
     130        2627 : dnode_create_lng(allocator *sa, lng data)
     131             : {
     132        5254 :         dnode *n = dnode_create(sa);
     133             : 
     134        2627 :         if (n) {
     135        2627 :                 n->data.l_val = data;
     136        2627 :                 n->type = type_lng;
     137             :         }
     138        2627 :         return n;
     139             : }
     140             : static dnode *
     141    11653696 : dnode_create_symbol(allocator *sa, symbol *data)
     142             : {
     143    23308783 :         dnode *n = dnode_create(sa);
     144             : 
     145    11655087 :         if (n) {
     146    11655087 :                 n->data.sym = data;
     147    11655087 :                 n->type = type_symbol;
     148             :         }
     149    11655087 :         return n;
     150             : }
     151             : 
     152             : static dnode *
     153     1077876 : dnode_create_type(allocator *sa, sql_subtype *data)
     154             : {
     155     1077876 :         dnode *n = dnode_create(sa);
     156             : 
     157     1077876 :         if (n) {
     158     1077876 :                 if (data)
     159     1077872 :                         n->data.typeval = *data;
     160             :                 else
     161           4 :                         n->data.typeval.type = NULL;
     162     1077876 :                 n->type = type_type;
     163             :         }
     164     1077876 :         return n;
     165             : }
     166             : 
     167             : dlist *
     168    12251958 : dlist_create(allocator *sa)
     169             : {
     170    12251958 :         dlist *l = SA_NEW(sa, dlist);
     171             : 
     172    12252117 :         if (l) {
     173    12252117 :                 l->h = l->t = NULL;
     174    12252117 :                 l->cnt = 0;
     175             :         }
     176    12252117 :         return l;
     177             : }
     178             : 
     179             : int
     180    11737200 : dlist_length(dlist *l)
     181             : {
     182    11737200 :         return l->cnt;
     183             : }
     184             : 
     185             : static dlist *
     186    29649223 : dlist_append_default(dlist *l, dnode *n)
     187             : {
     188    29649223 :         if (l->cnt) {
     189    17399441 :                 l->t->next = n;
     190             :         } else {
     191    12249782 :                 l->h = n;
     192             :         }
     193    29649223 :         l->t = n;
     194    29649223 :         l->cnt++;
     195    29649223 :         return l;
     196             : }
     197             : 
     198             : dlist *
     199     9127714 : dlist_append_string(allocator *sa, dlist *l, const char *data)
     200             : {
     201     9127714 :         dnode *n = dnode_create_string(sa, data);
     202             : 
     203     9127762 :         if (!n)
     204             :                 return NULL;
     205    18255524 :         return dlist_append_default(l, n);
     206             : }
     207             : 
     208             : dlist *
     209     4614434 : dlist_append_list(allocator *sa, dlist *l, dlist *data)
     210             : {
     211     4614434 :         dnode *n = dnode_create_list(sa, data);
     212             : 
     213     4615167 :         if (!n)
     214             :                 return NULL;
     215     9230334 :         return dlist_append_default(l, n);
     216             : }
     217             : 
     218             : dlist *
     219     3170698 : dlist_append_int(allocator *sa, dlist *l, int data)
     220             : {
     221     3170698 :         dnode *n = dnode_create_int(sa, data);
     222             : 
     223     3170704 :         if (!n)
     224             :                 return NULL;
     225     6341408 :         return dlist_append_default(l, n);
     226             : }
     227             : 
     228             : dlist *
     229        2627 : dlist_append_lng(allocator *sa, dlist *l, lng data)
     230             : {
     231        2627 :         dnode *n = dnode_create_lng(sa, data);
     232             : 
     233        2627 :         if (!n)
     234             :                 return NULL;
     235        5254 :         return dlist_append_default(l, n);
     236             : }
     237             : 
     238             : dlist *
     239    11653696 : dlist_append_symbol(allocator *sa, dlist *l, symbol *data)
     240             : {
     241    11653696 :         dnode *n = dnode_create_symbol(sa, data);
     242             : 
     243    11655087 :         if (!n)
     244             :                 return NULL;
     245    23310174 :         return dlist_append_default(l, n);
     246             : }
     247             : 
     248             : dlist *
     249     1077876 : dlist_append_type(allocator *sa, dlist *l, sql_subtype *data)
     250             : {
     251     1077876 :         dnode *n = dnode_create_type(sa, data);
     252             : 
     253     1077876 :         if (!n)
     254             :                 return NULL;
     255     2155752 :         return dlist_append_default(l, n);
     256             : }
     257             : 
     258             : symbol *
     259      354286 : newSelectNode(allocator *sa, int distinct, struct dlist *selection, struct dlist *into, symbol *from, symbol *where, symbol *groupby, symbol *having, symbol *orderby, symbol *name, symbol *limit, symbol *offset, symbol *sample, symbol *seed, symbol *window)
     260             : {
     261      354286 :         SelectNode *sn = SA_NEW(sa, SelectNode);
     262      354301 :         symbol *s = (symbol *) sn;
     263             : 
     264      354301 :         if (s) {
     265      354301 :                 symbol_init(s, SQL_SELECT, type_symbol);
     266      354301 :                 sn->distinct = distinct;
     267      354301 :                 sn->lateral = 0;
     268      354301 :                 sn->limit = limit;
     269      354301 :                 sn->offset = offset;
     270      354301 :                 sn->sample = sample;
     271      354301 :                 sn->seed = seed;
     272      354301 :                 sn->selection = selection;
     273      354301 :                 sn->into = into;
     274      354301 :                 sn->from = from;
     275      354301 :                 sn->where = where;
     276      354301 :                 sn->groupby = groupby;
     277      354301 :                 sn->having = having;
     278      354301 :                 sn->orderby = orderby;
     279      354301 :                 sn->name = name;
     280      354301 :                 sn->window = window;
     281             :         }
     282      354301 :         return s;
     283             : }
     284             : 
     285             : symbol *
     286     2205310 : newAtomNode(allocator *sa, atom *data)
     287             : {
     288     2205310 :         AtomNode *an = SA_NEW(sa, AtomNode);
     289     2204920 :         symbol *s = (symbol *) an;
     290             : 
     291     2204920 :         if (s) {
     292     2204920 :                 symbol_init(s, SQL_ATOM, type_symbol);
     293     2204920 :                 an->a = data;
     294             :         }
     295     2204920 :         return s;
     296             : }

Generated by: LCOV version 1.14