<!DOCTYPE HTML>
<!-- NewPage -->
<html lang="en">
<head>
<!-- Generated by javadoc -->
<title>ManageSnapshots</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<link rel="stylesheet" type="text/css" href="../../../stylesheet.css" title="Style">
<link rel="stylesheet" type="text/css" href="../../../jquery/jquery-ui.css" title="Style">
<script type="text/javascript" src="../../../script.js"></script>
<script type="text/javascript" src="../../../jquery/jszip/dist/jszip.min.js"></script>
<script type="text/javascript" src="../../../jquery/jszip-utils/dist/jszip-utils.min.js"></script>
<!--[if IE]>
<script type="text/javascript" src="../../../jquery/jszip-utils/dist/jszip-utils-ie.min.js"></script>
<![endif]-->
<script type="text/javascript" src="../../../jquery/jquery-3.5.1.js"></script>
<script type="text/javascript" src="../../../jquery/jquery-ui.js"></script>
</head>
<body>
<script type="text/javascript"><!--
    try {
        if (location.href.indexOf('is-external=true') == -1) {
            parent.document.title="ManageSnapshots";
        }
    }
    catch(err) {
    }
//-->
var data = {"i0":6,"i1":18,"i2":6,"i3":6,"i4":6,"i5":6,"i6":6,"i7":6,"i8":6,"i9":6,"i10":6,"i11":6,"i12":6,"i13":6,"i14":6,"i15":6,"i16":6};
var tabs = {65535:["t0","All Methods"],2:["t2","Instance Methods"],4:["t3","Abstract Methods"],16:["t5","Default Methods"]};
var altColor = "altColor";
var rowColor = "rowColor";
var tableTab = "tableTab";
var activeTableTab = "activeTableTab";
var pathtoroot = "../../../";
var useModuleDirectories = true;
loadScripts(document, 'script');</script>
<noscript>
<div>JavaScript is disabled on your browser.</div>
</noscript>
<header role="banner">
<nav role="navigation">
<div class="fixedNav">
<!-- ========= START OF TOP NAVBAR ======= -->
<div class="topNav"><a id="navbar.top">
<!--   -->
</a>
<div class="skipNav"><a href="#skip.navbar.top" title="Skip navigation links">Skip navigation links</a></div>
<a id="navbar.top.firstrow">
<!--   -->
</a>
<ul class="navList" title="Navigation">
<li><a href="../../../index.html">Overview</a></li>
<li><a href="package-summary.html">Package</a></li>
<li class="navBarCell1Rev">Class</li>
<li><a href="package-tree.html">Tree</a></li>
<li><a href="../../../deprecated-list.html">Deprecated</a></li>
<li><a href="../../../index-all.html">Index</a></li>
<li><a href="../../../help-doc.html">Help</a></li>
</ul>
</div>
<div class="subNav">
<ul class="navList" id="allclasses_navbar_top">
<li><a href="../../../allclasses.html">All&nbsp;Classes</a></li>
</ul>
<ul class="navListSearch">
<li><label for="search">SEARCH:</label>
<input type="text" id="search" value="search" disabled="disabled">
<input type="reset" id="reset" value="reset" disabled="disabled">
</li>
</ul>
<div>
<script type="text/javascript"><!--
  allClassesLink = document.getElementById("allclasses_navbar_top");
  if(window==top) {
    allClassesLink.style.display = "block";
  }
  else {
    allClassesLink.style.display = "none";
  }
  //-->
</script>
<noscript>
<div>JavaScript is disabled on your browser.</div>
</noscript>
</div>
<div>
<ul class="subNavList">
<li>Summary:&nbsp;</li>
<li>Nested&nbsp;|&nbsp;</li>
<li>Field&nbsp;|&nbsp;</li>
<li>Constr&nbsp;|&nbsp;</li>
<li><a href="#method.summary">Method</a></li>
</ul>
<ul class="subNavList">
<li>Detail:&nbsp;</li>
<li>Field&nbsp;|&nbsp;</li>
<li>Constr&nbsp;|&nbsp;</li>
<li><a href="#method.detail">Method</a></li>
</ul>
</div>
<a id="skip.navbar.top">
<!--   -->
</a></div>
<!-- ========= END OF TOP NAVBAR ========= -->
</div>
<div class="navPadding">&nbsp;</div>
<script type="text/javascript"><!--
$('.navPadding').css('padding-top', $('.fixedNav').css("height"));
//-->
</script>
</nav>
</header>
<!-- ======== START OF CLASS DATA ======== -->
<main role="main">
<div class="header">
<div class="subTitle"><span class="packageLabelInType">Package</span>&nbsp;<a href="package-summary.html">org.apache.iceberg</a></div>
<h2 title="Interface ManageSnapshots" class="title">Interface ManageSnapshots</h2>
</div>
<div class="contentContainer">
<div class="description">
<ul class="blockList">
<li class="blockList">
<dl>
<dt>All Superinterfaces:</dt>
<dd><code><a href="PendingUpdate.html" title="interface in org.apache.iceberg">PendingUpdate</a>&lt;<a href="Snapshot.html" title="interface in org.apache.iceberg">Snapshot</a>&gt;</code></dd>
</dl>
<dl>
<dt>All Known Implementing Classes:</dt>
<dd><code><a href="SnapshotManager.html" title="class in org.apache.iceberg">SnapshotManager</a></code></dd>
</dl>
<hr>
<pre>public interface <span class="typeNameLabel">ManageSnapshots</span>
extends <a href="PendingUpdate.html" title="interface in org.apache.iceberg">PendingUpdate</a>&lt;<a href="Snapshot.html" title="interface in org.apache.iceberg">Snapshot</a>&gt;</pre>
<div class="block">API for managing snapshots. Allows rolling table data back to a stated at an older table <a href="Snapshot.html" title="interface in org.apache.iceberg"><code>snapshot</code></a>. Rollback:

 <p>This API does not allow conflicting calls to <a href="#setCurrentSnapshot(long)"><code>setCurrentSnapshot(long)</code></a> and <a href="#rollbackToTime(long)"><code>rollbackToTime(long)</code></a>.

 <p>When committing, these changes will be applied to the current table metadata. Commit conflicts
 will not be resolved and will result in a <a href="exceptions/CommitFailedException.html" title="class in org.apache.iceberg.exceptions"><code>CommitFailedException</code></a>. Cherrypick:

 <p>In an audit workflow, new data is written to an orphan <a href="Snapshot.html" title="interface in org.apache.iceberg"><code>snapshot</code></a> that is not
 committed as the table's current state until it is audited. After auditing a change, it may need
 to be applied or cherry-picked on top of the latest snapshot instead of the one that was current
 when the audited changes were created. This class adds support for cherry-picking the changes
 from an orphan snapshot by applying them to the current snapshot. The output of the operation is
 a new snapshot with the changes from cherry-picked snapshot.

 <p></div>
</li>
</ul>
</div>
<div class="summary">
<ul class="blockList">
<li class="blockList">
<!-- ========== METHOD SUMMARY =========== -->
<section role="region">
<ul class="blockList">
<li class="blockList"><a id="method.summary">
<!--   -->
</a>
<h3>Method Summary</h3>
<table class="memberSummary">
<caption><span id="t0" class="activeTableTab"><span>All Methods</span><span class="tabEnd">&nbsp;</span></span><span id="t2" class="tableTab"><span><a href="javascript:show(2);">Instance Methods</a></span><span class="tabEnd">&nbsp;</span></span><span id="t3" class="tableTab"><span><a href="javascript:show(4);">Abstract Methods</a></span><span class="tabEnd">&nbsp;</span></span><span id="t5" class="tableTab"><span><a href="javascript:show(16);">Default Methods</a></span><span class="tabEnd">&nbsp;</span></span></caption>
<tr>
<th class="colFirst" scope="col">Modifier and Type</th>
<th class="colSecond" scope="col">Method</th>
<th class="colLast" scope="col">Description</th>
</tr>
<tr id="i0" class="altColor">
<td class="colFirst"><code><a href="ManageSnapshots.html" title="interface in org.apache.iceberg">ManageSnapshots</a></code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="#cherrypick(long)">cherrypick</a></span>&#8203;(long&nbsp;snapshotId)</code></th>
<td class="colLast">
<div class="block">Apply supported changes in given snapshot and create a new snapshot which will be set as the
 current snapshot on commit.</div>
</td>
</tr>
<tr id="i1" class="rowColor">
<td class="colFirst"><code>default <a href="ManageSnapshots.html" title="interface in org.apache.iceberg">ManageSnapshots</a></code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="#createBranch(java.lang.String)">createBranch</a></span>&#8203;(java.lang.String&nbsp;name)</code></th>
<td class="colLast">
<div class="block">Create a new branch.</div>
</td>
</tr>
<tr id="i2" class="altColor">
<td class="colFirst"><code><a href="ManageSnapshots.html" title="interface in org.apache.iceberg">ManageSnapshots</a></code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="#createBranch(java.lang.String,long)">createBranch</a></span>&#8203;(java.lang.String&nbsp;name,
            long&nbsp;snapshotId)</code></th>
<td class="colLast">
<div class="block">Create a new branch pointing to the given snapshot id.</div>
</td>
</tr>
<tr id="i3" class="rowColor">
<td class="colFirst"><code><a href="ManageSnapshots.html" title="interface in org.apache.iceberg">ManageSnapshots</a></code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="#createTag(java.lang.String,long)">createTag</a></span>&#8203;(java.lang.String&nbsp;name,
         long&nbsp;snapshotId)</code></th>
<td class="colLast">
<div class="block">Create a new tag pointing to the given snapshot id</div>
</td>
</tr>
<tr id="i4" class="altColor">
<td class="colFirst"><code><a href="ManageSnapshots.html" title="interface in org.apache.iceberg">ManageSnapshots</a></code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="#fastForwardBranch(java.lang.String,java.lang.String)">fastForwardBranch</a></span>&#8203;(java.lang.String&nbsp;name,
                 java.lang.String&nbsp;source)</code></th>
<td class="colLast">
<div class="block">Performs a fast-forward of the given target branch up to the source snapshot if target is an
 ancestor of source.</div>
</td>
</tr>
<tr id="i5" class="rowColor">
<td class="colFirst"><code><a href="ManageSnapshots.html" title="interface in org.apache.iceberg">ManageSnapshots</a></code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="#removeBranch(java.lang.String)">removeBranch</a></span>&#8203;(java.lang.String&nbsp;name)</code></th>
<td class="colLast">
<div class="block">Remove a branch by name</div>
</td>
</tr>
<tr id="i6" class="altColor">
<td class="colFirst"><code><a href="ManageSnapshots.html" title="interface in org.apache.iceberg">ManageSnapshots</a></code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="#removeTag(java.lang.String)">removeTag</a></span>&#8203;(java.lang.String&nbsp;name)</code></th>
<td class="colLast">
<div class="block">Remove the tag with the given name.</div>
</td>
</tr>
<tr id="i7" class="rowColor">
<td class="colFirst"><code><a href="ManageSnapshots.html" title="interface in org.apache.iceberg">ManageSnapshots</a></code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="#renameBranch(java.lang.String,java.lang.String)">renameBranch</a></span>&#8203;(java.lang.String&nbsp;name,
            java.lang.String&nbsp;newName)</code></th>
<td class="colLast">
<div class="block">Rename a branch</div>
</td>
</tr>
<tr id="i8" class="altColor">
<td class="colFirst"><code><a href="ManageSnapshots.html" title="interface in org.apache.iceberg">ManageSnapshots</a></code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="#replaceBranch(java.lang.String,long)">replaceBranch</a></span>&#8203;(java.lang.String&nbsp;name,
             long&nbsp;snapshotId)</code></th>
<td class="colLast">
<div class="block">Replaces the branch with the given name to point to the specified snapshot</div>
</td>
</tr>
<tr id="i9" class="rowColor">
<td class="colFirst"><code><a href="ManageSnapshots.html" title="interface in org.apache.iceberg">ManageSnapshots</a></code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="#replaceBranch(java.lang.String,java.lang.String)">replaceBranch</a></span>&#8203;(java.lang.String&nbsp;name,
             java.lang.String&nbsp;source)</code></th>
<td class="colLast">
<div class="block">Replaces the branch with the given name to point to the source snapshot.</div>
</td>
</tr>
<tr id="i10" class="altColor">
<td class="colFirst"><code><a href="ManageSnapshots.html" title="interface in org.apache.iceberg">ManageSnapshots</a></code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="#replaceTag(java.lang.String,long)">replaceTag</a></span>&#8203;(java.lang.String&nbsp;name,
          long&nbsp;snapshotId)</code></th>
<td class="colLast">
<div class="block">Replaces the tag with the given name to point to the specified snapshot.</div>
</td>
</tr>
<tr id="i11" class="rowColor">
<td class="colFirst"><code><a href="ManageSnapshots.html" title="interface in org.apache.iceberg">ManageSnapshots</a></code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="#rollbackTo(long)">rollbackTo</a></span>&#8203;(long&nbsp;snapshotId)</code></th>
<td class="colLast">
<div class="block">Rollback table's state to a specific <a href="Snapshot.html" title="interface in org.apache.iceberg"><code>Snapshot</code></a> identified by id.</div>
</td>
</tr>
<tr id="i12" class="altColor">
<td class="colFirst"><code><a href="ManageSnapshots.html" title="interface in org.apache.iceberg">ManageSnapshots</a></code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="#rollbackToTime(long)">rollbackToTime</a></span>&#8203;(long&nbsp;timestampMillis)</code></th>
<td class="colLast">
<div class="block">Roll this table's data back to the last <a href="Snapshot.html" title="interface in org.apache.iceberg"><code>Snapshot</code></a> before the given timestamp.</div>
</td>
</tr>
<tr id="i13" class="rowColor">
<td class="colFirst"><code><a href="ManageSnapshots.html" title="interface in org.apache.iceberg">ManageSnapshots</a></code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="#setCurrentSnapshot(long)">setCurrentSnapshot</a></span>&#8203;(long&nbsp;snapshotId)</code></th>
<td class="colLast">
<div class="block">Roll this table's data back to a specific <a href="Snapshot.html" title="interface in org.apache.iceberg"><code>Snapshot</code></a> identified by id.</div>
</td>
</tr>
<tr id="i14" class="altColor">
<td class="colFirst"><code><a href="ManageSnapshots.html" title="interface in org.apache.iceberg">ManageSnapshots</a></code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="#setMaxRefAgeMs(java.lang.String,long)">setMaxRefAgeMs</a></span>&#8203;(java.lang.String&nbsp;name,
              long&nbsp;maxRefAgeMs)</code></th>
<td class="colLast">
<div class="block">Updates the retention policy for a reference.</div>
</td>
</tr>
<tr id="i15" class="rowColor">
<td class="colFirst"><code><a href="ManageSnapshots.html" title="interface in org.apache.iceberg">ManageSnapshots</a></code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="#setMaxSnapshotAgeMs(java.lang.String,long)">setMaxSnapshotAgeMs</a></span>&#8203;(java.lang.String&nbsp;branchName,
                   long&nbsp;maxSnapshotAgeMs)</code></th>
<td class="colLast">
<div class="block">Updates the max snapshot age for a branch.</div>
</td>
</tr>
<tr id="i16" class="altColor">
<td class="colFirst"><code><a href="ManageSnapshots.html" title="interface in org.apache.iceberg">ManageSnapshots</a></code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="#setMinSnapshotsToKeep(java.lang.String,int)">setMinSnapshotsToKeep</a></span>&#8203;(java.lang.String&nbsp;branchName,
                     int&nbsp;minSnapshotsToKeep)</code></th>
<td class="colLast">
<div class="block">Updates the minimum number of snapshots to keep for a branch.</div>
</td>
</tr>
</table>
<ul class="blockList">
<li class="blockList"><a id="methods.inherited.from.class.org.apache.iceberg.PendingUpdate">
<!--   -->
</a>
<h3>Methods inherited from interface&nbsp;org.apache.iceberg.<a href="PendingUpdate.html" title="interface in org.apache.iceberg">PendingUpdate</a></h3>
<code><a href="PendingUpdate.html#apply()">apply</a>, <a href="PendingUpdate.html#commit()">commit</a>, <a href="PendingUpdate.html#updateEvent()">updateEvent</a></code></li>
</ul>
</li>
</ul>
</section>
</li>
</ul>
</div>
<div class="details">
<ul class="blockList">
<li class="blockList">
<!-- ============ METHOD DETAIL ========== -->
<section role="region">
<ul class="blockList">
<li class="blockList"><a id="method.detail">
<!--   -->
</a>
<h3>Method Detail</h3>
<a id="setCurrentSnapshot(long)">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>setCurrentSnapshot</h4>
<pre class="methodSignature"><a href="ManageSnapshots.html" title="interface in org.apache.iceberg">ManageSnapshots</a>&nbsp;setCurrentSnapshot&#8203;(long&nbsp;snapshotId)</pre>
<div class="block">Roll this table's data back to a specific <a href="Snapshot.html" title="interface in org.apache.iceberg"><code>Snapshot</code></a> identified by id.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>snapshotId</code> - long id of the snapshot to roll back table data to</dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>this for method chaining</dd>
<dt><span class="throwsLabel">Throws:</span></dt>
<dd><code>java.lang.IllegalArgumentException</code> - If the table has no snapshot with the given id</dd>
</dl>
</li>
</ul>
<a id="rollbackToTime(long)">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>rollbackToTime</h4>
<pre class="methodSignature"><a href="ManageSnapshots.html" title="interface in org.apache.iceberg">ManageSnapshots</a>&nbsp;rollbackToTime&#8203;(long&nbsp;timestampMillis)</pre>
<div class="block">Roll this table's data back to the last <a href="Snapshot.html" title="interface in org.apache.iceberg"><code>Snapshot</code></a> before the given timestamp.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>timestampMillis</code> - a long timestamp, as returned by <code>System.currentTimeMillis()</code></dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>this for method chaining</dd>
<dt><span class="throwsLabel">Throws:</span></dt>
<dd><code>java.lang.IllegalArgumentException</code> - If the table has no old snapshot before the given timestamp</dd>
</dl>
</li>
</ul>
<a id="rollbackTo(long)">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>rollbackTo</h4>
<pre class="methodSignature"><a href="ManageSnapshots.html" title="interface in org.apache.iceberg">ManageSnapshots</a>&nbsp;rollbackTo&#8203;(long&nbsp;snapshotId)</pre>
<div class="block">Rollback table's state to a specific <a href="Snapshot.html" title="interface in org.apache.iceberg"><code>Snapshot</code></a> identified by id.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>snapshotId</code> - long id of snapshot id to roll back table to. Must be an ancestor of the
     current snapshot</dd>
<dt><span class="throwsLabel">Throws:</span></dt>
<dd><code>java.lang.IllegalArgumentException</code> - If the table has no snapshot with the given id</dd>
<dd><code><a href="exceptions/ValidationException.html" title="class in org.apache.iceberg.exceptions">ValidationException</a></code> - If given snapshot id is not an ancestor of the current state</dd>
</dl>
</li>
</ul>
<a id="cherrypick(long)">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>cherrypick</h4>
<pre class="methodSignature"><a href="ManageSnapshots.html" title="interface in org.apache.iceberg">ManageSnapshots</a>&nbsp;cherrypick&#8203;(long&nbsp;snapshotId)</pre>
<div class="block">Apply supported changes in given snapshot and create a new snapshot which will be set as the
 current snapshot on commit.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>snapshotId</code> - a snapshotId whose changes to apply</dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>this for method chaining</dd>
<dt><span class="throwsLabel">Throws:</span></dt>
<dd><code>java.lang.IllegalArgumentException</code> - If the table has no snapshot with the given id</dd>
<dd><code><a href="exceptions/DuplicateWAPCommitException.html" title="class in org.apache.iceberg.exceptions">DuplicateWAPCommitException</a></code> - In case of a WAP workflow and if the table has a duplicate
     commit with same wapId</dd>
</dl>
</li>
</ul>
<a id="createBranch(java.lang.String)">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>createBranch</h4>
<pre class="methodSignature">default&nbsp;<a href="ManageSnapshots.html" title="interface in org.apache.iceberg">ManageSnapshots</a>&nbsp;createBranch&#8203;(java.lang.String&nbsp;name)</pre>
<div class="block">Create a new branch. The branch will point to current snapshot if the current snapshot is not
 NULL. Otherwise, the branch will point to a newly created empty snapshot.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>name</code> - branch name</dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>this for method chaining</dd>
<dt><span class="throwsLabel">Throws:</span></dt>
<dd><code>java.lang.IllegalArgumentException</code> - if a branch with the given name already exists</dd>
</dl>
</li>
</ul>
<a id="createBranch(java.lang.String,long)">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>createBranch</h4>
<pre class="methodSignature"><a href="ManageSnapshots.html" title="interface in org.apache.iceberg">ManageSnapshots</a>&nbsp;createBranch&#8203;(java.lang.String&nbsp;name,
                             long&nbsp;snapshotId)</pre>
<div class="block">Create a new branch pointing to the given snapshot id.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>name</code> - branch name</dd>
<dd><code>snapshotId</code> - id of the snapshot which will be the head of the branch</dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>this for method chaining</dd>
<dt><span class="throwsLabel">Throws:</span></dt>
<dd><code>java.lang.IllegalArgumentException</code> - if a branch with the given name already exists</dd>
</dl>
</li>
</ul>
<a id="createTag(java.lang.String,long)">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>createTag</h4>
<pre class="methodSignature"><a href="ManageSnapshots.html" title="interface in org.apache.iceberg">ManageSnapshots</a>&nbsp;createTag&#8203;(java.lang.String&nbsp;name,
                          long&nbsp;snapshotId)</pre>
<div class="block">Create a new tag pointing to the given snapshot id</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>name</code> - tag name</dd>
<dd><code>snapshotId</code> - snapshotId for the head of the new branch.</dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>this for method chaining</dd>
<dt><span class="throwsLabel">Throws:</span></dt>
<dd><code>java.lang.IllegalArgumentException</code> - if a tag with the given name already exists</dd>
</dl>
</li>
</ul>
<a id="removeBranch(java.lang.String)">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>removeBranch</h4>
<pre class="methodSignature"><a href="ManageSnapshots.html" title="interface in org.apache.iceberg">ManageSnapshots</a>&nbsp;removeBranch&#8203;(java.lang.String&nbsp;name)</pre>
<div class="block">Remove a branch by name</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>name</code> - branch name</dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>this for method chaining</dd>
<dt><span class="throwsLabel">Throws:</span></dt>
<dd><code>java.lang.IllegalArgumentException</code> - if the branch does not exist</dd>
</dl>
</li>
</ul>
<a id="renameBranch(java.lang.String,java.lang.String)">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>renameBranch</h4>
<pre class="methodSignature"><a href="ManageSnapshots.html" title="interface in org.apache.iceberg">ManageSnapshots</a>&nbsp;renameBranch&#8203;(java.lang.String&nbsp;name,
                             java.lang.String&nbsp;newName)</pre>
<div class="block">Rename a branch</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>name</code> - name of branch to rename</dd>
<dd><code>newName</code> - the desired new name of the branch</dd>
<dt><span class="throwsLabel">Throws:</span></dt>
<dd><code>java.lang.IllegalArgumentException</code> - if the branch to rename does not exist or if there is already
     a branch with the same name as the desired new name.</dd>
</dl>
</li>
</ul>
<a id="removeTag(java.lang.String)">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>removeTag</h4>
<pre class="methodSignature"><a href="ManageSnapshots.html" title="interface in org.apache.iceberg">ManageSnapshots</a>&nbsp;removeTag&#8203;(java.lang.String&nbsp;name)</pre>
<div class="block">Remove the tag with the given name.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>name</code> - tag name</dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>this for method chaining</dd>
<dt><span class="throwsLabel">Throws:</span></dt>
<dd><code>java.lang.IllegalArgumentException</code> - if the branch does not exist</dd>
</dl>
</li>
</ul>
<a id="replaceTag(java.lang.String,long)">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>replaceTag</h4>
<pre class="methodSignature"><a href="ManageSnapshots.html" title="interface in org.apache.iceberg">ManageSnapshots</a>&nbsp;replaceTag&#8203;(java.lang.String&nbsp;name,
                           long&nbsp;snapshotId)</pre>
<div class="block">Replaces the tag with the given name to point to the specified snapshot.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>name</code> - Tag to replace</dd>
<dd><code>snapshotId</code> - new snapshot id for the given tag</dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>this for method chaining</dd>
</dl>
</li>
</ul>
<a id="replaceBranch(java.lang.String,long)">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>replaceBranch</h4>
<pre class="methodSignature"><a href="ManageSnapshots.html" title="interface in org.apache.iceberg">ManageSnapshots</a>&nbsp;replaceBranch&#8203;(java.lang.String&nbsp;name,
                              long&nbsp;snapshotId)</pre>
<div class="block">Replaces the branch with the given name to point to the specified snapshot</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>name</code> - Branch to replace</dd>
<dd><code>snapshotId</code> - new snapshot id for the given branch</dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>this for method chaining</dd>
</dl>
</li>
</ul>
<a id="replaceBranch(java.lang.String,java.lang.String)">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>replaceBranch</h4>
<pre class="methodSignature"><a href="ManageSnapshots.html" title="interface in org.apache.iceberg">ManageSnapshots</a>&nbsp;replaceBranch&#8203;(java.lang.String&nbsp;name,
                              java.lang.String&nbsp;source)</pre>
<div class="block">Replaces the branch with the given name to point to the source snapshot. The source branch will
 remain unchanged, the target branch will retain its retention properties.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>name</code> - Branch to replace</dd>
<dd><code>source</code> - Source reference for the target to be replaced with</dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>this for method chaining</dd>
</dl>
</li>
</ul>
<a id="fastForwardBranch(java.lang.String,java.lang.String)">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>fastForwardBranch</h4>
<pre class="methodSignature"><a href="ManageSnapshots.html" title="interface in org.apache.iceberg">ManageSnapshots</a>&nbsp;fastForwardBranch&#8203;(java.lang.String&nbsp;name,
                                  java.lang.String&nbsp;source)</pre>
<div class="block">Performs a fast-forward of the given target branch up to the source snapshot if target is an
 ancestor of source. The source branch will remain unchanged, the target branch will retain its
 retention properties.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>name</code> - Branch to fast-forward</dd>
<dd><code>source</code> - Source reference for the target to be fast forwarded to</dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>this for method chaining</dd>
<dt><span class="throwsLabel">Throws:</span></dt>
<dd><code>java.lang.IllegalArgumentException</code> - if the target branch is not an ancestor of source</dd>
</dl>
</li>
</ul>
<a id="setMinSnapshotsToKeep(java.lang.String,int)">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>setMinSnapshotsToKeep</h4>
<pre class="methodSignature"><a href="ManageSnapshots.html" title="interface in org.apache.iceberg">ManageSnapshots</a>&nbsp;setMinSnapshotsToKeep&#8203;(java.lang.String&nbsp;branchName,
                                      int&nbsp;minSnapshotsToKeep)</pre>
<div class="block">Updates the minimum number of snapshots to keep for a branch.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>branchName</code> - branch name</dd>
<dd><code>minSnapshotsToKeep</code> - minimum number of snapshots to retain on the branch</dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>this for method chaining</dd>
<dt><span class="throwsLabel">Throws:</span></dt>
<dd><code>java.lang.IllegalArgumentException</code> - if the branch does not exist</dd>
</dl>
</li>
</ul>
<a id="setMaxSnapshotAgeMs(java.lang.String,long)">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>setMaxSnapshotAgeMs</h4>
<pre class="methodSignature"><a href="ManageSnapshots.html" title="interface in org.apache.iceberg">ManageSnapshots</a>&nbsp;setMaxSnapshotAgeMs&#8203;(java.lang.String&nbsp;branchName,
                                    long&nbsp;maxSnapshotAgeMs)</pre>
<div class="block">Updates the max snapshot age for a branch.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>branchName</code> - branch name</dd>
<dd><code>maxSnapshotAgeMs</code> - maximum snapshot age in milliseconds to retain on branch</dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>this for method chaining</dd>
<dt><span class="throwsLabel">Throws:</span></dt>
<dd><code>java.lang.IllegalArgumentException</code> - if the branch does not exist</dd>
</dl>
</li>
</ul>
<a id="setMaxRefAgeMs(java.lang.String,long)">
<!--   -->
</a>
<ul class="blockListLast">
<li class="blockList">
<h4>setMaxRefAgeMs</h4>
<pre class="methodSignature"><a href="ManageSnapshots.html" title="interface in org.apache.iceberg">ManageSnapshots</a>&nbsp;setMaxRefAgeMs&#8203;(java.lang.String&nbsp;name,
                               long&nbsp;maxRefAgeMs)</pre>
<div class="block">Updates the retention policy for a reference.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>name</code> - branch name</dd>
<dd><code>maxRefAgeMs</code> - retention age in milliseconds of the tag reference itself</dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>this for method chaining</dd>
<dt><span class="throwsLabel">Throws:</span></dt>
<dd><code>java.lang.IllegalArgumentException</code> - if the reference does not exist</dd>
</dl>
</li>
</ul>
</li>
</ul>
</section>
</li>
</ul>
</div>
</div>
</main>
<!-- ========= END OF CLASS DATA ========= -->
<footer role="contentinfo">
<nav role="navigation">
<!-- ======= START OF BOTTOM NAVBAR ====== -->
<div class="bottomNav"><a id="navbar.bottom">
<!--   -->
</a>
<div class="skipNav"><a href="#skip.navbar.bottom" title="Skip navigation links">Skip navigation links</a></div>
<a id="navbar.bottom.firstrow">
<!--   -->
</a>
<ul class="navList" title="Navigation">
<li><a href="../../../index.html">Overview</a></li>
<li><a href="package-summary.html">Package</a></li>
<li class="navBarCell1Rev">Class</li>
<li><a href="package-tree.html">Tree</a></li>
<li><a href="../../../deprecated-list.html">Deprecated</a></li>
<li><a href="../../../index-all.html">Index</a></li>
<li><a href="../../../help-doc.html">Help</a></li>
</ul>
</div>
<div class="subNav">
<ul class="navList" id="allclasses_navbar_bottom">
<li><a href="../../../allclasses.html">All&nbsp;Classes</a></li>
</ul>
<div>
<script type="text/javascript"><!--
  allClassesLink = document.getElementById("allclasses_navbar_bottom");
  if(window==top) {
    allClassesLink.style.display = "block";
  }
  else {
    allClassesLink.style.display = "none";
  }
  //-->
</script>
<noscript>
<div>JavaScript is disabled on your browser.</div>
</noscript>
</div>
<div>
<ul class="subNavList">
<li>Summary:&nbsp;</li>
<li>Nested&nbsp;|&nbsp;</li>
<li>Field&nbsp;|&nbsp;</li>
<li>Constr&nbsp;|&nbsp;</li>
<li><a href="#method.summary">Method</a></li>
</ul>
<ul class="subNavList">
<li>Detail:&nbsp;</li>
<li>Field&nbsp;|&nbsp;</li>
<li>Constr&nbsp;|&nbsp;</li>
<li><a href="#method.detail">Method</a></li>
</ul>
</div>
<a id="skip.navbar.bottom">
<!--   -->
</a></div>
<!-- ======== END OF BOTTOM NAVBAR ======= -->
</nav>
</footer>
</body>
</html>
