379 lines
6.2 KiB
C++
379 lines
6.2 KiB
C++
/*++
|
||
|
||
Copyright (c) 1991 Microsoft Corporation
|
||
|
||
Module Name:
|
||
|
||
indxbuff.hxx
|
||
|
||
Abstract:
|
||
|
||
this module contains the declarations for the NTFS_INDEX_BUFFER
|
||
class, which models index buffers in NTFS index trees.
|
||
|
||
Author:
|
||
|
||
Bill McJohn (billmc) 02-Sept-1991
|
||
|
||
Environment:
|
||
|
||
ULIB, User Mode
|
||
|
||
--*/
|
||
|
||
#if !defined( _NTFS_INDEX_BUFFER_DEFN_ )
|
||
|
||
#define _NTFS_INDEX_BUFFER_DEFN_
|
||
|
||
#include "hmem.hxx"
|
||
#include "indxtree.hxx"
|
||
|
||
DECLARE_CLASS( LOG_IO_DP_DRIVE );
|
||
DECLARE_CLASS( NTFS_ATTRIBUTE );
|
||
DECLARE_CLASS( NTFS_INDEX_TREE );
|
||
DECLARE_CLASS( NTFS_UPCASE_TABLE );
|
||
|
||
class NTFS_INDEX_BUFFER : public OBJECT {
|
||
|
||
FRIEND
|
||
BOOLEAN
|
||
NTFS_INDEX_TREE::InsertIntoBuffer(
|
||
PNTFS_INDEX_BUFFER TargetBuffer,
|
||
PINTSTACK ParentTrail,
|
||
PCINDEX_ENTRY NewEntry,
|
||
PINDEX_ENTRY InsertionPoint
|
||
);
|
||
|
||
FRIEND
|
||
BOOLEAN
|
||
NTFS_INDEX_TREE::InsertIntoRoot(
|
||
PCINDEX_ENTRY NewEntry,
|
||
PINDEX_ENTRY InsertionPoint
|
||
);
|
||
|
||
FRIEND
|
||
BOOLEAN
|
||
NTFS_INDEX_TREE::GetNextParent(
|
||
);
|
||
|
||
public:
|
||
|
||
DECLARE_CONSTRUCTOR( NTFS_INDEX_BUFFER );
|
||
|
||
VIRTUAL
|
||
~NTFS_INDEX_BUFFER(
|
||
);
|
||
|
||
NONVIRTUAL
|
||
BOOLEAN
|
||
Initialize(
|
||
IN PCLOG_IO_DP_DRIVE Drive,
|
||
IN VCN ThisBufferVcn,
|
||
IN ULONG ClusterSize,
|
||
IN ULONG ClustersPerBuffer,
|
||
IN ULONG BufferSize,
|
||
IN ULONG CollationRule,
|
||
IN PNTFS_UPCASE_TABLE UpcaseTable
|
||
);
|
||
|
||
NONVIRTUAL
|
||
VOID
|
||
Create(
|
||
IN BOOLEAN IsLeaf,
|
||
IN VCN EndEntryDownpointer
|
||
);
|
||
|
||
NONVIRTUAL
|
||
BOOLEAN
|
||
Read(
|
||
IN OUT PNTFS_ATTRIBUTE AllocationAttribute
|
||
);
|
||
|
||
NONVIRTUAL
|
||
BOOLEAN
|
||
Write(
|
||
IN OUT PNTFS_ATTRIBUTE AllocationAttribute
|
||
);
|
||
|
||
NONVIRTUAL
|
||
BOOLEAN
|
||
FindEntry(
|
||
IN PCINDEX_ENTRY SearchEntry,
|
||
IN OUT PULONG Ordinal,
|
||
OUT PINDEX_ENTRY* EntryFound
|
||
);
|
||
|
||
NONVIRTUAL
|
||
BOOLEAN
|
||
InsertEntry(
|
||
IN PCINDEX_ENTRY NewEntry,
|
||
IN PINDEX_ENTRY InsertPoint DEFAULT NULL
|
||
);
|
||
|
||
NONVIRTUAL
|
||
VOID
|
||
RemoveEntry(
|
||
IN PINDEX_ENTRY EntryToRemove
|
||
);
|
||
|
||
NONVIRTUAL
|
||
PINDEX_ENTRY
|
||
GetFirstEntry(
|
||
);
|
||
|
||
NONVIRTUAL
|
||
BOOLEAN
|
||
IsLeaf(
|
||
) CONST;
|
||
|
||
NONVIRTUAL
|
||
VCN
|
||
QueryVcn(
|
||
) CONST;
|
||
|
||
NONVIRTUAL
|
||
ULONG
|
||
QuerySize(
|
||
) CONST;
|
||
|
||
NONVIRTUAL
|
||
PINDEX_ALLOCATION_BUFFER
|
||
GetData(
|
||
);
|
||
|
||
NONVIRTUAL
|
||
PINDEX_ENTRY
|
||
FindSplitPoint(
|
||
);
|
||
|
||
NONVIRTUAL
|
||
BOOLEAN
|
||
IsEmpty(
|
||
);
|
||
|
||
NONVIRTUAL
|
||
BOOLEAN
|
||
SetLsn(
|
||
IN BIG_INT NewLsn
|
||
);
|
||
|
||
NONVIRTUAL
|
||
LSN
|
||
QueryLsn(
|
||
) CONST;
|
||
|
||
private:
|
||
|
||
NONVIRTUAL
|
||
VOID
|
||
Construct(
|
||
);
|
||
|
||
NONVIRTUAL
|
||
VOID
|
||
Destroy(
|
||
);
|
||
|
||
NONVIRTUAL
|
||
VOID
|
||
InsertClump(
|
||
IN ULONG LengthOfClump,
|
||
IN PCVOID Clump
|
||
);
|
||
|
||
NONVIRTUAL
|
||
VOID
|
||
RemoveClump(
|
||
IN ULONG LengthOfClump
|
||
);
|
||
|
||
|
||
|
||
VCN _ThisBufferVcn;
|
||
ULONG _ClusterSize;
|
||
ULONG _ClustersPerBuffer;
|
||
ULONG _BufferSize;
|
||
COLLATION_RULE _CollationRule;
|
||
PNTFS_UPCASE_TABLE _UpcaseTable;
|
||
|
||
HMEM _Mem;
|
||
PINDEX_ALLOCATION_BUFFER _Data;
|
||
};
|
||
|
||
|
||
INLINE
|
||
PINDEX_ENTRY
|
||
NTFS_INDEX_BUFFER::GetFirstEntry(
|
||
)
|
||
/*++
|
||
|
||
Routine Description:
|
||
|
||
This method returns a pointer to the first entry in the index buffer.
|
||
|
||
Arguments:
|
||
|
||
None.
|
||
|
||
Return Value:
|
||
|
||
A pointer to the first index entry in the buffer.
|
||
|
||
--*/
|
||
{
|
||
return( (PINDEX_ENTRY)( (PBYTE)&(_Data->IndexHeader) +
|
||
_Data->IndexHeader.FirstIndexEntry ) );
|
||
}
|
||
|
||
|
||
|
||
INLINE
|
||
BOOLEAN
|
||
NTFS_INDEX_BUFFER::IsLeaf(
|
||
) CONST
|
||
/*++
|
||
|
||
Routine Description:
|
||
|
||
This method determines whether this index buffer is a leaf.
|
||
|
||
Arguments:
|
||
|
||
None.
|
||
|
||
Return Value:
|
||
|
||
TRUE if this buffer is a leaf; FALSE otherwise.
|
||
|
||
--*/
|
||
{
|
||
return( !(_Data->IndexHeader.Flags & INDEX_NODE) );
|
||
}
|
||
|
||
|
||
INLINE
|
||
VCN
|
||
NTFS_INDEX_BUFFER::QueryVcn(
|
||
) CONST
|
||
/*++
|
||
|
||
Routine Description:
|
||
|
||
This method returns the VCN within the index allocation attribute
|
||
of this index buffer.
|
||
|
||
Arguments:
|
||
|
||
None.
|
||
|
||
Return Value:
|
||
|
||
The VCN within the index allocation attribute of this index buffer.
|
||
|
||
--*/
|
||
{
|
||
return _ThisBufferVcn;
|
||
}
|
||
|
||
|
||
INLINE
|
||
ULONG
|
||
NTFS_INDEX_BUFFER::QuerySize(
|
||
) CONST
|
||
/*++
|
||
|
||
Routine Description:
|
||
|
||
This method returns the size of this buffer. Note that it includes
|
||
any free space in the buffer, and that all buffers in a given tree
|
||
will have the same size.
|
||
|
||
Arguments:
|
||
|
||
None.
|
||
|
||
Return Value:
|
||
|
||
The size of the buffer.
|
||
--*/
|
||
{
|
||
return _BufferSize;
|
||
}
|
||
|
||
|
||
INLINE
|
||
PINDEX_ALLOCATION_BUFFER
|
||
NTFS_INDEX_BUFFER::GetData(
|
||
)
|
||
/*++
|
||
|
||
Routine Description:
|
||
|
||
This method returns the index buffer's data buffer. It's a back
|
||
door that allows the index tree to read and write the index buffer.
|
||
|
||
Arguments:
|
||
|
||
None.
|
||
|
||
Return Value:
|
||
|
||
The index buffer's data buffer.
|
||
|
||
--*/
|
||
{
|
||
return _Data;
|
||
}
|
||
|
||
|
||
INLINE
|
||
BOOLEAN
|
||
NTFS_INDEX_BUFFER::SetLsn(
|
||
IN BIG_INT NewLsn
|
||
)
|
||
/*++
|
||
|
||
Routine Description:
|
||
|
||
This method sets the Log Sequence Number in the index buffer.
|
||
|
||
Arguments:
|
||
|
||
NewLsn -- Supplies the new LSN
|
||
|
||
Return Value:
|
||
|
||
Always returns TRUE.
|
||
|
||
--*/
|
||
{
|
||
_Data->Lsn = NewLsn.GetLargeInteger();
|
||
return TRUE;
|
||
}
|
||
|
||
|
||
INLINE
|
||
LSN
|
||
NTFS_INDEX_BUFFER::QueryLsn(
|
||
) CONST
|
||
/*++
|
||
|
||
Routine Description:
|
||
|
||
This method sets the Log Sequence Number in the index buffer.
|
||
|
||
Arguments:
|
||
|
||
NewLsn -- Supplies the new LSN
|
||
|
||
Return Value:
|
||
|
||
Always returns TRUE.
|
||
|
||
--*/
|
||
{
|
||
return _Data->Lsn;
|
||
}
|
||
|
||
#endif
|