Symbian3/PDK/Source/GUID-00025EAD-C4B6-5408-96A3-FFDBBBDC7CAB.dita
author Dominic Pinkman <Dominic.Pinkman@Nokia.com>
Tue, 30 Mar 2010 11:56:28 +0100
changeset 5 f345bda72bc4
parent 3 46218c8b8afa
child 14 578be2adaf3e
permissions -rw-r--r--
Week 12 contribution of PDK documentation_content. See release notes for details. Fixes Bug 2054, Bug 1583, Bug 381, Bug 390, Bug 463, Bug 1897, Bug 344, Bug 1319, Bug 394, Bug 1520, Bug 1522, Bug 1892"

<?xml version="1.0" encoding="utf-8"?>
<!-- Copyright (c) 2007-2010 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: 
-->
<!DOCTYPE concept
  PUBLIC "-//OASIS//DTD DITA Concept//EN" "concept.dtd">
<concept id="GUID-00025EAD-C4B6-5408-96A3-FFDBBBDC7CAB" xml:lang="en"><title>How
to read and write a file</title><shortdesc>This topic describes how to reading transfer data from a file to
a descriptor, and writing transfers data from a descriptor to a file. </shortdesc><prolog><metadata><keywords/></metadata></prolog><conbody>
<p>Reading transfers data from a file to a descriptor, and writing transfers
data from a descriptor to a file. </p>
<p>Use <xref href="GUID-BE0804F6-4375-3C8A-8C83-968F510466E0.dita#GUID-BE0804F6-4375-3C8A-8C83-968F510466E0/GUID-94CCC141-8E26-3FA3-A222-D9A658AEA8A9"><apiname>RFile::Read()</apiname></xref> to read, and <xref href="GUID-BE0804F6-4375-3C8A-8C83-968F510466E0.dita#GUID-BE0804F6-4375-3C8A-8C83-968F510466E0/GUID-325997F1-3252-358E-B278-44D3A5418FAC"><apiname>RFile::Write()</apiname></xref> to
write. </p>
<codeblock id="GUID-28737C7A-70BA-5AA8-A4DC-0075A59CCB59" xml:space="preserve">// Open file1
_LIT(KMyFile,"c:\\documents\\file1");
RFile myFile;
User::LeaveIfError(myFile.Open(fs,KMyFile,EFileShareExclusive|EFileWrite
));

// Write to current file position: start of file
_LIT8(KWriteBuf,"write data");
myFile.Write(KWriteBuf);

// Read from position 0: start of file
TBuf8&lt;6&gt; readBuf1;
myFile.Read(0,readBuf1); // readBuf1 is now "write "

// Read from current position
TBuf8&lt;4&gt; readBuf2;
myFile.Read(readBuf2);      // readBuf2 is now "data"

</codeblock>
<section id="GUID-3AE9D1BD-036B-44EE-AF51-0DAEF8A00DA3"><title>Notes</title> <ul>
<li id="GUID-3F823A12-E192-5381-B8CC-FF377B1CEC0D"><p>In all cases, the file
data is treated as binary and byte descriptors are used (TDes8, TDesC8). Thus,
file operations are not dependent on the Unicode/non-Unicode build variant. </p> </li>
<li id="GUID-0A6255A4-12EC-5F60-9071-E001EA137585"><p>There are several variants
of both <codeph>Read()</codeph> and <codeph>Write()</codeph>. The basic <codeph>Read(TDes8&amp;
aDes)</codeph> and <codeph>Write(const TDesC8&amp; aDes)</codeph> are supplemented
by variants allowing the descriptor length to be overridden, or the seek position
of the first byte to be specified, or asynchronous completion, or any combination. </p> </li>
</ul> </section>
</conbody></concept>