home *** CD-ROM | disk | FTP | other *** search
/ Chip 2001 January / Chip_2001-01_cd1.bin / tema / mysql / mysql-3.23.28g-win-source.exe / myisammrg / myrg_rnext.c < prev    next >
C/C++ Source or Header  |  2000-09-14  |  3KB  |  87 lines

  1. /* Copyright (C) 2000 MySQL AB & MySQL Finland AB & TCX DataKonsult AB
  2.  
  3.    This program is free software; you can redistribute it and/or modify
  4.    it under the terms of the GNU General Public License as published by
  5.    the Free Software Foundation; either version 2 of the License, or
  6.    (at your option) any later version.
  7.  
  8.    This program is distributed in the hope that it will be useful,
  9.    but WITHOUT ANY WARRANTY; without even the implied warranty of
  10.    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  11.    GNU General Public License for more details.
  12.  
  13.    You should have received a copy of the GNU General Public License
  14.    along with this program; if not, write to the Free Software
  15.    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA */
  16.  
  17. #include "mymrgdef.h"
  18.  
  19.     /*
  20.        Read next row with the same key as previous read
  21.     */
  22.  
  23. int myrg_rnext(MYRG_INFO *info, byte *buf, int inx)
  24. {
  25.   int err;
  26.   MI_INFO *mi;
  27.  
  28.   /* at first, do rnext for the table found before */
  29.   if ((err=mi_rnext(info->current_table->table,NULL,inx)))
  30.   {
  31.     if (err == HA_ERR_END_OF_FILE)
  32.     {
  33.       queue_remove(&(info->by_key),0);
  34.       if (!info->by_key.elements)
  35.     return HA_ERR_END_OF_FILE;
  36.     }
  37.     else
  38.       return err;
  39.   }
  40.   else
  41.   {
  42.     /* Found here, adding to queue */
  43.     queue_top(&(info->by_key))=(byte *)(info->current_table);
  44.     queue_replaced(&(info->by_key));
  45.   }
  46.  
  47.   /* next, let's finish myrg_rkey's initial scan */
  48.   if ((err=_myrg_finish_scan(info, inx, HA_READ_KEY_OR_NEXT)))
  49.     return err;
  50.  
  51.   /* now, mymerge's read_next is as simple as one queue_top */
  52.   mi=(info->current_table=(MYRG_TABLE *)queue_top(&(info->by_key)))->table;
  53.   return mi_rrnd(mi,buf,mi->lastpos);
  54. }
  55.  
  56.  
  57. /* let's finish myrg_rkey's initial scan */
  58.  
  59. int _myrg_finish_scan(MYRG_INFO *info, int inx, enum ha_rkey_function type)
  60. {
  61.   int err;
  62.   MYRG_TABLE *table=info->last_used_table;
  63.   if (table < info->end_table)
  64.   {
  65.     MI_INFO *mi= table[-1].table;
  66.     byte *key_buff=(byte*) mi->lastkey+mi->s->base.max_key_length;
  67.     uint pack_key_length=  mi->last_rkey_length;
  68.  
  69.     for (; table < info->end_table ; table++)
  70.     {
  71.       mi=table->table;
  72.       if ((err=_mi_rkey(mi,NULL,inx,key_buff,pack_key_length,
  73.             type,FALSE)))
  74.       {
  75.     if (err == HA_ERR_KEY_NOT_FOUND)    /* If end of file */
  76.       continue;
  77.     return err;
  78.       }
  79.       /* Found here, adding to queue */
  80.       queue_insert(&(info->by_key),(byte *) table);
  81.     }
  82.     /* All tables are now used */
  83.     info->last_used_table=table;
  84.   }
  85.   return 0;
  86. }
  87.