mdfctn.c
上传用户:dgyhgb
上传日期:2007-01-07
资源大小:676k
文件大小:8k
源码类别:

SQL Server

开发平台:

Unix_Linux

  1. /*
  2.  *  mdfctn.c  - Modification 
  3.  *              Kernel of GNU SQL-server 
  4.  *
  5.  *  $Id: mdfctn.c,v 1.246 1997/04/10 06:57:28 vera Exp $
  6.  *
  7.  *  This file is a part of GNU SQL Server
  8.  *
  9.  *  Copyright (c) 1996, 1997, Free Software Foundation, Inc
  10.  *  Developed at the Institute of System Programming
  11.  *  This file is written by  Vera Ponomarenko
  12.  *
  13.  *  This program is free software; you can redistribute it and/or modify
  14.  *  it under the terms of the GNU General Public License as published by
  15.  *  the Free Software Foundation; either version 2 of the License, or
  16.  *  (at your option) any later version.
  17.  *
  18.  *  This program is distributed in the hope that it will be useful,
  19.  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
  20.  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  21.  *  GNU General Public License for more details.
  22.  *
  23.  *  You should have received a copy of the GNU General Public License
  24.  *  along with this program; if not, write to the Free Software
  25.  *  Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
  26.  *
  27.  *  Contacts:   gss@ispras.ru
  28.  *
  29.  */
  30. #include <assert.h>
  31. #include "destrn.h"
  32. #include "sctp.h"
  33. #include "strml.h"
  34. #include "fdcltrn.h"
  35. #include "xmem.h"
  36. extern char **scptab;
  37. extern i2_t maxscan;
  38. extern char *pbuflj;
  39. extern i4_t ljrsize;
  40. extern i4_t ljmsize;
  41. extern struct ADBL adlj;
  42. static
  43. int
  44. mod_tt_tuple(struct d_mesc *scpr, u2_t fmnum, u2_t *mfn, char *fl)
  45. {
  46.   struct des_trel *destrel;
  47.   struct des_field *df;
  48.   struct A pg;
  49.   struct des_tid *tid;
  50.   u2_t pn, newsize, fdf;
  51.   i2_t delta;
  52.   char *asp, *a;
  53.   u2_t *afi, *ai;
  54.   char *fval;
  55.   
  56.   destrel = (struct des_trel *) scpr->pobsc;
  57.   df = (struct des_field *) (destrel + 1);
  58.   fdf = destrel->fdftr;
  59.   if (testcmod (df, fdf, scpr->fmnsc, mfn, fl, &fval) != OK)
  60.     return (NCF);
  61.   tid = &((struct d_sc_r *) scpr)->curtid;
  62.   pn = tid->tpn;
  63.   asp = getwl (&pg, NRSNUM, pn);
  64.   afi = (u2_t *) (asp + phtrsize);
  65.   ai = afi + tid->tindex;
  66.   if (*ai == 0)
  67.     {
  68.       putwul (&pg, 'n');
  69.       scpr->prcrt = 0;
  70.       return (NCR);
  71.     }
  72.   assert (*ai <= BD_PAGESIZE);
  73.   a = asp + *ai;
  74.   newsize = cortform (df, fdf, destrel->fieldn, fl, fval, a, pbuflj, mfn);
  75.   delta = calsc (afi, ai) - newsize;
  76.   if (delta > 0)
  77.     comptr (asp, ai, delta);
  78.   if (delta >= 0)
  79.     {
  80.       bcopy (pbuflj, a, newsize);
  81.       putwul (&pg, 'm');
  82.     }
  83.   else
  84.     {
  85.       deltr (scpr, asp, ai, &(destrel->tobtr), pn);
  86.       putwul (&pg, 'm');
  87.       instr (&(destrel->tobtr), pbuflj, newsize);
  88.     }
  89.   return (OK);
  90. }
  91. static int
  92. mod_cort (char *fl, struct d_mesc *s, u2_t fmnum, u2_t *mfn,
  93.           struct d_r_t *desrel, struct des_tid *tid)
  94. {  
  95.   char *cort, *nc, *selc, *fval;
  96.   u2_t newsize, n, ni, ndc, corsize, fn, sn;
  97.   struct des_field *df;
  98.   i4_t rn;
  99.   CPNM cpn;
  100.   struct id_rel idr;
  101.   struct ADBL last_adlj;
  102.   struct des_tid ref_tid;
  103.   sn = desrel->segnr;
  104.   df = (struct des_field *) (desrel + 1);
  105.   if (testcmod (df, desrel->desrbd.fdfnum, fmnum, mfn, fl, &fval) != OK)
  106.     return (NCF);
  107.   cort = pbuflj + ljmsize;
  108.   if (readcort (sn, tid, cort, &corsize, &ref_tid) == NCR)
  109.     {
  110.       s->prcrt = 0;
  111.       return (NCR);
  112.     }
  113.   rn = desrel->desrbd.relnum;
  114.   fn = desrel->desrbd.fieldnum;
  115.   ndc = s->ndc;
  116.   idr.urn.segnum = sn;
  117.   idr.urn.obnum = rn;
  118.   idr.pagenum = desrel->pn_r;
  119.   idr.index = desrel->ind_r;
  120.   if (ndc < MAXCL)
  121.     {
  122.       if ((cpn = synlock (&idr, &desrel->desrbd, cort)) != 0)
  123. return (cpn);
  124.       s->ndc++;
  125.     }
  126.   else if (ndc == MAXCL)
  127.     {
  128.       selc = s->pslc;
  129.       if ((cpn = synlsc (s->modesc, &idr, selc + size2b, *(u2_t *) selc, fn, NULL)) != 0)
  130. return (cpn);
  131.       s->ndc++;
  132.     }
  133.   nc = cort + corsize;
  134.   newsize = cortform (df, desrel->desrbd.fdfnum, fn, fl, fval, cort, nc, mfn);
  135.   if ((cpn = synlock (&idr, &desrel->desrbd, nc)) != 0)
  136.     return (cpn);
  137.   modmes ();
  138.   last_adlj = adlj;
  139.   wmlj (MODLJ, ljmsize + corsize + newsize, &adlj, &idr, tid, 0);
  140.   if (newsize <size4b)
  141.     newsize = size4b;
  142.   ordmod (sn, rn, tid, &ref_tid, corsize, nc, newsize);
  143.   n = desrel->desrbd.indnum;
  144.   ni = mproind (desrel, n, cort, nc, tid);
  145.   if (ni < n)
  146.     {
  147.       wmlj (RLBLJ, ljrsize, &last_adlj, &idr, tid, 0);
  148.       mproind (desrel, ni + 1, nc, cort, tid);
  149.       ordmod (sn, rn, tid, &ref_tid, corsize, nc, newsize);
  150.       BUF_endop ();
  151.       return (NU);
  152.     }
  153.   BUF_endop ();
  154.   return (OK);
  155. }
  156. static
  157. int
  158. modcort (char *fl, struct d_mesc *s, u2_t scsz, struct d_r_t *desrel, struct des_tid *tid)
  159. {
  160.   u2_t *mfn;
  161.   
  162.   mfn = (u2_t *) ((char *) s + scsz + s->fnsc * size2b);
  163.   return (mod_cort( fl, s, s->fnsc, mfn, desrel, tid));
  164. }
  165. int
  166. mdfctn (i4_t scnum, char *fl)
  167. {
  168.   struct ldesscan *desscan;
  169.   struct d_mesc *scpr;
  170.   i4_t sctype;
  171.   
  172.   scpr = (struct d_mesc *) * (scptab + scnum);
  173.   if (scnum >= maxscan || scpr == NULL)
  174.     return (NDSC);
  175.   if (scpr->modesc != WSC && scpr->modesc != MSC)
  176.     return (NMS);
  177.   if (scpr->prcrt == 0)
  178.     return (NCR);
  179.   if ((sctype = scpr->obsc) == SCR)
  180.     { /* relation scan */
  181.       desscan = &((struct d_sc_i *) scpr)->dessc;
  182.       return (modcort (fl, scpr, scisize, (struct d_r_t *) scpr->pobsc, &desscan->ctidi));
  183.     }
  184.   else if (sctype == SCTR)
  185.     {
  186.       u2_t *mfn;
  187.       mfn = (u2_t *) ((char *) scpr + scrsize + scpr->fnsc * size2b);
  188.       return (mod_tt_tuple (scpr, scpr->fmnsc, mfn, fl));
  189.     }
  190.   else if (sctype == SCI)
  191.     { /* index scan */
  192.       desscan = &((struct d_sc_i *) scpr)->dessc;
  193.       return (modcort (fl, scpr, scisize, desscan->pdi->dri, &desscan->ctidi));
  194.     }
  195.   else
  196.     { /* filter scan */
  197.       struct d_sc_f *scfltr;
  198.       char *asp;
  199.       struct A pg;
  200.       struct des_tid *tid;
  201.       scfltr = (struct d_sc_f *) scpr;
  202.       asp = getwl (&pg, NRSNUM, scfltr->pnf);
  203.       tid = (struct des_tid *) (asp + scfltr->offf);
  204.       putwul (&pg, 'n');
  205.       return (modcort (fl, scpr, scfsize, ((struct des_fltr *) scpr->pobsc)->pdrtf, tid));
  206.     }
  207. }
  208. int
  209. testcmod (struct des_field *df, u2_t fdf, u2_t fmn, u2_t *mfn, char *fml, char **fval)
  210. {
  211.   u2_t i,fn,type;
  212.   unsigned char t;
  213.   i4_t sst;
  214.   char *a, *sc;
  215.   sst = 1;
  216.   a = fml;
  217.   for (i = 0; ((t = selsc1 (&a, sst++)) != ENDSC) && (i < fmn); i++)
  218.     {
  219.       fn = mfn[i];
  220.       if (t != EQ && t != NEQ && t != EQUN)
  221. return (NCF);
  222.       if (fn < fdf && t == EQUN)
  223. return (NCF);
  224.     }
  225.   if (t != ENDSC)
  226.     return (NCF);
  227.   if (sst % 2 == 0)
  228.     a++;
  229.   *fval = a;
  230.   sst = 1;
  231.   sc = fml; 
  232.   for (i = 0; (t = selsc1 (&sc, sst++)) != ENDSC; i++)
  233.     {
  234.       fn = mfn[i];
  235.       if(t2bunpack(a)>(df+fn)->field_size) return(NCF);
  236.       type= (df+fn)->field_type;
  237.       if(type== T1B || type==T2B || type==T4B || type== TFLOAT)
  238. a+=size2b;
  239.       a=proval(a,type);
  240.     }  
  241.   return (OK);
  242. }
  243. int
  244. mod_spec_flds (i4_t scnum, u2_t fmnum, u2_t * fmn, char * fl)
  245. {
  246.   struct ldesscan *desscan;
  247.   struct d_mesc *scpr;
  248.   i4_t sctype;
  249.   scpr = (struct d_mesc *) * (scptab + scnum);
  250.   if (scnum >= maxscan || scpr == NULL)
  251.     return (NDSC);
  252.   if (scpr->modesc != WSC && scpr->modesc != MSC)
  253.     return (NMS);
  254.   if (scpr->prcrt == 0)
  255.     return (NCR);
  256.   if ((sctype = scpr->obsc) == SCR)
  257.     { /* relation scan */
  258.       desscan = &((struct d_sc_i *) scpr)->dessc;
  259.       return (mod_cort (fl, scpr, fmnum, fmn, (struct d_r_t *) scpr->pobsc, &desscan->ctidi));
  260.     }
  261.   else if (sctype == SCTR)
  262.     {
  263.       return (mod_tt_tuple (scpr, fmnum, fmn, fl));
  264.     }
  265.   else if (sctype == SCI)
  266.     { /* index scan */
  267.       desscan = &((struct d_sc_i *) scpr)->dessc;
  268.       return (mod_cort (fl, scpr, fmnum, fmn, desscan->pdi->dri, &desscan->ctidi));
  269.     }
  270.   else
  271.     { /* filter scan */
  272.       struct d_sc_f *scfltr;
  273.       char *asp;
  274.       struct A pg;
  275.       struct des_tid *tid;
  276.       scfltr = (struct d_sc_f *) scpr;
  277.       asp = getwl (&pg, NRSNUM, scfltr->pnf);
  278.       tid = (struct des_tid *) (asp + scfltr->offf);
  279.       putwul (&pg, 'n');
  280.       return (mod_cort (fl, scpr, fmnum, fmn, ((struct des_fltr *) scpr->pobsc)->pdrtf, tid));
  281.     }
  282. }