9.04 beta

This commit is contained in:
Igor Pavlov
2009-06-02 00:00:00 +00:00
committed by Kornel Lesiński
parent 8874e4fbc9
commit 829409452d
440 changed files with 19803 additions and 9941 deletions

View File

@@ -2,26 +2,18 @@
#include "StdAfx.h"
#include "PropIDUtils.h"
#include "Common/IntToString.h"
#include "Common/StringConvert.h"
#include "Windows/FileFind.h"
#include "Windows/PropVariantConversions.h"
#include "../../PropID.h"
#include "PropIDUtils.h"
using namespace NWindows;
static UString ConvertUInt32ToString(UInt32 value)
{
wchar_t buffer[32];
ConvertUInt64ToString(value, buffer);
return buffer;
}
static void ConvertUInt32ToHex(UInt32 value, wchar_t *s)
void ConvertUInt32ToHex(UInt32 value, wchar_t *s)
{
for (int i = 0; i < 8; i++)
{
@@ -32,7 +24,9 @@ static void ConvertUInt32ToHex(UInt32 value, wchar_t *s)
s[8] = L'\0';
}
UString ConvertPropertyToString(const PROPVARIANT &propVariant, PROPID propID, bool full)
#define MY_ATTR_CHAR(a, n, c) ((a )& (1 << (n))) ? c : L'-';
UString ConvertPropertyToString(const PROPVARIANT &prop, PROPID propID, bool full)
{
switch(propID)
{
@@ -40,50 +34,63 @@ UString ConvertPropertyToString(const PROPVARIANT &propVariant, PROPID propID, b
case kpidATime:
case kpidMTime:
{
if (propVariant.vt != VT_FILETIME)
return UString(); // It is error;
if (prop.vt != VT_FILETIME)
break;
FILETIME localFileTime;
if (propVariant.filetime.dwHighDateTime == 0 &&
propVariant.filetime.dwLowDateTime == 0)
if ((prop.filetime.dwHighDateTime == 0 &&
prop.filetime.dwLowDateTime == 0) ||
!::FileTimeToLocalFileTime(&prop.filetime, &localFileTime))
return UString();
if (!::FileTimeToLocalFileTime(&propVariant.filetime, &localFileTime))
return UString(); // It is error;
return ConvertFileTimeToString(localFileTime, true, full);
}
case kpidCRC:
{
if(propVariant.vt != VT_UI4)
if (prop.vt != VT_UI4)
break;
wchar_t temp[12];
ConvertUInt32ToHex(propVariant.ulVal, temp);
ConvertUInt32ToHex(prop.ulVal, temp);
return temp;
}
case kpidAttrib:
{
if(propVariant.vt != VT_UI4)
if (prop.vt != VT_UI4)
break;
UString result;
UInt32 attributes = propVariant.ulVal;
if (NFile::NFind::NAttributes::IsReadOnly(attributes)) result += L'R';
if (NFile::NFind::NAttributes::IsHidden(attributes)) result += L'H';
if (NFile::NFind::NAttributes::IsSystem(attributes)) result += L'S';
if (NFile::NFind::NAttributes::IsDir(attributes)) result += L'D';
if (NFile::NFind::NAttributes::IsArchived(attributes)) result += L'A';
if (NFile::NFind::NAttributes::IsCompressed(attributes)) result += L'C';
if (NFile::NFind::NAttributes::IsEncrypted(attributes)) result += L'E';
return result;
UString res;
UInt32 a = prop.ulVal;
if (NFile::NFind::NAttributes::IsReadOnly(a)) res += L'R';
if (NFile::NFind::NAttributes::IsHidden(a)) res += L'H';
if (NFile::NFind::NAttributes::IsSystem(a)) res += L'S';
if (NFile::NFind::NAttributes::IsDir(a)) res += L'D';
if (NFile::NFind::NAttributes::IsArchived(a)) res += L'A';
if (NFile::NFind::NAttributes::IsCompressed(a)) res += L'C';
if (NFile::NFind::NAttributes::IsEncrypted(a)) res += L'E';
return res;
}
case kpidDictionarySize:
case kpidPosixAttrib:
{
if(propVariant.vt != VT_UI4)
if (prop.vt != VT_UI4)
break;
UInt32 size = propVariant.ulVal;
if (size % (1 << 20) == 0)
return ConvertUInt32ToString(size >> 20) + L"MB";
if (size % (1 << 10) == 0)
return ConvertUInt32ToString(size >> 10) + L"KB";
return ConvertUInt32ToString(size);
UString res;
UInt32 a = prop.ulVal;
wchar_t temp[16];
temp[0] = MY_ATTR_CHAR(a, 14, L'd');
for (int i = 6; i >= 0; i -= 3)
{
temp[7 - i] = MY_ATTR_CHAR(a, i + 2, L'r');
temp[8 - i] = MY_ATTR_CHAR(a, i + 1, L'w');
temp[9 - i] = MY_ATTR_CHAR(a, i + 0, L'x');
}
temp[10] = 0;
res = temp;
a &= ~0x1FF;
a &= ~0xC000;
if (a != 0)
{
ConvertUInt32ToHex(a, temp);
res = UString(temp) + L' ' + res;
}
return res;
}
}
return ConvertPropVariantToString(propVariant);
return ConvertPropVariantToString(prop);
}