blob: d5aee76621485346062876b46ff2114d5b211f11 [file]
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US">
<head>
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
<meta http-equiv="X-UA-Compatible" content="IE=11"/>
<meta name="generator" content="Doxygen 1.9.8"/>
<meta name="viewport" content="width=device-width, initial-scale=1"/>
<title>iceberg-cpp: iceberg::PendingUpdate 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="search/search.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="search/searchdata.js"></script>
<script type="text/javascript" src="search/search.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 id="projectrow">
<td id="projectalign">
<div id="projectname">iceberg-cpp
</div>
</td>
</tr>
</tbody>
</table>
</div>
<!-- end header part -->
<!-- Generated by Doxygen 1.9.8 -->
<script type="text/javascript">
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */
var searchBox = new SearchBox("searchBox", "search/",'.html');
/* @license-end */
</script>
<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:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */
$(function() {
initMenu('',true,false,'search.php','Search');
$(document).ready(function() { init_search(); });
});
/* @license-end */
</script>
<div id="main-nav"></div>
<!-- window showing the filter options -->
<div id="MSearchSelectWindow"
onmouseover="return searchBox.OnSearchSelectShow()"
onmouseout="return searchBox.OnSearchSelectHide()"
onkeydown="return searchBox.OnSearchSelectKey(event)">
</div>
<!-- iframe showing the search results (closed by default) -->
<div id="MSearchResultsWindow">
<div id="MSearchResults">
<div class="SRPage">
<div id="SRIndex">
<div id="SRResults"></div>
<div class="SRStatus" id="Loading">Loading...</div>
<div class="SRStatus" id="Searching">Searching...</div>
<div class="SRStatus" id="NoMatches">No Matches</div>
</div>
</div>
</div>
</div>
<div id="nav-path" class="navpath">
<ul>
<li class="navelem"><b>iceberg</b></li><li class="navelem"><a class="el" href="classiceberg_1_1PendingUpdate.html">PendingUpdate</a></li> </ul>
</div>
</div><!-- top -->
<div class="header">
<div class="summary">
<a href="#pub-types">Public Types</a> &#124;
<a href="#pub-methods">Public Member Functions</a> &#124;
<a href="#pro-methods">Protected Member Functions</a> &#124;
<a href="#pro-attribs">Protected Attributes</a> &#124;
<a href="classiceberg_1_1PendingUpdate-members.html">List of all members</a> </div>
<div class="headertitle"><div class="title">iceberg::PendingUpdate Class Reference<span class="mlabels"><span class="mlabel">abstract</span></span></div></div>
</div><!--header-->
<div class="contents">
<p>Base class for all kinds of table metadata updates.
<a href="classiceberg_1_1PendingUpdate.html#details">More...</a></p>
<p><code>#include &lt;<a class="el" href="pending__update_8h_source.html">pending_update.h</a>&gt;</code></p>
<div class="dynheader">
Inheritance diagram for iceberg::PendingUpdate:</div>
<div class="dyncontent">
<div class="center">
<img src="classiceberg_1_1PendingUpdate.png" usemap="#iceberg::PendingUpdate_map" alt=""/>
<map id="iceberg::PendingUpdate_map" name="iceberg::PendingUpdate_map">
<area href="classiceberg_1_1ErrorCollector.html" title="Base class for collecting errors in the builder pattern." alt="iceberg::ErrorCollector" shape="rect" coords="0,0,211,24"/>
<area href="classiceberg_1_1ExpireSnapshots.html" title="API for removing old snapshots from a table." alt="iceberg::ExpireSnapshots" shape="rect" coords="221,112,432,136"/>
<area href="classiceberg_1_1SetSnapshot.html" title="Sets the current snapshot directly or by rolling back." alt="iceberg::SetSnapshot" shape="rect" coords="221,168,432,192"/>
<area href="classiceberg_1_1SnapshotUpdate.html" title="Base class for operations that produce snapshots." alt="iceberg::SnapshotUpdate" shape="rect" coords="221,224,432,248"/>
<area href="classiceberg_1_1UpdateLocation.html" title="Updating table location with a new base location." alt="iceberg::UpdateLocation" shape="rect" coords="221,280,432,304"/>
<area href="classiceberg_1_1UpdatePartitionSpec.html" title="API for partition spec evolution." alt="iceberg::UpdatePartitionSpec" shape="rect" coords="221,336,432,360"/>
<area href="classiceberg_1_1UpdatePartitionStatistics.html" title="Updates table partition statistics." alt="iceberg::UpdatePartitionStatistics" shape="rect" coords="221,392,432,416"/>
<area href="classiceberg_1_1UpdateProperties.html" title="Updates table properties." alt="iceberg::UpdateProperties" shape="rect" coords="221,448,432,472"/>
<area href="classiceberg_1_1UpdateSchema.html" title="API for schema evolution." alt="iceberg::UpdateSchema" shape="rect" coords="221,504,432,528"/>
<area href="classiceberg_1_1UpdateSnapshotReference.html" title="Updates snapshot references." alt="iceberg::UpdateSnapshotReference" shape="rect" coords="221,560,432,584"/>
<area href="classiceberg_1_1UpdateSortOrder.html" title="Updating table sort order with a newly created order." alt="iceberg::UpdateSortOrder" shape="rect" coords="221,616,432,640"/>
<area href="classiceberg_1_1UpdateStatistics.html" title="Updates table statistics." alt="iceberg::UpdateStatistics" shape="rect" coords="221,672,432,696"/>
</map>
</div></div>
<table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="pub-types" name="pub-types"></a>
Public Types</h2></td></tr>
<tr class="memitem:a5bac3f32c6a0790ba222399fed5c1944" id="r_a5bac3f32c6a0790ba222399fed5c1944"><td class="memItemLeft" align="right" valign="top"><a id="a5bac3f32c6a0790ba222399fed5c1944" name="a5bac3f32c6a0790ba222399fed5c1944"></a>enum class &#160;</td><td class="memItemRight" valign="bottom"><b>Kind</b> : uint8_t { <br />
&#160;&#160;<b>kExpireSnapshots</b>
, <b>kSetSnapshot</b>
, <b>kUpdateLocation</b>
, <b>kUpdatePartitionSpec</b>
, <br />
&#160;&#160;<b>kUpdatePartitionStatistics</b>
, <b>kUpdateProperties</b>
, <b>kUpdateSchema</b>
, <b>kUpdateSnapshot</b>
, <br />
&#160;&#160;<b>kUpdateSnapshotReference</b>
, <b>kUpdateSortOrder</b>
, <b>kUpdateStatistics</b>
<br />
}</td></tr>
<tr class="separator:a5bac3f32c6a0790ba222399fed5c1944"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="pub-methods" name="pub-methods"></a>
Public Member Functions</h2></td></tr>
<tr class="memitem:a33fba65ffa4a85fd7c5b9984cb892812" id="r_a33fba65ffa4a85fd7c5b9984cb892812"><td class="memItemLeft" align="right" valign="top">virtual Kind&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classiceberg_1_1PendingUpdate.html#a33fba65ffa4a85fd7c5b9984cb892812">kind</a> () const =0</td></tr>
<tr class="memdesc:a33fba65ffa4a85fd7c5b9984cb892812"><td class="mdescLeft">&#160;</td><td class="mdescRight">Return the kind of this pending update. <br /></td></tr>
<tr class="separator:a33fba65ffa4a85fd7c5b9984cb892812"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aa2a0ff4c156fe5852d1d52bf5827db7e" id="r_aa2a0ff4c156fe5852d1d52bf5827db7e"><td class="memItemLeft" align="right" valign="top">virtual bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classiceberg_1_1PendingUpdate.html#aa2a0ff4c156fe5852d1d52bf5827db7e">IsRetryable</a> () const =0</td></tr>
<tr class="memdesc:aa2a0ff4c156fe5852d1d52bf5827db7e"><td class="mdescLeft">&#160;</td><td class="mdescRight">Whether this update can be retried after a commit conflict. <br /></td></tr>
<tr class="separator:aa2a0ff4c156fe5852d1d52bf5827db7e"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a4a5df6d83b7a4a3c4dac19a77945be71" id="r_a4a5df6d83b7a4a3c4dac19a77945be71"><td class="memItemLeft" align="right" valign="top">virtual Status&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classiceberg_1_1PendingUpdate.html#a4a5df6d83b7a4a3c4dac19a77945be71">Commit</a> ()</td></tr>
<tr class="memdesc:a4a5df6d83b7a4a3c4dac19a77945be71"><td class="mdescLeft">&#160;</td><td class="mdescRight">Apply the pending changes and commit. <br /></td></tr>
<tr class="separator:a4a5df6d83b7a4a3c4dac19a77945be71"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a60cfd4550ad0d06af250dd03c26bddb3" id="r_a60cfd4550ad0d06af250dd03c26bddb3"><td class="memItemLeft" align="right" valign="top">virtual Status&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classiceberg_1_1PendingUpdate.html#a60cfd4550ad0d06af250dd03c26bddb3">Finalize</a> (Result&lt; const <a class="el" href="structiceberg_1_1TableMetadata.html">TableMetadata</a> * &gt; commit_result)</td></tr>
<tr class="memdesc:a60cfd4550ad0d06af250dd03c26bddb3"><td class="mdescLeft">&#160;</td><td class="mdescRight">Finalize the pending update. <br /></td></tr>
<tr class="separator:a60cfd4550ad0d06af250dd03c26bddb3"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ac5c3549e22869ad7f6abd417ffcabbe2" id="r_ac5c3549e22869ad7f6abd417ffcabbe2"><td class="memItemLeft" align="right" valign="top"><a id="ac5c3549e22869ad7f6abd417ffcabbe2" name="ac5c3549e22869ad7f6abd417ffcabbe2"></a>
&#160;</td><td class="memItemRight" valign="bottom"><b>PendingUpdate</b> (const <a class="el" href="classiceberg_1_1PendingUpdate.html">PendingUpdate</a> &amp;)=delete</td></tr>
<tr class="separator:ac5c3549e22869ad7f6abd417ffcabbe2"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a3314053bba6a86931feb39c1487e2c8b" id="r_a3314053bba6a86931feb39c1487e2c8b"><td class="memItemLeft" align="right" valign="top"><a id="a3314053bba6a86931feb39c1487e2c8b" name="a3314053bba6a86931feb39c1487e2c8b"></a>
<a class="el" href="classiceberg_1_1PendingUpdate.html">PendingUpdate</a> &amp;&#160;</td><td class="memItemRight" valign="bottom"><b>operator=</b> (const <a class="el" href="classiceberg_1_1PendingUpdate.html">PendingUpdate</a> &amp;)=delete</td></tr>
<tr class="separator:a3314053bba6a86931feb39c1487e2c8b"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a18521611dee09ce7f85477f38d85e75d" id="r_a18521611dee09ce7f85477f38d85e75d"><td class="memItemLeft" align="right" valign="top"><a id="a18521611dee09ce7f85477f38d85e75d" name="a18521611dee09ce7f85477f38d85e75d"></a>
&#160;</td><td class="memItemRight" valign="bottom"><b>PendingUpdate</b> (<a class="el" href="classiceberg_1_1PendingUpdate.html">PendingUpdate</a> &amp;&amp;) noexcept=default</td></tr>
<tr class="separator:a18521611dee09ce7f85477f38d85e75d"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a9e71d56c145591059c7e2f6ee0305295" id="r_a9e71d56c145591059c7e2f6ee0305295"><td class="memItemLeft" align="right" valign="top"><a id="a9e71d56c145591059c7e2f6ee0305295" name="a9e71d56c145591059c7e2f6ee0305295"></a>
<a class="el" href="classiceberg_1_1PendingUpdate.html">PendingUpdate</a> &amp;&#160;</td><td class="memItemRight" valign="bottom"><b>operator=</b> (<a class="el" href="classiceberg_1_1PendingUpdate.html">PendingUpdate</a> &amp;&amp;) noexcept=default</td></tr>
<tr class="separator:a9e71d56c145591059c7e2f6ee0305295"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="inherit_header pub_methods_classiceberg_1_1ErrorCollector"><td colspan="2" onclick="javascript:toggleInherit('pub_methods_classiceberg_1_1ErrorCollector')"><img src="closed.png" alt="-"/>&#160;Public Member Functions inherited from <a class="el" href="classiceberg_1_1ErrorCollector.html">iceberg::ErrorCollector</a></td></tr>
<tr class="memitem:a827c296a8527f87f76d7f9321e7ee68f inherit pub_methods_classiceberg_1_1ErrorCollector" id="r_a827c296a8527f87f76d7f9321e7ee68f"><td class="memItemLeft" align="right" valign="top">
&#160;</td><td class="memItemRight" valign="bottom"><b>ErrorCollector</b> (<a class="el" href="classiceberg_1_1ErrorCollector.html">ErrorCollector</a> &amp;&amp;)=default</td></tr>
<tr class="separator:a827c296a8527f87f76d7f9321e7ee68f inherit pub_methods_classiceberg_1_1ErrorCollector"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a22311658715152d8e6e27834240ce446 inherit pub_methods_classiceberg_1_1ErrorCollector" id="r_a22311658715152d8e6e27834240ce446"><td class="memItemLeft" align="right" valign="top">
<a class="el" href="classiceberg_1_1ErrorCollector.html">ErrorCollector</a> &amp;&#160;</td><td class="memItemRight" valign="bottom"><b>operator=</b> (<a class="el" href="classiceberg_1_1ErrorCollector.html">ErrorCollector</a> &amp;&amp;)=default</td></tr>
<tr class="separator:a22311658715152d8e6e27834240ce446 inherit pub_methods_classiceberg_1_1ErrorCollector"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ab3fa546cd2748fe418db9c0933542755 inherit pub_methods_classiceberg_1_1ErrorCollector" id="r_ab3fa546cd2748fe418db9c0933542755"><td class="memItemLeft" align="right" valign="top">
&#160;</td><td class="memItemRight" valign="bottom"><b>ErrorCollector</b> (const <a class="el" href="classiceberg_1_1ErrorCollector.html">ErrorCollector</a> &amp;)=default</td></tr>
<tr class="separator:ab3fa546cd2748fe418db9c0933542755 inherit pub_methods_classiceberg_1_1ErrorCollector"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aaba366560be481bfa9538735f3a38e3e inherit pub_methods_classiceberg_1_1ErrorCollector" id="r_aaba366560be481bfa9538735f3a38e3e"><td class="memItemLeft" align="right" valign="top">
<a class="el" href="classiceberg_1_1ErrorCollector.html">ErrorCollector</a> &amp;&#160;</td><td class="memItemRight" valign="bottom"><b>operator=</b> (const <a class="el" href="classiceberg_1_1ErrorCollector.html">ErrorCollector</a> &amp;)=default</td></tr>
<tr class="separator:aaba366560be481bfa9538735f3a38e3e inherit pub_methods_classiceberg_1_1ErrorCollector"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a3a20345150b136c918ffe8947a7d75e1 inherit pub_methods_classiceberg_1_1ErrorCollector" id="r_a3a20345150b136c918ffe8947a7d75e1"><td class="memTemplParams" colspan="2">template&lt;typename... Args&gt; </td></tr>
<tr class="memitem:a3a20345150b136c918ffe8947a7d75e1 inherit pub_methods_classiceberg_1_1ErrorCollector"><td class="memTemplItemLeft" align="right" valign="top">auto &amp;&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="classiceberg_1_1ErrorCollector.html#a3a20345150b136c918ffe8947a7d75e1">AddError</a> (this auto &amp;self, ErrorKind kind, const std::format_string&lt; Args... &gt; fmt, Args &amp;&amp;... args)</td></tr>
<tr class="memdesc:a3a20345150b136c918ffe8947a7d75e1 inherit pub_methods_classiceberg_1_1ErrorCollector"><td class="mdescLeft">&#160;</td><td class="mdescRight">Add a specific error and return reference to derived class. <br /></td></tr>
<tr class="separator:a3a20345150b136c918ffe8947a7d75e1 inherit pub_methods_classiceberg_1_1ErrorCollector"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a5e555954de121d0908dcf4648da446e3 inherit pub_methods_classiceberg_1_1ErrorCollector" id="r_a5e555954de121d0908dcf4648da446e3"><td class="memItemLeft" align="right" valign="top">auto &amp;&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classiceberg_1_1ErrorCollector.html#a5e555954de121d0908dcf4648da446e3">AddError</a> (this auto &amp;self, <a class="el" href="structiceberg_1_1Error.html">Error</a> err)</td></tr>
<tr class="memdesc:a5e555954de121d0908dcf4648da446e3 inherit pub_methods_classiceberg_1_1ErrorCollector"><td class="mdescLeft">&#160;</td><td class="mdescRight">Add an existing error object and return reference to derived class. <br /></td></tr>
<tr class="separator:a5e555954de121d0908dcf4648da446e3 inherit pub_methods_classiceberg_1_1ErrorCollector"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a5749264a2234092a5246056a1c72ee51 inherit pub_methods_classiceberg_1_1ErrorCollector" id="r_a5749264a2234092a5246056a1c72ee51"><td class="memItemLeft" align="right" valign="top">auto &amp;&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classiceberg_1_1ErrorCollector.html#a5749264a2234092a5246056a1c72ee51">AddError</a> (this auto &amp;self, std::unexpected&lt; <a class="el" href="structiceberg_1_1Error.html">Error</a> &gt; err)</td></tr>
<tr class="memdesc:a5749264a2234092a5246056a1c72ee51 inherit pub_methods_classiceberg_1_1ErrorCollector"><td class="mdescLeft">&#160;</td><td class="mdescRight">Add an unexpected result's error and return reference to derived class. <br /></td></tr>
<tr class="separator:a5749264a2234092a5246056a1c72ee51 inherit pub_methods_classiceberg_1_1ErrorCollector"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a8813b3fe2a3cc112e6db19c87b8422ae inherit pub_methods_classiceberg_1_1ErrorCollector" id="r_a8813b3fe2a3cc112e6db19c87b8422ae"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classiceberg_1_1ErrorCollector.html#a8813b3fe2a3cc112e6db19c87b8422ae">has_errors</a> () const</td></tr>
<tr class="memdesc:a8813b3fe2a3cc112e6db19c87b8422ae inherit pub_methods_classiceberg_1_1ErrorCollector"><td class="mdescLeft">&#160;</td><td class="mdescRight">Check if any errors have been collected. <br /></td></tr>
<tr class="separator:a8813b3fe2a3cc112e6db19c87b8422ae inherit pub_methods_classiceberg_1_1ErrorCollector"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:afae10739a78bbffc2609a63e52821195 inherit pub_methods_classiceberg_1_1ErrorCollector" id="r_afae10739a78bbffc2609a63e52821195"><td class="memItemLeft" align="right" valign="top">size_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classiceberg_1_1ErrorCollector.html#afae10739a78bbffc2609a63e52821195">error_count</a> () const</td></tr>
<tr class="memdesc:afae10739a78bbffc2609a63e52821195 inherit pub_methods_classiceberg_1_1ErrorCollector"><td class="mdescLeft">&#160;</td><td class="mdescRight">Get the number of errors collected. <br /></td></tr>
<tr class="separator:afae10739a78bbffc2609a63e52821195 inherit pub_methods_classiceberg_1_1ErrorCollector"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a16cbe7b6d423a372c9e68d970ff2c3ea inherit pub_methods_classiceberg_1_1ErrorCollector" id="r_a16cbe7b6d423a372c9e68d970ff2c3ea"><td class="memItemLeft" align="right" valign="top">Status&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classiceberg_1_1ErrorCollector.html#a16cbe7b6d423a372c9e68d970ff2c3ea">CheckErrors</a> () const</td></tr>
<tr class="memdesc:a16cbe7b6d423a372c9e68d970ff2c3ea inherit pub_methods_classiceberg_1_1ErrorCollector"><td class="mdescLeft">&#160;</td><td class="mdescRight">Check for accumulated errors and return them if any exist. <br /></td></tr>
<tr class="separator:a16cbe7b6d423a372c9e68d970ff2c3ea inherit pub_methods_classiceberg_1_1ErrorCollector"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a274df2b90b0c22156a4c339aa30a4401 inherit pub_methods_classiceberg_1_1ErrorCollector" id="r_a274df2b90b0c22156a4c339aa30a4401"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classiceberg_1_1ErrorCollector.html#a274df2b90b0c22156a4c339aa30a4401">ClearErrors</a> ()</td></tr>
<tr class="memdesc:a274df2b90b0c22156a4c339aa30a4401 inherit pub_methods_classiceberg_1_1ErrorCollector"><td class="mdescLeft">&#160;</td><td class="mdescRight">Clear all accumulated errors. <br /></td></tr>
<tr class="separator:a274df2b90b0c22156a4c339aa30a4401 inherit pub_methods_classiceberg_1_1ErrorCollector"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a101fb70f2ad50a6023de932dc2eca96c inherit pub_methods_classiceberg_1_1ErrorCollector" id="r_a101fb70f2ad50a6023de932dc2eca96c"><td class="memItemLeft" align="right" valign="top">
const std::vector&lt; <a class="el" href="structiceberg_1_1Error.html">Error</a> &gt; &amp;&#160;</td><td class="memItemRight" valign="bottom"><b>errors</b> () const</td></tr>
<tr class="memdesc:a101fb70f2ad50a6023de932dc2eca96c inherit pub_methods_classiceberg_1_1ErrorCollector"><td class="mdescLeft">&#160;</td><td class="mdescRight">Get read-only access to all collected errors. <br /></td></tr>
<tr class="separator:a101fb70f2ad50a6023de932dc2eca96c inherit pub_methods_classiceberg_1_1ErrorCollector"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="pro-methods" name="pro-methods"></a>
Protected Member Functions</h2></td></tr>
<tr class="memitem:a1bc9b1eb7bfa1c832c65331b2e6bba6f" id="r_a1bc9b1eb7bfa1c832c65331b2e6bba6f"><td class="memItemLeft" align="right" valign="top"><a id="a1bc9b1eb7bfa1c832c65331b2e6bba6f" name="a1bc9b1eb7bfa1c832c65331b2e6bba6f"></a>
&#160;</td><td class="memItemRight" valign="bottom"><b>PendingUpdate</b> (std::shared_ptr&lt; <a class="el" href="classiceberg_1_1TransactionContext.html">TransactionContext</a> &gt; ctx)</td></tr>
<tr class="separator:a1bc9b1eb7bfa1c832c65331b2e6bba6f"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a93721051561748b1a29e75b7d4cbbd86" id="r_a93721051561748b1a29e75b7d4cbbd86"><td class="memItemLeft" align="right" valign="top"><a id="a93721051561748b1a29e75b7d4cbbd86" name="a93721051561748b1a29e75b7d4cbbd86"></a>
const <a class="el" href="structiceberg_1_1TableMetadata.html">TableMetadata</a> &amp;&#160;</td><td class="memItemRight" valign="bottom"><b>base</b> () const</td></tr>
<tr class="separator:a93721051561748b1a29e75b7d4cbbd86"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="pro-attribs" name="pro-attribs"></a>
Protected Attributes</h2></td></tr>
<tr class="memitem:a48306a581b00f16c85af172a41b7dcee" id="r_a48306a581b00f16c85af172a41b7dcee"><td class="memItemLeft" align="right" valign="top"><a id="a48306a581b00f16c85af172a41b7dcee" name="a48306a581b00f16c85af172a41b7dcee"></a>
std::shared_ptr&lt; <a class="el" href="classiceberg_1_1TransactionContext.html">TransactionContext</a> &gt;&#160;</td><td class="memItemRight" valign="bottom"><b>ctx_</b></td></tr>
<tr class="separator:a48306a581b00f16c85af172a41b7dcee"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="inherit_header pro_attribs_classiceberg_1_1ErrorCollector"><td colspan="2" onclick="javascript:toggleInherit('pro_attribs_classiceberg_1_1ErrorCollector')"><img src="closed.png" alt="-"/>&#160;Protected Attributes inherited from <a class="el" href="classiceberg_1_1ErrorCollector.html">iceberg::ErrorCollector</a></td></tr>
<tr class="memitem:a354d1e7287bb45926a4b563f80d0c623 inherit pro_attribs_classiceberg_1_1ErrorCollector" id="r_a354d1e7287bb45926a4b563f80d0c623"><td class="memItemLeft" align="right" valign="top">
std::vector&lt; <a class="el" href="structiceberg_1_1Error.html">Error</a> &gt;&#160;</td><td class="memItemRight" valign="bottom"><b>errors_</b></td></tr>
<tr class="separator:a354d1e7287bb45926a4b563f80d0c623 inherit pro_attribs_classiceberg_1_1ErrorCollector"><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>Base class for all kinds of table metadata updates. </p>
<p>Any created <code><a class="el" href="classiceberg_1_1PendingUpdate.html" title="Base class for all kinds of table metadata updates.">PendingUpdate</a></code> instance is tracked by the <code><a class="el" href="classiceberg_1_1Transaction.html" title="A transaction for performing multiple updates to a table.">Transaction</a></code> instance and commit is also delegated to the <code><a class="el" href="classiceberg_1_1Transaction.html" title="A transaction for performing multiple updates to a table.">Transaction</a></code> instance.</p>
<dl class="section note"><dt>Note</dt><dd>Implementations are expected to use builder pattern and errors should be handled by the <a class="el" href="classiceberg_1_1ErrorCollector.html" title="Base class for collecting errors in the builder pattern.">ErrorCollector</a> base class. </dd></dl>
</div><h2 class="groupheader">Member Function Documentation</h2>
<a id="a4a5df6d83b7a4a3c4dac19a77945be71" name="a4a5df6d83b7a4a3c4dac19a77945be71"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a4a5df6d83b7a4a3c4dac19a77945be71">&#9670;&#160;</a></span>Commit()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">Status iceberg::PendingUpdate::Commit </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>Apply the pending changes and commit. </p>
<dl class="section return"><dt>Returns</dt><dd>An OK status if the commit was successful, or an error:<ul>
<li>ValidationFailed: if it cannot be applied to the current table metadata.</li>
<li>CommitFailed: if it cannot be committed due to conflicts.</li>
<li>CommitStateUnknown: unknown status, no cleanup should be done. </li>
</ul>
</dd></dl>
</div>
</div>
<a id="a60cfd4550ad0d06af250dd03c26bddb3" name="a60cfd4550ad0d06af250dd03c26bddb3"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a60cfd4550ad0d06af250dd03c26bddb3">&#9670;&#160;</a></span>Finalize()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">Status iceberg::PendingUpdate::Finalize </td>
<td>(</td>
<td class="paramtype">Result&lt; const <a class="el" href="structiceberg_1_1TableMetadata.html">TableMetadata</a> * &gt;&#160;</td>
<td class="paramname"><em>commit_result</em></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>Finalize the pending update. </p>
<p>This method is called after the update is committed. Implementations should override this method to clean up any resources.</p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramname">commit_result</td><td>The committed table metadata when the commit succeeds, or the commit error when it fails. </td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>Status indicating success or failure </dd></dl>
<p>Reimplemented in <a class="el" href="classiceberg_1_1ExpireSnapshots.html#a364947643027e15ce866184cba1afdb6">iceberg::ExpireSnapshots</a>, and <a class="el" href="classiceberg_1_1SnapshotUpdate.html#ad942dda206e9c6454493a63eb48df0e0">iceberg::SnapshotUpdate</a>.</p>
</div>
</div>
<a id="aa2a0ff4c156fe5852d1d52bf5827db7e" name="aa2a0ff4c156fe5852d1d52bf5827db7e"></a>
<h2 class="memtitle"><span class="permalink"><a href="#aa2a0ff4c156fe5852d1d52bf5827db7e">&#9670;&#160;</a></span>IsRetryable()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">virtual bool iceberg::PendingUpdate::IsRetryable </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">pure virtual</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Whether this update can be retried after a commit conflict. </p>
<p>Implemented in <a class="el" href="classiceberg_1_1ExpireSnapshots.html#a8d677add7f52334b97770d67b144b52c">iceberg::ExpireSnapshots</a>, <a class="el" href="classiceberg_1_1SetSnapshot.html#af5f018a0c0b7693c4a66346576e5cc83">iceberg::SetSnapshot</a>, <a class="el" href="classiceberg_1_1SnapshotUpdate.html#a97b2753654e1304914509f29dcf0a7ff">iceberg::SnapshotUpdate</a>, <a class="el" href="classiceberg_1_1UpdateLocation.html#a910a0c066d90a1afdd02ff7c2df09049">iceberg::UpdateLocation</a>, <a class="el" href="classiceberg_1_1UpdatePartitionSpec.html#a3acf18c5554a5ad2896438c67c21e640">iceberg::UpdatePartitionSpec</a>, <a class="el" href="classiceberg_1_1UpdatePartitionStatistics.html#a2fb34d7d713d8435e37aa180a92f6e79">iceberg::UpdatePartitionStatistics</a>, <a class="el" href="classiceberg_1_1UpdateProperties.html#a68ef80ef9bf9b05e5610dfa900c416a3">iceberg::UpdateProperties</a>, <a class="el" href="classiceberg_1_1UpdateSchema.html#aa4758f53a5c789d70a32d62dae40addb">iceberg::UpdateSchema</a>, <a class="el" href="classiceberg_1_1UpdateSnapshotReference.html#a93ec2b5eb604f1cb33c9b3fc09a60345">iceberg::UpdateSnapshotReference</a>, <a class="el" href="classiceberg_1_1UpdateSortOrder.html#ae6de4e251d7ffa6b3f1c5435bd11aae7">iceberg::UpdateSortOrder</a>, and <a class="el" href="classiceberg_1_1UpdateStatistics.html#aa59f74741a668abb29aa1f801421edd6">iceberg::UpdateStatistics</a>.</p>
</div>
</div>
<a id="a33fba65ffa4a85fd7c5b9984cb892812" name="a33fba65ffa4a85fd7c5b9984cb892812"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a33fba65ffa4a85fd7c5b9984cb892812">&#9670;&#160;</a></span>kind()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">virtual Kind iceberg::PendingUpdate::kind </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">pure virtual</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Return the kind of this pending update. </p>
<p>Implemented in <a class="el" href="classiceberg_1_1ExpireSnapshots.html#ad2d859da01c54f38b741f3e97aef9b70">iceberg::ExpireSnapshots</a>, <a class="el" href="classiceberg_1_1SetSnapshot.html#ad453605d3b56053d37f5a227c8385585">iceberg::SetSnapshot</a>, <a class="el" href="classiceberg_1_1UpdateLocation.html#aaf4a907185bf48cce7d84cd57147e9da">iceberg::UpdateLocation</a>, <a class="el" href="classiceberg_1_1UpdatePartitionSpec.html#a6f438d6aaa000f06347b0ae44e29e23c">iceberg::UpdatePartitionSpec</a>, <a class="el" href="classiceberg_1_1UpdatePartitionStatistics.html#acb3c652016e0016b2d1ec98eda7b2533">iceberg::UpdatePartitionStatistics</a>, <a class="el" href="classiceberg_1_1UpdateProperties.html#ad4a7eac6a75b0a950c41bb18eda1eab5">iceberg::UpdateProperties</a>, <a class="el" href="classiceberg_1_1UpdateSchema.html#a6e69f3190d5c89c1c76ca357f39c7af5">iceberg::UpdateSchema</a>, <a class="el" href="classiceberg_1_1UpdateSnapshotReference.html#a607504fa70250fcbacd8abf5c009dec6">iceberg::UpdateSnapshotReference</a>, <a class="el" href="classiceberg_1_1UpdateSortOrder.html#a0eebd552bb09815015f758f69e4975e1">iceberg::UpdateSortOrder</a>, <a class="el" href="classiceberg_1_1UpdateStatistics.html#a7bdf59fd1eb3866a5f6840f6c36d4d1a">iceberg::UpdateStatistics</a>, and <a class="el" href="classiceberg_1_1SnapshotUpdate.html#ae194773e0ce37df3780121314322f440">iceberg::SnapshotUpdate</a>.</p>
</div>
</div>
<hr/>The documentation for this class was generated from the following files:<ul>
<li>iceberg/update/<a class="el" href="pending__update_8h_source.html">pending_update.h</a></li>
<li>iceberg/update/<b>pending_update.cc</b></li>
</ul>
</div><!-- contents -->
<!-- start footer part -->
<hr class="footer"/><address class="footer"><small>
Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.9.8
</small></address>
</body>
</html>