Sophie

Sophie

distrib > Mageia > 7 > armv7hl > media > core-release > by-pkgid > 0a67b807a02637f2cae68649d519a89d > files > 1481

libcryptopp-devel-7.0.0-1.mga7.armv7hl.rpm

<!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.14"/>
<meta name="viewport" content="width=device-width, initial-scale=1"/>
<title>Crypto++: Poly1305_Base&lt; T &gt; Class Template 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="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">Crypto++
   &#160;<span id="projectnumber">7.0</span>
   </div>
   <div id="projectbrief">Free&nbsp;C&#43;&#43;&nbsp;class&nbsp;library&nbsp;of&nbsp;cryptographic&nbsp;schemes</div>
  </td>
 </tr>
 </tbody>
</table>
</div>
<!-- end header part -->
<!-- Generated by Doxygen 1.8.14 -->
<script type="text/javascript" src="menudata.js"></script>
<script type="text/javascript" src="menu.js"></script>
<script type="text/javascript">
/* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&amp;dn=gpl-2.0.txt GPL-v2 */
$(function() {
  initMenu('',false,false,'search.php','Search');
});
/* @license-end */</script>
<div id="main-nav"></div>
</div><!-- top -->
<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="#pub-static-attribs">Static Public Attributes</a> &#124;
<a href="class_poly1305___base-members.html">List of all members</a>  </div>
  <div class="headertitle">
<div class="title">Poly1305_Base&lt; T &gt; Class Template Reference</div>  </div>
</div><!--header-->
<div class="contents">

<p><a class="el" href="class_poly1305.html" title="Poly1305 message authentication code. ">Poly1305</a> message authentication code base class.  
 <a href="class_poly1305___base.html#details">More...</a></p>
<div id="dynsection-0" onclick="return toggleVisibility(this)" class="dynheader closed" style="cursor:pointer;">
  <img id="dynsection-0-trigger" src="closed.png" alt="+"/> Inheritance diagram for Poly1305_Base&lt; T &gt;:</div>
<div id="dynsection-0-summary" class="dynsummary" style="display:block;">
</div>
<div id="dynsection-0-content" class="dyncontent" style="display:none;">
 <div class="center">
  <img src="class_poly1305___base.png" usemap="#Poly1305_5FBase_3C_20T_20_3E_map" alt=""/>
  <map id="Poly1305_5FBase_3C_20T_20_3E_map" name="Poly1305_5FBase_3C_20T_20_3E_map">
<area href="class_fixed_key_length.html" alt="FixedKeyLength&lt; 32, SimpleKeyingInterface::UNIQUE_IV, 16 &gt;" shape="rect" coords="0,168,775,192"/>
<area href="class_message_authentication_code.html" title="Interface for message authentication codes. " alt="MessageAuthenticationCode" shape="rect" coords="785,168,1560,192"/>
<area href="class_simple_keying_interface.html" title="Interface for algorithms that take byte strings as keys. " alt="SimpleKeyingInterface" shape="rect" coords="392,112,1167,136"/>
<area href="class_hash_transformation.html" title="Interface for hash functions and data processing part of MACs. " alt="HashTransformation" shape="rect" coords="1177,112,1952,136"/>
<area href="class_algorithm.html" title="Interface for all crypto algorithms. " alt="Algorithm" shape="rect" coords="1177,56,1952,80"/>
<area href="class_clonable.html" title="Interface for cloning objects. " alt="Clonable" shape="rect" coords="1177,0,1952,24"/>
<area href="class_simple_keying_interface_impl.html" alt="SimpleKeyingInterfaceImpl&lt; Poly1305_Base&lt; T &gt;, Poly1305_Base&lt; T &gt; &gt;" shape="rect" coords="392,280,1167,304"/>
<area href="class_algorithm_impl.html" alt="AlgorithmImpl&lt; SimpleKeyingInterfaceImpl&lt; Poly1305_Base&lt; T &gt;, Poly1305_Base&lt; T &gt; &gt;, Poly1305_Base&lt; T &gt; &gt;" shape="rect" coords="392,336,1167,360"/>
<area href="class_message_authentication_code_impl.html" alt="MessageAuthenticationCodeImpl&lt; Poly1305_Base&lt; T &gt; &gt;" shape="rect" coords="392,392,1167,416"/>
<area href="class_clonable_impl.html" alt="ClonableImpl&lt; MessageAuthenticationCodeFinal&lt; Poly1305_Base&lt; T &gt; &gt;, MessageAuthenticationCodeImpl&lt; Poly1305_Base&lt; T &gt; &gt; &gt;" shape="rect" coords="392,448,1167,472"/>
<area href="class_message_authentication_code_final.html" alt="MessageAuthenticationCodeFinal&lt; Poly1305_Base&lt; T &gt; &gt;" shape="rect" coords="392,504,1167,528"/>
<area href="class_poly1305.html" title="Poly1305 message authentication code. " alt="Poly1305&lt; T &gt;" shape="rect" coords="392,560,1167,584"/>
</map>
 </div></div>
<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:aebdc8e79fbe6397a25a166a63c199489"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_poly1305___base.html#aebdc8e79fbe6397a25a166a63c199489">Resynchronize</a> (const byte *iv, int ivLength=-1)</td></tr>
<tr class="memdesc:aebdc8e79fbe6397a25a166a63c199489"><td class="mdescLeft">&#160;</td><td class="mdescRight">Resynchronize with an IV.  <a href="#aebdc8e79fbe6397a25a166a63c199489">More...</a><br /></td></tr>
<tr class="separator:aebdc8e79fbe6397a25a166a63c199489"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a6b72e58e0916f5cc75055e4c6785fdc6"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_poly1305___base.html#a6b72e58e0916f5cc75055e4c6785fdc6">GetNextIV</a> (<a class="el" href="class_random_number_generator.html">RandomNumberGenerator</a> &amp;rng, byte *iv)</td></tr>
<tr class="memdesc:a6b72e58e0916f5cc75055e4c6785fdc6"><td class="mdescLeft">&#160;</td><td class="mdescRight">Retrieves a secure IV for the next message.  <a href="#a6b72e58e0916f5cc75055e4c6785fdc6">More...</a><br /></td></tr>
<tr class="separator:a6b72e58e0916f5cc75055e4c6785fdc6"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a823d58a924c6c0caa9c731092c3c93f0"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_poly1305___base.html#a823d58a924c6c0caa9c731092c3c93f0">UncheckedSetKey</a> (const byte *key, unsigned int length, const <a class="el" href="class_name_value_pairs.html">NameValuePairs</a> &amp;params)</td></tr>
<tr class="memdesc:a823d58a924c6c0caa9c731092c3c93f0"><td class="mdescLeft">&#160;</td><td class="mdescRight">Sets the key for this object without performing parameter validation.  <a href="#a823d58a924c6c0caa9c731092c3c93f0">More...</a><br /></td></tr>
<tr class="separator:a823d58a924c6c0caa9c731092c3c93f0"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a13640c0e9edc4bd6783ef9c7abd694ea"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_poly1305___base.html#a13640c0e9edc4bd6783ef9c7abd694ea">Update</a> (const byte *input, size_t length)</td></tr>
<tr class="memdesc:a13640c0e9edc4bd6783ef9c7abd694ea"><td class="mdescLeft">&#160;</td><td class="mdescRight">Updates a hash with additional input.  <a href="#a13640c0e9edc4bd6783ef9c7abd694ea">More...</a><br /></td></tr>
<tr class="separator:a13640c0e9edc4bd6783ef9c7abd694ea"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a350554631a23d196217b483843a4e6b0"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_poly1305___base.html#a350554631a23d196217b483843a4e6b0">TruncatedFinal</a> (byte *mac, size_t size)</td></tr>
<tr class="memdesc:a350554631a23d196217b483843a4e6b0"><td class="mdescLeft">&#160;</td><td class="mdescRight">Computes the hash of the current message.  <a href="#a350554631a23d196217b483843a4e6b0">More...</a><br /></td></tr>
<tr class="separator:a350554631a23d196217b483843a4e6b0"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ad62eb9211cf1d982f69812790502b6ec"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_poly1305___base.html#ad62eb9211cf1d982f69812790502b6ec">Restart</a> ()</td></tr>
<tr class="memdesc:ad62eb9211cf1d982f69812790502b6ec"><td class="mdescLeft">&#160;</td><td class="mdescRight">Restart the hash.  <a href="#ad62eb9211cf1d982f69812790502b6ec">More...</a><br /></td></tr>
<tr class="separator:ad62eb9211cf1d982f69812790502b6ec"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ac7355133d6eef88697c931c5d46e0016"><td class="memItemLeft" align="right" valign="top">unsigned int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_poly1305___base.html#ac7355133d6eef88697c931c5d46e0016">BlockSize</a> () const</td></tr>
<tr class="memdesc:ac7355133d6eef88697c931c5d46e0016"><td class="mdescLeft">&#160;</td><td class="mdescRight">Provides the block size of the compression function.  <a href="#ac7355133d6eef88697c931c5d46e0016">More...</a><br /></td></tr>
<tr class="separator:ac7355133d6eef88697c931c5d46e0016"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a18a6d6100a2283a045e8865a7e2be129"><td class="memItemLeft" align="right" valign="top">unsigned int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_poly1305___base.html#a18a6d6100a2283a045e8865a7e2be129">DigestSize</a> () const</td></tr>
<tr class="memdesc:a18a6d6100a2283a045e8865a7e2be129"><td class="mdescLeft">&#160;</td><td class="mdescRight">Provides the digest size of the hash.  <a href="#a18a6d6100a2283a045e8865a7e2be129">More...</a><br /></td></tr>
<tr class="separator:a18a6d6100a2283a045e8865a7e2be129"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="inherit_header pub_methods_class_simple_keying_interface"><td colspan="2" onclick="javascript:toggleInherit('pub_methods_class_simple_keying_interface')"><img src="closed.png" alt="-"/>&#160;Public Member Functions inherited from <a class="el" href="class_simple_keying_interface.html">SimpleKeyingInterface</a></td></tr>
<tr class="memitem:a2631c49dac4d5ec055c5dc88c6243578 inherit pub_methods_class_simple_keying_interface"><td class="memItemLeft" align="right" valign="top">virtual size_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_simple_keying_interface.html#a2631c49dac4d5ec055c5dc88c6243578">MinKeyLength</a> () const =0</td></tr>
<tr class="memdesc:a2631c49dac4d5ec055c5dc88c6243578 inherit pub_methods_class_simple_keying_interface"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns smallest valid key length.  <a href="class_simple_keying_interface.html#a2631c49dac4d5ec055c5dc88c6243578">More...</a><br /></td></tr>
<tr class="separator:a2631c49dac4d5ec055c5dc88c6243578 inherit pub_methods_class_simple_keying_interface"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ae02fcb4e1f6141e728ae37612cde6fff inherit pub_methods_class_simple_keying_interface"><td class="memItemLeft" align="right" valign="top">virtual size_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_simple_keying_interface.html#ae02fcb4e1f6141e728ae37612cde6fff">MaxKeyLength</a> () const =0</td></tr>
<tr class="memdesc:ae02fcb4e1f6141e728ae37612cde6fff inherit pub_methods_class_simple_keying_interface"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns largest valid key length.  <a href="class_simple_keying_interface.html#ae02fcb4e1f6141e728ae37612cde6fff">More...</a><br /></td></tr>
<tr class="separator:ae02fcb4e1f6141e728ae37612cde6fff inherit pub_methods_class_simple_keying_interface"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ae90dfc0bdfd13e214fd46e357ef64e98 inherit pub_methods_class_simple_keying_interface"><td class="memItemLeft" align="right" valign="top">virtual size_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_simple_keying_interface.html#ae90dfc0bdfd13e214fd46e357ef64e98">DefaultKeyLength</a> () const =0</td></tr>
<tr class="memdesc:ae90dfc0bdfd13e214fd46e357ef64e98 inherit pub_methods_class_simple_keying_interface"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns default key length.  <a href="class_simple_keying_interface.html#ae90dfc0bdfd13e214fd46e357ef64e98">More...</a><br /></td></tr>
<tr class="separator:ae90dfc0bdfd13e214fd46e357ef64e98 inherit pub_methods_class_simple_keying_interface"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aa6601819d376802e9698e815d00a5cba inherit pub_methods_class_simple_keying_interface"><td class="memItemLeft" align="right" valign="top">virtual size_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_simple_keying_interface.html#aa6601819d376802e9698e815d00a5cba">GetValidKeyLength</a> (size_t keylength) const =0</td></tr>
<tr class="memdesc:aa6601819d376802e9698e815d00a5cba inherit pub_methods_class_simple_keying_interface"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns a valid key length for the algorithm.  <a href="class_simple_keying_interface.html#aa6601819d376802e9698e815d00a5cba">More...</a><br /></td></tr>
<tr class="separator:aa6601819d376802e9698e815d00a5cba inherit pub_methods_class_simple_keying_interface"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a597adcc7c00b5c14fa588276efeb613d inherit pub_methods_class_simple_keying_interface"><td class="memItemLeft" align="right" valign="top">virtual bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_simple_keying_interface.html#a597adcc7c00b5c14fa588276efeb613d">IsValidKeyLength</a> (size_t keylength) const</td></tr>
<tr class="memdesc:a597adcc7c00b5c14fa588276efeb613d inherit pub_methods_class_simple_keying_interface"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns whether keylength is a valid key length.  <a href="class_simple_keying_interface.html#a597adcc7c00b5c14fa588276efeb613d">More...</a><br /></td></tr>
<tr class="separator:a597adcc7c00b5c14fa588276efeb613d inherit pub_methods_class_simple_keying_interface"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:adf3c29b3ef3af74788a58c7c49887fd7 inherit pub_methods_class_simple_keying_interface"><td class="memItemLeft" align="right" valign="top">virtual void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_simple_keying_interface.html#adf3c29b3ef3af74788a58c7c49887fd7">SetKey</a> (const byte *key, size_t length, const <a class="el" href="class_name_value_pairs.html">NameValuePairs</a> &amp;params=<a class="el" href="cryptlib_8h.html#a04be65ada92ccb1e6aac0d94b4cc394b">g_nullNameValuePairs</a>)</td></tr>
<tr class="memdesc:adf3c29b3ef3af74788a58c7c49887fd7 inherit pub_methods_class_simple_keying_interface"><td class="mdescLeft">&#160;</td><td class="mdescRight">Sets or reset the key of this object.  <a href="class_simple_keying_interface.html#adf3c29b3ef3af74788a58c7c49887fd7">More...</a><br /></td></tr>
<tr class="separator:adf3c29b3ef3af74788a58c7c49887fd7 inherit pub_methods_class_simple_keying_interface"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a0401f9c67930805180964bc02ae0ac1c inherit pub_methods_class_simple_keying_interface"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_simple_keying_interface.html#a0401f9c67930805180964bc02ae0ac1c">SetKeyWithRounds</a> (const byte *key, size_t length, int rounds)</td></tr>
<tr class="memdesc:a0401f9c67930805180964bc02ae0ac1c inherit pub_methods_class_simple_keying_interface"><td class="mdescLeft">&#160;</td><td class="mdescRight">Sets or reset the key of this object.  <a href="class_simple_keying_interface.html#a0401f9c67930805180964bc02ae0ac1c">More...</a><br /></td></tr>
<tr class="separator:a0401f9c67930805180964bc02ae0ac1c inherit pub_methods_class_simple_keying_interface"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a5b4e358c514fd743840967bc595a34c2 inherit pub_methods_class_simple_keying_interface"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_simple_keying_interface.html#a5b4e358c514fd743840967bc595a34c2">SetKeyWithIV</a> (const byte *key, size_t length, const byte *iv, size_t ivLength)</td></tr>
<tr class="memdesc:a5b4e358c514fd743840967bc595a34c2 inherit pub_methods_class_simple_keying_interface"><td class="mdescLeft">&#160;</td><td class="mdescRight">Sets or reset the key of this object.  <a href="class_simple_keying_interface.html#a5b4e358c514fd743840967bc595a34c2">More...</a><br /></td></tr>
<tr class="separator:a5b4e358c514fd743840967bc595a34c2 inherit pub_methods_class_simple_keying_interface"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ac25e27eaeae2e909741c07de93caef49 inherit pub_methods_class_simple_keying_interface"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_simple_keying_interface.html#ac25e27eaeae2e909741c07de93caef49">SetKeyWithIV</a> (const byte *key, size_t length, const byte *iv)</td></tr>
<tr class="memdesc:ac25e27eaeae2e909741c07de93caef49 inherit pub_methods_class_simple_keying_interface"><td class="mdescLeft">&#160;</td><td class="mdescRight">Sets or reset the key of this object.  <a href="class_simple_keying_interface.html#ac25e27eaeae2e909741c07de93caef49">More...</a><br /></td></tr>
<tr class="separator:ac25e27eaeae2e909741c07de93caef49 inherit pub_methods_class_simple_keying_interface"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a867b535e5c4a11704d0645272e8b03f9 inherit pub_methods_class_simple_keying_interface"><td class="memItemLeft" align="right" valign="top">virtual <a class="el" href="class_simple_keying_interface.html#a88201c180fbfaa9fef2715252546ad6e">IV_Requirement</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_simple_keying_interface.html#a867b535e5c4a11704d0645272e8b03f9">IVRequirement</a> () const =0</td></tr>
<tr class="memdesc:a867b535e5c4a11704d0645272e8b03f9 inherit pub_methods_class_simple_keying_interface"><td class="mdescLeft">&#160;</td><td class="mdescRight">Minimal requirement for secure IVs.  <a href="class_simple_keying_interface.html#a867b535e5c4a11704d0645272e8b03f9">More...</a><br /></td></tr>
<tr class="separator:a867b535e5c4a11704d0645272e8b03f9 inherit pub_methods_class_simple_keying_interface"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a71039112353cc70e9859ebd95037cc1a inherit pub_methods_class_simple_keying_interface"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_simple_keying_interface.html#a71039112353cc70e9859ebd95037cc1a">IsResynchronizable</a> () const</td></tr>
<tr class="memdesc:a71039112353cc70e9859ebd95037cc1a inherit pub_methods_class_simple_keying_interface"><td class="mdescLeft">&#160;</td><td class="mdescRight">Determines if the object can be resynchronized.  <a href="class_simple_keying_interface.html#a71039112353cc70e9859ebd95037cc1a">More...</a><br /></td></tr>
<tr class="separator:a71039112353cc70e9859ebd95037cc1a inherit pub_methods_class_simple_keying_interface"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aa09fd0893ac8c6068e07ce30bb55c1d9 inherit pub_methods_class_simple_keying_interface"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_simple_keying_interface.html#aa09fd0893ac8c6068e07ce30bb55c1d9">CanUseRandomIVs</a> () const</td></tr>
<tr class="memdesc:aa09fd0893ac8c6068e07ce30bb55c1d9 inherit pub_methods_class_simple_keying_interface"><td class="mdescLeft">&#160;</td><td class="mdescRight">Determines if the object can use random IVs.  <a href="class_simple_keying_interface.html#aa09fd0893ac8c6068e07ce30bb55c1d9">More...</a><br /></td></tr>
<tr class="separator:aa09fd0893ac8c6068e07ce30bb55c1d9 inherit pub_methods_class_simple_keying_interface"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ab98803e8744b73663e7e9c872eef822b inherit pub_methods_class_simple_keying_interface"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_simple_keying_interface.html#ab98803e8744b73663e7e9c872eef822b">CanUsePredictableIVs</a> () const</td></tr>
<tr class="memdesc:ab98803e8744b73663e7e9c872eef822b inherit pub_methods_class_simple_keying_interface"><td class="mdescLeft">&#160;</td><td class="mdescRight">Determines if the object can use random but possibly predictable IVs.  <a href="class_simple_keying_interface.html#ab98803e8744b73663e7e9c872eef822b">More...</a><br /></td></tr>
<tr class="separator:ab98803e8744b73663e7e9c872eef822b inherit pub_methods_class_simple_keying_interface"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:afbf7065f7db5439d471d1bcc260d3bd5 inherit pub_methods_class_simple_keying_interface"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_simple_keying_interface.html#afbf7065f7db5439d471d1bcc260d3bd5">CanUseStructuredIVs</a> () const</td></tr>
<tr class="memdesc:afbf7065f7db5439d471d1bcc260d3bd5 inherit pub_methods_class_simple_keying_interface"><td class="mdescLeft">&#160;</td><td class="mdescRight">Determines if the object can use structured IVs.  <a href="class_simple_keying_interface.html#afbf7065f7db5439d471d1bcc260d3bd5">More...</a><br /></td></tr>
<tr class="separator:afbf7065f7db5439d471d1bcc260d3bd5 inherit pub_methods_class_simple_keying_interface"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ac6da9a8d3c783014ab54a2a3ee9e676a inherit pub_methods_class_simple_keying_interface"><td class="memItemLeft" align="right" valign="top">virtual unsigned int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_simple_keying_interface.html#ac6da9a8d3c783014ab54a2a3ee9e676a">IVSize</a> () const</td></tr>
<tr class="memdesc:ac6da9a8d3c783014ab54a2a3ee9e676a inherit pub_methods_class_simple_keying_interface"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns length of the IV accepted by this object.  <a href="class_simple_keying_interface.html#ac6da9a8d3c783014ab54a2a3ee9e676a">More...</a><br /></td></tr>
<tr class="separator:ac6da9a8d3c783014ab54a2a3ee9e676a inherit pub_methods_class_simple_keying_interface"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:af2f7dd9da3a75651615b0ccae71f34a5 inherit pub_methods_class_simple_keying_interface"><td class="memItemLeft" align="right" valign="top">unsigned int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_simple_keying_interface.html#af2f7dd9da3a75651615b0ccae71f34a5">DefaultIVLength</a> () const</td></tr>
<tr class="memdesc:af2f7dd9da3a75651615b0ccae71f34a5 inherit pub_methods_class_simple_keying_interface"><td class="mdescLeft">&#160;</td><td class="mdescRight">Provides the default size of an IV.  <a href="class_simple_keying_interface.html#af2f7dd9da3a75651615b0ccae71f34a5">More...</a><br /></td></tr>
<tr class="separator:af2f7dd9da3a75651615b0ccae71f34a5 inherit pub_methods_class_simple_keying_interface"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ab94b9751aba4f3660accb673095180c0 inherit pub_methods_class_simple_keying_interface"><td class="memItemLeft" align="right" valign="top">virtual unsigned int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_simple_keying_interface.html#ab94b9751aba4f3660accb673095180c0">MinIVLength</a> () const</td></tr>
<tr class="memdesc:ab94b9751aba4f3660accb673095180c0 inherit pub_methods_class_simple_keying_interface"><td class="mdescLeft">&#160;</td><td class="mdescRight">Provides the minimum size of an IV.  <a href="class_simple_keying_interface.html#ab94b9751aba4f3660accb673095180c0">More...</a><br /></td></tr>
<tr class="separator:ab94b9751aba4f3660accb673095180c0 inherit pub_methods_class_simple_keying_interface"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a8fc07e61d83ce9639d9b3608fb5dd8cb inherit pub_methods_class_simple_keying_interface"><td class="memItemLeft" align="right" valign="top">virtual unsigned int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_simple_keying_interface.html#a8fc07e61d83ce9639d9b3608fb5dd8cb">MaxIVLength</a> () const</td></tr>
<tr class="memdesc:a8fc07e61d83ce9639d9b3608fb5dd8cb inherit pub_methods_class_simple_keying_interface"><td class="mdescLeft">&#160;</td><td class="mdescRight">Provides the maximum size of an IV.  <a href="class_simple_keying_interface.html#a8fc07e61d83ce9639d9b3608fb5dd8cb">More...</a><br /></td></tr>
<tr class="separator:a8fc07e61d83ce9639d9b3608fb5dd8cb inherit pub_methods_class_simple_keying_interface"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="inherit_header pub_methods_class_hash_transformation"><td colspan="2" onclick="javascript:toggleInherit('pub_methods_class_hash_transformation')"><img src="closed.png" alt="-"/>&#160;Public Member Functions inherited from <a class="el" href="class_hash_transformation.html">HashTransformation</a></td></tr>
<tr class="memitem:a39b0a4c4cdc11fda358f9975b5e4137e inherit pub_methods_class_hash_transformation"><td class="memItemLeft" align="right" valign="top"><a class="el" href="class_hash_transformation.html">HashTransformation</a> &amp;&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_hash_transformation.html#a39b0a4c4cdc11fda358f9975b5e4137e">Ref</a> ()</td></tr>
<tr class="memdesc:a39b0a4c4cdc11fda358f9975b5e4137e inherit pub_methods_class_hash_transformation"><td class="mdescLeft">&#160;</td><td class="mdescRight">Provides a reference to this object.  <a href="class_hash_transformation.html#a39b0a4c4cdc11fda358f9975b5e4137e">More...</a><br /></td></tr>
<tr class="separator:a39b0a4c4cdc11fda358f9975b5e4137e inherit pub_methods_class_hash_transformation"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a9fc0b332ef36900ca6ea5d949e95aba1 inherit pub_methods_class_hash_transformation"><td class="memItemLeft" align="right" valign="top">virtual byte *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_hash_transformation.html#a9fc0b332ef36900ca6ea5d949e95aba1">CreateUpdateSpace</a> (size_t &amp;size)</td></tr>
<tr class="memdesc:a9fc0b332ef36900ca6ea5d949e95aba1 inherit pub_methods_class_hash_transformation"><td class="mdescLeft">&#160;</td><td class="mdescRight">Request space which can be written into by the caller.  <a href="class_hash_transformation.html#a9fc0b332ef36900ca6ea5d949e95aba1">More...</a><br /></td></tr>
<tr class="separator:a9fc0b332ef36900ca6ea5d949e95aba1 inherit pub_methods_class_hash_transformation"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aa0b8c7a110d8968268fd02ec32b9a8e8 inherit pub_methods_class_hash_transformation"><td class="memItemLeft" align="right" valign="top">virtual void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_hash_transformation.html#aa0b8c7a110d8968268fd02ec32b9a8e8">Final</a> (byte *digest)</td></tr>
<tr class="memdesc:aa0b8c7a110d8968268fd02ec32b9a8e8 inherit pub_methods_class_hash_transformation"><td class="mdescLeft">&#160;</td><td class="mdescRight">Computes the hash of the current message.  <a href="class_hash_transformation.html#aa0b8c7a110d8968268fd02ec32b9a8e8">More...</a><br /></td></tr>
<tr class="separator:aa0b8c7a110d8968268fd02ec32b9a8e8 inherit pub_methods_class_hash_transformation"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:af68588a8333e11066a0da91506cebbb4 inherit pub_methods_class_hash_transformation"><td class="memItemLeft" align="right" valign="top">unsigned int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_hash_transformation.html#af68588a8333e11066a0da91506cebbb4">TagSize</a> () const</td></tr>
<tr class="memdesc:af68588a8333e11066a0da91506cebbb4 inherit pub_methods_class_hash_transformation"><td class="mdescLeft">&#160;</td><td class="mdescRight">Provides the tag size of the hash.  <a href="class_hash_transformation.html#af68588a8333e11066a0da91506cebbb4">More...</a><br /></td></tr>
<tr class="separator:af68588a8333e11066a0da91506cebbb4 inherit pub_methods_class_hash_transformation"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aee97908d965930ee454f7a88b0ff0f71 inherit pub_methods_class_hash_transformation"><td class="memItemLeft" align="right" valign="top">virtual unsigned int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_hash_transformation.html#aee97908d965930ee454f7a88b0ff0f71">OptimalBlockSize</a> () const</td></tr>
<tr class="memdesc:aee97908d965930ee454f7a88b0ff0f71 inherit pub_methods_class_hash_transformation"><td class="mdescLeft">&#160;</td><td class="mdescRight">Provides the input block size most efficient for this hash.  <a href="class_hash_transformation.html#aee97908d965930ee454f7a88b0ff0f71">More...</a><br /></td></tr>
<tr class="separator:aee97908d965930ee454f7a88b0ff0f71 inherit pub_methods_class_hash_transformation"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a927a808007503246a745a564ad451da5 inherit pub_methods_class_hash_transformation"><td class="memItemLeft" align="right" valign="top">virtual unsigned int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_hash_transformation.html#a927a808007503246a745a564ad451da5">OptimalDataAlignment</a> () const</td></tr>
<tr class="memdesc:a927a808007503246a745a564ad451da5 inherit pub_methods_class_hash_transformation"><td class="mdescLeft">&#160;</td><td class="mdescRight">Provides input and output data alignment for optimal performance.  <a href="class_hash_transformation.html#a927a808007503246a745a564ad451da5">More...</a><br /></td></tr>
<tr class="separator:a927a808007503246a745a564ad451da5 inherit pub_methods_class_hash_transformation"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:af8124c4fca23b74bbdc43660bdae692c inherit pub_methods_class_hash_transformation"><td class="memItemLeft" align="right" valign="top">virtual void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_hash_transformation.html#af8124c4fca23b74bbdc43660bdae692c">CalculateDigest</a> (byte *digest, const byte *input, size_t length)</td></tr>
<tr class="memdesc:af8124c4fca23b74bbdc43660bdae692c inherit pub_methods_class_hash_transformation"><td class="mdescLeft">&#160;</td><td class="mdescRight">Updates the hash with additional input and computes the hash of the current message.  <a href="class_hash_transformation.html#af8124c4fca23b74bbdc43660bdae692c">More...</a><br /></td></tr>
<tr class="separator:af8124c4fca23b74bbdc43660bdae692c inherit pub_methods_class_hash_transformation"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a16c4aecd047015d513feef4ed5b929ba inherit pub_methods_class_hash_transformation"><td class="memItemLeft" align="right" valign="top">virtual bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_hash_transformation.html#a16c4aecd047015d513feef4ed5b929ba">Verify</a> (const byte *digest)</td></tr>
<tr class="memdesc:a16c4aecd047015d513feef4ed5b929ba inherit pub_methods_class_hash_transformation"><td class="mdescLeft">&#160;</td><td class="mdescRight">Verifies the hash of the current message.  <a href="class_hash_transformation.html#a16c4aecd047015d513feef4ed5b929ba">More...</a><br /></td></tr>
<tr class="separator:a16c4aecd047015d513feef4ed5b929ba inherit pub_methods_class_hash_transformation"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:acad96df68e70d922683e5063057130b2 inherit pub_methods_class_hash_transformation"><td class="memItemLeft" align="right" valign="top">virtual bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_hash_transformation.html#acad96df68e70d922683e5063057130b2">VerifyDigest</a> (const byte *digest, const byte *input, size_t length)</td></tr>
<tr class="memdesc:acad96df68e70d922683e5063057130b2 inherit pub_methods_class_hash_transformation"><td class="mdescLeft">&#160;</td><td class="mdescRight">Updates the hash with additional input and verifies the hash of the current message.  <a href="class_hash_transformation.html#acad96df68e70d922683e5063057130b2">More...</a><br /></td></tr>
<tr class="separator:acad96df68e70d922683e5063057130b2 inherit pub_methods_class_hash_transformation"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a0b6917657eaec935750fd83e28270d76 inherit pub_methods_class_hash_transformation"><td class="memItemLeft" align="right" valign="top">virtual void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_hash_transformation.html#a0b6917657eaec935750fd83e28270d76">CalculateTruncatedDigest</a> (byte *digest, size_t digestSize, const byte *input, size_t length)</td></tr>
<tr class="memdesc:a0b6917657eaec935750fd83e28270d76 inherit pub_methods_class_hash_transformation"><td class="mdescLeft">&#160;</td><td class="mdescRight">Updates the hash with additional input and computes the hash of the current message.  <a href="class_hash_transformation.html#a0b6917657eaec935750fd83e28270d76">More...</a><br /></td></tr>
<tr class="separator:a0b6917657eaec935750fd83e28270d76 inherit pub_methods_class_hash_transformation"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a0f6069eadf492d970c3eb8cdf656e742 inherit pub_methods_class_hash_transformation"><td class="memItemLeft" align="right" valign="top">virtual bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_hash_transformation.html#a0f6069eadf492d970c3eb8cdf656e742">TruncatedVerify</a> (const byte *digest, size_t digestLength)</td></tr>
<tr class="memdesc:a0f6069eadf492d970c3eb8cdf656e742 inherit pub_methods_class_hash_transformation"><td class="mdescLeft">&#160;</td><td class="mdescRight">Verifies the hash of the current message.  <a href="class_hash_transformation.html#a0f6069eadf492d970c3eb8cdf656e742">More...</a><br /></td></tr>
<tr class="separator:a0f6069eadf492d970c3eb8cdf656e742 inherit pub_methods_class_hash_transformation"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a7958e99717019e8b9f91672bdfe9e086 inherit pub_methods_class_hash_transformation"><td class="memItemLeft" align="right" valign="top">virtual bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_hash_transformation.html#a7958e99717019e8b9f91672bdfe9e086">VerifyTruncatedDigest</a> (const byte *digest, size_t digestLength, const byte *input, size_t length)</td></tr>
<tr class="memdesc:a7958e99717019e8b9f91672bdfe9e086 inherit pub_methods_class_hash_transformation"><td class="mdescLeft">&#160;</td><td class="mdescRight">Updates the hash with additional input and verifies the hash of the current message.  <a href="class_hash_transformation.html#a7958e99717019e8b9f91672bdfe9e086">More...</a><br /></td></tr>
<tr class="separator:a7958e99717019e8b9f91672bdfe9e086 inherit pub_methods_class_hash_transformation"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="inherit_header pub_methods_class_algorithm"><td colspan="2" onclick="javascript:toggleInherit('pub_methods_class_algorithm')"><img src="closed.png" alt="-"/>&#160;Public Member Functions inherited from <a class="el" href="class_algorithm.html">Algorithm</a></td></tr>
<tr class="memitem:a1c77f5117ca2cd881baf26a364cfc606 inherit pub_methods_class_algorithm"><td class="memItemLeft" align="right" valign="top">&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_algorithm.html#a1c77f5117ca2cd881baf26a364cfc606">Algorithm</a> (bool checkSelfTestStatus=true)</td></tr>
<tr class="memdesc:a1c77f5117ca2cd881baf26a364cfc606 inherit pub_methods_class_algorithm"><td class="mdescLeft">&#160;</td><td class="mdescRight">Interface for all crypto algorithms.  <a href="class_algorithm.html#a1c77f5117ca2cd881baf26a364cfc606">More...</a><br /></td></tr>
<tr class="separator:a1c77f5117ca2cd881baf26a364cfc606 inherit pub_methods_class_algorithm"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a4f31510a192d1121856efe8ad0a9b844 inherit pub_methods_class_algorithm"><td class="memItemLeft" align="right" valign="top">virtual std::string&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_algorithm.html#a4f31510a192d1121856efe8ad0a9b844">AlgorithmName</a> () const</td></tr>
<tr class="memdesc:a4f31510a192d1121856efe8ad0a9b844 inherit pub_methods_class_algorithm"><td class="mdescLeft">&#160;</td><td class="mdescRight">Provides the name of this algorithm.  <a href="class_algorithm.html#a4f31510a192d1121856efe8ad0a9b844">More...</a><br /></td></tr>
<tr class="separator:a4f31510a192d1121856efe8ad0a9b844 inherit pub_methods_class_algorithm"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="inherit_header pub_methods_class_clonable"><td colspan="2" onclick="javascript:toggleInherit('pub_methods_class_clonable')"><img src="closed.png" alt="-"/>&#160;Public Member Functions inherited from <a class="el" href="class_clonable.html">Clonable</a></td></tr>
<tr class="memitem:ad0016ba2d505c23aa85aad49e6c19bb7 inherit pub_methods_class_clonable"><td class="memItemLeft" align="right" valign="top">virtual <a class="el" href="class_clonable.html">Clonable</a> *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_clonable.html#ad0016ba2d505c23aa85aad49e6c19bb7">Clone</a> () const</td></tr>
<tr class="memdesc:ad0016ba2d505c23aa85aad49e6c19bb7 inherit pub_methods_class_clonable"><td class="mdescLeft">&#160;</td><td class="mdescRight">Copies this object.  <a href="class_clonable.html#ad0016ba2d505c23aa85aad49e6c19bb7">More...</a><br /></td></tr>
<tr class="separator:ad0016ba2d505c23aa85aad49e6c19bb7 inherit pub_methods_class_clonable"><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:a292e5c323264e96f6de51aa20cbb4f7e"><td class="memItemLeft" align="right" valign="top"><a id="a292e5c323264e96f6de51aa20cbb4f7e"></a>
static std::string&#160;</td><td class="memItemRight" valign="bottom"><b>StaticAlgorithmName</b> ()</td></tr>
<tr class="separator:a292e5c323264e96f6de51aa20cbb4f7e"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="inherit_header pub_static_methods_class_fixed_key_length"><td colspan="2" onclick="javascript:toggleInherit('pub_static_methods_class_fixed_key_length')"><img src="closed.png" alt="-"/>&#160;Static Public Member Functions inherited from <a class="el" href="class_fixed_key_length.html">FixedKeyLength&lt; 32, SimpleKeyingInterface::UNIQUE_IV, 16 &gt;</a></td></tr>
<tr class="memitem:a33b626ceb451a6897ef71e4aa73efce5 inherit pub_static_methods_class_fixed_key_length"><td class="memItemLeft" align="right" valign="top">static size_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fixed_key_length.html#a33b626ceb451a6897ef71e4aa73efce5">StaticGetValidKeyLength</a> (size_t keylength)</td></tr>
<tr class="memdesc:a33b626ceb451a6897ef71e4aa73efce5 inherit pub_static_methods_class_fixed_key_length"><td class="mdescLeft">&#160;</td><td class="mdescRight">The default key length for the algorithm provided by a static function.  <a href="class_fixed_key_length.html#a33b626ceb451a6897ef71e4aa73efce5">More...</a><br /></td></tr>
<tr class="separator:a33b626ceb451a6897ef71e4aa73efce5 inherit pub_static_methods_class_fixed_key_length"><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-attribs"></a>
Static Public Attributes</h2></td></tr>
<tr class="memitem:acacc861930c836f9909054fda3e1b777"><td class="memItemLeft" align="right" valign="top"><a id="acacc861930c836f9909054fda3e1b777"></a>
static const int&#160;</td><td class="memItemRight" valign="bottom"><b>DIGESTSIZE</b> =T::BLOCKSIZE</td></tr>
<tr class="separator:acacc861930c836f9909054fda3e1b777"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ac2396b4ccec6b3b4d96e19764a4c49ec"><td class="memItemLeft" align="right" valign="top"><a id="ac2396b4ccec6b3b4d96e19764a4c49ec"></a>
static const int&#160;</td><td class="memItemRight" valign="bottom"><b>BLOCKSIZE</b> =T::BLOCKSIZE</td></tr>
<tr class="separator:ac2396b4ccec6b3b4d96e19764a4c49ec"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="inherit_header pub_static_attribs_class_fixed_key_length"><td colspan="2" onclick="javascript:toggleInherit('pub_static_attribs_class_fixed_key_length')"><img src="closed.png" alt="-"/>&#160;Static Public Attributes inherited from <a class="el" href="class_fixed_key_length.html">FixedKeyLength&lt; 32, SimpleKeyingInterface::UNIQUE_IV, 16 &gt;</a></td></tr>
<tr class="memitem:ab994d881a105849f64a973373e8f282c inherit pub_static_attribs_class_fixed_key_length"><td class="memItemLeft" align="right" valign="top">static const int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fixed_key_length.html#ab994d881a105849f64a973373e8f282c">KEYLENGTH</a></td></tr>
<tr class="memdesc:ab994d881a105849f64a973373e8f282c inherit pub_static_attribs_class_fixed_key_length"><td class="mdescLeft">&#160;</td><td class="mdescRight">The default key length used by the algorithm provided as a constant.  <a href="class_fixed_key_length.html#ab994d881a105849f64a973373e8f282c">More...</a><br /></td></tr>
<tr class="separator:ab994d881a105849f64a973373e8f282c inherit pub_static_attribs_class_fixed_key_length"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a198440f34bfe0f343fab3cdbef586a3b inherit pub_static_attribs_class_fixed_key_length"><td class="memItemLeft" align="right" valign="top">static const int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fixed_key_length.html#a198440f34bfe0f343fab3cdbef586a3b">MIN_KEYLENGTH</a></td></tr>
<tr class="memdesc:a198440f34bfe0f343fab3cdbef586a3b inherit pub_static_attribs_class_fixed_key_length"><td class="mdescLeft">&#160;</td><td class="mdescRight">The minimum key length used by the algorithm provided as a constant.  <a href="class_fixed_key_length.html#a198440f34bfe0f343fab3cdbef586a3b">More...</a><br /></td></tr>
<tr class="separator:a198440f34bfe0f343fab3cdbef586a3b inherit pub_static_attribs_class_fixed_key_length"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a7c599a7ebb4e0fa4773c4cd1b4023b18 inherit pub_static_attribs_class_fixed_key_length"><td class="memItemLeft" align="right" valign="top">static const int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fixed_key_length.html#a7c599a7ebb4e0fa4773c4cd1b4023b18">MAX_KEYLENGTH</a></td></tr>
<tr class="memdesc:a7c599a7ebb4e0fa4773c4cd1b4023b18 inherit pub_static_attribs_class_fixed_key_length"><td class="mdescLeft">&#160;</td><td class="mdescRight">The maximum key length used by the algorithm provided as a constant.  <a href="class_fixed_key_length.html#a7c599a7ebb4e0fa4773c4cd1b4023b18">More...</a><br /></td></tr>
<tr class="separator:a7c599a7ebb4e0fa4773c4cd1b4023b18 inherit pub_static_attribs_class_fixed_key_length"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a1e9951e11c42a0a8c75bd959bcf26f31 inherit pub_static_attribs_class_fixed_key_length"><td class="memItemLeft" align="right" valign="top">static const int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fixed_key_length.html#a1e9951e11c42a0a8c75bd959bcf26f31">DEFAULT_KEYLENGTH</a></td></tr>
<tr class="memdesc:a1e9951e11c42a0a8c75bd959bcf26f31 inherit pub_static_attribs_class_fixed_key_length"><td class="mdescLeft">&#160;</td><td class="mdescRight">The default key length used by the algorithm provided as a constant.  <a href="class_fixed_key_length.html#a1e9951e11c42a0a8c75bd959bcf26f31">More...</a><br /></td></tr>
<tr class="separator:a1e9951e11c42a0a8c75bd959bcf26f31 inherit pub_static_attribs_class_fixed_key_length"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ab1a634167fe78a3ee06554a268e6d61c inherit pub_static_attribs_class_fixed_key_length"><td class="memItemLeft" align="right" valign="top">static const int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fixed_key_length.html#ab1a634167fe78a3ee06554a268e6d61c">IV_REQUIREMENT</a></td></tr>
<tr class="memdesc:ab1a634167fe78a3ee06554a268e6d61c inherit pub_static_attribs_class_fixed_key_length"><td class="mdescLeft">&#160;</td><td class="mdescRight">The default IV requirements for the algorithm provided as a constant.  <a href="class_fixed_key_length.html#ab1a634167fe78a3ee06554a268e6d61c">More...</a><br /></td></tr>
<tr class="separator:ab1a634167fe78a3ee06554a268e6d61c inherit pub_static_attribs_class_fixed_key_length"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a467a0101968e4181f770509e19ebef28 inherit pub_static_attribs_class_fixed_key_length"><td class="memItemLeft" align="right" valign="top">static const int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fixed_key_length.html#a467a0101968e4181f770509e19ebef28">IV_LENGTH</a></td></tr>
<tr class="memdesc:a467a0101968e4181f770509e19ebef28 inherit pub_static_attribs_class_fixed_key_length"><td class="mdescLeft">&#160;</td><td class="mdescRight">The default IV length used by the algorithm provided as a constant.  <a href="class_fixed_key_length.html#a467a0101968e4181f770509e19ebef28">More...</a><br /></td></tr>
<tr class="separator:a467a0101968e4181f770509e19ebef28 inherit pub_static_attribs_class_fixed_key_length"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="inherited"></a>
Additional Inherited Members</h2></td></tr>
<tr class="inherit_header pub_types_class_simple_keying_interface"><td colspan="2" onclick="javascript:toggleInherit('pub_types_class_simple_keying_interface')"><img src="closed.png" alt="-"/>&#160;Public Types inherited from <a class="el" href="class_simple_keying_interface.html">SimpleKeyingInterface</a></td></tr>
<tr class="memitem:a88201c180fbfaa9fef2715252546ad6e inherit pub_types_class_simple_keying_interface"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_simple_keying_interface.html#a88201c180fbfaa9fef2715252546ad6e">IV_Requirement</a> { <br />
&#160;&#160;<a class="el" href="class_simple_keying_interface.html#a88201c180fbfaa9fef2715252546ad6ea1cc32e69fe4f385e54d9d482a2ab5a56">UNIQUE_IV</a> = 0, 
<a class="el" href="class_simple_keying_interface.html#a88201c180fbfaa9fef2715252546ad6ea4520c4379ee3a1aed95a36e2235ba338">RANDOM_IV</a>, 
<a class="el" href="class_simple_keying_interface.html#a88201c180fbfaa9fef2715252546ad6eaceff3ad4b12bcb6d7b61a5bd543a815c">UNPREDICTABLE_RANDOM_IV</a>, 
<a class="el" href="class_simple_keying_interface.html#a88201c180fbfaa9fef2715252546ad6eab659bf6d2c470c50c14bfbab5b2d45ab">INTERNALLY_GENERATED_IV</a>, 
<br />
&#160;&#160;<a class="el" href="class_simple_keying_interface.html#a88201c180fbfaa9fef2715252546ad6eac1d24de3dedd05c28516f452d3ace417">NOT_RESYNCHRONIZABLE</a>
<br />
 }</td></tr>
<tr class="memdesc:a88201c180fbfaa9fef2715252546ad6e"><td class="mdescLeft">&#160;</td><td class="mdescRight">Secure IVs requirements as enumerated values.  <a href="class_simple_keying_interface.html#a88201c180fbfaa9fef2715252546ad6e">More...</a><br /></td></tr>
<tr class="separator:a88201c180fbfaa9fef2715252546ad6e inherit pub_types_class_simple_keying_interface"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table>
<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2>
<div class="textblock"><h3>template&lt;class T&gt;<br />
class Poly1305_Base&lt; T &gt;</h3>

<p><a class="el" href="class_poly1305.html" title="Poly1305 message authentication code. ">Poly1305</a> message authentication code base class. </p>
<dl class="tparams"><dt>Template Parameters</dt><dd>
  <table class="tparams">
    <tr><td class="paramname">T</td><td>class derived from <a class="el" href="struct_block_cipher_documentation.html" title="Provides Encryption and Decryption typedefs used by derived classes to implement a block cipher...">BlockCipherDocumentation</a> with 16-byte key and 16-byte blocksize </td></tr>
  </table>
  </dd>
</dl>
<dl class="section since"><dt>Since</dt><dd>Crypto++ 6.0 </dd></dl>

<p class="definition">Definition at line <a class="el" href="poly1305_8h_source.html#l00059">59</a> of file <a class="el" href="poly1305_8h_source.html">poly1305.h</a>.</p>
</div><h2 class="groupheader">Member Function Documentation</h2>
<a id="aebdc8e79fbe6397a25a166a63c199489"></a>
<h2 class="memtitle"><span class="permalink"><a href="#aebdc8e79fbe6397a25a166a63c199489">&#9670;&nbsp;</a></span>Resynchronize()</h2>

<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class T &gt; </div>
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">void <a class="el" href="class_poly1305___base.html">Poly1305_Base</a>&lt; T &gt;::Resynchronize </td>
          <td>(</td>
          <td class="paramtype">const byte *&#160;</td>
          <td class="paramname"><em>iv</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">int&#160;</td>
          <td class="paramname"><em>ivLength</em> = <code>-1</code>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">virtual</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Resynchronize with an IV. </p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">iv</td><td>the initialization vector </td></tr>
    <tr><td class="paramname">ivLength</td><td>the size of the initialization vector, in bytes</td></tr>
  </table>
  </dd>
</dl>
<p><a class="el" href="class_poly1305___base.html#aebdc8e79fbe6397a25a166a63c199489" title="Resynchronize with an IV. ">Resynchronize()</a> resynchronizes with an IV provided by the caller. <code>ivLength=-1</code> means use <a class="el" href="class_simple_keying_interface.html#ac6da9a8d3c783014ab54a2a3ee9e676a" title="Returns length of the IV accepted by this object. ">IVSize()</a>. </p><dl class="exception"><dt>Exceptions</dt><dd>
  <table class="exception">
    <tr><td class="paramname"><a class="el" href="class_not_implemented.html" title="A method was called which was not implemented. ">NotImplemented()</a></td><td>if the object does not support resynchronization </td></tr>
  </table>
  </dd>
</dl>

<p>Reimplemented from <a class="el" href="class_simple_keying_interface.html#ae576137a46ca56005e82f1505cf3cccc">SimpleKeyingInterface</a>.</p>

<p class="definition">Definition at line <a class="el" href="poly1305_8cpp_source.html#l00244">244</a> of file <a class="el" href="poly1305_8cpp_source.html">poly1305.cpp</a>.</p>

</div>
</div>
<a id="a6b72e58e0916f5cc75055e4c6785fdc6"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a6b72e58e0916f5cc75055e4c6785fdc6">&#9670;&nbsp;</a></span>GetNextIV()</h2>

<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class T &gt; </div>
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">void <a class="el" href="class_poly1305___base.html">Poly1305_Base</a>&lt; T &gt;::GetNextIV </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="class_random_number_generator.html">RandomNumberGenerator</a> &amp;&#160;</td>
          <td class="paramname"><em>rng</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">byte *&#160;</td>
          <td class="paramname"><em>iv</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">virtual</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Retrieves a secure IV for the next message. </p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">rng</td><td>a <a class="el" href="class_random_number_generator.html" title="Interface for random number generators. ">RandomNumberGenerator</a> to produce keying material </td></tr>
    <tr><td class="paramname">iv</td><td>a block of bytes to receive the IV</td></tr>
  </table>
  </dd>
</dl>
<p>The IV must be at least <a class="el" href="class_simple_keying_interface.html#ac6da9a8d3c783014ab54a2a3ee9e676a" title="Returns length of the IV accepted by this object. ">IVSize()</a> in length.</p>
<p>This method should be called after you finish encrypting one message and are ready to start the next one. After calling it, you must call <a class="el" href="class_simple_keying_interface.html#adf3c29b3ef3af74788a58c7c49887fd7" title="Sets or reset the key of this object. ">SetKey()</a> or <a class="el" href="class_poly1305___base.html#aebdc8e79fbe6397a25a166a63c199489" title="Resynchronize with an IV. ">Resynchronize()</a>. before using this object again.</p>
<p>Internally, the base class implementation calls <a class="el" href="class_random_number_generator.html" title="Interface for random number generators. ">RandomNumberGenerator</a>'s GenerateBlock() </p><dl class="section note"><dt>Note</dt><dd>This method is not implemented on decryption objects. </dd></dl>

<p>Reimplemented from <a class="el" href="class_simple_keying_interface.html#ac8277d1517add6fd455ca576bee57fe2">SimpleKeyingInterface</a>.</p>

<p class="definition">Definition at line <a class="el" href="poly1305_8cpp_source.html#l00252">252</a> of file <a class="el" href="poly1305_8cpp_source.html">poly1305.cpp</a>.</p>

</div>
</div>
<a id="a823d58a924c6c0caa9c731092c3c93f0"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a823d58a924c6c0caa9c731092c3c93f0">&#9670;&nbsp;</a></span>UncheckedSetKey()</h2>

<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class T &gt; </div>
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">void <a class="el" href="class_poly1305___base.html">Poly1305_Base</a>&lt; T &gt;::UncheckedSetKey </td>
          <td>(</td>
          <td class="paramtype">const byte *&#160;</td>
          <td class="paramname"><em>key</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">unsigned int&#160;</td>
          <td class="paramname"><em>length</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const <a class="el" href="class_name_value_pairs.html">NameValuePairs</a> &amp;&#160;</td>
          <td class="paramname"><em>params</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">virtual</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Sets the key for this object without performing parameter validation. </p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">key</td><td>a byte buffer used to key the cipher </td></tr>
    <tr><td class="paramname">length</td><td>the length of the byte buffer </td></tr>
    <tr><td class="paramname">params</td><td>additional parameters passed as <a class="el" href="class_name_value_pairs.html" title="Interface for retrieving values given their names. ">NameValuePairs</a></td></tr>
  </table>
  </dd>
</dl>
<p>key must be at least DEFAULT_KEYLENGTH in length. </p>

<p>Implements <a class="el" href="class_simple_keying_interface.html">SimpleKeyingInterface</a>.</p>

<p class="definition">Definition at line <a class="el" href="poly1305_8cpp_source.html#l00015">15</a> of file <a class="el" href="poly1305_8cpp_source.html">poly1305.cpp</a>.</p>

</div>
</div>
<a id="a13640c0e9edc4bd6783ef9c7abd694ea"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a13640c0e9edc4bd6783ef9c7abd694ea">&#9670;&nbsp;</a></span>Update()</h2>

<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class T &gt; </div>
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">void <a class="el" href="class_poly1305___base.html">Poly1305_Base</a>&lt; T &gt;::Update </td>
          <td>(</td>
          <td class="paramtype">const byte *&#160;</td>
          <td class="paramname"><em>input</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">size_t&#160;</td>
          <td class="paramname"><em>length</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">virtual</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Updates a hash with additional input. </p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">input</td><td>the additional input as a buffer </td></tr>
    <tr><td class="paramname">length</td><td>the size of the buffer, in bytes </td></tr>
  </table>
  </dd>
</dl>

<p>Implements <a class="el" href="class_hash_transformation.html#aafabefaf445b65d3ba0d8e1c0294afe5">HashTransformation</a>.</p>

<p class="definition">Definition at line <a class="el" href="poly1305_8cpp_source.html#l00053">53</a> of file <a class="el" href="poly1305_8cpp_source.html">poly1305.cpp</a>.</p>

</div>
</div>
<a id="a350554631a23d196217b483843a4e6b0"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a350554631a23d196217b483843a4e6b0">&#9670;&nbsp;</a></span>TruncatedFinal()</h2>

<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class T &gt; </div>
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">void <a class="el" href="class_poly1305___base.html">Poly1305_Base</a>&lt; T &gt;::TruncatedFinal </td>
          <td>(</td>
          <td class="paramtype">byte *&#160;</td>
          <td class="paramname"><em>digest</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">size_t&#160;</td>
          <td class="paramname"><em>digestSize</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">virtual</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Computes the hash of the current message. </p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">digest</td><td>a pointer to the buffer to receive the hash </td></tr>
    <tr><td class="paramname">digestSize</td><td>the size of the truncated digest, in bytes</td></tr>
  </table>
  </dd>
</dl>
<p><a class="el" href="class_poly1305___base.html#a350554631a23d196217b483843a4e6b0" title="Computes the hash of the current message. ">TruncatedFinal()</a> call <a class="el" href="class_hash_transformation.html#aa0b8c7a110d8968268fd02ec32b9a8e8" title="Computes the hash of the current message. ">Final()</a> and then copies digestSize bytes to digest. The hash is restarted the hash for the next message. </p>

<p>Implements <a class="el" href="class_hash_transformation.html#a590ecda344aa0fb045abf42ec08823b2">HashTransformation</a>.</p>

<p class="definition">Definition at line <a class="el" href="poly1305_8cpp_source.html#l00167">167</a> of file <a class="el" href="poly1305_8cpp_source.html">poly1305.cpp</a>.</p>

</div>
</div>
<a id="ad62eb9211cf1d982f69812790502b6ec"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ad62eb9211cf1d982f69812790502b6ec">&#9670;&nbsp;</a></span>Restart()</h2>

<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class T &gt; </div>
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">void <a class="el" href="class_poly1305___base.html">Poly1305_Base</a>&lt; T &gt;::Restart </td>
          <td>(</td>
          <td class="paramname"></td><td>)</td>
          <td></td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">virtual</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Restart the hash. </p>
<p>Discards the current state, and restart for a new message </p>

<p>Reimplemented from <a class="el" href="class_hash_transformation.html#a92752eebac10497211d7a065faba8725">HashTransformation</a>.</p>

<p class="definition">Definition at line <a class="el" href="poly1305_8cpp_source.html#l00258">258</a> of file <a class="el" href="poly1305_8cpp_source.html">poly1305.cpp</a>.</p>

</div>
</div>
<a id="ac7355133d6eef88697c931c5d46e0016"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ac7355133d6eef88697c931c5d46e0016">&#9670;&nbsp;</a></span>BlockSize()</h2>

<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class T &gt; </div>
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">unsigned int <a class="el" href="class_poly1305___base.html">Poly1305_Base</a>&lt; T &gt;::BlockSize </td>
          <td>(</td>
          <td class="paramname"></td><td>)</td>
          <td> const</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">virtual</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Provides the block size of the compression function. </p>
<dl class="section return"><dt>Returns</dt><dd>the block size of the compression function, in bytes</dd></dl>
<p><a class="el" href="class_poly1305___base.html#ac7355133d6eef88697c931c5d46e0016" title="Provides the block size of the compression function. ">BlockSize()</a> will return 0 if the hash is not block based. For example, <a class="el" href="class_s_h_a3.html" title="SHA3 message digest base class. ">SHA3</a> is a recursive hash (not an iterative hash), and it does not have a block size. </p>

<p>Reimplemented from <a class="el" href="class_hash_transformation.html#a09c66b86bbe3c13ea9e8d74775696d42">HashTransformation</a>.</p>

<p class="definition">Definition at line <a class="el" href="poly1305_8h_source.html#l00080">80</a> of file <a class="el" href="poly1305_8h_source.html">poly1305.h</a>.</p>

</div>
</div>
<a id="a18a6d6100a2283a045e8865a7e2be129"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a18a6d6100a2283a045e8865a7e2be129">&#9670;&nbsp;</a></span>DigestSize()</h2>

<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class T &gt; </div>
<table class="mlabels">
  <tr>
  <td class="mlabels-left">
      <table class="memname">
        <tr>
          <td class="memname">unsigned int <a class="el" href="class_poly1305___base.html">Poly1305_Base</a>&lt; T &gt;::DigestSize </td>
          <td>(</td>
          <td class="paramname"></td><td>)</td>
          <td> const</td>
        </tr>
      </table>
  </td>
  <td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">virtual</span></span>  </td>
  </tr>
</table>
</div><div class="memdoc">

<p>Provides the digest size of the hash. </p>
<dl class="section return"><dt>Returns</dt><dd>the digest size of the hash. </dd></dl>

<p>Implements <a class="el" href="class_hash_transformation.html#a9f42cc280bac76b884ad12615c0dabb5">HashTransformation</a>.</p>

<p class="definition">Definition at line <a class="el" href="poly1305_8h_source.html#l00081">81</a> of file <a class="el" href="poly1305_8h_source.html">poly1305.h</a>.</p>

</div>
</div>
<hr/>The documentation for this class was generated from the following files:<ul>
<li><a class="el" href="poly1305_8h_source.html">poly1305.h</a></li>
<li><a class="el" href="poly1305_8cpp_source.html">poly1305.cpp</a></li>
</ul>
</div><!-- contents -->
<!-- start footer part -->
<hr class="footer"/><address class="footer"><small>
Generated on Sun Sep 16 2018 07:58:50 for Crypto++ by &#160;<a href="http://www.doxygen.org/index.html">
<img class="footer" src="doxygen.png" alt="doxygen"/>
</a> 1.8.14
</small></address>
</body>
</html>