summaryrefslogtreecommitdiff
path: root/mysys
diff options
context:
space:
mode:
authorjimw@mysql.com <>2005-02-23 13:59:04 -0800
committerjimw@mysql.com <>2005-02-23 13:59:04 -0800
commit3ecabaa9f7c0f6cf5d38391c5e38580d798802fa (patch)
treef51e092086c91300bf59f2ff67c407425d2f51f9 /mysys
parenta50be4d42b9ea0cfd6a73c387e0039a6aad3b887 (diff)
downloadmariadb-git-3ecabaa9f7c0f6cf5d38391c5e38580d798802fa.tar.gz
Don't try to create a symlink if the DATA DIRECTORY specified for a table
is the same as the normal datadir for that database. (Bug #8707)
Diffstat (limited to 'mysys')
-rw-r--r--mysys/my_symlink2.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/mysys/my_symlink2.c b/mysys/my_symlink2.c
index 913f632fbb4..80dca7d56ac 100644
--- a/mysys/my_symlink2.c
+++ b/mysys/my_symlink2.c
@@ -32,6 +32,7 @@ File my_create_with_symlink(const char *linkname, const char *filename,
int tmp_errno;
/* Test if we should create a link */
int create_link;
+ char abs_linkname[FN_REFLEN];
DBUG_ENTER("my_create_with_symlink");
if (my_disable_symlinks)
@@ -42,7 +43,11 @@ File my_create_with_symlink(const char *linkname, const char *filename,
filename= linkname;
}
else
- create_link= (linkname && strcmp(linkname,filename));
+ {
+ if (linkname)
+ my_realpath(&abs_linkname, linkname, MYF(0));
+ create_link= (linkname && strcmp(abs_linkname,filename));
+ }
if (!(MyFlags & MY_DELETE_OLD))
{