docs/ikteam: Delete most files.
[haiku.git] / docs / develop / support / usecases / BMemoryIOUseCases.html
blob38ce5e3994894481f84552adbe59c745c3d30bbe
1 <!-- saved from url=(0022)http://internet.e-mail -->
2 <HTML>
3 <HEAD>
4 <TITLE>BMemoryIO Use Cases and Implementation Details</TITLE>
5 </HEAD>
7 <BODY BGCOLOR="white" LINK="#000067" VLINK="#000067" ALINK="#0000FF">
9 <FONT FACE="Verdana,Arial,Helvetica,sans-serif" SIZE="-1">
11 <H1>BMemoryIO Use Cases and Implementation Details:</H1>
13 <P>This document describes the BMemoryIO interface and some basics of how it is implemented.
14 The document has the following sections:</P>
16 <OL>
17 <LI><A HREF="#interface">BMemoryIO Interface</A></LI>
18 <LI><A HREF="#usecases">BMemoryIO Use Cases</A></LI>
19 <LI><A HREF="#implement">BMemoryIO Implementation</A></LI>
20 </OL>
22 <A NAME="interface"></A><H2>BMemoryIO Interface:</H2>
24 <P>The BMemoryIO class represent a buffer of dynamically allocated memory. You assign the
25 buffer to a BMemoryIO object on construction. The best source of information for the BMemoryIO interface
26 can be found
27 <A HREF="file:///boot/beos/documentation/Be%20Book/The%20Support%20Kit/MemoryIO.html">here in the Be Book</A>.
28 </P>
30 <A NAME="usecases"></A><H2>BMemoryIO Use Cases:</H2>
32 <P>The following use cases cover the BMemoryIO functionality:</P>
34 <OL>
36 <LI><P><B>Construction 1:</B> A BMemoryIO can be created by specifying a void pointer
37 and a ssize_t option. These options are used to determine the buffer to assign to the BMemoryIO object and its
38 size. No check is done to determine if the buffer is valid or if it contains at least the number of byte specified.</P></LI>
40 <LI><P><B>Construction 2:</B> As the one above, but the buffer is specified with a const void pointer.
41 The BMemoryIO object becomes read only, and every subsequent Write(), WriteAt() and SetSize() calls will
42 return B_NOT_ALLOWED.</P></LI>
44 <LI><P><B>Destruction:</B> The BMemoryIO destructor does nothing. It's up to the caller the responsibility
45 to free the buffer assigned on construction.</P></LI>
47 <LI><P><B>Reading 1:</B> When ReadAt() is called, the BMemoryIO returns the number of bytes read from the specified
48 position. ReadAt() takes three arguments: the position where to begin the read operation, the buffer where to put the read data,
49 and the number of bytes to read. This function does not read outside of the buffer.
50 If the specified position is invalid (i.e. outside bounds) this function returns 0. If the read operation
51 begins at a valid position, but the sum of position and bytes to read is bigger than the max size (specified on construction), BMemoryIO
52 returns just the available data.</P></LI>
54 <LI><P><B>Reading 2.</B> BMemoryIO inherits the Read() function from BPositionIO. This function read the specified amount
55 of data from the current position, and put it into the specified buffer, then it moves the I/O index forward of the number of read bytes.
56 This function behaves like the above. </P></LI>
58 <LI><P><B>Writing 1:</B> When WriteAt() is called, BMemoryIO returns the number of bytes written to the specified position.
59 WriteAt() takes three arguments: the position where to begin the write operation, the buffer from which to read the data to write, and the
60 number of bytes to write. If the BMemoryIO object was constructed with the const constructor, this function returns B_NOT_ALLOWED.
61 This function does not write outside of the buffer bounds. If the specified position is invalid (i.e. outside bounds) this function returns 0. If the write operation begins at a valid position, but the sum of position and bytes to write is bigger than the max size (specified on construction), BMemoryIO
62 returns just the amount of data which can be written.
63 If the BMemoryIO object has been shrunk (see the Size Change case), and the write operation is outside the current bounds (but inside the
64 bounds specified on construction) this function re-enlarge it to accomodate the data.</P></LI>
66 <LI><P><B>Writing 2.</B> BMemoryIO inherits the Write() function from BPositionIO. This function write the specified amount
67 of data to the current position of the BMemoryIO object, reading from the specified buffer, then it moves the I/O index forward
68 of the number of read bytes.
69 This function behaves like the above. </P></LI>
71 <LI><P><B>Size Changes:</B> The SetSize() member function enlarges or shrink the amount of data which can be read/write.
72 If the BMemoryIO object was constructed with the const constructor, this function always returns B_NOT_ALLOWED.
73 Any SetSize call with a size parameter bigger than the size specified on construction will fail and return B_ERROR. Shrinking the buffer
74 is always possible, and the function returns B_OK. Negative values are not allowed, and the function returns B_ERROR.
75 </P></LI>
77 <LI><P><B>Seeking.</B> Seek() sets the position in the data buffer where the Read() and Write() functions (inherited from
78 BPositionIO) begin reading and writing. How the position argument is understood depends on the mode flag. There are three possible modes:
79 <UL>
80 <LI><P>
81 SEEK_SET. The position passed is an offset from the beginning of allocated memory; in other
82 words, the current position is set to position. For this mode, position should be a positive
83 value.
84 </P></LI>
85 <LI><P>
86 SEEK_CUR. The position argument is an offset from the current position; the value of the
87 argument is added to the current position. </P></LI>
88 <LI><P>
89 SEEK_END. The position argument is an offset from the end of the buffer for a BMemoryIO
90 object. Positive values seek beyond the end of the buffer or data; negative
91 values seek backwards into the data. </P></LI>
92 </UL>
93 Seek() Always return the new position.
94 </P></LI>
96 <LI><P><B>Position:</B> The Position() call always return the current position.</P></LI>
98 </OL>
100 <A NAME="implement"></A><H2>BMemoryIO Implementation:</H2>
102 <P>The implementation of the BMemoryIO is simple. It consist in implementing memory read/write on a buffer
103 with an index.</P>
105 </BODY>
106 </HTML>