os/kernelhwsrv/userlibandfileserver/fileserver/sfsrv/cl_clamp.cpp
author sl
Tue, 10 Jun 2014 14:32:02 +0200
changeset 1 260cb5ec6c19
permissions -rw-r--r--
Update contrib.
sl@0
     1
// Copyright (c) 2006-2009 Nokia Corporation and/or its subsidiary(-ies).
sl@0
     2
// All rights reserved.
sl@0
     3
// This component and the accompanying materials are made available
sl@0
     4
// under the terms of the License "Eclipse Public License v1.0"
sl@0
     5
// which accompanies this distribution, and is available
sl@0
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
sl@0
     7
//
sl@0
     8
// Initial Contributors:
sl@0
     9
// Nokia Corporation - initial contribution.
sl@0
    10
//
sl@0
    11
// Contributors:
sl@0
    12
//
sl@0
    13
// Description:
sl@0
    14
// f32\sfsrv\cl_clamp.cpp
sl@0
    15
// 
sl@0
    16
//
sl@0
    17
sl@0
    18
#include <f32file.h>
sl@0
    19
#include <e32ldr_private.h>
sl@0
    20
sl@0
    21
sl@0
    22
EXPORT_C TInt RFileClamp::Clamp(RFile& aFile)
sl@0
    23
/**
sl@0
    24
	Clamp the supplied file and store the resulting cookie in this object.
sl@0
    25
sl@0
    26
	@param	aFile			File to clamp.
sl@0
    27
	@return					Symbian OS error code.
sl@0
    28
 */
sl@0
    29
	{
sl@0
    30
	return aFile.Clamp(*this);
sl@0
    31
	}
sl@0
    32
sl@0
    33
EXPORT_C TInt RFileClamp::Close(RFs& aFs)
sl@0
    34
/**
sl@0
    35
	Unclamp the file which was clamped with this object.
sl@0
    36
	It is safe to call this function a handle that was not
sl@0
    37
	successfully opened.
sl@0
    38
sl@0
    39
	@param	aFs				File server session which was used to
sl@0
    40
							generate this clamp cookie value.
sl@0
    41
	@return					Symbian OS error code.
sl@0
    42
 */
sl@0
    43
	{
sl@0
    44
	TInt r = KErrNone;
sl@0
    45
sl@0
    46
	TBool opened = !(iCookie[0] == 0 && iCookie[1] == 0);
sl@0
    47
	if (opened)
sl@0
    48
		{
sl@0
    49
		r = aFs.Unclamp(*this);
sl@0
    50
		if (r == KErrNone)
sl@0
    51
			*this = RFileClamp();
sl@0
    52
		}
sl@0
    53
sl@0
    54
	return r;
sl@0
    55
	}
sl@0
    56
sl@0
    57