Files
pip/doc/html/class_p_i_chunk_stream.html

145 lines
16 KiB
HTML

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
<meta name="generator" content="Doxygen 1.8.13"/>
<meta name="viewport" content="width=device-width, initial-scale=1"/>
<title>PIP: PIChunkStream Class Reference</title>
<link href="tabs.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="dynsections.js"></script>
<link href="navtree.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="resize.js"></script>
<script type="text/javascript" src="navtreedata.js"></script>
<script type="text/javascript" src="navtree.js"></script>
<script type="text/javascript">
$(document).ready(initResizable);
</script>
<link href="doxygen.css" rel="stylesheet" type="text/css" />
</head>
<body>
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
<div id="titlearea">
<table cellspacing="0" cellpadding="0">
<tbody>
<tr style="height: 56px;">
<td id="projectalign" style="padding-left: 0.5em;">
<div id="projectname">PIP
&#160;<span id="projectnumber">1.4.0</span>
</div>
<div id="projectbrief">Platform-Independent Primitives</div>
</td>
</tr>
</tbody>
</table>
</div>
<!-- end header part -->
<!-- Generated by Doxygen 1.8.13 -->
<script type="text/javascript" src="menudata.js"></script>
<script type="text/javascript" src="menu.js"></script>
<script type="text/javascript">
$(function() {
initMenu('',false,false,'search.php','Search');
});
</script>
<div id="main-nav"></div>
</div><!-- top -->
<div id="side-nav" class="ui-resizable side-nav-resizable">
<div id="nav-tree">
<div id="nav-tree-contents">
<div id="nav-sync" class="sync"></div>
</div>
</div>
<div id="splitbar" style="-moz-user-select:none;"
class="ui-resizable-handle">
</div>
</div>
<script type="text/javascript">
$(document).ready(function(){initNavTree('class_p_i_chunk_stream.html','');});
</script>
<div id="doc-content">
<div class="header">
<div class="summary">
<a href="#pub-methods">Public Member Functions</a> &#124;
<a href="#pub-static-methods">Static Public Member Functions</a> &#124;
<a href="class_p_i_chunk_stream-members.html">List of all members</a> </div>
<div class="headertitle">
<div class="title">PIChunkStream Class Reference</div> </div>
</div><!--header-->
<div class="contents">
<p>Class for binary serialization.
<a href="class_p_i_chunk_stream.html#details">More...</a></p>
<table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-methods"></a>
Public Member Functions</h2></td></tr>
<tr class="memitem:a9b0680f7b75f247a5fc4c9d366edf43f"><td class="memItemLeft" align="right" valign="top"><a id="a9b0680f7b75f247a5fc4c9d366edf43f"></a>
&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_p_i_chunk_stream.html#a9b0680f7b75f247a5fc4c9d366edf43f">PIChunkStream</a> (const <a class="el" href="class_p_i_byte_array.html">PIByteArray</a> &amp;<a class="el" href="class_p_i_chunk_stream.html#a01fea43dff1a046ab062647f831466ef">data</a>)</td></tr>
<tr class="memdesc:a9b0680f7b75f247a5fc4c9d366edf43f"><td class="mdescLeft">&#160;</td><td class="mdescRight">Contructs stream for read from "data". <br /></td></tr>
<tr class="separator:a9b0680f7b75f247a5fc4c9d366edf43f"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a604f6dc1e095daa47442320ffa6b944b"><td class="memItemLeft" align="right" valign="top"><a id="a604f6dc1e095daa47442320ffa6b944b"></a>
&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_p_i_chunk_stream.html#a604f6dc1e095daa47442320ffa6b944b">PIChunkStream</a> (<a class="el" href="class_p_i_byte_array.html">PIByteArray</a> *<a class="el" href="class_p_i_chunk_stream.html#a01fea43dff1a046ab062647f831466ef">data</a>=0)</td></tr>
<tr class="memdesc:a604f6dc1e095daa47442320ffa6b944b"><td class="mdescLeft">&#160;</td><td class="mdescRight">Contructs stream for read or write to/from "data", or empty stream for write. <br /></td></tr>
<tr class="separator:a604f6dc1e095daa47442320ffa6b944b"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a01fea43dff1a046ab062647f831466ef"><td class="memItemLeft" align="right" valign="top"><a id="a01fea43dff1a046ab062647f831466ef"></a>
<a class="el" href="class_p_i_byte_array.html">PIByteArray</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_p_i_chunk_stream.html#a01fea43dff1a046ab062647f831466ef">data</a> () const</td></tr>
<tr class="memdesc:a01fea43dff1a046ab062647f831466ef"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns internal buffer with written data. <br /></td></tr>
<tr class="separator:a01fea43dff1a046ab062647f831466ef"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a6868bc79c950346046e3f0948a8a9958"><td class="memItemLeft" align="right" valign="top"><a id="a6868bc79c950346046e3f0948a8a9958"></a>
bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_p_i_chunk_stream.html#a6868bc79c950346046e3f0948a8a9958">atEnd</a> () const</td></tr>
<tr class="memdesc:a6868bc79c950346046e3f0948a8a9958"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns if there is end of stream. <br /></td></tr>
<tr class="separator:a6868bc79c950346046e3f0948a8a9958"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ac7f7588cf308dd128b6fdd8ac678cceb"><td class="memItemLeft" align="right" valign="top"><a id="ac7f7588cf308dd128b6fdd8ac678cceb"></a>
int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_p_i_chunk_stream.html#ac7f7588cf308dd128b6fdd8ac678cceb">read</a> ()</td></tr>
<tr class="memdesc:ac7f7588cf308dd128b6fdd8ac678cceb"><td class="mdescLeft">&#160;</td><td class="mdescRight">Read one chunk from stream and returns its ID. <br /></td></tr>
<tr class="separator:ac7f7588cf308dd128b6fdd8ac678cceb"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ae50f13503bcff6cce8f5d8c6984595c1"><td class="memItemLeft" align="right" valign="top"><a id="ae50f13503bcff6cce8f5d8c6984595c1"></a>
int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_p_i_chunk_stream.html#ae50f13503bcff6cce8f5d8c6984595c1">getID</a> ()</td></tr>
<tr class="memdesc:ae50f13503bcff6cce8f5d8c6984595c1"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns last readed chunk ID. <br /></td></tr>
<tr class="separator:ae50f13503bcff6cce8f5d8c6984595c1"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ae3b78b34774fdb36076a12e505c721a2"><td class="memTemplParams" colspan="2"><a id="ae3b78b34774fdb36076a12e505c721a2"></a>
template&lt;typename T &gt; </td></tr>
<tr class="memitem:ae3b78b34774fdb36076a12e505c721a2"><td class="memTemplItemLeft" align="right" valign="top">T&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="class_p_i_chunk_stream.html#ae3b78b34774fdb36076a12e505c721a2">getData</a> () const</td></tr>
<tr class="memdesc:ae3b78b34774fdb36076a12e505c721a2"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns value of last readed chunk. <br /></td></tr>
<tr class="separator:ae3b78b34774fdb36076a12e505c721a2"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a59bfd24c5577d92446528bce027bfa28"><td class="memTemplParams" colspan="2"><a id="a59bfd24c5577d92446528bce027bfa28"></a>
template&lt;typename T &gt; </td></tr>
<tr class="memitem:a59bfd24c5577d92446528bce027bfa28"><td class="memTemplItemLeft" align="right" valign="top">void&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="class_p_i_chunk_stream.html#a59bfd24c5577d92446528bce027bfa28">get</a> (T &amp;v) const</td></tr>
<tr class="memdesc:a59bfd24c5577d92446528bce027bfa28"><td class="mdescLeft">&#160;</td><td class="mdescRight">Place value of last readed chunk into "v". <br /></td></tr>
<tr class="separator:a59bfd24c5577d92446528bce027bfa28"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-static-methods"></a>
Static Public Member Functions</h2></td></tr>
<tr class="memitem:aa53cc70261d65c9476980ba21ec1f933"><td class="memTemplParams" colspan="2"><a id="aa53cc70261d65c9476980ba21ec1f933"></a>
template&lt;typename T &gt; </td></tr>
<tr class="memitem:aa53cc70261d65c9476980ba21ec1f933"><td class="memTemplItemLeft" align="right" valign="top">static Chunk&lt; T &gt;&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="class_p_i_chunk_stream.html#aa53cc70261d65c9476980ba21ec1f933">chunk</a> (int id, const T &amp;<a class="el" href="class_p_i_chunk_stream.html#a01fea43dff1a046ab062647f831466ef">data</a>)</td></tr>
<tr class="memdesc:aa53cc70261d65c9476980ba21ec1f933"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns chunk with ID "id" and value "data" for write to stream. <br /></td></tr>
<tr class="separator:aa53cc70261d65c9476980ba21ec1f933"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table>
<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2>
<div class="textblock"><p>Class for binary serialization. </p>
<h1><a class="anchor" id="PIChunkStream_sec0"></a>
Synopsis</h1>
<p>This class provides very handly mechanism to store and restore values to and from <em><a class="el" href="class_p_i_byte_array.html" title="Byte array. ">PIByteArray</a></em>. The main advantage of using this class is that your binary data become independent from order and collection of your values.</p>
<h1><a class="anchor" id="PIChunkStream_sec1"></a>
Mechanism</h1>
<p>PIChunkStream works with items called "chunk". Chunk is an ID and any value that can be stored and restored to <em><a class="el" href="class_p_i_byte_array.html" title="Byte array. ">PIByteArray</a></em> with stream operators &lt;&lt; and &gt;&gt;. You can place chunks to stream and read chunks from stream.</p>
<p>To construct PIChunkStream for writing data use any constructor. Empty constructor creates internal empty buffer that can be accessed by function <em><a class="el" href="class_p_i_chunk_stream.html#a01fea43dff1a046ab062647f831466ef" title="Returns internal buffer with written data. ">data()</a></em>. Non-empty constructor works with given byte array.</p>
<p>To read chunks from byte array use function <em><a class="el" href="class_p_i_chunk_stream.html#ac7f7588cf308dd128b6fdd8ac678cceb" title="Read one chunk from stream and returns its ID. ">read()</a></em> that returns ID of next chunk. Then you can get value of this chunk with function <em><a class="el" href="class_p_i_chunk_stream.html#ae3b78b34774fdb36076a12e505c721a2" title="Returns value of last readed chunk. ">getData()</a></em>, but you should definitely know type of this value. You can read from byte array while <em><a class="el" href="class_p_i_chunk_stream.html#a6868bc79c950346046e3f0948a8a9958" title="Returns if there is end of stream. ">atEnd()</a></em> if false.</p>
<h1><a class="anchor" id="PIChunkStream_ex0"></a>
Example</h1>
<p>Prepare your structs to work with PIChunkStream </p><div class="fragment"><div class="line"><span class="comment">// Your struct</span></div><div class="line"><span class="keyword">struct </span>S {</div><div class="line"> <span class="keywordtype">int</span> i;</div><div class="line"> <span class="keywordtype">float</span> f;</div><div class="line"> <a class="code" href="class_p_i_string.html">PIString</a> s;</div><div class="line">};</div><div class="line"></div><div class="line"><span class="comment">// Operators</span></div><div class="line"><a class="code" href="class_p_i_byte_array.html">PIByteArray</a> &amp; operator &lt;&lt;(<a class="code" href="class_p_i_byte_array.html">PIByteArray</a> &amp; b, <span class="keyword">const</span> S &amp; s) {b &lt;&lt; s.i &lt;&lt; s.f &lt;&lt; s.s; <span class="keywordflow">return</span> b;}</div><div class="line"><a class="code" href="class_p_i_byte_array.html">PIByteArray</a> &amp; operator &gt;&gt;(<a class="code" href="class_p_i_byte_array.html">PIByteArray</a> &amp; b, S &amp; s) {b &gt;&gt; s.i &gt;&gt; s.f &gt;&gt; s.s; <span class="keywordflow">return</span> b;}</div></div><!-- fragment --><p>Writing to PIChunkStream </p><div class="fragment"><div class="line"><span class="comment">// Write chunk stream</span></div><div class="line">S s;</div><div class="line">s.i = 99;</div><div class="line">s.f = 0.01;</div><div class="line">s.s = <span class="stringliteral">&quot;SSS&quot;</span>;</div><div class="line"><a class="code" href="class_p_i_vector.html">PIVector&lt;float&gt;</a> f;</div><div class="line">f &lt;&lt; -1. &lt;&lt; 2.5 &lt;&lt; 11.;</div><div class="line"><span class="comment">// write some data to empty stream</span></div><div class="line"><a class="code" href="class_p_i_chunk_stream.html">PIChunkStream</a> cs;</div><div class="line">cs &lt;&lt; cs.<a class="code" href="class_p_i_chunk_stream.html#aa53cc70261d65c9476980ba21ec1f933">chunk</a>(1, <span class="keywordtype">int</span>(10))</div><div class="line"> &lt;&lt; cs.<a class="code" href="class_p_i_chunk_stream.html#aa53cc70261d65c9476980ba21ec1f933">chunk</a>(2, <a class="code" href="class_p_i_string.html">PIString</a>(<span class="stringliteral">&quot;text&quot;</span>))</div><div class="line"> &lt;&lt; cs.<a class="code" href="class_p_i_chunk_stream.html#aa53cc70261d65c9476980ba21ec1f933">chunk</a>(4, f)</div><div class="line"> &lt;&lt; cs.<a class="code" href="class_p_i_chunk_stream.html#aa53cc70261d65c9476980ba21ec1f933">chunk</a>(3, s);</div><div class="line"><span class="comment">// now you can take cs.data() and send or place it somewhere ...</span></div></div><!-- fragment --><p>Reading from PIChunkStream </p><div class="fragment"><div class="line"><span class="comment">// create stream for read, cs from upper code</span></div><div class="line"><a class="code" href="class_p_i_byte_array.html">PIByteArray</a> ba(cs.<a class="code" href="class_p_i_chunk_stream.html#a01fea43dff1a046ab062647f831466ef">data</a>());</div><div class="line"><a class="code" href="class_p_i_chunk_stream.html">PIChunkStream</a> cs2(ba);</div><div class="line"><span class="keywordtype">int</span> i(0);</div><div class="line"><a class="code" href="class_p_i_string.html">PIString</a> str;</div><div class="line">S s;</div><div class="line"><a class="code" href="class_p_i_vector.html">PIVector&lt;float&gt;</a> f;</div><div class="line"><span class="comment">// read from stream</span></div><div class="line"><span class="keywordflow">while</span> (!cs2.atEnd()) {</div><div class="line"> <span class="keywordflow">switch</span> (cs2.read()) {</div><div class="line"> <span class="keywordflow">case</span> 1: i = cs2.getData&lt;<span class="keywordtype">int</span>&gt;(); <span class="keywordflow">break</span>;</div><div class="line"> <span class="keywordflow">case</span> 2: str = cs2.getData&lt;<a class="code" href="class_p_i_string.html">PIString</a>&gt;(); <span class="keywordflow">break</span>;</div><div class="line"> <span class="keywordflow">case</span> 3: s = cs2.getData&lt;S&gt;(); <span class="keywordflow">break</span>;</div><div class="line"> <span class="keywordflow">case</span> 4: f = cs2.getData&lt;<a class="code" href="class_p_i_vector.html">PIVector&lt;float&gt;</a> &gt;(); <span class="keywordflow">break</span>;</div><div class="line"> }</div><div class="line">}</div><div class="line"><a class="code" href="picout_8h.html#ad21862cbba89aead064fbef4c825030e">piCout</a> &lt;&lt; i &lt;&lt; str &lt;&lt; f &lt;&lt; s.i &lt;&lt; s.f &lt;&lt; s.s;</div></div><!-- fragment --></div></div><!-- contents -->
</div><!-- doc-content -->
<!-- start footer part -->
<div id="nav-path" class="navpath"><!-- id is needed for treeview function! -->
<ul>
<li class="navelem"><a class="el" href="class_p_i_chunk_stream.html">PIChunkStream</a></li>
<li class="footer">Generated on Fri Dec 8 2017 16:36:05 for PIP by
<a href="http://www.doxygen.org/index.html">
<img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.8.13 </li>
</ul>
</div>
</body>
</html>