1
/* Copyright (C) 2000-2003 MySQL AB
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; version 2 of the License.
7
This program is distributed in the hope that it will be useful,
8
but WITHOUT ANY WARRANTY; without even the implied warranty of
9
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
10
GNU General Public License for more details.
12
You should have received a copy of the GNU General Public License
13
along with this program; if not, write to the Free Software
14
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
19
Read next row with the same key as previous read
22
int myrg_rnext(MYRG_INFO *info, uchar *buf, int inx)
27
if (!info->current_table)
28
return (HA_ERR_KEY_NOT_FOUND);
30
/* at first, do rnext for the table found before */
31
if ((err=mi_rnext(info->current_table->table,NULL,inx)))
33
if (err == HA_ERR_END_OF_FILE)
35
queue_remove(&(info->by_key),0);
36
if (!info->by_key.elements)
37
return HA_ERR_END_OF_FILE;
44
/* Found here, adding to queue */
45
queue_top(&(info->by_key))=(uchar *)(info->current_table);
46
queue_replaced(&(info->by_key));
49
/* now, mymerge's read_next is as simple as one queue_top */
50
mi=(info->current_table=(MYRG_TABLE *)queue_top(&(info->by_key)))->table;
51
return _myrg_mi_read_record(mi,buf);