mariadb/heap/hp_open.c

93 lines
2.6 KiB
C
Raw Normal View History

2000-07-31 21:29:14 +02:00
/* Copyright (C) 2000 MySQL AB & MySQL Finland AB & TCX DataKonsult AB
2000-07-31 21:29:14 +02:00
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
2000-07-31 21:29:14 +02:00
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
2000-07-31 21:29:14 +02:00
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
/* open a heap-database */
#include "heapdef.h"
#ifdef VMS
#include "hp_static.c" /* Stupid vms-linker */
#endif
#include "my_sys.h"
2002-06-07 13:47:36 +02:00
HP_INFO *heap_open(const char *name, int mode)
{
2000-07-31 21:29:14 +02:00
HP_INFO *info;
HP_SHARE *share;
2000-07-31 21:29:14 +02:00
DBUG_ENTER("heap_open");
pthread_mutex_lock(&THR_LOCK_heap);
2002-06-07 13:47:36 +02:00
if (!(share= hp_find_named_heap(name)))
2000-07-31 21:29:14 +02:00
{
2002-06-07 13:47:36 +02:00
my_errno= ENOENT;
pthread_mutex_unlock(&THR_LOCK_heap);
DBUG_RETURN(0);
2000-07-31 21:29:14 +02:00
}
2002-06-07 13:47:36 +02:00
if (!(info= (HP_INFO*) my_malloc((uint) sizeof(HP_INFO) +
2 * share->max_key_length,
2000-07-31 21:29:14 +02:00
MYF(MY_ZEROFILL))))
{
pthread_mutex_unlock(&THR_LOCK_heap);
DBUG_RETURN(0);
}
2002-06-07 13:47:36 +02:00
share->open_count++;
2000-07-31 21:29:14 +02:00
#ifdef THREAD
thr_lock_data_init(&share->lock,&info->lock,NULL);
#endif
info->open_list.data= (void*) info;
heap_open_list= list_add(heap_open_list,&info->open_list);
2000-07-31 21:29:14 +02:00
pthread_mutex_unlock(&THR_LOCK_heap);
info->s= share;
info->lastkey= (byte*) (info + 1);
info->recbuf= (byte*) (info->lastkey + share->max_key_length);
info->mode= mode;
2000-07-31 21:29:14 +02:00
info->current_record= (ulong) ~0L; /* No current record */
info->current_ptr= 0;
info->current_hash_ptr= 0;
info->lastinx= info->errkey= -1;
info->update= 0;
2000-07-31 21:29:14 +02:00
#ifndef DBUG_OFF
info->opt_flag= READ_CHECK_USED; /* Check when changing */
2000-07-31 21:29:14 +02:00
#endif
DBUG_PRINT("exit",("heap: 0x%lx reclength: %d records_in_block: %d",
2000-07-31 21:29:14 +02:00
info,share->reclength,share->block.records_in_block));
DBUG_RETURN(info);
2002-06-07 13:47:36 +02:00
}
2000-07-31 21:29:14 +02:00
/* map name to a heap-nr. If name isn't found return 0 */
HP_SHARE *hp_find_named_heap(const char *name)
2000-07-31 21:29:14 +02:00
{
LIST *pos;
HP_SHARE *info;
DBUG_ENTER("heap_find");
DBUG_PRINT("enter",("name: %s",name));
2002-06-07 13:47:36 +02:00
for (pos= heap_share_list; pos; pos= pos->next)
2000-07-31 21:29:14 +02:00
{
2002-06-07 13:47:36 +02:00
info= (HP_SHARE*) pos->data;
if (!strcmp(name, info->name))
2000-07-31 21:29:14 +02:00
{
DBUG_PRINT("exit", ("Old heap_database: 0x%lx",info));
2000-07-31 21:29:14 +02:00
DBUG_RETURN(info);
}
}
2002-06-07 13:47:36 +02:00
DBUG_RETURN((HP_SHARE *) 0);
2000-07-31 21:29:14 +02:00
}