mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-14 14:03:58 +00:00
Use a symlink instead of a hard link for fishd.socket compatibility path
On OS X, work around filesystem corruption triggered by having hard links in /tmp, by using a symlink instead.
This commit is contained in:
parent
0986b6d991
commit
b3aa187867
1 changed files with 10 additions and 1 deletions
11
fishd.cpp
11
fishd.cpp
|
@ -626,12 +626,21 @@ repeat:
|
||||||
|
|
||||||
// Attempt to hardlink the old socket name so that old versions of fish keep working on upgrade
|
// Attempt to hardlink the old socket name so that old versions of fish keep working on upgrade
|
||||||
// Not critical if it fails
|
// Not critical if it fails
|
||||||
|
// On OS X, we use symlinks instead of hardlinks to work around a filesystem corruption bug http://openradar.appspot.com/19687545
|
||||||
|
// On Linux, we use hardlinks instead of symlinks for compatibility with the Yama security model - see #1859
|
||||||
|
int (*linkfunc)(const char *, const char *);
|
||||||
|
#if __APPLE__
|
||||||
|
linkfunc = symlink;
|
||||||
|
#else
|
||||||
|
linkfunc = link;
|
||||||
|
#endif
|
||||||
|
|
||||||
if (unlink(old_sock_name.c_str()) != 0 && errno != ENOENT)
|
if (unlink(old_sock_name.c_str()) != 0 && errno != ENOENT)
|
||||||
{
|
{
|
||||||
debug(0, L"Could not create legacy socket path");
|
debug(0, L"Could not create legacy socket path");
|
||||||
wperror(L"unlink");
|
wperror(L"unlink");
|
||||||
}
|
}
|
||||||
else if (link(sock_name.c_str(), old_sock_name.c_str()) != 0)
|
else if (linkfunc(sock_name.c_str(), old_sock_name.c_str()) != 0)
|
||||||
{
|
{
|
||||||
debug(0, L"Could not create legacy socket path");
|
debug(0, L"Could not create legacy socket path");
|
||||||
wperror(L"link");
|
wperror(L"link");
|
||||||
|
|
Loading…
Reference in a new issue