windows-nt/Source/XPSP1/NT/base/fs/ntfs/tests/bshell/tqfile.c
2020-09-26 16:20:57 +08:00

1673 lines
38 KiB
C
Raw Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

#include "brian.h"
typedef struct _ASYNC_QFILE {
USHORT FileIndex;
PUSHORT BufferIndexPtr;
USHORT BufferIndex;
ULONG Length;
FILE_INFORMATION_CLASS FileInfoClass;
BOOLEAN DisplayParms;
BOOLEAN VerboseResults;
USHORT AsyncIndex;
} ASYNC_QFILE, *PASYNC_QFILE;
#define QFILE_LENGTH_DEFAULT 100
#define FILE_INFO_CLASS_DEFAULT FileAllInformation
#define DISPLAY_PARMS_DEFAULT FALSE
#define VERBOSE_DEFAULT FALSE
#define DISPLAY_INDEX_DEFAULT 0
VOID
FullQFile(
IN OUT PASYNC_QFILE AsyncQFile
);
VOID
DisplayQFileBasicInformation (
IN USHORT BufferIndex
);
VOID
DisplayQFileStandardInformation (
IN USHORT BufferIndex
);
VOID
DisplayQFileInternalInformation (
IN USHORT BufferIndex
);
VOID
DisplayQFileEaInformation (
IN USHORT BufferIndex
);
VOID
DisplayQFileAccessInformation (
IN USHORT BufferIndex
);
VOID
DisplayQFileNameInformation (
IN USHORT BufferIndex
);
VOID
DisplayQFilePositionInformation (
IN USHORT BufferIndex
);
VOID
DisplayQFileModeInformation (
IN USHORT BufferIndex
);
VOID
DisplayQFileAlignmentInformation (
IN USHORT BufferIndex
);
VOID
DisplayQFileAllInformation (
IN USHORT BufferIndex
);
VOID
DisplayQFileStreamInformation (
IN USHORT BufferIndex
);
VOID
DisplayQFileAlternateNameInformation (
IN USHORT BufferIndex
);
VOID
DisplayQFileNetworkQueryInformation (
IN USHORT BufferIndex
);
VOID
DisplayBasicInformation (
IN PFILE_BASIC_INFORMATION FileInfo
);
VOID
DisplayStandardInformation (
IN PFILE_STANDARD_INFORMATION FileInfo
);
VOID
DisplayInternalInformation (
IN PFILE_INTERNAL_INFORMATION FileInfo
);
VOID
DisplayEaInformation (
IN PFILE_EA_INFORMATION FileInfo
);
VOID
DisplayAccessInformation (
IN PFILE_ACCESS_INFORMATION FileInfo
);
VOID
DisplayNameInformation (
IN PFILE_NAME_INFORMATION FileInfo
);
VOID
DisplayPositionInformation (
IN PFILE_POSITION_INFORMATION FileInfo
);
VOID
DisplayModeInformation (
IN PFILE_MODE_INFORMATION FileInfo
);
VOID
DisplayAlignmentInformation (
IN PFILE_ALIGNMENT_INFORMATION FileInfo
);
VOID
DisplayStreamInformation (
IN PFILE_STREAM_INFORMATION FileInfo
);
VOID
DisplayNetworkOpenInformation (
IN PFILE_NETWORK_OPEN_INFORMATION FileInfo
);
VOID
InputQFile (
IN PCHAR ParamBuffer
)
{
ULONG FileIndex;
PUSHORT BufferIndexPtr;
USHORT BufferIndex;
ULONG Length;
FILE_INFORMATION_CLASS FileInfoClass;
BOOLEAN DisplayParms;
BOOLEAN VerboseResults;
USHORT AsyncIndex;
BOOLEAN ParamReceived;
BOOLEAN LastInput;
//
// Set the defaults.
//
BufferIndexPtr = NULL;
BufferIndex = 0;
Length = QFILE_LENGTH_DEFAULT;
FileInfoClass = FILE_INFO_CLASS_DEFAULT;
DisplayParms = DISPLAY_PARMS_DEFAULT;
VerboseResults = VERBOSE_DEFAULT;
AsyncIndex = 0;
ParamReceived = FALSE;
LastInput = TRUE;
//
// While there is more input, analyze the parameter and update the
// query flags.
//
while (TRUE) {
ULONG DummyCount;
ULONG TempIndex;
//
// Swallow leading white spaces.
//
ParamBuffer = SwallowWhite( ParamBuffer, &DummyCount );
if (*ParamBuffer) {
//
// If the next parameter is legal then check the paramter value.
// Update the parameter value.
//
if ((*ParamBuffer == '-'
|| *ParamBuffer == '/')
&& (ParamBuffer++, *ParamBuffer != '\0')) {
BOOLEAN SwitchBool;
//
// Switch on the next character.
//
switch (*ParamBuffer) {
//
// Update the buffer index.
//
case 'b' :
case 'B' :
//
// Move to the next character, as long as there
// are no white spaces continue analyzing letters.
// On the first bad letter, skip to the next
// parameter.
//
ParamBuffer++;
TempIndex = AsciiToInteger( ParamBuffer );
BufferIndex = (USHORT) TempIndex;
BufferIndexPtr = &BufferIndex;
Length = Buffers[BufferIndex].Length;
ParamBuffer = SwallowNonWhite( ParamBuffer, &DummyCount );
break;
//
// Update the byte count.
//
case 'l' :
case 'L' :
//
// Move to the next character, as long as there
// are no white spaces continue analyzing letters.
// On the first bad letter, skip to the next
// parameter.
//
ParamBuffer++;
Length = AsciiToInteger( ParamBuffer );
ParamBuffer = SwallowNonWhite( ParamBuffer, &DummyCount );
break;
//
// Update the file handle index.
//
case 'i' :
case 'I' :
//
// Move to the next character, as long as there
// are no white spaces continue analyzing letters.
// On the first bad letter, skip to the next
// parameter.
//
ParamBuffer++;
FileIndex = AsciiToInteger( ParamBuffer );
ParamBuffer = SwallowNonWhite( ParamBuffer, &DummyCount );
ParamReceived = TRUE;
break;
//
// Update the information class.
//
case 'c' :
case 'C' :
//
// Move to the next character, as long as there
// are no white spaces continue analyzing letters.
// On the first bad letter, skip to the next
// parameter.
//
ParamBuffer++;
SwitchBool = TRUE;
while (*ParamBuffer
&& *ParamBuffer != ' '
&& *ParamBuffer != '\t') {
//
// Perform switch on character.
//
switch (*ParamBuffer) {
case 'a' :
case 'A' :
FileInfoClass = FileBasicInformation;
break;
case 'b' :
case 'B' :
FileInfoClass = FileStandardInformation;
break;
case 'c' :
case 'C' :
FileInfoClass = FileInternalInformation;
break;
case 'd' :
case 'D' :
FileInfoClass = FileEaInformation;
break;
case 'e' :
case 'E' :
FileInfoClass = FileAccessInformation;
break;
case 'f' :
case 'F' :
FileInfoClass = FileNameInformation;
break;
case 'g' :
case 'G' :
FileInfoClass = FilePositionInformation;
break;
case 'h' :
case 'H' :
FileInfoClass = FileModeInformation;
break;
case 'i' :
case 'I' :
FileInfoClass = FileAlignmentInformation;
break;
case 'j' :
case 'J' :
FileInfoClass = FileAllInformation;
break;
case 'k' :
case 'K' :
FileInfoClass = FileStreamInformation;
break;
case 'l' :
case 'L' :
FileInfoClass = FileAlternateNameInformation;
break;
case 'm' :
case 'M' :
FileInfoClass = FileNetworkOpenInformation;
break;
default :
ParamBuffer = SwallowNonWhite( ParamBuffer, &DummyCount );
SwitchBool = FALSE;
}
if (!SwitchBool) {
break;
}
ParamBuffer++;
}
break;
case 'v' :
case 'V' :
//
// Legal values for params are T/t or F/f.
//
ParamBuffer++;
if( *ParamBuffer == 'T'
|| *ParamBuffer == 't' ) {
VerboseResults = TRUE;
ParamBuffer++;
} else if( *ParamBuffer == 'F'
|| *ParamBuffer == 'f' ) {
VerboseResults = FALSE;
ParamBuffer++;
}
break;
case 'y' :
case 'Y' :
//
// Set the display parms flag and jump over this
// character.
//
DisplayParms = TRUE;
ParamBuffer = SwallowNonWhite( ParamBuffer, &DummyCount );
break;
case 'z' :
case 'Z' :
//
// Set flag for more input and jump over this char.
//
LastInput = FALSE;
ParamBuffer = SwallowNonWhite( ParamBuffer, &DummyCount );
break;
default :
//
// Swallow to the next white space and continue the
// loop.
//
ParamBuffer = SwallowNonWhite( ParamBuffer, &DummyCount );
}
}
//
// Else the text is invalid, skip the entire block.
//
//
//
// Else if there is no input then exit.
//
} else if( LastInput ) {
break;
//
// Else try to read another line for open parameters.
//
} else {
}
}
//
// If no parameters were received then display the syntax message.
//
if (!ParamReceived) {
printf( "\n Usage: qf [options]* -i<index> [options]*\n" );
printf( "\n Options:" );
printf( "\n -i<digits> File index" );
printf( "\n -l<digits> Buffer length" );
printf( "\n -b<digits> Buffer index" );
printf( "\n -c<char> File information class" );
printf( "\n -v[t|f] Verbose results" );
printf( "\n -y Display parameters to query" );
printf( "\n -z Additional input line" );
printf( "\n\n" );
//
// Else call our read routine.
//
} else {
NTSTATUS Status;
SIZE_T RegionSize;
ULONG TempIndex;
PASYNC_QFILE AsyncQFile;
HANDLE ThreadHandle;
ULONG ThreadId;
RegionSize = sizeof( ASYNC_QFILE );
Status = AllocateBuffer( 0, &RegionSize, &TempIndex );
AsyncIndex = (USHORT) TempIndex;
if (!NT_SUCCESS( Status )) {
printf("\n\tInputQFile: Unable to allocate async structure" );
} else {
AsyncQFile = (PASYNC_QFILE) Buffers[AsyncIndex].Buffer;
AsyncQFile->FileIndex = (USHORT) FileIndex;
AsyncQFile->BufferIndex = BufferIndex;
AsyncQFile->BufferIndexPtr = BufferIndexPtr
? &AsyncQFile->BufferIndex
: BufferIndexPtr;
AsyncQFile->Length = Length;
AsyncQFile->FileInfoClass = FileInfoClass;
AsyncQFile->DisplayParms = DisplayParms;
AsyncQFile->VerboseResults = VerboseResults;
AsyncQFile->AsyncIndex = AsyncIndex;
if (!SynchronousCmds) {
ThreadHandle = CreateThread( NULL,
0,
FullQFile,
AsyncQFile,
0,
&ThreadId );
if (ThreadHandle == 0) {
printf( "\nInputQFile: Spawning thread fails -> %d\n", GetLastError() );
DeallocateBuffer( AsyncIndex );
return;
}
} else {
FullQFile( AsyncQFile );
}
}
}
return;
}
VOID
FullQFile(
IN OUT PASYNC_QFILE AsyncQFile
)
{
NTSTATUS Status;
IO_STATUS_BLOCK Iosb;
USHORT ThisBufferIndex;
BOOLEAN UnwindQFileBuffer = FALSE;
Status = STATUS_SUCCESS;
if (AsyncQFile->DisplayParms) {
bprint "\nQFile Parameters" );
bprint "\n File Handle Index -> %d", AsyncQFile->FileIndex );
bprint "\n Buffer Index Ptr -> %08lx", AsyncQFile->BufferIndexPtr );
if (AsyncQFile->BufferIndexPtr) {
bprint "\n BufferIndex value -> %04x", AsyncQFile->BufferIndex );
}
bprint "\n Length -> %08lx", AsyncQFile->Length );
bprint "\n FileInfoClass -> %08lx", AsyncQFile->FileInfoClass );
bprint "\n\n" );
}
try {
SIZE_T ThisLength;
//
// If we need a buffer, allocate it now.
//
if (AsyncQFile->BufferIndexPtr == NULL) {
ULONG TempIndex;
ThisLength = 4096;
Status = AllocateBuffer( 0L, &ThisLength, &TempIndex );
ThisBufferIndex = (USHORT) TempIndex;
if (!NT_SUCCESS( Status )) {
bprint "\n\tFullQFile: Unable to allocate a query buffer" );
try_return( Status );
}
bprint "\n\tFullQFile: Reading into buffer -> %04x\n", ThisBufferIndex );
bprint "\n" );
UnwindQFileBuffer = TRUE;
AsyncQFile->Length = (ULONG) ThisLength;
} else {
ThisBufferIndex = AsyncQFile->BufferIndex;
}
//
// Check that the buffer index is valid.
//
if (ThisBufferIndex >= MAX_BUFFERS) {
bprint "\n\tFullQFile: The read buffer index is invalid" );
try_return( Status = STATUS_INVALID_HANDLE );
}
//
// Check that the file index is valid.
//
if (AsyncQFile->FileIndex >= MAX_HANDLES) {
bprint "\n\tFullQFile: The file index is invalid" );
try_return( Status = STATUS_INVALID_HANDLE );
}
//
// Call the query file routine.
//
Status = NtQueryInformationFile( Handles[AsyncQFile->FileIndex].Handle,
&Iosb,
Buffers[ThisBufferIndex].Buffer,
AsyncQFile->Length,
AsyncQFile->FileInfoClass );
UnwindQFileBuffer = FALSE;
if (AsyncQFile->VerboseResults) {
bprint "\nQuery File: Status -> %08lx", Status );
if (NT_SUCCESS( Status )) {
bprint "\n Iosb.Information -> %08lx", Iosb.Information );
bprint "\n Iosb.Status -> %08lx", Iosb.Status );
}
bprint "\n" );
}
try_return( Status );
try_exit: NOTHING;
} finally {
if (UnwindQFileBuffer) {
DeallocateBuffer( ThisBufferIndex );
}
DeallocateBuffer( AsyncQFile->AsyncIndex );
}
NtTerminateThread( 0, STATUS_SUCCESS );
}
VOID
InputDisplayQFile (
IN PCHAR ParamBuffer
)
{
FILE_INFORMATION_CLASS FileInfoClass;
ULONG BufferIndex;
BOOLEAN ParamReceived;
BOOLEAN LastInput;
//
// Set the defaults.
//
BufferIndex = DISPLAY_INDEX_DEFAULT;
FileInfoClass = FILE_INFO_CLASS_DEFAULT;
ParamReceived = FALSE;
LastInput = TRUE;
//
// While there is more input, analyze the parameter and update the
// query flags.
//
while (TRUE) {
ULONG DummyCount;
//
// Swallow leading white spaces.
//
ParamBuffer = SwallowWhite( ParamBuffer, &DummyCount );
if (*ParamBuffer) {
//
// If the next parameter is legal then check the paramter value.
// Update the parameter value.
//
if ((*ParamBuffer == '-'
|| *ParamBuffer == '/')
&& (ParamBuffer++, *ParamBuffer != '\0')) {
BOOLEAN SwitchBool;
//
// Switch on the next character.
//
switch( *ParamBuffer ) {
//
// Check the buffer index.
//
case 'b' :
case 'B' :
//
// Move to the next character, as long as there
// are no white spaces continue analyzing letters.
// On the first bad letter, skip to the next
// parameter.
//
ParamBuffer++;
BufferIndex = AsciiToInteger( ParamBuffer );
ParamBuffer = SwallowNonWhite( ParamBuffer, &DummyCount );
ParamReceived = TRUE;
break;
//
// Update the desired access.
//
case 'c' :
case 'C' :
//
// Move to the next character, as long as there
// are no white spaces continue analyzing letters.
// On the first bad letter, skip to the next
// parameter.
//
ParamBuffer++;
SwitchBool = TRUE;
while (*ParamBuffer
&& *ParamBuffer != ' '
&& *ParamBuffer != '\t') {
//
// Perform switch on character.
//
switch (*ParamBuffer) {
case 'a' :
case 'A' :
FileInfoClass = FileBasicInformation;
break;
case 'b' :
case 'B' :
FileInfoClass = FileStandardInformation;
break;
case 'c' :
case 'C' :
FileInfoClass = FileInternalInformation;
break;
case 'd' :
case 'D' :
FileInfoClass = FileEaInformation;
break;
case 'e' :
case 'E' :
FileInfoClass = FileAccessInformation;
break;
case 'f' :
case 'F' :
FileInfoClass = FileNameInformation;
break;
case 'g' :
case 'G' :
FileInfoClass = FilePositionInformation;
break;
case 'h' :
case 'H' :
FileInfoClass = FileModeInformation;
break;
case 'i' :
case 'I' :
FileInfoClass = FileAlignmentInformation;
break;
case 'j' :
case 'J' :
FileInfoClass = FileAllInformation;
break;
case 'k' :
case 'K' :
FileInfoClass = FileStreamInformation;
break;
case 'l' :
case 'L' :
FileInfoClass = FileAlternateNameInformation;
break;
case 'm' :
case 'M' :
FileInfoClass = FileNetworkOpenInformation;
break;
default :
ParamBuffer = SwallowNonWhite( ParamBuffer, &DummyCount );
SwitchBool = FALSE;
}
if (!SwitchBool) {
break;
}
ParamBuffer++;
}
break;
default :
//
// Swallow to the next white space and continue the
// loop.
//
ParamBuffer = SwallowNonWhite( ParamBuffer, &DummyCount );
}
}
//
// Else the text is invalid, skip the entire block.
//
//
//
// Else if there is no input then exit.
//
} else if ( LastInput ) {
break;
//
// Else try to read another line for open parameters.
//
} else {
}
}
//
// If no parameters were received then display the syntax message.
//
if (!ParamReceived) {
printf( "\n Usage: dqf [options]* -b<digits> [options]*\n" );
printf( "\n Options:" );
printf( "\n -b<digits> Buffer index" );
printf( "\n -c<char> Key to buffer format" );
printf( "\n\n" );
//
// Else call our display buffer routine.
//
} else {
switch (FileInfoClass) {
case FileBasicInformation:
DisplayQFileBasicInformation( (USHORT) BufferIndex );
break;
case FileStandardInformation:
DisplayQFileStandardInformation( (USHORT) BufferIndex );
break;
case FileInternalInformation:
DisplayQFileInternalInformation( (USHORT) BufferIndex );
break;
case FileEaInformation:
DisplayQFileEaInformation( (USHORT) BufferIndex );
break;
case FileAccessInformation:
DisplayQFileAccessInformation( (USHORT) BufferIndex );
break;
case FileNameInformation:
DisplayQFileNameInformation( (USHORT) BufferIndex );
break;
case FilePositionInformation:
DisplayQFilePositionInformation( (USHORT) BufferIndex );
break;
case FileModeInformation:
DisplayQFileModeInformation( (USHORT) BufferIndex );
break;
case FileAlignmentInformation:
DisplayQFileAlignmentInformation( (USHORT) BufferIndex );
break;
case FileAllInformation:
DisplayQFileAllInformation( (USHORT) BufferIndex );
break;
case FileStreamInformation:
DisplayQFileStreamInformation( (USHORT) BufferIndex );
break;
case FileAlternateNameInformation:
DisplayQFileAlternateNameInformation( (USHORT) BufferIndex );
break;
case FileNetworkOpenInformation:
DisplayQFileNetworkQueryInformation( (USHORT) BufferIndex );
break;
}
}
}
VOID
DisplayQFileBasicInformation (
IN USHORT BufferIndex
)
{
PFILE_BASIC_INFORMATION FileInfo;
if (!Buffers[BufferIndex].Used) {
printf( "\nDisplayQFileBasicInformation: Invalid buffer\n" );
return;
}
try {
FileInfo = (PFILE_BASIC_INFORMATION) Buffers[BufferIndex].Buffer;
printf( "\n\nBasic File Information\n" );
DisplayBasicInformation( FileInfo );
printf( "\n" );
try_return( NOTHING );
try_exit: NOTHING;
} finally {
if (AbnormalTermination()) {
printf( "\nDisplayQFileBasicInformation: AbnormalTermination\n" );
}
}
return;
}
VOID
DisplayQFileStandardInformation (
IN USHORT BufferIndex
)
{
PFILE_STANDARD_INFORMATION FileInfo;
if (!Buffers[BufferIndex].Used) {
printf( "\nDisplayQFileStandardInformation: Invalid buffer\n" );
return;
}
try {
FileInfo = (PFILE_STANDARD_INFORMATION) Buffers[BufferIndex].Buffer;
printf( "\n\nStandard File Information\n" );
DisplayStandardInformation( FileInfo );
printf( "\n" );
try_return( NOTHING );
try_exit: NOTHING;
} finally {
if (AbnormalTermination()) {
printf( "\nDisplayQFileStandardInformation: AbnormalTermination\n" );
}
}
return;
}
VOID
DisplayQFileInternalInformation (
IN USHORT BufferIndex
)
{
PFILE_INTERNAL_INFORMATION FileInfo;
if (!Buffers[BufferIndex].Used) {
printf( "\nDisplayQFileInternalInformation: Invalid buffer\n" );
return;
}
try {
FileInfo = (PFILE_INTERNAL_INFORMATION) Buffers[BufferIndex].Buffer;
printf( "\n\nInternal File Information\n" );
DisplayInternalInformation( FileInfo );
printf( "\n" );
try_return( NOTHING );
try_exit: NOTHING;
} finally {
if (AbnormalTermination()) {
printf( "\nDisplayQFileInternalInformation: AbnormalTermination\n" );
}
}
return;
}
VOID
DisplayQFileEaInformation (
IN USHORT BufferIndex
)
{
PFILE_EA_INFORMATION FileInfo;
if (!Buffers[BufferIndex].Used) {
printf( "\nDisplayQFileEaInformation: Invalid buffer\n" );
return;
}
try {
FileInfo = (PFILE_EA_INFORMATION) Buffers[BufferIndex].Buffer;
printf( "\n\nEa File Information\n" );
DisplayEaInformation( FileInfo );
printf( "\n" );
try_return( NOTHING );
try_exit: NOTHING;
} finally {
if (AbnormalTermination()) {
printf( "\nDisplayQFileEaInformation: AbnormalTermination\n" );
}
}
return;
}
VOID
DisplayQFileAccessInformation (
IN USHORT BufferIndex
)
{
PFILE_ACCESS_INFORMATION FileInfo;
if (!Buffers[BufferIndex].Used) {
printf( "\nDisplayQFileAccessInformation: Invalid buffer\n" );
return;
}
try {
FileInfo = (PFILE_ACCESS_INFORMATION) Buffers[BufferIndex].Buffer;
printf( "\n\nAccess File Information\n" );
DisplayAccessInformation( FileInfo );
printf( "\n" );
try_return( NOTHING );
try_exit: NOTHING;
} finally {
if (AbnormalTermination()) {
printf( "\nDisplayQFileAccessInformation: AbnormalTermination\n" );
}
}
return;
}
VOID
DisplayQFileNameInformation (
IN USHORT BufferIndex
)
{
PFILE_NAME_INFORMATION FileInfo;
if (!Buffers[BufferIndex].Used) {
printf( "\nDisplayQFileNameInformation: Invalid buffer\n" );
return;
}
try {
FileInfo = (PFILE_NAME_INFORMATION) Buffers[BufferIndex].Buffer;
printf( "\n\nName File Information\n" );
DisplayNameInformation( FileInfo );
printf( "\n" );
try_return( NOTHING );
try_exit: NOTHING;
} finally {
if (AbnormalTermination()) {
printf( "\nDisplayQFileNameInformation: AbnormalTermination\n" );
}
}
return;
}
VOID
DisplayQFilePositionInformation (
IN USHORT BufferIndex
)
{
PFILE_POSITION_INFORMATION FileInfo;
if (!Buffers[BufferIndex].Used) {
printf( "\nDisplayQFilePositionInformation: Invalid buffer\n" );
return;
}
try {
FileInfo = (PFILE_POSITION_INFORMATION) Buffers[BufferIndex].Buffer;
printf( "\n\nPosition File Information\n" );
DisplayPositionInformation( FileInfo );
printf( "\n" );
try_return( NOTHING );
try_exit: NOTHING;
} finally {
if (AbnormalTermination()) {
printf( "\nDisplayQFilePositionInformation: AbnormalTermination\n" );
}
}
return;
}
VOID
DisplayQFileModeInformation (
IN USHORT BufferIndex
)
{
PFILE_MODE_INFORMATION FileInfo;
if (!Buffers[BufferIndex].Used) {
printf( "\nDisplayQFileModeInformation: Invalid buffer\n" );
return;
}
try {
FileInfo = (PFILE_MODE_INFORMATION) Buffers[BufferIndex].Buffer;
printf( "\n\nMode File Information\n" );
DisplayModeInformation( FileInfo );
printf( "\n" );
try_return( NOTHING );
try_exit: NOTHING;
} finally {
if (AbnormalTermination()) {
printf( "\nDisplayQFileModeInformation: AbnormalTermination\n" );
}
}
return;
}
VOID
DisplayQFileAlignmentInformation (
IN USHORT BufferIndex
)
{
PFILE_ALIGNMENT_INFORMATION FileInfo;
if (!Buffers[BufferIndex].Used) {
printf( "\nDisplayQFileAlignmentInformation: Invalid buffer\n" );
return;
}
try {
FileInfo = (PFILE_ALIGNMENT_INFORMATION) Buffers[BufferIndex].Buffer;
printf( "\n\nAlignment File Information\n" );
DisplayAlignmentInformation( FileInfo );
printf( "\n" );
try_return( NOTHING );
try_exit: NOTHING;
} finally {
if (AbnormalTermination()) {
printf( "\nDisplayQFileAlignmentInformation: AbnormalTermination\n" );
}
}
return;
}
VOID
DisplayQFileAllInformation (
IN USHORT BufferIndex
)
{
PFILE_ALL_INFORMATION FileInfo;
if (!Buffers[BufferIndex].Used) {
printf( "\nDisplayQFileAllInformation: Invalid buffer\n" );
return;
}
try {
FileInfo = (PFILE_ALL_INFORMATION) Buffers[BufferIndex].Buffer;
printf( "\n\nAll File Information\n" );
DisplayNameInformation( &FileInfo->NameInformation );
DisplayBasicInformation( &FileInfo->BasicInformation );
DisplayStandardInformation( &FileInfo->StandardInformation );
DisplayInternalInformation( &FileInfo->InternalInformation );
DisplayEaInformation( &FileInfo->EaInformation );
DisplayAccessInformation( &FileInfo->AccessInformation );
DisplayPositionInformation( &FileInfo->PositionInformation );
DisplayModeInformation( &FileInfo->ModeInformation );
DisplayAlignmentInformation( &FileInfo->AlignmentInformation );
printf( "\n" );
try_return( NOTHING );
try_exit: NOTHING;
} finally {
if (AbnormalTermination()) {
printf( "\nDisplayQFileBasicInformation: AbnormalTermination\n" );
}
}
return;
}
VOID
DisplayQFileStreamInformation (
IN USHORT BufferIndex
)
{
PFILE_STREAM_INFORMATION FileInfo;
ULONG NextOffset;
if (!Buffers[BufferIndex].Used) {
printf( "\nDisplayQFileStreamInformation: Invalid buffer\n" );
return;
}
try {
NextOffset = 0;
FileInfo = (PFILE_STREAM_INFORMATION) Buffers[BufferIndex].Buffer;
printf( "\n\nStream File Information\n" );
do {
FileInfo = (PFILE_STREAM_INFORMATION) ((PUCHAR) FileInfo + NextOffset);
DisplayStreamInformation( FileInfo );
NextOffset = FileInfo->NextEntryOffset;
} while ( NextOffset );
printf( "\n" );
try_return( NOTHING );
try_exit: NOTHING;
} finally {
if (AbnormalTermination()) {
printf( "\nDisplayQFileStreamInformation: AbnormalTermination\n" );
}
}
return;
}
VOID
DisplayQFileAlternateNameInformation (
IN USHORT BufferIndex
)
{
PFILE_NAME_INFORMATION FileInfo;
if (!Buffers[BufferIndex].Used) {
printf( "\nDisplayQFileAlternateNameInformation: Invalid buffer\n" );
return;
}
try {
FileInfo = (PFILE_NAME_INFORMATION) Buffers[BufferIndex].Buffer;
printf( "\n\nAlternate Name File Information\n" );
DisplayNameInformation( FileInfo );
printf( "\n" );
try_return( NOTHING );
try_exit: NOTHING;
} finally {
if (AbnormalTermination()) {
printf( "\nDisplayQFileAlternateNameInformation: AbnormalTermination\n" );
}
}
return;
}
VOID
DisplayQFileNetworkQueryInformation (
IN USHORT BufferIndex
)
{
PFILE_NETWORK_OPEN_INFORMATION FileInfo;
if (!Buffers[BufferIndex].Used) {
printf( "\nDisplayQFileNetworkQueryInformation: Invalid buffer\n" );
return;
}
try {
FileInfo = (PFILE_NETWORK_OPEN_INFORMATION) Buffers[BufferIndex].Buffer;
printf( "\n\nNetwork Open File Information\n" );
DisplayNetworkOpenInformation( FileInfo );
printf( "\n" );
try_return( NOTHING );
try_exit: NOTHING;
} finally {
if (AbnormalTermination()) {
printf( "\nDisplayQFileNetworkOpenInformation: AbnormalTermination\n" );
}
}
return;
}
VOID
DisplayBasicInformation (
IN PFILE_BASIC_INFORMATION FileInfo
)
{
printf( "\n\tCreation Time -> " );
PrintTime( &FileInfo->CreationTime );
printf( "\n\tLast Access Time -> " );
PrintTime( &FileInfo->LastAccessTime );
printf( "\n\tLast Write Time -> " );
PrintTime( &FileInfo->LastWriteTime );
printf( "\n\tChange Time -> " );
PrintTime( &FileInfo->ChangeTime );
printf( "\n\tFile Attributes -> %08lx", FileInfo->FileAttributes );
return;
}
VOID
DisplayStandardInformation (
IN PFILE_STANDARD_INFORMATION FileInfo
)
{
printf( "\n\tAllocation Size -> " );
PrintLargeInteger( &FileInfo->AllocationSize );
printf( "\n\tEnd Of File -> " );
PrintLargeInteger( &FileInfo->EndOfFile );
printf( "\n\tNumber of Links -> %08lx", FileInfo->NumberOfLinks );
printf( "\n\tDelete Pending -> %04x", FileInfo->DeletePending );
printf( "\n\tDirectory -> %d", FileInfo->Directory );
return;
}
VOID
DisplayInternalInformation (
IN PFILE_INTERNAL_INFORMATION FileInfo
)
{
printf( "\n\tFile Index.LowPart -> %08lx", FileInfo->IndexNumber.LowPart );
printf( "\n\tFile Index.HighPart -> %08lx", FileInfo->IndexNumber.HighPart );
printf( "\n\n\tFile Index.LowPart -> %ld", FileInfo->IndexNumber.LowPart );
printf( "\n\tFile Index.HighPart -> %ld", FileInfo->IndexNumber.HighPart );
return;
}
VOID
DisplayEaInformation (
IN PFILE_EA_INFORMATION FileInfo
)
{
printf( "\n\tEa Size -> %08lx", FileInfo->EaSize );
return;
}
VOID
DisplayAccessInformation (
IN PFILE_ACCESS_INFORMATION FileInfo
)
{
printf( "\n\tAccess Flags -> %08lx", FileInfo->AccessFlags );
return;
}
VOID
DisplayNameInformation (
IN PFILE_NAME_INFORMATION FileInfo
)
{
ANSI_STRING AnsiString;
UNICODE_STRING UnicodeString;
UnicodeString.MaximumLength =
UnicodeString.Length = (USHORT) FileInfo->FileNameLength;
UnicodeString.Buffer = (PWSTR) &FileInfo->FileName;
UnicodeString.MaximumLength += 2;
RtlUnicodeStringToAnsiString( &AnsiString,
&UnicodeString,
TRUE );
printf( "\n\tFile Name -> %s", AnsiString.Buffer );
RtlFreeAnsiString( &AnsiString );
return;
}
VOID
DisplayPositionInformation (
IN PFILE_POSITION_INFORMATION FileInfo
)
{
printf( "\n\tFile Position -> " );
PrintLargeInteger( &FileInfo->CurrentByteOffset );
return;
}
VOID
DisplayModeInformation (
IN PFILE_MODE_INFORMATION FileInfo
)
{
printf( "\n\tFile Mode -> %08lx", FileInfo->Mode );
return;
}
VOID
DisplayAlignmentInformation (
IN PFILE_ALIGNMENT_INFORMATION FileInfo
)
{
printf( "\n\tAlignment -> %08lx", FileInfo->AlignmentRequirement );
return;
}
VOID
DisplayStreamInformation (
IN PFILE_STREAM_INFORMATION FileInfo
)
{
UNICODE_STRING UnicodeString;
ANSI_STRING AnsiString;
printf( "\n\tStreamSize -> " );
PrintLargeInteger( &FileInfo->StreamSize );
printf( "\n\tStreamAllocationSize -> " );
PrintLargeInteger( &FileInfo->StreamAllocationSize );
printf( "\n\tStreamNameLength -> %08lx", FileInfo->StreamNameLength );
UnicodeString.MaximumLength = (USHORT) FileInfo->StreamNameLength + 2;
UnicodeString.Length = (USHORT) FileInfo->StreamNameLength;
UnicodeString.Buffer = (PWSTR) &FileInfo->StreamName;
RtlUnicodeStringToAnsiString( &AnsiString,
&UnicodeString,
TRUE );
printf( "\n\tStream Name -> %s", AnsiString.Buffer );
RtlFreeAnsiString( &AnsiString );
}
VOID
DisplayNetworkOpenInformation (
IN PFILE_NETWORK_OPEN_INFORMATION FileInfo
)
{
printf( "\n\tCreation Time -> " );
PrintTime( &FileInfo->CreationTime );
printf( "\n\tLast Access Time -> " );
PrintTime( &FileInfo->LastAccessTime );
printf( "\n\tLast Write Time -> " );
PrintTime( &FileInfo->LastWriteTime );
printf( "\n\tChange Time -> " );
PrintTime( &FileInfo->ChangeTime );
printf( "\n\tAllocation Size -> " );
PrintLargeInteger( &FileInfo->AllocationSize );
printf( "\n\tEnd Of File -> " );
PrintLargeInteger( &FileInfo->EndOfFile );
printf( "\n\tFile Attributes -> %08lx", FileInfo->FileAttributes );
}