userlibandfileserver/fileserver/sfat/sl_dir.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Thu, 07 Jan 2010 13:38:45 +0200
changeset 6 0173bcd7697c
parent 2 4122176ea935
permissions -rw-r--r--
Revision: 201001 Kit: 201001

// Copyright (c) 1996-2009 Nokia Corporation and/or its subsidiary(-ies).
// All rights reserved.
// This component and the accompanying materials are made available
// under the terms of the License "Eclipse Public License v1.0"
// which accompanies this distribution, and is available
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
//
// Initial Contributors:
// Nokia Corporation - initial contribution.
//
// Contributors:
//
// Description:
// f32\sfat\sl_dir.cpp
// 
//

//!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
//!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
//!!
//!! WARNING!! DO NOT edit this file !! '\sfat' component is obsolete and is not being used. '\sfat32'replaces it
//!!
//!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
//!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

#include "sl_std.h"

CFatDirCB* CFatDirCB::NewL()
//
// Static constructor
//
    {

    CFatDirCB* fatDirCB=new(ELeave) CFatDirCB;
    return fatDirCB;
    }

CFatDirCB::CFatDirCB()
//
// Constructor
//
    {
    }

CFatDirCB::~CFatDirCB()
//
// Destructor
//
    {
    
    delete iMatch;
    delete iLongNameBuf;
    }

void CFatDirCB::SetDirL(const TFatDirEntry& anEntry,const TDesC& aName)
//
// Set the current entry to anEntryAddr
//
    {

    __PRINT(_L("CFatDirCB::SetDirL"));  
//  iEntryAddr=0;
//  iPending=EFalse;
    iEntry=anEntry;
    iCurrentPos.iCluster= FatMount().StartCluster(iEntry);
    iMatch=aName.AllocL();
    if (iUidType[0]!=TUid::Null() || iUidType[1]!=TUid::Null() || iUidType[2]!=TUid::Null())
        iMatchUid=ETrue;
    }

LOCAL_C TBool CompareUid(const TUidType& aUidTrg, const TUidType& aUidSuitor)
//
// Compare the suitor to the target pattern
//
    {
    
    if (aUidTrg[0]!=TUid::Null() && aUidTrg[0]!=aUidSuitor[0])
        return(EFalse);
    if (aUidTrg[1]!=TUid::Null() && aUidTrg[1]!=aUidSuitor[1])
        return(EFalse);
    if (aUidTrg[2]!=TUid::Null() && aUidTrg[2]!=aUidSuitor[2])
        return(EFalse);
    return(ETrue);
    }

void CFatDirCB::ReadL(TEntry &anEntry)
//
// Read the next entry from the directory.
//
    {

    __PRINT(_L("CFatDirCB::ReadL"));
    
    FatMount().CheckStateConsistentL();
    

    Mem::FillZ(&anEntry.iType,sizeof(TUidType));

    TPtr entryName(anEntry.iName.Des());
    FOREVER
        {
        if (iPending)
            entryName=(*iLongNameBuf);
        else
            {
            FatMount().FindDosNameL(*iMatch,iAtt,iCurrentPos,iEntry,entryName,KErrEof);
            FatMount().MoveToNextEntryL(iCurrentPos);
            }
        iPending=EFalse;
        if (iEntry.Attributes()&~KEntryAttMaskSupported)
            continue; // Ignore illegal entries
        anEntry.iAtt=iEntry.Attributes();
        anEntry.iSize=iEntry.Size();
        anEntry.iModified=iEntry.Time(FatMount().TimeOffset() );
    
        if (entryName.Length()==0)
            {
            //  VFAT entry names are always created for UNICODE at an earlier stage
            //  However, UNICODE builds may still encounter genuine FAT filenames through
            //  the introduction of files created using a narrow (ASCII) build
            TBuf8<0x20> dosName(DosNameFromStdFormat(iEntry.Name()));
            LocaleUtils::ConvertToUnicodeL(entryName, dosName);
            }
        TBool matchedUid=ETrue;
        if (iMatchUid && (anEntry.iAtt&KEntryAttDir)==EFalse)
            {
            if ((TUint)anEntry.iSize>=sizeof(TCheckedUid))
                FatMount().ReadUidL(FatMount().StartCluster(iEntry),anEntry);
            if (CompareUid(iUidType,anEntry.iType)==EFalse)
                matchedUid=EFalse;
            }
                    
        if (matchedUid)
            break;
        }
    if ((iAtt&KEntryAttAllowUid)==0 || (anEntry.iAtt&KEntryAttDir) || (TUint)anEntry.iSize<sizeof(TCheckedUid))
        return;
    if (iMatchUid==EFalse)
        {
        TInt r;
        TRAP(r,FatMount().ReadUidL(FatMount().StartCluster(iEntry),anEntry));
        if(r!=KErrNone && r!=KErrCorrupt)
            User::Leave(r);
        }
    }

void CFatDirCB::StoreLongEntryNameL(const TDesC& aName)
//
// Store aName while next read is pending
//
    {

    AllocBufferL(iLongNameBuf,aName);
    }