Sophie

Sophie

distrib > * > 2010.0 > * > by-pkgid > b36c97ff723e66f0f38bce83645c99dc > files > 176

exiv2-doc-0.18.2-1mdv2010.0.x86_64.rpm

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html><head><meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
<title>Exiv2: Exiv2::DataBuf Class Reference</title>
<link href="tabs.css" rel="stylesheet" type="text/css">
<link href="doxygen.css" rel="stylesheet" type="text/css">
</head><body>
<!-- Generated by Doxygen 1.5.9 -->
<div class="navigation" id="top">
  <div class="tabs">
    <ul>
      <li><a href="index.html"><span>Main&nbsp;Page</span></a></li>
      <li><a href="namespaces.html"><span>Namespaces</span></a></li>
      <li class="current"><a href="annotated.html"><span>Classes</span></a></li>
      <li><a href="files.html"><span>Files</span></a></li>
      <li><a href="examples.html"><span>Examples</span></a></li>
    <li>
      <form action="search.php" method="get">
        <table cellspacing="0" cellpadding="0" border="0">
          <tr>
            <td><label>&nbsp;<u>S</u>earch&nbsp;for&nbsp;</label></td>
            <td><input type="text" name="query" value="" size="20" accesskey="s"/></td>
          </tr>
        </table>
      </form>
    </li>
    </ul>
  </div>
  <div class="tabs">
    <ul>
      <li><a href="annotated.html"><span>Class&nbsp;List</span></a></li>
      <li><a href="classes.html"><span>Class&nbsp;Index</span></a></li>
      <li><a href="hierarchy.html"><span>Class&nbsp;Hierarchy</span></a></li>
      <li><a href="functions.html"><span>Class&nbsp;Members</span></a></li>
    </ul>
  </div>
  <div class="navpath"><a class="el" href="namespaceExiv2.html">Exiv2</a>::<a class="el" href="classExiv2_1_1DataBuf.html">DataBuf</a>
  </div>
</div>
<div class="contents">
<h1>Exiv2::DataBuf Class Reference</h1><!-- doxytag: class="Exiv2::DataBuf" -->Utility class containing a character array. All it does is to take care of memory allocation and deletion. Its primary use is meant to be as a stack variable in functions that need a temporary data buffer.  
<a href="#_details">More...</a>
<p>
<code>#include &lt;types.hpp&gt;</code>
<p>

<p>
<a href="classExiv2_1_1DataBuf-members.html">List of all members.</a><table border="0" cellpadding="0" cellspacing="0">
<tr><td></td></tr>
<tr><td colspan="2"><br><h2>Public Member Functions</h2></td></tr>
<tr><td colspan="2"><div class="groupHeader">Creators</div></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="7acbb6dd1dc8ba1cfded52cafffe1da9"></a><!-- doxytag: member="Exiv2::DataBuf::DataBuf" ref="7acbb6dd1dc8ba1cfded52cafffe1da9" args="()" -->
&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classExiv2_1_1DataBuf.html#7acbb6dd1dc8ba1cfded52cafffe1da9">DataBuf</a> ()</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Default constructor. <br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="a7f5e919eddab5d8623cebbc6af91328"></a><!-- doxytag: member="Exiv2::DataBuf::DataBuf" ref="a7f5e919eddab5d8623cebbc6af91328" args="(long size)" -->
&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classExiv2_1_1DataBuf.html#a7f5e919eddab5d8623cebbc6af91328">DataBuf</a> (long size)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Constructor with an initial buffer size. <br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="a0a63b749954741d5516dd58265b2e5c"></a><!-- doxytag: member="Exiv2::DataBuf::DataBuf" ref="a0a63b749954741d5516dd58265b2e5c" args="(const byte *pData, long size)" -->
&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classExiv2_1_1DataBuf.html#a0a63b749954741d5516dd58265b2e5c">DataBuf</a> (const <a class="el" href="namespaceExiv2.html#16f60a5bd4207fe155f6cf93a15efa72">byte</a> *pData, long size)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Constructor, copies an existing buffer. <br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="f94cfd1ae0f844d5facfb93a0d0a061e"></a><!-- doxytag: member="Exiv2::DataBuf::DataBuf" ref="f94cfd1ae0f844d5facfb93a0d0a061e" args="(DataBuf &amp;rhs)" -->
&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classExiv2_1_1DataBuf.html#f94cfd1ae0f844d5facfb93a0d0a061e">DataBuf</a> (<a class="el" href="classExiv2_1_1DataBuf.html">DataBuf</a> &amp;rhs)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Copy constructor. Transfers the buffer to the newly created object similar to std::auto_ptr, i.e., the original object is modified. <br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="b5ee5eefc2521158847edeb0ff12ac6c"></a><!-- doxytag: member="Exiv2::DataBuf::~DataBuf" ref="b5ee5eefc2521158847edeb0ff12ac6c" args="()" -->
&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classExiv2_1_1DataBuf.html#b5ee5eefc2521158847edeb0ff12ac6c">~DataBuf</a> ()</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Destructor, deletes the allocated buffer. <br></td></tr>
<tr><td colspan="2"><div class="groupHeader">Manipulators</div></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="064e231bd57cea71fdee957a1dac3ab5"></a><!-- doxytag: member="Exiv2::DataBuf::operator=" ref="064e231bd57cea71fdee957a1dac3ab5" args="(DataBuf &amp;rhs)" -->
<a class="el" href="classExiv2_1_1DataBuf.html">DataBuf</a> &amp;&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classExiv2_1_1DataBuf.html#064e231bd57cea71fdee957a1dac3ab5">operator=</a> (<a class="el" href="classExiv2_1_1DataBuf.html">DataBuf</a> &amp;rhs)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Assignment operator. Transfers the buffer and releases the buffer at the original object similar to std::auto_ptr, i.e., the original object is modified. <br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="be06b478dee2d020c4bde3f974bdeb90"></a><!-- doxytag: member="Exiv2::DataBuf::alloc" ref="be06b478dee2d020c4bde3f974bdeb90" args="(long size)" -->
void&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classExiv2_1_1DataBuf.html#be06b478dee2d020c4bde3f974bdeb90">alloc</a> (long size)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Allocate a data buffer of at least the given size. Note that if the requested <em>size</em> is less than the current buffer size, no new memory is allocated and the buffer size doesn't change. <br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="2fb958d6820e3790d14ab143159f50b2"></a><!-- doxytag: member="Exiv2::DataBuf::release" ref="2fb958d6820e3790d14ab143159f50b2" args="()" -->
std::pair&lt; <a class="el" href="namespaceExiv2.html#16f60a5bd4207fe155f6cf93a15efa72">byte</a> *, long &gt;&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classExiv2_1_1DataBuf.html#2fb958d6820e3790d14ab143159f50b2">release</a> ()</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Release ownership of the buffer to the caller. Returns the buffer as a data pointer and size pair, resets the internal buffer. <br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="c553cc3082d217d4b139dfca83602076"></a><!-- doxytag: member="Exiv2::DataBuf::reset" ref="c553cc3082d217d4b139dfca83602076" args="(std::pair&lt; byte *, long &gt;=std::make_pair((byte *)(0), long(0)))" -->
void&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classExiv2_1_1DataBuf.html#c553cc3082d217d4b139dfca83602076">reset</a> (std::pair&lt; <a class="el" href="namespaceExiv2.html#16f60a5bd4207fe155f6cf93a15efa72">byte</a> *, long &gt;=std::make_pair((<a class="el" href="namespaceExiv2.html#16f60a5bd4207fe155f6cf93a15efa72">byte</a> *)(0), long(0)))</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Reset value. <br></td></tr>
<tr><td colspan="2"><div class="groupHeader">Conversions</div></td></tr>
<tr><td colspan="2"><div class="groupText">Special conversions with auxiliary type to enable copies and assignments, similar to those used for std::auto_ptr. See <a href="http://www.josuttis.com/libbook/auto_ptr.html">http://www.josuttis.com/libbook/auto_ptr.html</a> for a discussion. <br><br></div></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="49057ada097161d6863bdfdcce8f06d5"></a><!-- doxytag: member="Exiv2::DataBuf::DataBuf" ref="49057ada097161d6863bdfdcce8f06d5" args="(DataBufRef rhs)" -->
&nbsp;</td><td class="memItemRight" valign="bottom"><b>DataBuf</b> (<a class="el" href="structExiv2_1_1DataBufRef.html">DataBufRef</a> rhs)</td></tr>

<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="eef26ca96f18232a773b4b52e919c5cd"></a><!-- doxytag: member="Exiv2::DataBuf::operator=" ref="eef26ca96f18232a773b4b52e919c5cd" args="(DataBufRef rhs)" -->
<a class="el" href="classExiv2_1_1DataBuf.html">DataBuf</a> &amp;&nbsp;</td><td class="memItemRight" valign="bottom"><b>operator=</b> (<a class="el" href="structExiv2_1_1DataBufRef.html">DataBufRef</a> rhs)</td></tr>

<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="018caf9c4407860f8dbc27b40b2af426"></a><!-- doxytag: member="Exiv2::DataBuf::operator DataBufRef" ref="018caf9c4407860f8dbc27b40b2af426" args="()" -->
&nbsp;</td><td class="memItemRight" valign="bottom"><b>operator DataBufRef</b> ()</td></tr>

<tr><td colspan="2"><br><h2>Public Attributes</h2></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="9a00173081c913d3add58854d9ad2c39"></a><!-- doxytag: member="Exiv2::DataBuf::pData_" ref="9a00173081c913d3add58854d9ad2c39" args="" -->
<a class="el" href="namespaceExiv2.html#16f60a5bd4207fe155f6cf93a15efa72">byte</a> *&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classExiv2_1_1DataBuf.html#9a00173081c913d3add58854d9ad2c39">pData_</a></td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Pointer to the buffer, 0 if none has been allocated. <br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="5e6028d5cdae2e149749667cf66c3e91"></a><!-- doxytag: member="Exiv2::DataBuf::size_" ref="5e6028d5cdae2e149749667cf66c3e91" args="" -->
long&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classExiv2_1_1DataBuf.html#5e6028d5cdae2e149749667cf66c3e91">size_</a></td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">The current size of the buffer. <br></td></tr>
</table>
<hr><a name="_details"></a><h2>Detailed Description</h2>
Utility class containing a character array. All it does is to take care of memory allocation and deletion. Its primary use is meant to be as a stack variable in functions that need a temporary data buffer. <hr>The documentation for this class was generated from the following files:<ul>
<li><a class="el" href="types_8hpp.html">types.hpp</a><li>types.cpp</ul>
</div>
<hr size="1"><address style="text-align: right;"><small>Generated on Thu Jun 25 15:18:08 2009 for Exiv2 by&nbsp;
<a href="http://www.doxygen.org/index.html">
<img src="doxygen.png" alt="doxygen" align="middle" border="0"></a> 1.5.9 </small></address>
</body>
</html>