
SetFile has an optional style argument which defaulted to the native style. This patch makes that argument mandatory so clients of the FileSpec class are forced to think about the correct syntax. At the same time this introduces a (protected) convenience method to update the file from within the FileSpec class that keeps the current style. These two changes together prevent a potential pitfall where the style might be forgotten, leading to the path being updated and the style unintentionally being changed to the host style. llvm-svn: 334663
76 lines
1.9 KiB
C++
76 lines
1.9 KiB
C++
//===-- FileSystem.cpp ------------------------------------------*- C++ -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "lldb/Host/FileSystem.h"
|
|
|
|
// C includes
|
|
#include <dirent.h>
|
|
#include <sys/mount.h>
|
|
#include <sys/param.h>
|
|
#include <sys/stat.h>
|
|
#include <sys/types.h>
|
|
#include <unistd.h>
|
|
#if defined(__NetBSD__)
|
|
#include <sys/statvfs.h>
|
|
#endif
|
|
|
|
// lldb Includes
|
|
#include "lldb/Host/Host.h"
|
|
#include "lldb/Utility/Status.h"
|
|
#include "lldb/Utility/StreamString.h"
|
|
|
|
#include "llvm/Support/FileSystem.h"
|
|
|
|
using namespace lldb;
|
|
using namespace lldb_private;
|
|
|
|
const char *FileSystem::DEV_NULL = "/dev/null";
|
|
|
|
Status FileSystem::Symlink(const FileSpec &src, const FileSpec &dst) {
|
|
Status error;
|
|
if (::symlink(dst.GetCString(), src.GetCString()) == -1)
|
|
error.SetErrorToErrno();
|
|
return error;
|
|
}
|
|
|
|
Status FileSystem::Readlink(const FileSpec &src, FileSpec &dst) {
|
|
Status error;
|
|
char buf[PATH_MAX];
|
|
ssize_t count = ::readlink(src.GetCString(), buf, sizeof(buf) - 1);
|
|
if (count < 0)
|
|
error.SetErrorToErrno();
|
|
else {
|
|
buf[count] = '\0'; // Success
|
|
dst.SetFile(buf, false, FileSpec::Style::native);
|
|
}
|
|
return error;
|
|
}
|
|
|
|
Status FileSystem::ResolveSymbolicLink(const FileSpec &src, FileSpec &dst) {
|
|
char resolved_path[PATH_MAX];
|
|
if (!src.GetPath(resolved_path, sizeof(resolved_path))) {
|
|
return Status("Couldn't get the canonical path for %s", src.GetCString());
|
|
}
|
|
|
|
char real_path[PATH_MAX + 1];
|
|
if (realpath(resolved_path, real_path) == nullptr) {
|
|
Status err;
|
|
err.SetErrorToErrno();
|
|
return err;
|
|
}
|
|
|
|
dst = FileSpec(real_path, false);
|
|
|
|
return Status();
|
|
}
|
|
|
|
FILE *FileSystem::Fopen(const char *path, const char *mode) {
|
|
return ::fopen(path, mode);
|
|
}
|