* Made our struct stat POSIX compliant again -- the time_t fields have been
replaced by timespec fields. Via macros the structure is still source compatible with the old one. * Introduced header <compat/sys/stat.h> that defines the old stat structure (as stat_beos) and conversion functions * Introduced versions for [l,f]stat(). * Added symbol versions for BDirectory::GetStatFor() for sake of binary compatibility. * BStatable::GetStat(): Renamed the old method, changed its parameter to stat_beos*, and and made it private. Added a new version (using up a reserved vtable slot). It remains source and binary compatible. * BRefFilter::Filter(): Changed the struct stat* parameter to struct stat_beos* for sake of binary compatibility. This breaks source compatibility, though, which we can't help, since the class doesn't have reserved vtable slots. * Fixed several issues with the stat structure change, mostly adjusted uses of BRefFilter. git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@30830 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
f15e418bab
commit
bcfe344c53
@ -10,8 +10,10 @@
|
||||
#include <EntryList.h>
|
||||
#include <StorageDefs.h>
|
||||
|
||||
|
||||
class BFile;
|
||||
class BSymLink;
|
||||
struct stat_beos;
|
||||
|
||||
|
||||
class BDirectory : public BNode, public BEntryList {
|
||||
@ -64,6 +66,9 @@ class BDirectory : public BNode, public BEntryList {
|
||||
friend class BEntry;
|
||||
friend class BFile;
|
||||
|
||||
status_t _GetStatFor(const char *path, struct stat *st) const;
|
||||
status_t _GetStatFor(const char *path, struct stat_beos *st) const;
|
||||
|
||||
virtual void _ErectorDirectory1();
|
||||
virtual void _ErectorDirectory2();
|
||||
virtual void _ErectorDirectory3();
|
||||
|
@ -14,6 +14,7 @@ class BMessage;
|
||||
class BMessenger;
|
||||
class BWindow;
|
||||
struct stat;
|
||||
struct stat_beos;
|
||||
|
||||
|
||||
class BRefFilter {
|
||||
@ -22,7 +23,7 @@ class BRefFilter {
|
||||
virtual ~BRefFilter() {};
|
||||
#endif
|
||||
virtual bool Filter(const entry_ref* ref, BNode* node,
|
||||
struct stat* stat, const char* mimeType) = 0;
|
||||
struct stat_beos* stat, const char* mimeType) = 0;
|
||||
};
|
||||
|
||||
|
||||
|
@ -11,9 +11,11 @@
|
||||
#include <sys/types.h>
|
||||
#include <sys/stat.h>
|
||||
|
||||
|
||||
struct node_ref;
|
||||
struct stat_beos;
|
||||
class BVolume;
|
||||
|
||||
|
||||
|
||||
class BStatable {
|
||||
public:
|
||||
@ -21,6 +23,11 @@ class BStatable {
|
||||
virtual ~BStatable();
|
||||
#endif
|
||||
|
||||
private:
|
||||
virtual status_t _GetStat(struct stat_beos *st) const;
|
||||
// provided for BeOS compatibility
|
||||
|
||||
public:
|
||||
virtual status_t GetStat(struct stat *st) const = 0;
|
||||
|
||||
bool IsFile() const;
|
||||
@ -38,7 +45,7 @@ class BStatable {
|
||||
status_t GetPermissions(mode_t *perms) const;
|
||||
status_t SetPermissions(mode_t perms);
|
||||
|
||||
status_t GetSize(off_t *size) const;
|
||||
status_t GetSize(off_t *size) const;
|
||||
|
||||
status_t GetModificationTime(time_t *mtime) const;
|
||||
status_t SetModificationTime(time_t mtime);
|
||||
@ -55,7 +62,6 @@ class BStatable {
|
||||
friend class BEntry;
|
||||
friend class BNode;
|
||||
|
||||
virtual void _OhSoStatable1();
|
||||
virtual void _OhSoStatable2();
|
||||
virtual void _OhSoStatable3();
|
||||
uint32 _reserved[4];
|
||||
|
48
headers/posix/compat/sys/stat.h
Normal file
48
headers/posix/compat/sys/stat.h
Normal file
@ -0,0 +1,48 @@
|
||||
/*
|
||||
* Copyright 2002-2009, Haiku Inc. All Rights Reserved.
|
||||
* Distributed under the terms of the MIT License.
|
||||
*/
|
||||
#ifndef _COMPAT_SYS_STAT_H_
|
||||
#define _COMPAT_SYS_STAT_H_
|
||||
|
||||
|
||||
#include <sys/stat.h>
|
||||
|
||||
|
||||
/* helper struct allowing us to avoid problems with the st_*time macros */
|
||||
typedef struct {
|
||||
time_t tv_sec;
|
||||
} stat_beos_time;
|
||||
|
||||
|
||||
struct stat_beos {
|
||||
dev_t st_dev; /* device ID that this file resides on */
|
||||
ino_t st_ino; /* this file's serial inode ID */
|
||||
mode_t st_mode; /* file mode (rwx for user, group, etc) */
|
||||
nlink_t st_nlink; /* number of hard links to this file */
|
||||
uid_t st_uid; /* user ID of the owner of this file */
|
||||
gid_t st_gid; /* group ID of the owner of this file */
|
||||
off_t st_size; /* size in bytes of this file */
|
||||
dev_t st_rdev; /* device type (not used) */
|
||||
blksize_t st_blksize; /* preferred block size for I/O */
|
||||
stat_beos_time st_atim; /* last access time */
|
||||
stat_beos_time st_mtim; /* last modification time */
|
||||
stat_beos_time st_ctim; /* last change time, not creation time */
|
||||
stat_beos_time st_crtim; /* creation time */
|
||||
};
|
||||
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
extern void convert_to_stat_beos(const struct stat* stat,
|
||||
struct stat_beos* beosStat);
|
||||
extern void convert_from_stat_beos(const struct stat_beos* beosStat,
|
||||
struct stat* stat);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif /* _COMPAT_SYS_STAT_H_ */
|
@ -7,6 +7,7 @@
|
||||
|
||||
|
||||
#include <sys/types.h>
|
||||
#include <time.h>
|
||||
|
||||
|
||||
struct stat {
|
||||
@ -19,14 +20,21 @@ struct stat {
|
||||
off_t st_size; /* size in bytes of this file */
|
||||
dev_t st_rdev; /* device type (not used) */
|
||||
blksize_t st_blksize; /* preferred block size for I/O */
|
||||
time_t st_atime; /* last access time */
|
||||
time_t st_mtime; /* last modification time */
|
||||
time_t st_ctime; /* last change time, not creation time */
|
||||
time_t st_crtime; /* creation time */
|
||||
struct timespec st_atim; /* last access time */
|
||||
struct timespec st_mtim; /* last modification time */
|
||||
struct timespec st_ctim; /* last change time, not creation time */
|
||||
struct timespec st_crtim; /* creation time */
|
||||
unsigned int st_type; /* attribute/index type */
|
||||
blkcnt_t st_blocks; /* number of blocks allocated for object */
|
||||
};
|
||||
|
||||
/* source compatibility with old stat structure */
|
||||
#define st_atime st_atim.tv_sec
|
||||
#define st_mtime st_mtim.tv_sec
|
||||
#define st_ctime st_ctim.tv_sec
|
||||
#define st_crtime st_crtim.tv_sec
|
||||
|
||||
|
||||
/* extended file types */
|
||||
#define S_ATTR_DIR 01000000000 /* attribute directory */
|
||||
#define S_ATTR 02000000000 /* attribute */
|
||||
|
@ -10,6 +10,12 @@
|
||||
#define BEOS_FS_API_VERSION 2
|
||||
|
||||
|
||||
/* helper struct allowing us to avoid problems with the st_*time macros */
|
||||
typedef struct {
|
||||
time_t tv_sec;
|
||||
} stat_beos_time;
|
||||
|
||||
|
||||
// BeOS structures
|
||||
|
||||
typedef struct beos_iovec {
|
||||
@ -36,10 +42,10 @@ struct beos_stat {
|
||||
off_t st_size;
|
||||
dev_t st_rdev;
|
||||
size_t st_blksize;
|
||||
time_t st_atime;
|
||||
time_t st_mtime;
|
||||
time_t st_ctime;
|
||||
time_t st_crtime;
|
||||
stat_beos_time st_atim;
|
||||
stat_beos_time st_mtim;
|
||||
stat_beos_time st_ctim;
|
||||
stat_beos_time st_crtim;
|
||||
};
|
||||
|
||||
struct beos_fs_info {
|
||||
@ -161,7 +167,7 @@ typedef int beos_op_read_indexdir(void *ns, void *cookie, long *num,
|
||||
typedef int beos_op_create_index(void *ns, const char *name, int type,
|
||||
int flags);
|
||||
typedef int beos_op_remove_index(void *ns, const char *name);
|
||||
typedef int beos_op_rename_index(void *ns, const char *oldname,
|
||||
typedef int beos_op_rename_index(void *ns, const char *oldname,
|
||||
const char *newname);
|
||||
typedef int beos_op_stat_index(void *ns, const char *name,
|
||||
struct beos_index_info *buf);
|
||||
|
@ -14,6 +14,8 @@
|
||||
#include <stdio.h>
|
||||
#include <string.h>
|
||||
|
||||
#include <compat/sys/stat.h>
|
||||
|
||||
|
||||
DirectoryRefFilter::DirectoryRefFilter()
|
||||
{
|
||||
@ -21,8 +23,8 @@ DirectoryRefFilter::DirectoryRefFilter()
|
||||
|
||||
|
||||
bool
|
||||
DirectoryRefFilter::Filter(const entry_ref *ref, BNode* node, struct stat *st,
|
||||
const char *filetype)
|
||||
DirectoryRefFilter::Filter(const entry_ref *ref, BNode* node,
|
||||
struct stat_beos *st, const char *filetype)
|
||||
{
|
||||
if (S_ISDIR(st->st_mode))
|
||||
return true;
|
||||
|
@ -19,7 +19,7 @@ const uint32 MSG_DIRECTORY = 'mDIR';
|
||||
class DirectoryRefFilter : public BRefFilter {
|
||||
public:
|
||||
DirectoryRefFilter();
|
||||
bool Filter(const entry_ref *ref, BNode* node, struct stat *st,
|
||||
bool Filter(const entry_ref *ref, BNode* node, struct stat_beos *st,
|
||||
const char *filetype);
|
||||
};
|
||||
|
||||
|
@ -13,6 +13,8 @@
|
||||
#include <stdio.h>
|
||||
#include <unistd.h>
|
||||
|
||||
#include <compat/sys/stat.h>
|
||||
|
||||
|
||||
ExpanderRule::ExpanderRule(BString mimetype, BString filenameExtension,
|
||||
BString listingCmd, BString expandCmd)
|
||||
@ -127,7 +129,7 @@ ExpanderRules::MatchingRule(BString &fileName, const char *filetype)
|
||||
if (rule->MimeType().IsValid() && rule->MimeType() == filetype)
|
||||
return rule;
|
||||
int32 extPosition = fileName.FindLast(rule->FilenameExtension());
|
||||
if (extPosition != -1
|
||||
if (extPosition != -1
|
||||
&& extPosition == (length - rule->FilenameExtension().Length()))
|
||||
return rule;
|
||||
}
|
||||
@ -156,7 +158,7 @@ RuleRefFilter::RuleRefFilter(ExpanderRules &rules)
|
||||
|
||||
|
||||
bool
|
||||
RuleRefFilter::Filter(const entry_ref *ref, BNode* node, struct stat *st,
|
||||
RuleRefFilter::Filter(const entry_ref *ref, BNode* node, struct stat_beos *st,
|
||||
const char *filetype)
|
||||
{
|
||||
if (node->IsDirectory() || node->IsSymLink())
|
||||
|
@ -46,7 +46,7 @@ class ExpanderRules {
|
||||
class RuleRefFilter : public BRefFilter {
|
||||
public:
|
||||
RuleRefFilter(ExpanderRules &rules);
|
||||
bool Filter(const entry_ref *ref, BNode* node, struct stat *st,
|
||||
bool Filter(const entry_ref *ref, BNode* node, struct stat_beos *st,
|
||||
const char *filetype);
|
||||
protected:
|
||||
ExpanderRules &fRules;
|
||||
|
@ -66,8 +66,8 @@ enum {
|
||||
class DirectoryRefFilter : public BRefFilter {
|
||||
public:
|
||||
virtual ~DirectoryRefFilter() {}
|
||||
bool Filter(const entry_ref* ref, BNode* node, struct stat* stat,
|
||||
const char* filetype)
|
||||
bool Filter(const entry_ref* ref, BNode* node,
|
||||
struct stat_beos* stat, const char* filetype)
|
||||
{
|
||||
return node->IsDirectory();
|
||||
}
|
||||
@ -501,7 +501,7 @@ ScreenshotWindow::_UpdatePreviewPanel()
|
||||
{
|
||||
float height = 150.0f;
|
||||
|
||||
float width = (fScreenshot->Bounds().Width() /
|
||||
float width = (fScreenshot->Bounds().Width() /
|
||||
fScreenshot->Bounds().Height()) * height;
|
||||
|
||||
// to prevent a preview way too wide
|
||||
@ -517,7 +517,7 @@ ScreenshotWindow::_UpdatePreviewPanel()
|
||||
fPreview->ClearViewBitmap();
|
||||
fPreview->SetViewBitmap(fScreenshot, fScreenshot->Bounds(),
|
||||
fPreview->Bounds(), B_FOLLOW_ALL, 0);
|
||||
|
||||
|
||||
BCardLayout* layout = dynamic_cast<BCardLayout*> (GetLayout());
|
||||
if (layout)
|
||||
layout->SetVisibleItem(1L);
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 2002-2008, Haiku Inc.
|
||||
* Copyright 2002-2009, Haiku Inc.
|
||||
* Distributed under the terms of the MIT License.
|
||||
*
|
||||
* Authors:
|
||||
@ -11,7 +11,10 @@
|
||||
|
||||
#include "storage_support.h"
|
||||
|
||||
#include <syscalls.h>
|
||||
#include <fcntl.h>
|
||||
#include <string.h>
|
||||
|
||||
#include <compat/sys/stat.h>
|
||||
|
||||
#include <Directory.h>
|
||||
#include <Entry.h>
|
||||
@ -20,8 +23,7 @@
|
||||
#include <Path.h>
|
||||
#include <SymLink.h>
|
||||
|
||||
#include <fcntl.h>
|
||||
#include <string.h>
|
||||
#include <syscalls.h>
|
||||
|
||||
|
||||
extern mode_t __gUmask;
|
||||
@ -509,7 +511,7 @@ BDirectory::Contains(const BEntry *entry, int32 nodeFlags) const
|
||||
return false;
|
||||
|
||||
uint32 dirLen = strlen(dirPath.Path());
|
||||
|
||||
|
||||
if (!strncmp(dirPath.Path(), entryPath.Path(), dirLen)) {
|
||||
// if the paths are identical, return a match to stay consistent with
|
||||
// BeOS behavior.
|
||||
@ -520,7 +522,8 @@ BDirectory::Contains(const BEntry *entry, int32 nodeFlags) const
|
||||
}
|
||||
|
||||
|
||||
/*! \brief Returns the stat structure of the entry referred to by the supplied
|
||||
/*! \fn status_t BDirectory::GetStatFor(const char *path, struct stat *st) const
|
||||
\brief Returns the stat structure of the entry referred to by the supplied
|
||||
path name.
|
||||
\param path the entry's path name. May be relative to this directory or
|
||||
absolute, or \c NULL to get the directories stat info.
|
||||
@ -538,21 +541,7 @@ BDirectory::Contains(const BEntry *entry, int32 nodeFlags) const
|
||||
- \c B_NO_MORE_FDS: The application has run out of file descriptors.
|
||||
- \c B_NOT_A_DIRECTORY: \a path includes a non-directory.
|
||||
*/
|
||||
status_t
|
||||
BDirectory::GetStatFor(const char *path, struct stat *st) const
|
||||
{
|
||||
if (!st)
|
||||
return B_BAD_VALUE;
|
||||
if (InitCheck() != B_OK)
|
||||
return B_NO_INIT;
|
||||
|
||||
if (path != NULL) {
|
||||
if (path[0] == '\0')
|
||||
return B_ENTRY_NOT_FOUND;
|
||||
return _kern_read_stat(fDirFd, path, false, st, sizeof(struct stat));
|
||||
}
|
||||
return GetStat(st);
|
||||
}
|
||||
// Implemented as BDirectory::_GetStatFor().
|
||||
|
||||
|
||||
/*! \brief Returns the BDirectory's next entry as a BEntry.
|
||||
@ -866,6 +855,36 @@ BDirectory::operator=(const BDirectory &dir)
|
||||
}
|
||||
|
||||
|
||||
status_t
|
||||
BDirectory::_GetStatFor(const char *path, struct stat *st) const
|
||||
{
|
||||
if (!st)
|
||||
return B_BAD_VALUE;
|
||||
if (InitCheck() != B_OK)
|
||||
return B_NO_INIT;
|
||||
|
||||
if (path != NULL) {
|
||||
if (path[0] == '\0')
|
||||
return B_ENTRY_NOT_FOUND;
|
||||
return _kern_read_stat(fDirFd, path, false, st, sizeof(struct stat));
|
||||
}
|
||||
return GetStat(st);
|
||||
}
|
||||
|
||||
|
||||
status_t
|
||||
BDirectory::_GetStatFor(const char *path, struct stat_beos *st) const
|
||||
{
|
||||
struct stat newStat;
|
||||
status_t error = _GetStatFor(path, &newStat);
|
||||
if (error != B_OK)
|
||||
return error;
|
||||
|
||||
convert_to_stat_beos(&newStat, st);
|
||||
return B_OK;
|
||||
}
|
||||
|
||||
|
||||
// FBC
|
||||
void BDirectory::_ErectorDirectory1() {}
|
||||
void BDirectory::_ErectorDirectory2() {}
|
||||
@ -969,3 +988,28 @@ create_directory(const char *path, mode_t mode)
|
||||
return B_OK;
|
||||
}
|
||||
|
||||
|
||||
// #pragma mark - symbol versions
|
||||
|
||||
|
||||
#if __GNUC__ == 2 // gcc 2
|
||||
|
||||
// BeOS compatible GetStatFor()
|
||||
B_DEFINE_SYMBOL_VERSION("_GetStatFor__C10BDirectoryPCcP9stat_beos",
|
||||
"GetStatFor__C10BDirectoryPCcP4stat@LIBBE_BASE");
|
||||
|
||||
// Haiku GetStatFor()
|
||||
B_DEFINE_SYMBOL_VERSION("_GetStatFor__C10BDirectoryPCcP4stat",
|
||||
"GetStatFor__C10BDirectoryPCcP4stat@@LIBBE_1_ALPHA1");
|
||||
|
||||
#else // gcc 4
|
||||
|
||||
// BeOS compatible GetStatFor()
|
||||
B_DEFINE_SYMBOL_VERSION("_ZNK10BDirectory11_GetStatForEPKcP9stat_beos",
|
||||
"_ZNK10BDirectory10GetStatForEPKcP4stat@LIBBE_BASE");
|
||||
|
||||
// Haiku GetStatFor()
|
||||
B_DEFINE_SYMBOL_VERSION("_ZNK10BDirectory11_GetStatForEPKcP4stat",
|
||||
"_ZNK10BDirectory10GetStatForEPKcP4stat@@LIBBE_1_ALPHA1");
|
||||
|
||||
#endif // gcc 4
|
||||
|
@ -13,14 +13,17 @@
|
||||
*/
|
||||
|
||||
#include <Statable.h>
|
||||
|
||||
#include <sys/stat.h>
|
||||
|
||||
#include <compat/sys/stat.h>
|
||||
|
||||
#include <Node.h>
|
||||
#include <NodeMonitor.h>
|
||||
#include <Volume.h>
|
||||
|
||||
#include <sys/stat.h>
|
||||
|
||||
|
||||
#if __GNUC__ > 3
|
||||
#if __GNUC__ > 2
|
||||
BStatable::~BStatable()
|
||||
{
|
||||
}
|
||||
@ -37,6 +40,22 @@ BStatable::~BStatable()
|
||||
- \c B_NOT_ALLOWED: Read only node or volume.
|
||||
*/
|
||||
|
||||
|
||||
/*! \brief GetStat() compatibility version.
|
||||
*/
|
||||
status_t
|
||||
BStatable::_GetStat(struct stat_beos *st) const
|
||||
{
|
||||
struct stat newStat;
|
||||
status_t error = GetStat(&newStat);
|
||||
if (error != B_OK)
|
||||
return error;
|
||||
|
||||
convert_to_stat_beos(&newStat, st);
|
||||
return B_OK;
|
||||
}
|
||||
|
||||
|
||||
/*! \brief Returns if the current node is a file.
|
||||
\return \c true, if the BNode is properly initialized and is a file,
|
||||
\c false otherwise.
|
||||
@ -47,7 +66,7 @@ BStatable::IsFile() const
|
||||
struct stat statData;
|
||||
if (GetStat(&statData) == B_OK)
|
||||
return S_ISREG(statData.st_mode);
|
||||
else
|
||||
else
|
||||
return false;
|
||||
}
|
||||
|
||||
@ -61,7 +80,7 @@ BStatable::IsDirectory() const
|
||||
struct stat statData;
|
||||
if (GetStat(&statData) == B_OK)
|
||||
return S_ISDIR(statData.st_mode);
|
||||
else
|
||||
else
|
||||
return false;
|
||||
}
|
||||
|
||||
@ -75,15 +94,15 @@ BStatable::IsSymLink() const
|
||||
struct stat statData;
|
||||
if (GetStat(&statData) == B_OK)
|
||||
return S_ISLNK(statData.st_mode);
|
||||
else
|
||||
else
|
||||
return false;
|
||||
}
|
||||
|
||||
|
||||
/*! \brief Returns a node_ref for the current node.
|
||||
\param ref the node_ref structure to be filled in
|
||||
\see GetStat() for return codes
|
||||
*/
|
||||
status_t
|
||||
status_t
|
||||
BStatable::GetNodeRef(node_ref *ref) const
|
||||
{
|
||||
status_t error = (ref ? B_OK : B_BAD_VALUE);
|
||||
@ -96,12 +115,12 @@ BStatable::GetNodeRef(node_ref *ref) const
|
||||
}
|
||||
return error;
|
||||
}
|
||||
|
||||
|
||||
/*! \brief Returns the owner of the node.
|
||||
\param owner a pointer to a uid_t variable to be set to the result
|
||||
\see GetStat() for return codes
|
||||
*/
|
||||
status_t
|
||||
status_t
|
||||
BStatable::GetOwner(uid_t *owner) const
|
||||
{
|
||||
status_t error = (owner ? B_OK : B_BAD_VALUE);
|
||||
@ -117,14 +136,14 @@ BStatable::GetOwner(uid_t *owner) const
|
||||
\param owner the new owner
|
||||
\see GetStat() for return codes
|
||||
*/
|
||||
status_t
|
||||
status_t
|
||||
BStatable::SetOwner(uid_t owner)
|
||||
{
|
||||
struct stat statData;
|
||||
statData.st_uid = owner;
|
||||
return set_stat(statData, B_STAT_UID);
|
||||
}
|
||||
|
||||
|
||||
/*! \brief Returns the group owner of the node.
|
||||
\param group a pointer to a gid_t variable to be set to the result
|
||||
\see GetStat() for return codes
|
||||
@ -152,7 +171,7 @@ BStatable::SetGroup(gid_t group)
|
||||
statData.st_gid = group;
|
||||
return set_stat(statData, B_STAT_GID);
|
||||
}
|
||||
|
||||
|
||||
/*! \brief Returns the permissions of the node.
|
||||
\param perms a pointer to a mode_t variable to be set to the result
|
||||
\see GetStat() for return codes
|
||||
@ -302,7 +321,18 @@ BStatable::GetVolume(BVolume *vol) const
|
||||
return error;
|
||||
}
|
||||
|
||||
void BStatable::_OhSoStatable1() {}
|
||||
|
||||
// _OhSoStatable1() -> GetStat()
|
||||
extern "C" status_t
|
||||
#if __GNUC__ == 2
|
||||
_OhSoStatable1__9BStatable(const BStatable *self, struct stat *st)
|
||||
#else
|
||||
_ZN9BStatable14_OhSoStatable1Ev(const BStatable *self, struct stat *st)
|
||||
#endif
|
||||
{
|
||||
return self->GetStat(st);
|
||||
}
|
||||
|
||||
|
||||
void BStatable::_OhSoStatable2() {}
|
||||
void BStatable::_OhSoStatable3() {}
|
||||
|
||||
|
@ -32,20 +32,22 @@ names are registered trademarks or trademarks of their respective holders.
|
||||
All rights reserved.
|
||||
*/
|
||||
|
||||
#include <ctype.h>
|
||||
#include <errno.h>
|
||||
#include <float.h>
|
||||
#include <fs_attr.h>
|
||||
#include <fs_info.h>
|
||||
#include <ctype.h>
|
||||
#include <stdlib.h>
|
||||
#include <map>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
|
||||
#include <compat/sys/stat.h>
|
||||
|
||||
#include <Alert.h>
|
||||
#include <Application.h>
|
||||
#include <Clipboard.h>
|
||||
#include <Debug.h>
|
||||
#include <Dragger.h>
|
||||
#include <fs_attr.h>
|
||||
#include <fs_info.h>
|
||||
#include <Screen.h>
|
||||
#include <Query.h>
|
||||
#include <List.h>
|
||||
@ -140,7 +142,7 @@ const unsigned char kCopyCursor[] = { 16, 1, 1, 1,
|
||||
0x00, 0x00, 0x70, 0x00, 0x78, 0x00, 0x78, 0x00,
|
||||
0x3f, 0xc0, 0x3f, 0xf8, 0x1f, 0xfc, 0x1f, 0xfe,
|
||||
0x7f, 0xfe, 0xff, 0xfe, 0xff, 0xfe, 0x7f, 0xfe,
|
||||
0x1f, 0xfe, 0x07, 0xfe, 0x03, 0xf8, 0x00, 0x00
|
||||
0x1f, 0xfe, 0x07, 0xfe, 0x03, 0xf8, 0x00, 0x00
|
||||
};
|
||||
|
||||
const char *kNoCopyToTrashStr = "Sorry, you can't copy items to the Trash.";
|
||||
@ -177,7 +179,7 @@ AddPosesResult::ReleaseModels(void)
|
||||
|
||||
static BPose *
|
||||
BSearch(PoseList *table, const BPose* key, BPoseView *view,
|
||||
int (*cmp)(const BPose *, const BPose *, BPoseView *),
|
||||
int (*cmp)(const BPose *, const BPose *, BPoseView *),
|
||||
bool returnClosest = true);
|
||||
|
||||
static int
|
||||
@ -647,7 +649,7 @@ BPoseView::SaveState(AttributeStreamNode *node)
|
||||
node->Write(viewStateAttr, viewStateAttrForeign, B_RAW_TYPE,
|
||||
stream.Position(), stream.Buffer());
|
||||
|
||||
fStateNeedsSaving = false;
|
||||
fStateNeedsSaving = false;
|
||||
}
|
||||
|
||||
|
||||
@ -874,7 +876,7 @@ void
|
||||
BPoseView::ScrollTo(BPoint point)
|
||||
{
|
||||
_inherited::ScrollTo(point);
|
||||
|
||||
|
||||
//keep the view state in sync.
|
||||
if (ViewMode() == kListMode)
|
||||
fViewState->SetListOrigin(LeftTop());
|
||||
@ -1385,7 +1387,7 @@ BPoseView::AddPosesTask(void *castToParams)
|
||||
|
||||
BMessage finishedSending(kAddPosesCompleted);
|
||||
lock.Target().SendMessage(&finishedSending);
|
||||
|
||||
|
||||
} catch (failToLock) {
|
||||
// we are here because the window got closed or otherwise failed to
|
||||
// lock
|
||||
@ -1632,7 +1634,7 @@ BPoseView::CreatePoses(Model **models, PoseInfo *poseInfoArray, int32 count,
|
||||
|
||||
// pose adopts model and deletes it when done
|
||||
|
||||
if (fInsertedNodes.find(*(model->NodeRef())) != fInsertedNodes.end()
|
||||
if (fInsertedNodes.find(*(model->NodeRef())) != fInsertedNodes.end()
|
||||
|| FindZombie(model->NodeRef())) {
|
||||
watch_node(model->NodeRef(), B_STOP_WATCHING, this);
|
||||
delete model;
|
||||
@ -1793,7 +1795,7 @@ BPoseView::CreatePoses(Model **models, PoseInfo *poseInfoArray, int32 count,
|
||||
|
||||
model->CloseNode();
|
||||
}
|
||||
|
||||
|
||||
be_clipboard->Unlock();
|
||||
|
||||
FinishPendingScroll(listViewScrollBy, viewBounds);
|
||||
@ -1820,8 +1822,14 @@ BPoseView::ShouldShowPose(const Model *model, const PoseInfo *poseInfo)
|
||||
return false;
|
||||
|
||||
// check filter before adding item
|
||||
return !fRefFilter || fRefFilter->Filter(model->EntryRef(), model->Node(),
|
||||
const_cast<StatStruct *>(model->StatBuf()), model->MimeType());
|
||||
if (!fRefFilter)
|
||||
return true;
|
||||
|
||||
struct stat_beos statBeOS;
|
||||
convert_to_stat_beos(model->StatBuf(), &statBeOS);
|
||||
|
||||
return fRefFilter->Filter(model->EntryRef(), model->Node(), &statBeOS,
|
||||
model->MimeType());
|
||||
}
|
||||
|
||||
|
||||
@ -2441,7 +2449,7 @@ BPoseView::RemoveColumn(BColumn *columnToRemove, bool runAlert)
|
||||
// make sure last column is not removed
|
||||
if (CountColumns() == 1) {
|
||||
if (runAlert) {
|
||||
BAlert *alert = new BAlert("",
|
||||
BAlert *alert = new BAlert("",
|
||||
"You must have at least one Attribute showing.",
|
||||
"Cancel", 0, 0, B_WIDTH_AS_USUAL, B_WARNING_ALERT);
|
||||
alert->SetShortcut(0, B_ESCAPE);
|
||||
@ -4028,7 +4036,7 @@ bool
|
||||
BPoseView::HandleMessageDropped(BMessage *message)
|
||||
{
|
||||
ASSERT(message->WasDropped());
|
||||
|
||||
|
||||
// reset system cursor in case it was altered by drag and drop
|
||||
SetViewCursor(B_CURSOR_SYSTEM_DEFAULT);
|
||||
fCursorCheck = false;
|
||||
@ -4550,7 +4558,7 @@ void
|
||||
BPoseView::MoveSelectionInto(Model *destFolder, BContainerWindow *srcWindow,
|
||||
BContainerWindow *destWindow, uint32 buttons, BPoint loc, bool forceCopy,
|
||||
bool forceMove, bool createLink, bool relativeLink, BPoint clickPt, bool dropOnGrid)
|
||||
{
|
||||
{
|
||||
AutoLock<BWindow> lock(srcWindow);
|
||||
if (!lock)
|
||||
return;
|
||||
@ -4593,11 +4601,11 @@ BPoseView::MoveSelectionInto(Model *destFolder, BContainerWindow *srcWindow,
|
||||
targetView->DuplicateSelection(&clickPt, &loc);
|
||||
return;
|
||||
}
|
||||
|
||||
|
||||
if (targetView->ViewMode() == kListMode) // can't move in list view
|
||||
return;
|
||||
|
||||
BPoint delta = loc - clickPt;
|
||||
|
||||
BPoint delta = loc - clickPt;
|
||||
int32 count = targetView->fSelectionList->CountItems();
|
||||
for (int32 index = 0; index < count; index++) {
|
||||
BPose *pose = targetView->fSelectionList->ItemAt(index);
|
||||
@ -4691,7 +4699,7 @@ BPoseView::MoveSelectionInto(Model *destFolder, BContainerWindow *srcWindow,
|
||||
if (!CheckDevicesEqual(srcList->ItemAt(0), destFolder))
|
||||
moveMode = kCopySelectionTo;
|
||||
}
|
||||
|
||||
|
||||
FSMoveToFolder(srcList, destEntry, moveMode, pointList);
|
||||
return;
|
||||
}
|
||||
@ -4719,7 +4727,7 @@ BPoseView::MoveSelectionTo(BPoint dropPt, BPoint clickPt,
|
||||
|
||||
uint32 buttons = (uint32)window->CurrentMessage()->FindInt32("buttons");
|
||||
bool pinToGrid = (modifiers() & B_COMMAND_KEY) != 0;
|
||||
MoveSelectionInto(TargetModel(), srcWindow, window, buttons, dropPt,
|
||||
MoveSelectionInto(TargetModel(), srcWindow, window, buttons, dropPt,
|
||||
false, false, false, false, clickPt, pinToGrid);
|
||||
}
|
||||
|
||||
@ -5535,7 +5543,7 @@ CheckVolumeReadOnly(const entry_ref *ref)
|
||||
alert->Go();
|
||||
return false;
|
||||
}
|
||||
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
@ -6602,7 +6610,7 @@ BPoseView::DragSelectedPoses(const BPose *pose, BPoint clickPoint)
|
||||
if (strcasecmp(type, kPlainTextMimeType) == 0) {
|
||||
// got a text file
|
||||
|
||||
|
||||
|
||||
file.Seek(0, SEEK_SET);
|
||||
off_t size = 0;
|
||||
file.GetSize(&size);
|
||||
@ -7303,7 +7311,7 @@ bool
|
||||
BPoseView::DeletePose(const node_ref *itemNode, BPose *pose, int32 index)
|
||||
{
|
||||
watch_node(itemNode, B_STOP_WATCHING, this);
|
||||
|
||||
|
||||
if (!pose)
|
||||
pose = fPoseList->FindPose(itemNode, &index);
|
||||
|
||||
@ -7640,13 +7648,13 @@ BPoseView::SwitchDir(const entry_ref *newDirRef, AttributeStreamNode *node)
|
||||
|
||||
// Restore state, might fail if the state has never been saved for this node
|
||||
uint32 oldMode = ViewMode();
|
||||
bool viewStateRestored = false;
|
||||
if (node) {
|
||||
bool viewStateRestored = false;
|
||||
if (node) {
|
||||
BViewState *previousState = fViewState;
|
||||
RestoreState(node);
|
||||
RestoreState(node);
|
||||
viewStateRestored = (fViewState != previousState);
|
||||
}
|
||||
|
||||
|
||||
if (viewStateRestored) {
|
||||
// Make sure the title view reset its items
|
||||
fTitleView->Reset();
|
||||
@ -7708,7 +7716,7 @@ BPoseView::SwitchDir(const entry_ref *newDirRef, AttributeStreamNode *node)
|
||||
else AddPoses(TargetModel());
|
||||
TargetModel()->CloseNode();
|
||||
|
||||
Invalidate();
|
||||
Invalidate();
|
||||
|
||||
fLastKeyTime = 0;
|
||||
}
|
||||
@ -7818,7 +7826,7 @@ BPoseView::SetDefaultPrinter()
|
||||
BMessenger tracker(kTrackerSignature);
|
||||
if (!tracker.IsValid()) {
|
||||
BAlert *alert = new BAlert("", "The Tracker must be running "
|
||||
"to see set the default printer.", "Cancel", NULL,
|
||||
"to see set the default printer.", "Cancel", NULL,
|
||||
NULL, B_WIDTH_AS_USUAL, B_WARNING_ALERT);
|
||||
alert->SetShortcut(0, B_ESCAPE);
|
||||
alert->Go();
|
||||
@ -8180,7 +8188,7 @@ BPoseView::UpdateScrollRange()
|
||||
|
||||
// set proportions for bars
|
||||
BRect totalExtent(extent | bounds);
|
||||
|
||||
|
||||
if (fHScrollBar && totalExtent.Width() != 0.0) {
|
||||
float proportion = bounds.Width() / totalExtent.Width();
|
||||
if (fHScrollBar->Proportion() != proportion)
|
||||
@ -8880,7 +8888,7 @@ BPoseView::UpdateDropTarget(BPoint mouseLoc, const BMessage *dragMessage,
|
||||
|| (trackingContextMenu && !targetPose))
|
||||
// no change
|
||||
return false;
|
||||
|
||||
|
||||
fCursorCheck = true;
|
||||
if (fDropTarget && !DragSelectionContains(fDropTarget, dragMessage))
|
||||
HiliteDropTarget(false);
|
||||
@ -8905,23 +8913,23 @@ BPoseView::UpdateDropTarget(BPoint mouseLoc, const BMessage *dragMessage,
|
||||
fDropTarget = NULL;
|
||||
fCursorCheck = false;
|
||||
}
|
||||
}
|
||||
}
|
||||
if (targetModel == NULL)
|
||||
targetModel = TargetModel();
|
||||
|
||||
|
||||
entry_ref srcRef;
|
||||
if (targetModel->IsDirectory() && dragMessage->HasRef("refs")
|
||||
if (targetModel->IsDirectory() && dragMessage->HasRef("refs")
|
||||
&& dragMessage->FindRef("refs", &srcRef) == B_OK) {
|
||||
Model srcModel (&srcRef);
|
||||
if (!CheckDevicesEqual(&srcRef, targetModel)
|
||||
&& !srcModel.IsVolume()
|
||||
if (!CheckDevicesEqual(&srcRef, targetModel)
|
||||
&& !srcModel.IsVolume()
|
||||
&& !srcModel.IsRoot()) {
|
||||
BCursor copyCursor(kCopyCursor);
|
||||
SetViewCursor(©Cursor);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
SetViewCursor(B_CURSOR_SYSTEM_DEFAULT);
|
||||
return true;
|
||||
}
|
||||
@ -9066,7 +9074,7 @@ BPoseView::HiliteDropTarget(bool hiliteState)
|
||||
return;
|
||||
}
|
||||
|
||||
// don't unselect the fAlreadySelectedDropTarget
|
||||
// don't unselect the fAlreadySelectedDropTarget
|
||||
if ((fAlreadySelectedDropTarget == fDropTarget) && !hiliteState) {
|
||||
fAlreadySelectedDropTarget = NULL;
|
||||
return;
|
||||
|
@ -162,7 +162,7 @@ CustomRefFilter::CustomRefFilter(bool imageFiltering)
|
||||
|
||||
bool
|
||||
CustomRefFilter::Filter(const entry_ref *ref, BNode* node,
|
||||
struct stat *stat, const char *filetype)
|
||||
struct stat_beos *stat, const char *filetype)
|
||||
{
|
||||
if (!fImageFiltering)
|
||||
return node->IsDirectory();
|
||||
|
@ -21,7 +21,7 @@ class CustomRefFilter : public BRefFilter {
|
||||
CustomRefFilter(bool imageFiltering);
|
||||
virtual ~CustomRefFilter() {};
|
||||
|
||||
bool Filter(const entry_ref *ref, BNode* node, struct stat *st,
|
||||
bool Filter(const entry_ref *ref, BNode* node, struct stat_beos *st,
|
||||
const char *filetype);
|
||||
|
||||
protected:
|
||||
|
@ -1,5 +1,7 @@
|
||||
SubDir HAIKU_TOP src system kernel lib ;
|
||||
|
||||
UsePrivateHeaders shared ;
|
||||
|
||||
# kernel libroot os files
|
||||
|
||||
KernelMergeObject kernel_os_main.o :
|
||||
@ -114,8 +116,6 @@ KernelMergeObject kernel_lib_posix.o :
|
||||
|
||||
# misc
|
||||
|
||||
UsePrivateHeaders shared ;
|
||||
|
||||
SEARCH_SOURCE = [ FDirName $(HAIKU_TOP) src kits support ] ;
|
||||
|
||||
KernelMergeObject kernel_misc.o :
|
||||
|
@ -1,88 +1,152 @@
|
||||
/*
|
||||
* Copyright 2009, Ingo Weinhold, ingo_weinhold@gmx.de. All rights reserved.
|
||||
* Copyright 2002-2008, Axel Dörfler, axeld@pinc-software.de. All rights reserved.
|
||||
* Distributed under the terms of the MIT License.
|
||||
*/
|
||||
|
||||
|
||||
#include <syscalls.h>
|
||||
|
||||
#include <sys/stat.h>
|
||||
#include <errno.h>
|
||||
|
||||
#include <compat/sys/stat.h>
|
||||
|
||||
#define RETURN_AND_SET_ERRNO(err) \
|
||||
if (err < 0) { \
|
||||
errno = err; \
|
||||
return -1; \
|
||||
} \
|
||||
return err;
|
||||
#include <symbol_versioning.h>
|
||||
#include <syscall_utils.h>
|
||||
|
||||
|
||||
// BeOS compatibility
|
||||
#define BEOS_STAT_SIZE 60
|
||||
// prototypes for the compiler
|
||||
int _stat_current(const char* path, struct stat* stat);
|
||||
int _fstat_current(int fd, struct stat* stat);
|
||||
int _lstat_current(const char* path, struct stat* stat);
|
||||
int _stat_beos(const char* path, struct stat_beos* beosStat);
|
||||
int _fstat_beos(int fd, struct stat_beos* beosStat);
|
||||
int _lstat_beos(const char* path, struct stat_beos* beosStat);
|
||||
|
||||
|
||||
int
|
||||
stat(const char *path, struct stat *stat)
|
||||
_stat_current(const char* path, struct stat* stat)
|
||||
{
|
||||
int status = _kern_read_stat(-1, path, true, stat, BEOS_STAT_SIZE/*sizeof(struct stat)*/);
|
||||
int status = _kern_read_stat(-1, path, true, stat, sizeof(struct stat));
|
||||
|
||||
RETURN_AND_SET_ERRNO(status);
|
||||
}
|
||||
|
||||
|
||||
int
|
||||
fstat(int fd, struct stat *stat)
|
||||
_fstat_current(int fd, struct stat* stat)
|
||||
{
|
||||
int status = _kern_read_stat(fd, NULL, false, stat, BEOS_STAT_SIZE/*sizeof(struct stat)*/);
|
||||
int status = _kern_read_stat(fd, NULL, false, stat, sizeof(struct stat));
|
||||
|
||||
RETURN_AND_SET_ERRNO(status);
|
||||
}
|
||||
|
||||
|
||||
int
|
||||
lstat(const char *path, struct stat *stat)
|
||||
_lstat_current(const char* path, struct stat* stat)
|
||||
{
|
||||
int status = _kern_read_stat(-1, path, false, stat, BEOS_STAT_SIZE/*sizeof(struct stat)*/);
|
||||
int status = _kern_read_stat(-1, path, false, stat, sizeof(struct stat));
|
||||
|
||||
RETURN_AND_SET_ERRNO(status);
|
||||
}
|
||||
|
||||
|
||||
// #pragma mark - BeOS compatibility
|
||||
// #pragma mark - BeOS compatibility
|
||||
|
||||
|
||||
#ifndef _KERNEL_MODE
|
||||
|
||||
int __be_stat(const char *path, struct stat *stat);
|
||||
int __be_fstat(int fd, struct stat *stat);
|
||||
int __be_lstat(const char *path, struct stat *stat);
|
||||
|
||||
|
||||
int
|
||||
__be_stat(const char *path, struct stat *stat)
|
||||
void
|
||||
convert_to_stat_beos(const struct stat* stat, struct stat_beos* beosStat)
|
||||
{
|
||||
int status = _kern_read_stat(-1, path, true, stat, BEOS_STAT_SIZE);
|
||||
if (stat == NULL || beosStat == NULL)
|
||||
return;
|
||||
|
||||
RETURN_AND_SET_ERRNO(status);
|
||||
beosStat->st_dev = stat->st_dev;
|
||||
beosStat->st_ino = stat->st_ino;
|
||||
beosStat->st_mode = stat->st_mode;
|
||||
beosStat->st_nlink = stat->st_nlink;
|
||||
beosStat->st_uid = stat->st_uid;
|
||||
beosStat->st_gid = stat->st_gid;
|
||||
beosStat->st_size = stat->st_size;
|
||||
beosStat->st_rdev = stat->st_rdev;
|
||||
beosStat->st_blksize = stat->st_blksize;
|
||||
beosStat->st_atime = stat->st_atime;
|
||||
beosStat->st_mtime = stat->st_mtime;
|
||||
beosStat->st_ctime = stat->st_ctime;
|
||||
beosStat->st_crtime = stat->st_crtime;
|
||||
}
|
||||
|
||||
|
||||
void
|
||||
convert_from_stat_beos(const struct stat_beos* beosStat, struct stat* stat)
|
||||
{
|
||||
if (stat == NULL || beosStat == NULL)
|
||||
return;
|
||||
|
||||
stat->st_dev = beosStat->st_dev;
|
||||
stat->st_ino = beosStat->st_ino;
|
||||
stat->st_mode = beosStat->st_mode;
|
||||
stat->st_nlink = beosStat->st_nlink;
|
||||
stat->st_uid = beosStat->st_uid;
|
||||
stat->st_gid = beosStat->st_gid;
|
||||
stat->st_size = beosStat->st_size;
|
||||
stat->st_rdev = beosStat->st_rdev;
|
||||
stat->st_blksize = beosStat->st_blksize;
|
||||
stat->st_atim.tv_sec = beosStat->st_atime;
|
||||
stat->st_atim.tv_nsec = 0;
|
||||
stat->st_mtim.tv_sec = beosStat->st_mtime;
|
||||
stat->st_mtim.tv_nsec = 0;
|
||||
stat->st_ctim.tv_sec = beosStat->st_ctime;
|
||||
stat->st_ctim.tv_nsec = 0;
|
||||
stat->st_crtim.tv_sec = beosStat->st_crtime;
|
||||
stat->st_crtim.tv_nsec = 0;
|
||||
stat->st_type = 0;
|
||||
stat->st_blocks = 0;
|
||||
}
|
||||
|
||||
|
||||
int
|
||||
__be_fstat(int fd, struct stat *stat)
|
||||
_stat_beos(const char* path, struct stat_beos* beosStat)
|
||||
{
|
||||
int status = _kern_read_stat(fd, NULL, false, stat, BEOS_STAT_SIZE);
|
||||
struct stat stat;
|
||||
if (_stat_current(path, &stat) != 0)
|
||||
return -1;
|
||||
|
||||
RETURN_AND_SET_ERRNO(status);
|
||||
convert_to_stat_beos(&stat, beosStat);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
int
|
||||
__be_lstat(const char *path, struct stat *stat)
|
||||
_fstat_beos(int fd, struct stat_beos* beosStat)
|
||||
{
|
||||
int status = _kern_read_stat(-1, path, false, stat, BEOS_STAT_SIZE);
|
||||
struct stat stat;
|
||||
if (_fstat_current(fd, &stat) != 0)
|
||||
return -1;
|
||||
|
||||
RETURN_AND_SET_ERRNO(status);
|
||||
convert_to_stat_beos(&stat, beosStat);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
#endif // !_KERNEL_MODE
|
||||
|
||||
int
|
||||
_lstat_beos(const char* path, struct stat_beos* beosStat)
|
||||
{
|
||||
struct stat stat;
|
||||
if (_lstat_current(path, &stat) != 0)
|
||||
return -1;
|
||||
|
||||
convert_to_stat_beos(&stat, beosStat);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
DEFINE_LIBROOT_KERNEL_SYMBOL_VERSION("_stat_beos", "stat@", "BASE");
|
||||
DEFINE_LIBROOT_KERNEL_SYMBOL_VERSION("_fstat_beos", "fstat@", "BASE");
|
||||
DEFINE_LIBROOT_KERNEL_SYMBOL_VERSION("_lstat_beos", "lstat@", "BASE");
|
||||
|
||||
DEFINE_LIBROOT_KERNEL_SYMBOL_VERSION("_stat_current", "stat@@", "1_ALPHA1");
|
||||
DEFINE_LIBROOT_KERNEL_SYMBOL_VERSION("_fstat_current", "fstat@@", "1_ALPHA1");
|
||||
DEFINE_LIBROOT_KERNEL_SYMBOL_VERSION("_lstat_current", "lstat@@", "1_ALPHA1");
|
||||
|
Loading…
Reference in New Issue
Block a user