Commit 8444cabd authored by unknown's avatar unknown

fix for bug#5650 ('replace' does not follow symlinks)

fix now checks if the original (from) file is a symlink and uses the
link name. This prevents creation of a new file (and loss of symlink)
when renaming the tempfile. 
parent eaa81cf5
...@@ -1053,12 +1053,18 @@ static int convert_file(REPLACE *rep, my_string name) ...@@ -1053,12 +1053,18 @@ static int convert_file(REPLACE *rep, my_string name)
int error; int error;
FILE *in,*out; FILE *in,*out;
char dir_buff[FN_REFLEN], tempname[FN_REFLEN]; char dir_buff[FN_REFLEN], tempname[FN_REFLEN];
char link_name[FN_REFLEN], *org_name = name;
File temp_file; File temp_file;
DBUG_ENTER("convert_file"); DBUG_ENTER("convert_file");
if (!(in=my_fopen(name,O_RDONLY,MYF(MY_WME)))) /* check if name is a symlink */
#ifdef HAVE_READLINK
org_name= (!my_disable_symlinks &&
!my_readlink(link_name, name, MYF(0))) ? link_name : name;
#endif
if (!(in= my_fopen(org_name,O_RDONLY,MYF(MY_WME))))
DBUG_RETURN(1); DBUG_RETURN(1);
dirname_part(dir_buff,name); dirname_part(dir_buff,org_name);
if ((temp_file= create_temp_file(tempname, dir_buff, "PR", O_WRONLY, if ((temp_file= create_temp_file(tempname, dir_buff, "PR", O_WRONLY,
MYF(MY_WME))) < 0) MYF(MY_WME))) < 0)
{ {
...@@ -1075,7 +1081,7 @@ static int convert_file(REPLACE *rep, my_string name) ...@@ -1075,7 +1081,7 @@ static int convert_file(REPLACE *rep, my_string name)
my_fclose(in,MYF(0)); my_fclose(out,MYF(0)); my_fclose(in,MYF(0)); my_fclose(out,MYF(0));
if (updated && ! error) if (updated && ! error)
my_redel(name,tempname,MYF(MY_WME | MY_LINK_WARNING)); my_redel(org_name,tempname,MYF(MY_WME | MY_LINK_WARNING));
else else
my_delete(tempname,MYF(MY_WME)); my_delete(tempname,MYF(MY_WME));
if (!silent && ! error) if (!silent && ! error)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment