myrg_create.c 2.09 KB
Newer Older
bk@work.mysql.com's avatar
bk@work.mysql.com committed
1
/* Copyright (C) 2000 MySQL AB & MySQL Finland AB & TCX DataKonsult AB
monty@hundin.mysql.fi's avatar
monty@hundin.mysql.fi committed
2

bk@work.mysql.com's avatar
bk@work.mysql.com committed
3 4 5 6
   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.
monty@hundin.mysql.fi's avatar
monty@hundin.mysql.fi committed
7

bk@work.mysql.com's avatar
bk@work.mysql.com committed
8 9 10 11
   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.
monty@hundin.mysql.fi's avatar
monty@hundin.mysql.fi committed
12

bk@work.mysql.com's avatar
bk@work.mysql.com committed
13 14 15 16 17 18
   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 */

/* Create a MYMERGE_-file */

19
#include "myrg_def.h"
bk@work.mysql.com's avatar
bk@work.mysql.com committed
20 21 22 23 24 25

	/* create file named 'name' and save filenames in it
	   table_names should be NULL or a vector of string-pointers with
	   a NULL-pointer last
	   */

26 27
int myrg_create(const char *name, const char **table_names,
                uint insert_method, my_bool fix_names)
bk@work.mysql.com's avatar
bk@work.mysql.com committed
28 29 30 31 32 33 34 35 36
{
  int save_errno;
  uint errpos;
  File file;
  char buff[FN_REFLEN],*end;
  DBUG_ENTER("myrg_create");

  errpos=0;
  if ((file = my_create(fn_format(buff,name,"",MYRG_NAME_EXT,4),0,
37
       O_RDWR | O_EXCL | O_NOFOLLOW,MYF(MY_WME))) < 0)
bk@work.mysql.com's avatar
bk@work.mysql.com committed
38 39 40
    goto err;
  errpos=1;
  if (table_names)
41
  {
bk@work.mysql.com's avatar
bk@work.mysql.com committed
42 43 44
    for ( ; *table_names ; table_names++)
    {
      strmov(buff,*table_names);
45 46
      if (fix_names)
	fn_same(buff,name,4);
bk@work.mysql.com's avatar
bk@work.mysql.com committed
47
      *(end=strend(buff))='\n';
48 49
      end[1]=0;
      if (my_write(file,buff,(uint) (end-buff+1),
bk@work.mysql.com's avatar
bk@work.mysql.com committed
50 51 52
		   MYF(MY_WME | MY_NABP)))
	goto err;
    }
53
  }
54 55 56
  if (insert_method != MERGE_INSERT_DISABLED)
  {
    end=strxmov(buff,"#INSERT_METHOD=",
57
		get_type(&merge_insert_method,insert_method-1),"\n",NullS);
58 59 60
    if (my_write(file,buff,(uint) (end-buff),MYF(MY_WME | MY_NABP)))
        goto err;
  }
bk@work.mysql.com's avatar
bk@work.mysql.com committed
61 62 63 64 65 66 67 68 69 70 71 72
  if (my_close(file,MYF(0)))
    goto err;
  DBUG_RETURN(0);

err:
  save_errno=my_errno ? my_errno : -1;
  switch (errpos) {
  case 1:
    VOID(my_close(file,MYF(0)));
  }
  DBUG_RETURN(my_errno=save_errno);
} /* myrg_create */