mirror of
https://github.com/ksherlock/afp.git
synced 2025-01-05 04:29:26 +00:00
linux compile fixup
This commit is contained in:
parent
f398ac94f0
commit
240cc298b6
@ -1,37 +1,28 @@
|
|||||||
#include "finder_info.h"
|
#include "finder_info.h"
|
||||||
|
#include "xattr.h"
|
||||||
|
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
|
#if defined (_WIN32)
|
||||||
|
#define WIN32_LEAN_AND_MEAN
|
||||||
|
#include <windows.h>
|
||||||
|
#define XATTR_FINDERINFO_NAME "AFP_AfpInfo"
|
||||||
|
#else
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
#if defined(__APPLE__)
|
#if defined(__APPLE__)
|
||||||
#include <sys/xattr.h>
|
#include <sys/xattr.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(__linux__)
|
#if defined(__linux__)
|
||||||
#include <sys/xattr.h>
|
|
||||||
#define XATTR_FINDERINFO_NAME "user.com.apple.FinderInfo"
|
#define XATTR_FINDERINFO_NAME "user.com.apple.FinderInfo"
|
||||||
#define XATTR_RESOURCEFORK_NAME "user.com.apple.ResourceFork"
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(__FreeBSD__)
|
|
||||||
#include <sys/types.h>
|
|
||||||
#include <sys/extattr.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(_AIX)
|
|
||||||
#include <sys/ea.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
#if defined (_WIN32)
|
|
||||||
#include <windows.h>
|
|
||||||
#define XATTR_FINDERINFO_NAME "AFP_AfpInfo"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef XATTR_FINDERINFO_NAME
|
#ifndef XATTR_FINDERINFO_NAME
|
||||||
#define XATTR_FINDERINFO_NAME "com.apple.FinderInfo"
|
#define XATTR_FINDERINFO_NAME "com.apple.FinderInfo"
|
||||||
@ -213,87 +204,6 @@ namespace {
|
|||||||
return t;
|
return t;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* extended attributes functions.
|
|
||||||
*/
|
|
||||||
#if defined(__APPLE__)
|
|
||||||
ssize_t size_xattr(int fd, const char *xattr) {
|
|
||||||
return fgetxattr(fd, xattr, NULL, 0, 0, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
ssize_t read_xattr(int fd, const char *xattr, void *buffer, size_t size) {
|
|
||||||
return fgetxattr(fd, xattr, buffer, size, 0, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
ssize_t write_xattr(int fd, const char *xattr, const void *buffer, size_t size) {
|
|
||||||
if (fsetxattr(fd, xattr, buffer, size, 0, 0) < 0) return -1;
|
|
||||||
return size;
|
|
||||||
}
|
|
||||||
|
|
||||||
int remove_xattr(int fd, const char *xattr) {
|
|
||||||
return fremovexattr(fd, xattr, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
#elif defined(__linux__)
|
|
||||||
ssize_t size_xattr(int fd, const char *xattr) {
|
|
||||||
return fgetxattr(fd, xattr, NULL, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
ssize_t read_xattr(int fd, const char *xattr, void *buffer, size_t size) {
|
|
||||||
return fgetxattr(fd, xattr, buffer, size);
|
|
||||||
}
|
|
||||||
|
|
||||||
ssize_t write_xattr(int fd, const char *xattr, const void *buffer, size_t size) {
|
|
||||||
if (fsetxattr(fd, xattr, buffer, size, 0) < 0) return -1;
|
|
||||||
return size;
|
|
||||||
}
|
|
||||||
|
|
||||||
int remove_xattr(int fd, const char *xattr) {
|
|
||||||
return fremovexattr(fd, xattr);
|
|
||||||
}
|
|
||||||
|
|
||||||
#elif defined(__FreeBSD__)
|
|
||||||
ssize_t size_xattr(int fd, const char *xattr) {
|
|
||||||
return extattr_get_fd(fd, EXTATTR_NAMESPACE_USER, xattr, NULL, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
ssize_t read_xattr(int fd, const char *xattr, void *buffer, size_t size) {
|
|
||||||
return extattr_get_fd(fd, EXTATTR_NAMESPACE_USER, xattr, buffer, size);
|
|
||||||
}
|
|
||||||
|
|
||||||
ssize_t write_xattr(int fd, const char *xattr, const void *buffer, size_t size) {
|
|
||||||
return extattr_set_fd(fd, EXTATTR_NAMESPACE_USER, xattr, buffer, size);
|
|
||||||
}
|
|
||||||
|
|
||||||
int remove_xattr(int fd, const char *xattr) {
|
|
||||||
return extattr_delete_fd(fd, EXTATTR_NAMESPACE_USER, xattr);
|
|
||||||
}
|
|
||||||
|
|
||||||
#elif defined(_AIX)
|
|
||||||
ssize_t size_xattr(int fd, const char *xattr) {
|
|
||||||
/*
|
|
||||||
struct stat64x st;
|
|
||||||
if (fstatea(fd, xattr, &st) < 0) return -1;
|
|
||||||
return st.st_size;
|
|
||||||
*/
|
|
||||||
return fgetea(fd, xattr, NULL, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
ssize_t read_xattr(int fd, const char *xattr, void *buffer, size_t size) {
|
|
||||||
return fgetea(fd, xattr, buffer, size);
|
|
||||||
}
|
|
||||||
|
|
||||||
ssize_t write_xattr(int fd, const char *xattr, const void *buffer, size_t size) {
|
|
||||||
if (fsetea(fd, xattr, buffer, size, 0) < 0) return -1;
|
|
||||||
return size;
|
|
||||||
}
|
|
||||||
|
|
||||||
int remove_xattr(int fd, const char *xattr) {
|
|
||||||
return fremoveea(fd, xattr);
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
void set_or_throw_error(std::error_code *ec, int error, const std::string &what) {
|
void set_or_throw_error(std::error_code *ec, int error, const std::string &what) {
|
||||||
if (ec) *ec = std::error_code(error, std::system_category());
|
if (ec) *ec = std::error_code(error, std::system_category());
|
||||||
@ -423,6 +333,11 @@ namespace {
|
|||||||
|
|
||||||
#else
|
#else
|
||||||
|
|
||||||
|
void set_or_throw_error(std::error_code *ec, const std::string &what) {
|
||||||
|
auto e = errno;
|
||||||
|
set_or_throw_error(ec, e, what);
|
||||||
|
}
|
||||||
|
|
||||||
void fi_close(int fd) {
|
void fi_close(int fd) {
|
||||||
close(fd);
|
close(fd);
|
||||||
}
|
}
|
||||||
@ -538,7 +453,7 @@ void finder_info::close() {
|
|||||||
if (_fd != INVALID_HANDLE_VALUE) CloseHandle(_fd);
|
if (_fd != INVALID_HANDLE_VALUE) CloseHandle(_fd);
|
||||||
_fd = INVALID_HANDLE_VALUE;
|
_fd = INVALID_HANDLE_VALUE;
|
||||||
#else
|
#else
|
||||||
if (_fd >= 0) close(_fd);
|
if (_fd >= 0) ::close(_fd);
|
||||||
_fd = -1;
|
_fd = -1;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -1,6 +1,8 @@
|
|||||||
#include "resource_fork.h"
|
#include "resource_fork.h"
|
||||||
#include "xattr.h"
|
#include "xattr.h"
|
||||||
|
|
||||||
|
#include <cstring>
|
||||||
|
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
#define WIN32_LEAN_AND_MEAN
|
#define WIN32_LEAN_AND_MEAN
|
||||||
#include <windows.h>
|
#include <windows.h>
|
||||||
@ -97,12 +99,12 @@ namespace {
|
|||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
void set_or_throw_error(std::error_code *ec, const char *what) {
|
void set_or_throw_error(std::error_code *ec, const char *what) {
|
||||||
auto e = errno
|
auto e = errno;
|
||||||
set_or_throw_error(ec, e, what);
|
set_or_throw_error(ec, e, what);
|
||||||
}
|
}
|
||||||
|
|
||||||
void set_or_throw_error(std::error_code *ec, const std::string &what) {
|
void set_or_throw_error(std::error_code *ec, const std::string &what) {
|
||||||
auto e = errno
|
auto e = errno;
|
||||||
set_or_throw_error(ec, e, what);
|
set_or_throw_error(ec, e, what);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -237,9 +239,9 @@ namespace afp {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
resource_fork::close() {
|
void resource_fork::close() {
|
||||||
close(_fd);
|
::close(_fd);
|
||||||
_fd = -;1
|
_fd = -1;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -256,9 +258,9 @@ namespace afp {
|
|||||||
case write_only umode = O_WRONLY | O_CREAT; break;
|
case write_only umode = O_WRONLY | O_CREAT; break;
|
||||||
case read_write: umode = O_RDWR | O_CREAT; break;
|
case read_write: umode = O_RDWR | O_CREAT; break;
|
||||||
}
|
}
|
||||||
_fd = attropen(path.c_str(), XATTR_RESOURCEFORK_NAME, umode, 0666);
|
_fd = ::attropen(path.c_str(), XATTR_RESOURCEFORK_NAME, umode, 0666);
|
||||||
if (_fd < 0) {
|
if (_fd < 0) {
|
||||||
set_or_throw_error(ec, "attropen");
|
set_or_throw_error(&ec, "attropen");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
@ -283,9 +285,9 @@ namespace afp {
|
|||||||
case read_write: umode = O_RDWR | O_CREAT; break;
|
case read_write: umode = O_RDWR | O_CREAT; break;
|
||||||
}
|
}
|
||||||
|
|
||||||
_fd = open(s.c_str(), umode, 0666);
|
_fd = ::open(s.c_str(), umode, 0666);
|
||||||
if (_fd < 0) {
|
if (_fd < 0) {
|
||||||
set_or_throw_error(ec, "open");
|
set_or_throw_error(&ec, "open");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
@ -296,9 +298,9 @@ namespace afp {
|
|||||||
#ifdef FD_RESOURCE_FORK
|
#ifdef FD_RESOURCE_FORK
|
||||||
size_t resource_fork::read(void *buffer, size_t n, std::error_code &) {
|
size_t resource_fork::read(void *buffer, size_t n, std::error_code &) {
|
||||||
ec.clear();
|
ec.clear();
|
||||||
auto rv = read(_fd, buffer, n);
|
auto rv = ::read(_fd, buffer, n);
|
||||||
if (rv < 0) {
|
if (rv < 0) {
|
||||||
set_or_throw_error(ec, "read");
|
set_or_throw_error(&ec, "read");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
return rv;
|
return rv;
|
||||||
@ -306,9 +308,9 @@ namespace afp {
|
|||||||
|
|
||||||
size_t resource_fork::write(const void *buffer, size_t n, std::error_code &) {
|
size_t resource_fork::write(const void *buffer, size_t n, std::error_code &) {
|
||||||
ec.clear();
|
ec.clear();
|
||||||
auto rv = write(_fd, buffer, n);
|
auto rv = ::write(_fd, buffer, n);
|
||||||
if (rv < 0) {
|
if (rv < 0) {
|
||||||
set_or_throw_error(ec, "write");
|
set_or_throw_error(&ec, "write");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
return rv;
|
return rv;
|
||||||
@ -316,8 +318,8 @@ namespace afp {
|
|||||||
|
|
||||||
bool resource_fork::truncate(size_t pos, std::error_code &ec) {
|
bool resource_fork::truncate(size_t pos, std::error_code &ec) {
|
||||||
ec.clear();
|
ec.clear();
|
||||||
if (ftruncate(_fd, pos) < 0) {
|
if (::ftruncate(_fd, pos) < 0) {
|
||||||
set_or_throw_error(ec, "ftruncate");
|
set_or_throw_error(&ec, "ftruncate");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
@ -325,8 +327,8 @@ namespace afp {
|
|||||||
|
|
||||||
bool resource_fork::seek(size_t pos, std::error_code &ec) {
|
bool resource_fork::seek(size_t pos, std::error_code &ec) {
|
||||||
ec.clear();
|
ec.clear();
|
||||||
if (lseek(_fd, pos, SEEK_SET) < 0) {
|
if (::lseek(_fd, pos, SEEK_SET) < 0) {
|
||||||
set_or_throw_error(ec, "lseek");
|
set_or_throw_error(&ec, "lseek");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
@ -336,7 +338,7 @@ namespace afp {
|
|||||||
ec.clear();
|
ec.clear();
|
||||||
struct stat st;
|
struct stat st;
|
||||||
if (fstat(_fd, &st) < 0) {
|
if (fstat(_fd, &st) < 0) {
|
||||||
set_or_throw_error(ec, "fstat");
|
set_or_throw_error(&ec, "fstat");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
return st.st_size;
|
return st.st_size;
|
||||||
@ -363,7 +365,7 @@ namespace afp {
|
|||||||
if (errno == ENOATTR) {
|
if (errno == ENOATTR) {
|
||||||
return rv;
|
return rv;
|
||||||
}
|
}
|
||||||
set_or_throw_error(ec, "size_xattr");
|
set_or_throw_error(&ec, "size_xattr");
|
||||||
return rv;
|
return rv;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -373,7 +375,7 @@ namespace afp {
|
|||||||
rv.resize(size);
|
rv.resize(size);
|
||||||
|
|
||||||
for(;;) {
|
for(;;) {
|
||||||
tsize = read_xattr(_fd, XATTR_RESOURCEFORK_NAME, tmp.data(), size);
|
tsize = read_xattr(_fd, XATTR_RESOURCEFORK_NAME, rv.data(), size);
|
||||||
if (tsize < 0) {
|
if (tsize < 0) {
|
||||||
if (errno == EINTR) continue;
|
if (errno == EINTR) continue;
|
||||||
if (errno == ERANGE) break;
|
if (errno == ERANGE) break;
|
||||||
@ -381,7 +383,7 @@ namespace afp {
|
|||||||
rv.clear();
|
rv.clear();
|
||||||
return rv;
|
return rv;
|
||||||
}
|
}
|
||||||
set_or_throw_error(ec, "read_xattr");
|
set_or_throw_error(&ec, "read_xattr");
|
||||||
rv.clear();
|
rv.clear();
|
||||||
return rv;
|
return rv;
|
||||||
}
|
}
|
||||||
@ -394,9 +396,9 @@ namespace afp {
|
|||||||
bool resource_fork::open(const std::string &s, open_mode mode, std::error_code &ec) {
|
bool resource_fork::open(const std::string &s, open_mode mode, std::error_code &ec) {
|
||||||
close();
|
close();
|
||||||
ec.clear();
|
ec.clear();
|
||||||
_fd = open(s.c_str(), O_RDONLY);
|
_fd = ::open(s.c_str(), O_RDONLY);
|
||||||
if (_fd < 0) {
|
if (_fd < 0) {
|
||||||
set_or_throw_error(ec, "open");
|
set_or_throw_error(&ec, "open");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
_mode = mode;
|
_mode = mode;
|
||||||
@ -409,7 +411,7 @@ namespace afp {
|
|||||||
ec.clear();
|
ec.clear();
|
||||||
auto rv = size_xattr(_fd, XATTR_RESOURCEFORK_NAME);
|
auto rv = size_xattr(_fd, XATTR_RESOURCEFORK_NAME);
|
||||||
if (rv < 0) {
|
if (rv < 0) {
|
||||||
set_or_throw_error(ec, "size_xattr");
|
set_or_throw_error(&ec, "size_xattr");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
return rv;
|
return rv;
|
||||||
@ -418,11 +420,11 @@ namespace afp {
|
|||||||
size_t resource_fork::read(void *buffer, size_t n, std::error_code &ec) {
|
size_t resource_fork::read(void *buffer, size_t n, std::error_code &ec) {
|
||||||
ec.clear();
|
ec.clear();
|
||||||
if (_fd < 0) {
|
if (_fd < 0) {
|
||||||
set_or_throw_error(ec, EBADF, "read");
|
set_or_throw_error(&ec, EBADF, "read");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
if (_mode == write_only) {
|
if (_mode == write_only) {
|
||||||
set_or_throw_error(ec, EPERM, "read");
|
set_or_throw_error(&ec, EPERM, "read");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -443,27 +445,27 @@ namespace afp {
|
|||||||
size_t resource_fork::write(const void *buffer, size_t n, std::error_code &ec) {
|
size_t resource_fork::write(const void *buffer, size_t n, std::error_code &ec) {
|
||||||
ec.clear();
|
ec.clear();
|
||||||
if (_fd < 0) {
|
if (_fd < 0) {
|
||||||
set_or_throw_error(ec, EBADF, "write");
|
set_or_throw_error(&ec, EBADF, "write");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
if (_mode == read_only) {
|
if (_mode == read_only) {
|
||||||
set_or_throw_error(ec, EPERM, "write");
|
set_or_throw_error(&ec, EPERM, "write");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (n == 0) return 0;
|
if (n == 0) return 0;
|
||||||
|
|
||||||
auto tmp = read_rfork(_fd, ec);
|
auto tmp = read_rfork(_fd, ec);
|
||||||
if (ec) return ec;
|
if (ec) return 0;
|
||||||
|
|
||||||
if (_offset > tmp.size()) {
|
if (_offset > tmp.size()) {
|
||||||
tmp.resize(_offset);
|
tmp.resize(_offset);
|
||||||
}
|
}
|
||||||
tmp.append((const uint8_t *)buffer, (const uint8_t *buffer) + n);
|
tmp.insert(tmp.end(), (const uint8_t *)buffer, (const uint8_t *)buffer + n);
|
||||||
|
|
||||||
auto rv = write_xattr(_fd, XATTR_RESOURCEFORK_NAME, tmp.data(), tmp.size());
|
auto rv = write_xattr(_fd, XATTR_RESOURCEFORK_NAME, tmp.data(), tmp.size());
|
||||||
if (rv < 0) {
|
if (rv < 0) {
|
||||||
set_or_throw_error(ec, "write_xattr");
|
set_or_throw_error(&ec, "write_xattr");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
return n;
|
return n;
|
||||||
@ -473,11 +475,11 @@ namespace afp {
|
|||||||
|
|
||||||
ec.clear();
|
ec.clear();
|
||||||
if (_fd < 0) {
|
if (_fd < 0) {
|
||||||
set_or_throw_error(ec, EBADF, "resource_fork::truncate");
|
set_or_throw_error(&ec, EBADF, "resource_fork::truncate");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
if (_mode == read_only) {
|
if (_mode == read_only) {
|
||||||
set_or_throw_error(ec, EPERM, "resource_fork::truncate");
|
set_or_throw_error(&ec, EPERM, "resource_fork::truncate");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -485,7 +487,7 @@ namespace afp {
|
|||||||
if (pos == 0) {
|
if (pos == 0) {
|
||||||
auto rv = remove_xattr(_fd, XATTR_RESOURCEFORK_NAME);
|
auto rv = remove_xattr(_fd, XATTR_RESOURCEFORK_NAME);
|
||||||
if (rv < 0) {
|
if (rv < 0) {
|
||||||
set_or_throw_error(ec, "remove_xattr");
|
set_or_throw_error(&ec, "remove_xattr");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
@ -496,7 +498,7 @@ namespace afp {
|
|||||||
tmp.resize(pos);
|
tmp.resize(pos);
|
||||||
auto rv = write_xattr(_fd, XATTR_RESOURCEFORK_NAME, tmp.data(), pos);
|
auto rv = write_xattr(_fd, XATTR_RESOURCEFORK_NAME, tmp.data(), pos);
|
||||||
if (rv < 0) {
|
if (rv < 0) {
|
||||||
set_or_throw_error(ec, "write_xattr");
|
set_or_throw_error(&ec, "write_xattr");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
_offset = pos;
|
_offset = pos;
|
||||||
@ -505,7 +507,7 @@ namespace afp {
|
|||||||
bool resource_fork::seek(size_t pos, std::error_code &ec) {
|
bool resource_fork::seek(size_t pos, std::error_code &ec) {
|
||||||
ec.clear();
|
ec.clear();
|
||||||
if (_fd < 0) {
|
if (_fd < 0) {
|
||||||
set_or_throw_error(ec, EBADF, "truncate");
|
set_or_throw_error(&ec, EBADF, "truncate");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user