Fixed the dirent.d_reclen calculation - define KEEP_WRONG_DIRENT_RECLEN to

enable the old and compatible behaviour (on BeOS R5, all available file
systems seem to do that wrong).


git-svn-id: file:///srv/svn/repos/haiku/trunk/current@826 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Axel Dörfler 2002-08-19 13:31:04 +00:00
parent 599a8de01a
commit ba04be1db0
3 changed files with 35 additions and 9 deletions

View File

@ -1,7 +1,16 @@
SubDir OBOS_TOP src add-ons kernel file_systems bfs ;
if $(DEBUG) {
local defines = [ FDefines DEBUG ] ;
# set some additional defines
{
local defines =
KEEP_WRONG_DIRENT_RECLEN
;
if $(DEBUG) {
defines += DEBUG ;
}
defines = [ FDefines $(defines) ] ;
SubDirCcFlags $(defines) ;
SubDirC++Flags $(defines) ;
}

View File

@ -779,7 +779,7 @@ Equation::Match(Inode *inode,const char *attributeName,int32 type,const uint8 *k
// get a pointer to the attribute in question
union value value;
uint8 *buffer;
// first, check if we are matching for a live query and use that value
if (attributeName != NULL && !strcmp(fAttribute,attributeName)) {
if (key == NULL) {
@ -807,7 +807,7 @@ Equation::Match(Inode *inode,const char *attributeName,int32 type,const uint8 *k
// then for attributes in the small_data section, and finally for the
// real attributes
Inode *attribute;
inode->SmallDataLock().Lock();
small_data *smallData = inode->FindSmallData(fAttribute);
if (smallData != NULL) {
@ -823,10 +823,10 @@ Equation::Match(Inode *inode,const char *attributeName,int32 type,const uint8 *k
buffer = (uint8 *)&value;
type = attribute->Node()->type;
size = attribute->Size();
if (size > INODE_FILE_NAME_LENGTH)
size = INODE_FILE_NAME_LENGTH;
if (attribute->ReadAt(0,buffer,&size) < B_OK) {
inode->ReleaseAttribute(attribute);
return B_IO_ERROR;
@ -870,7 +870,7 @@ Equation::CalculateScore(Index &index)
// least one character to set your index to
fScore = 5;
}
// take index size into account (1024 is the current node size
// in our B+trees)
// 2048 * 2048 == 4194304 is the maximum score (for an empty
@ -884,7 +884,7 @@ Equation::PrepareQuery(Volume */*volume*/, Index &index, TreeIterator **iterator
{
type_code type;
status_t status = index.SetTo(fAttribute);
// special case for OP_UNEQUAL - it will always operate through the whole index
// but we need the call to the original index to get the correct type
if (status < B_OK || fOp == OP_UNEQUAL) {
@ -895,7 +895,7 @@ Equation::PrepareQuery(Volume */*volume*/, Index &index, TreeIterator **iterator
if (index.SetTo("name") < B_OK)
return B_ENTRY_NOT_FOUND;
fHasIndex = false;
} else {
fHasIndex = true;
@ -1045,7 +1045,15 @@ Equation::GetNextMatching(Volume *volume, TreeIterator *iterator,
dirent->d_pdev = volume->ID();
dirent->d_pino = volume->ToVnode(inode->Parent());
strcpy(dirent->d_name,inode->Name());
#ifdef KEEP_WRONG_DIRENT_RECLEN
// ToDo: The available file systems in BeOS apparently don't set the
// correct d_reclen - we are copying that behaviour if requested, but
// if it doesn't break compatibility, we will remove it.
dirent->d_reclen = strlen(dirent->d_name);
#else
dirent->d_reclen = sizeof(struct dirent) + strlen(dirent->d_name);
#endif
}
put_vnode(volume->ID(), inode->ID());

View File

@ -1403,7 +1403,12 @@ bfs_read_dir(void *_ns, void *_node, void *_cookie, long *num,
dirent->d_dev = volume->ID();
dirent->d_ino = id;
#ifdef KEEP_WRONG_DIRENT_RECLEN
dirent->d_reclen = length;
#else
dirent->d_reclen = sizeof(struct dirent) + length;
#endif
*num = 1;
return B_OK;
@ -1526,7 +1531,11 @@ bfs_read_attrdir(void *_ns, void *node, void *_cookie, long *num, struct dirent
Volume *volume = (Volume *)_ns;
dirent->d_dev = volume->ID();
#ifdef KEEP_WRONG_DIRENT_RECLEN
dirent->d_reclen = length;
#else
dirent->d_reclen = sizeof(struct dirent) + length;
#endif
*num = 1;
return B_OK;