You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@hbase.apache.org by gi...@apache.org on 2020/12/31 20:17:24 UTC

[hbase-site] branch asf-site updated: Published site at 043da5f5eebd009a14780d12b4e70011b200b5bb.

This is an automated email from the ASF dual-hosted git repository.

git-site-role pushed a commit to branch asf-site
in repository https://gitbox.apache.org/repos/asf/hbase-site.git


The following commit(s) were added to refs/heads/asf-site by this push:
     new 08b065b  Published site at 043da5f5eebd009a14780d12b4e70011b200b5bb.
08b065b is described below

commit 08b065bd6b5db8d1ecbf245b7f0d6d2adf217e2a
Author: jenkins <bu...@apache.org>
AuthorDate: Thu Dec 31 20:17:10 2020 +0000

    Published site at 043da5f5eebd009a14780d12b4e70011b200b5bb.
---
 acid-semantics.html                                |    2 +-
 apache_hbase_reference_guide.pdf                   |    4 +-
 .../org/apache/hadoop/hbase/util/RegionMover.html  |    4 +-
 book.html                                          |    2 +-
 bulk-loads.html                                    |    2 +-
 checkstyle-aggregate.html                          |  182 +-
 coc.html                                           |    2 +-
 dependencies.html                                  |    2 +-
 dependency-convergence.html                        |    2 +-
 dependency-info.html                               |    2 +-
 dependency-management.html                         |    6 +-
 devapidocs/constant-values.html                    |   16 +-
 devapidocs/index-all.html                          |    8 +
 .../apache/hadoop/hbase/backup/package-tree.html   |    4 +-
 .../apache/hadoop/hbase/chaos/package-tree.html    |    2 +-
 .../hadoop/hbase/client/AsyncConnectionImpl.html   |   50 +-
 .../apache/hadoop/hbase/client/package-tree.html   |   22 +-
 .../hadoop/hbase/coprocessor/package-tree.html     |    2 +-
 .../apache/hadoop/hbase/filter/package-tree.html   |    6 +-
 .../hadoop/hbase/hbtop/terminal/package-tree.html  |    2 +-
 .../org/apache/hadoop/hbase/http/package-tree.html |    4 +-
 .../org/apache/hadoop/hbase/io/hfile/HFile.html    |   20 +-
 .../apache/hadoop/hbase/io/hfile/HFileInfo.html    |  167 +-
 .../apache/hadoop/hbase/io/hfile/package-tree.html |    4 +-
 .../org/apache/hadoop/hbase/ipc/package-tree.html  |    2 +-
 .../hadoop/hbase/mapreduce/package-tree.html       |    4 +-
 .../hbase/master/assignment/package-tree.html      |    2 +-
 .../hadoop/hbase/master/balancer/package-tree.html |    2 +-
 .../apache/hadoop/hbase/master/package-tree.html   |    6 +-
 .../hbase/master/procedure/package-tree.html       |    2 +-
 .../org/apache/hadoop/hbase/package-tree.html      |   18 +-
 .../hadoop/hbase/procedure2/package-tree.html      |    6 +-
 .../hbase/procedure2/store/wal/package-tree.html   |    2 +-
 .../apache/hadoop/hbase/quotas/package-tree.html   |    8 +-
 .../hbase/regionserver/MetricsRegionServer.html    |  149 +-
 .../regionserver/ScannerContext.LimitScope.html    |    4 +-
 .../regionserver/ScannerContext.NextState.html     |    4 +-
 .../hadoop/hbase/regionserver/package-tree.html    |   16 +-
 .../regionserver/querymatcher/package-tree.html    |    2 +-
 .../hbase/regionserver/wal/package-tree.html       |    4 +-
 .../hadoop/hbase/replication/package-tree.html     |    2 +-
 .../hadoop/hbase/security/access/package-tree.html |    6 +-
 .../apache/hadoop/hbase/security/package-tree.html |    2 +-
 .../apache/hadoop/hbase/thrift/package-tree.html   |    2 +-
 .../HBaseFsck.CheckRegionConsistencyWorkItem.html  |   10 +-
 .../hbase/util/HBaseFsck.FileLockCallable.html     |   16 +-
 .../hadoop/hbase/util/HBaseFsck.HBaseFsckTool.html |    6 +-
 .../util/HBaseFsck.PrintingErrorReporter.html      |   42 +-
 .../HBaseFsck.RegionBoundariesInformation.html     |   16 +-
 .../hbase/util/HBaseFsck.WorkItemHdfsDir.html      |   12 +-
 .../util/HBaseFsck.WorkItemHdfsRegionInfo.html     |   12 +-
 .../hbase/util/HBaseFsck.WorkItemOverlapMerge.html |   10 +-
 .../hbase/util/HBaseFsck.WorkItemRegion.html       |   16 +-
 .../org/apache/hadoop/hbase/util/HBaseFsck.html    |  414 +-
 .../org/apache/hadoop/hbase/util/package-tree.html |   12 +-
 .../org/apache/hadoop/hbase/wal/package-tree.html  |    2 +-
 .../hadoop/hbase/client/AsyncConnectionImpl.html   |  435 +-
 .../hbase/client/example/AsyncClientExample.html   |    2 +-
 .../FSDataInputStreamWrapper.ReadStatistics.html   |   26 +-
 .../hadoop/hbase/io/FSDataInputStreamWrapper.html  |   26 +-
 .../hbase/io/hfile/HFile.CachingBlockReader.html   |  347 +-
 .../apache/hadoop/hbase/io/hfile/HFile.Reader.html |  347 +-
 .../apache/hadoop/hbase/io/hfile/HFile.Writer.html |  347 +-
 .../hadoop/hbase/io/hfile/HFile.WriterFactory.html |  347 +-
 .../org/apache/hadoop/hbase/io/hfile/HFile.html    |  347 +-
 .../apache/hadoop/hbase/io/hfile/HFileInfo.html    |  947 +--
 .../master/HMaster.TableDescriptorGetter.html      |  342 +-
 .../org/apache/hadoop/hbase/master/HMaster.html    |  342 +-
 .../hbase/regionserver/MetricsRegionServer.html    |  496 +-
 .../HBaseFsck.CheckRegionConsistencyWorkItem.html  | 7697 ++++++++++----------
 .../hbase/util/HBaseFsck.FileLockCallable.html     | 7697 ++++++++++----------
 .../hadoop/hbase/util/HBaseFsck.HBaseFsckTool.html | 7697 ++++++++++----------
 .../util/HBaseFsck.PrintingErrorReporter.html      | 7697 ++++++++++----------
 .../HBaseFsck.RegionBoundariesInformation.html     | 7697 ++++++++++----------
 .../hbase/util/HBaseFsck.WorkItemHdfsDir.html      | 7697 ++++++++++----------
 .../util/HBaseFsck.WorkItemHdfsRegionInfo.html     | 7697 ++++++++++----------
 .../hbase/util/HBaseFsck.WorkItemOverlapMerge.html | 7697 ++++++++++----------
 .../hbase/util/HBaseFsck.WorkItemRegion.html       | 7697 ++++++++++----------
 .../org/apache/hadoop/hbase/util/HBaseFsck.html    | 7697 ++++++++++----------
 .../hbase/util/RegionMover.RegionMoverBuilder.html |    4 +-
 .../org/apache/hadoop/hbase/util/RegionMover.html  |    4 +-
 downloads.html                                     |    2 +-
 export_control.html                                |    2 +-
 index.html                                         |    2 +-
 issue-tracking.html                                |    2 +-
 mail-lists.html                                    |    2 +-
 metrics.html                                       |    2 +-
 old_news.html                                      |    2 +-
 plugin-management.html                             |    2 +-
 plugins.html                                       |    2 +-
 poweredbyhbase.html                                |    2 +-
 project-info.html                                  |    2 +-
 project-reports.html                               |    2 +-
 project-summary.html                               |    2 +-
 pseudo-distributed.html                            |    2 +-
 replication.html                                   |    2 +-
 resources.html                                     |    2 +-
 source-repository.html                             |    2 +-
 sponsors.html                                      |    2 +-
 supportingprojects.html                            |    2 +-
 team-list.html                                     |    2 +-
 ...ncTableRegionReplicasRead.FailPrimaryGetCP.html |   12 +-
 .../AbstractTestAsyncTableRegionReplicasRead.html  |   54 +-
 .../hadoop/hbase/client/TestAsyncAdminBase.html    |   50 +-
 ...syncAdminBuilder.TestMaxRetriesCoprocessor.html |   10 +-
 ...minBuilder.TestOperationTimeoutCoprocessor.html |   10 +-
 ...syncAdminBuilder.TestRpcTimeoutCoprocessor.html |    8 +-
 .../hadoop/hbase/client/TestAsyncAdminBuilder.html |   36 +-
 .../hbase/client/TestAsyncClusterAdminApi2.html    |   20 +-
 .../hbase/client/TestAsyncMetaRegionLocator.html   |   18 +-
 .../client/TestAsyncNonMetaRegionLocator.html      |   76 +-
 ...atorConcurrenyLimit.CountingRegionObserver.html |   10 +-
 ...stAsyncNonMetaRegionLocatorConcurrenyLimit.html |   32 +-
 ...TestAsyncRegionLocator.SleepRegionObserver.html |    8 +-
 .../hbase/client/TestAsyncRegionLocator.html       |   28 +-
 .../TestAsyncSingleRequestRpcRetryingCaller.html   |   34 +-
 .../apache/hadoop/hbase/client/TestAsyncTable.html |  108 +-
 .../TestAsyncTableLocateRegionForDeletedTable.html |   24 +-
 .../TestAsyncTableNoncedRetry.SleepOnceCP.html     |   10 +-
 .../hbase/client/TestAsyncTableNoncedRetry.html    |   40 +-
 .../TestAsyncTableScanMetrics.ScanWithMetrics.html |    4 +-
 .../hbase/client/TestAsyncTableScanMetrics.html    |   40 +-
 ...estCatalogReplicaLoadBalanceSimpleSelector.html |   26 +-
 .../hbase/client/TestMetaRegionLocationCache.html  |   26 +-
 .../hbase/client/TestZKConnectionRegistry.html     |   22 +-
 .../TestMasterOperationsForRegionReplicas.html     |   26 +-
 ...TestEndToEndSplitTransaction.RegionChecker.html |   24 +-
 ...estEndToEndSplitTransaction.RegionSplitter.html |   22 +-
 .../regionserver/TestEndToEndSplitTransaction.html |   36 +-
 .../hbase/replication/TestReplicationBase.html     |   86 +-
 .../replication/TestReplicationSyncUpToolBase.html |   54 +-
 ...TestSerialReplicationEndpoint.TestEndpoint.html |   16 +-
 .../TestSerialReplicationEndpoint.html             |   24 +-
 ...ncTableRegionReplicasRead.FailPrimaryGetCP.html |  361 +-
 .../AbstractTestAsyncTableRegionReplicasRead.html  |  361 +-
 .../hadoop/hbase/client/TestAsyncAdminBase.html    |  269 +-
 ...syncAdminBuilder.TestMaxRetriesCoprocessor.html |  409 +-
 ...minBuilder.TestOperationTimeoutCoprocessor.html |  409 +-
 ...syncAdminBuilder.TestRpcTimeoutCoprocessor.html |  409 +-
 .../hadoop/hbase/client/TestAsyncAdminBuilder.html |  409 +-
 .../hbase/client/TestAsyncClusterAdminApi2.html    |  191 +-
 .../hbase/client/TestAsyncMetaRegionLocator.html   |  127 +-
 .../client/TestAsyncNonMetaRegionLocator.html      |  869 +--
 ...atorConcurrenyLimit.CountingRegionObserver.html |  277 +-
 ...stAsyncNonMetaRegionLocatorConcurrenyLimit.html |  277 +-
 ...TestAsyncRegionLocator.SleepRegionObserver.html |  251 +-
 .../hbase/client/TestAsyncRegionLocator.html       |  251 +-
 .../TestAsyncSingleRequestRpcRetryingCaller.html   |  309 +-
 .../apache/hadoop/hbase/client/TestAsyncTable.html | 3265 ++++-----
 .../TestAsyncTableLocateRegionForDeletedTable.html |  165 +-
 .../TestAsyncTableNoncedRetry.SleepOnceCP.html     |  291 +-
 .../hbase/client/TestAsyncTableNoncedRetry.html    |  291 +-
 .../TestAsyncTableScanMetrics.ScanWithMetrics.html |  275 +-
 .../hbase/client/TestAsyncTableScanMetrics.html    |  275 +-
 ...estCatalogReplicaLoadBalanceSimpleSelector.html |  184 +-
 .../hbase/client/TestMetaRegionLocationCache.html  |  343 +-
 .../hbase/client/TestZKConnectionRegistry.html     |  197 +-
 .../TestMasterOperationsForRegionReplicas.html     |  150 +-
 ...TestEndToEndSplitTransaction.RegionChecker.html |  994 ++-
 ...estEndToEndSplitTransaction.RegionSplitter.html |  994 ++-
 .../regionserver/TestEndToEndSplitTransaction.html |  994 ++-
 ...plitTransactionOnCluster.CustomSplitPolicy.html |  158 +-
 ...actionOnCluster.FailingSplitMasterObserver.html |  158 +-
 .../TestSplitTransactionOnCluster.MyMaster.html    |  158 +-
 ...itTransactionOnCluster.MyMasterRpcServices.html |  158 +-
 .../TestSplitTransactionOnCluster.html             |  158 +-
 .../hbase/replication/TestReplicationBase.html     |  652 +-
 .../replication/TestReplicationSyncUpToolBase.html |  289 +-
 ...TestSerialReplicationEndpoint.TestEndpoint.html |  309 +-
 .../TestSerialReplicationEndpoint.html             |  309 +-
 170 files changed, 49873 insertions(+), 49764 deletions(-)

diff --git a/acid-semantics.html b/acid-semantics.html
index 83db1d4..b953815 100644
--- a/acid-semantics.html
+++ b/acid-semantics.html
@@ -467,7 +467,7 @@
         <div class="row">
             <p>Copyright &copy;2007&#x2013;2020
 <a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2020-12-30</li>
+All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2020-12-31</li>
 </p>
         </div>
         <p id="poweredBy" class="pull-right"><a href="http://maven.apache.org/" title="Built by Maven" class="poweredBy"><img class="builtBy" alt="Built by Maven" src="./images/logos/maven-feather.png" /></a>
diff --git a/apache_hbase_reference_guide.pdf b/apache_hbase_reference_guide.pdf
index e84f593..ed94bde 100644
--- a/apache_hbase_reference_guide.pdf
+++ b/apache_hbase_reference_guide.pdf
@@ -5,8 +5,8 @@
 /Author (Apache HBase Team)
 /Creator (Asciidoctor PDF 1.5.3, based on Prawn 2.2.2)
 /Producer (Apache HBase Team)
-/ModDate (D:20201230200432+00'00')
-/CreationDate (D:20201230201436+00'00')
+/ModDate (D:20201231200440+00'00')
+/CreationDate (D:20201231201444+00'00')
 >>
 endobj
 2 0 obj
diff --git a/apidocs/src-html/org/apache/hadoop/hbase/util/RegionMover.html b/apidocs/src-html/org/apache/hadoop/hbase/util/RegionMover.html
index 65b5503..3e9e470 100644
--- a/apidocs/src-html/org/apache/hadoop/hbase/util/RegionMover.html
+++ b/apidocs/src-html/org/apache/hadoop/hbase/util/RegionMover.html
@@ -129,8 +129,8 @@
 <span class="sourceLineNo">121</span><a name="line.121"></a>
 <span class="sourceLineNo">122</span>  @Override<a name="line.122"></a>
 <span class="sourceLineNo">123</span>  public void close() {<a name="line.123"></a>
-<span class="sourceLineNo">124</span>    IOUtils.closeQuietly(this.admin);<a name="line.124"></a>
-<span class="sourceLineNo">125</span>    IOUtils.closeQuietly(this.conn);<a name="line.125"></a>
+<span class="sourceLineNo">124</span>    IOUtils.closeQuietly(this.admin, e -&gt; LOG.warn("failed to close admin", e));<a name="line.124"></a>
+<span class="sourceLineNo">125</span>    IOUtils.closeQuietly(this.conn, e -&gt; LOG.warn("failed to close conn", e));<a name="line.125"></a>
 <span class="sourceLineNo">126</span>  }<a name="line.126"></a>
 <span class="sourceLineNo">127</span><a name="line.127"></a>
 <span class="sourceLineNo">128</span>  /**<a name="line.128"></a>
diff --git a/book.html b/book.html
index d26596c..7c340cf 100644
--- a/book.html
+++ b/book.html
@@ -46207,7 +46207,7 @@ org/apache/hadoop/hbase/security/access/AccessControlClient.revoke:(Lorg/apache/
 <div id="footer">
 <div id="footer-text">
 Version 3.0.0-SNAPSHOT<br>
-Last updated 2020-12-30 20:04:32 UTC
+Last updated 2020-12-31 20:04:40 UTC
 </div>
 </div>
 <link rel="stylesheet" href="./coderay-asciidoctor.css">
diff --git a/bulk-loads.html b/bulk-loads.html
index 617f756..acbf558 100644
--- a/bulk-loads.html
+++ b/bulk-loads.html
@@ -172,7 +172,7 @@
         <div class="row">
             <p>Copyright &copy;2007&#x2013;2020
 <a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2020-12-30</li>
+All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2020-12-31</li>
 </p>
         </div>
         <p id="poweredBy" class="pull-right"><a href="http://maven.apache.org/" title="Built by Maven" class="poweredBy"><img class="builtBy" alt="Built by Maven" src="./images/logos/maven-feather.png" /></a>
diff --git a/checkstyle-aggregate.html b/checkstyle-aggregate.html
index 891bfea..32bb283 100644
--- a/checkstyle-aggregate.html
+++ b/checkstyle-aggregate.html
@@ -16952,13 +16952,13 @@
 <td>coding</td>
 <td>InnerAssignment</td>
 <td>Inner assignments should be avoided.</td>
-<td>117</td></tr>
+<td>118</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>coding</td>
 <td>InnerAssignment</td>
 <td>Inner assignments should be avoided.</td>
-<td>135</td></tr></table></div>
+<td>136</td></tr></table></div>
 <div class="section">
 <h3 id="org.apache.hadoop.hbase.client.TestAsyncTableScanner.java">org/apache/hadoop/hbase/client/TestAsyncTableScanner.java</h3>
 <table border="0" class="table table-striped">
@@ -17054,61 +17054,61 @@
 <td>whitespace</td>
 <td>MethodParamPad</td>
 <td>'(' should be on the previous line.</td>
-<td>98</td></tr>
+<td>100</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'block' child has incorrect indentation level 8, expected level should be 10.</td>
-<td>118</td></tr>
+<td>120</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'try' has incorrect indentation level 8, expected level should be 10.</td>
-<td>119</td></tr>
+<td>121</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'try' child has incorrect indentation level 10, expected level should be 12.</td>
-<td>120</td></tr>
+<td>122</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'try' child has incorrect indentation level 10, expected level should be 12.</td>
-<td>122</td></tr>
+<td>124</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'try rcurly' has incorrect indentation level 8, expected level should be 10.</td>
-<td>123</td></tr>
+<td>125</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'catch' child has incorrect indentation level 10, expected level should be 12.</td>
-<td>124</td></tr>
+<td>126</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'catch rcurly' has incorrect indentation level 8, expected level should be 10.</td>
-<td>125</td></tr>
+<td>127</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'block' child has incorrect indentation level 8, expected level should be 10.</td>
-<td>126</td></tr>
+<td>128</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'block rcurly' has incorrect indentation level 6, expected level should be 8.</td>
-<td>127</td></tr></table></div>
+<td>129</td></tr></table></div>
 <div class="section">
 <h3 id="org.apache.hadoop.hbase.client.TestCheckAndMutate.java">org/apache/hadoop/hbase/client/TestCheckAndMutate.java</h3>
 <table border="0" class="table table-striped">
@@ -29783,13 +29783,13 @@
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 118).</td>
-<td>366</td></tr>
+<td>374</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 118).</td>
-<td>368</td></tr></table></div>
+<td>376</td></tr></table></div>
 <div class="section">
 <h3 id="org.apache.hadoop.hbase.io.hfile.HFilePrettyPrinter.java">org/apache/hadoop/hbase/io/hfile/HFilePrettyPrinter.java</h3>
 <table border="0" class="table table-striped">
@@ -50222,7 +50222,7 @@
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 110).</td>
-<td>243</td></tr></table></div>
+<td>247</td></tr></table></div>
 <div class="section">
 <h3 id="org.apache.hadoop.hbase.regionserver.MetricsRegionServerSource.java">org/apache/hadoop/hbase/regionserver/MetricsRegionServerSource.java</h3>
 <table border="0" class="table table-striped">
@@ -70631,451 +70631,451 @@
 <td>imports</td>
 <td>ImportOrder</td>
 <td>Wrong order for 'org.apache.yetus.audience.InterfaceAudience' import.</td>
-<td>142</td></tr>
+<td>143</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>blocks</td>
 <td>NeedBraces</td>
 <td>'if' construct must use '{}'s.</td>
-<td>710</td></tr>
+<td>711</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'if' child has incorrect indentation level 11, expected level should be 10.</td>
-<td>768</td></tr>
+<td>769</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>blocks</td>
 <td>NeedBraces</td>
 <td>'if' construct must use '{}'s.</td>
-<td>846</td></tr>
+<td>847</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>design</td>
 <td>VisibilityModifier</td>
 <td>Variable 'regionName' must be private and have accessor methods.</td>
-<td>873</td></tr>
+<td>874</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>design</td>
 <td>VisibilityModifier</td>
 <td>Variable 'metaFirstKey' must be private and have accessor methods.</td>
-<td>874</td></tr>
+<td>875</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>design</td>
 <td>VisibilityModifier</td>
 <td>Variable 'metaLastKey' must be private and have accessor methods.</td>
-<td>875</td></tr>
+<td>876</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>design</td>
 <td>VisibilityModifier</td>
 <td>Variable 'storesFirstKey' must be private and have accessor methods.</td>
-<td>876</td></tr>
+<td>877</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>design</td>
 <td>VisibilityModifier</td>
 <td>Variable 'storesLastKey' must be private and have accessor methods.</td>
-<td>877</td></tr>
+<td>878</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>whitespace</td>
 <td>MethodParamPad</td>
 <td>'(' is preceded with whitespace.</td>
-<td>879</td></tr>
+<td>880</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>blocks</td>
 <td>NeedBraces</td>
 <td>'if' construct must use '{}'s.</td>
-<td>933</td></tr>
+<td>934</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>blocks</td>
 <td>NeedBraces</td>
 <td>'if' construct must use '{}'s.</td>
-<td>935</td></tr>
+<td>936</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>blocks</td>
 <td>NeedBraces</td>
 <td>'if' construct must use '{}'s.</td>
-<td>1010</td></tr>
+<td>1011</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>whitespace</td>
 <td>ParenPad</td>
 <td>')' is preceded with whitespace.</td>
-<td>1045</td></tr>
+<td>1046</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>blocks</td>
 <td>NeedBraces</td>
 <td>'if' construct must use '{}'s.</td>
-<td>1142</td></tr>
+<td>1143</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>blocks</td>
 <td>NeedBraces</td>
 <td>'if' construct must use '{}'s.</td>
-<td>1147</td></tr>
+<td>1148</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>blocks</td>
 <td>NeedBraces</td>
 <td>'if' construct must use '{}'s.</td>
-<td>1197</td></tr>
+<td>1198</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>blocks</td>
 <td>NeedBraces</td>
 <td>'if' construct must use '{}'s.</td>
-<td>1201</td></tr>
+<td>1202</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 118).</td>
-<td>1207</td></tr>
+<td>1208</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 113).</td>
-<td>1208</td></tr>
+<td>1209</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 104).</td>
-<td>1216</td></tr>
+<td>1217</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 113).</td>
-<td>1217</td></tr>
+<td>1218</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 101).</td>
-<td>1219</td></tr>
+<td>1220</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>blocks</td>
 <td>NeedBraces</td>
 <td>'if' construct must use '{}'s.</td>
-<td>1233</td></tr>
+<td>1234</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>1367</td></tr>
+<td>1368</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>1368</td></tr>
+<td>1369</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>1370</td></tr>
+<td>1371</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 102).</td>
-<td>1388</td></tr>
+<td>1389</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>1389</td></tr>
+<td>1390</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>blocks</td>
 <td>NeedBraces</td>
 <td>'if' construct must use '{}'s.</td>
-<td>1393</td></tr>
+<td>1394</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>1404</td></tr>
+<td>1405</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 109).</td>
-<td>1423</td></tr>
+<td>1424</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>1424</td></tr>
+<td>1425</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 104).</td>
-<td>1453</td></tr>
+<td>1454</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 123).</td>
-<td>1456</td></tr>
+<td>1457</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 102).</td>
-<td>1467</td></tr>
+<td>1468</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>1609</td></tr>
+<td>1610</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>1610</td></tr>
+<td>1611</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'throws' has incorrect indentation level 2, expected level should be 4.</td>
-<td>1613</td></tr>
+<td>1614</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'if' has incorrect indentation level 7, expected level should be 6.</td>
-<td>1648</td></tr>
+<td>1649</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'if' child has incorrect indentation level 9, expected level should be 8.</td>
-<td>1651</td></tr>
+<td>1652</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'if rcurly' has incorrect indentation level 7, expected level should be 6.</td>
-<td>1652</td></tr>
+<td>1653</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'throws' has incorrect indentation level 2, expected level should be 4.</td>
-<td>1780</td></tr>
+<td>1781</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>whitespace</td>
 <td>ParenPad</td>
 <td>')' is preceded with whitespace.</td>
-<td>1970</td></tr>
+<td>1971</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>blocks</td>
 <td>NeedBraces</td>
 <td>'if' construct must use '{}'s.</td>
-<td>2098</td></tr>
+<td>2099</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>blocks</td>
 <td>NeedBraces</td>
 <td>'if' construct must use '{}'s.</td>
-<td>2140</td></tr>
+<td>2141</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>MethodLength</td>
 <td>Method length is 235 lines (max allowed is 150).</td>
-<td>2161</td></tr>
+<td>2162</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>blocks</td>
 <td>NeedBraces</td>
 <td>'if' construct must use '{}'s.</td>
-<td>2164</td></tr>
+<td>2165</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>blocks</td>
 <td>NeedBraces</td>
 <td>'if' construct must use '{}'s.</td>
-<td>2236</td></tr>
+<td>2237</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>2402</td></tr>
+<td>2403</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'method def' child has incorrect indentation level 6, expected level should be 4.</td>
-<td>2613</td></tr>
+<td>2614</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>2654</td></tr>
+<td>2655</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>2655</td></tr>
+<td>2656</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'.' has incorrect indentation level 10, expected level should be 12.</td>
-<td>2681</td></tr>
+<td>2682</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>design</td>
 <td>VisibilityModifier</td>
 <td>Variable 'errorCount' must be private and have accessor methods.</td>
-<td>2879</td></tr>
+<td>2880</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>2943</td></tr>
+<td>2944</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 104).</td>
-<td>3109</td></tr>
+<td>3110</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 104).</td>
-<td>3180</td></tr>
+<td>3181</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 115).</td>
-<td>3493</td></tr>
+<td>3494</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 108).</td>
-<td>3536</td></tr>
+<td>3537</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 107).</td>
-<td>3541</td></tr>
+<td>3542</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 104).</td>
-<td>3542</td></tr>
+<td>3543</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 111).</td>
-<td>3549</td></tr>
+<td>3550</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 116).</td>
-<td>3554</td></tr>
+<td>3555</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 107).</td>
-<td>3561</td></tr>
+<td>3562</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 106).</td>
-<td>3563</td></tr>
+<td>3564</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 113).</td>
-<td>3566</td></tr>
+<td>3567</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 145).</td>
-<td>3568</td></tr>
+<td>3569</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 104).</td>
-<td>3569</td></tr>
+<td>3570</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 179).</td>
-<td>3570</td></tr>
+<td>3571</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 113).</td>
-<td>3572</td></tr>
+<td>3573</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>3597</td></tr>
+<td>3598</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>3598</td></tr>
+<td>3599</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>blocks</td>
 <td>LeftCurly</td>
 <td>'{' at column 39 should have line break after.</td>
-<td>3614</td></tr>
+<td>3615</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>MethodLength</td>
 <td>Method length is 227 lines (max allowed is 150).</td>
-<td>3624</td></tr></table></div>
+<td>3625</td></tr></table></div>
 <div class="section">
 <h3 id="org.apache.hadoop.hbase.util.HBaseFsckRepair.java">org/apache/hadoop/hbase/util/HBaseFsckRepair.java</h3>
 <table border="0" class="table table-striped">
@@ -75689,7 +75689,7 @@
         <div class="row">
             <p>Copyright &copy;2007&#x2013;2020
 <a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2020-12-30</li>
+All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2020-12-31</li>
 </p>
         </div>
         <p id="poweredBy" class="pull-right"><a href="http://maven.apache.org/" title="Built by Maven" class="poweredBy"><img class="builtBy" alt="Built by Maven" src="./images/logos/maven-feather.png" /></a>
diff --git a/coc.html b/coc.html
index 897ff59..1c91ecd 100644
--- a/coc.html
+++ b/coc.html
@@ -241,7 +241,7 @@ email to <a class="externalLink" href="mailto:private@hbase.apache.org">the priv
         <div class="row">
             <p>Copyright &copy;2007&#x2013;2020
 <a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2020-12-30</li>
+All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2020-12-31</li>
 </p>
         </div>
         <p id="poweredBy" class="pull-right"><a href="http://maven.apache.org/" title="Built by Maven" class="poweredBy"><img class="builtBy" alt="Built by Maven" src="./images/logos/maven-feather.png" /></a>
diff --git a/dependencies.html b/dependencies.html
index 27b9335..6a870b9 100644
--- a/dependencies.html
+++ b/dependencies.html
@@ -313,7 +313,7 @@
         <div class="row">
             <p>Copyright &copy;2007&#x2013;2020
 <a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2020-12-30</li>
+All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2020-12-31</li>
 </p>
         </div>
         <p id="poweredBy" class="pull-right"><a href="http://maven.apache.org/" title="Built by Maven" class="poweredBy"><img class="builtBy" alt="Built by Maven" src="./images/logos/maven-feather.png" /></a>
diff --git a/dependency-convergence.html b/dependency-convergence.html
index 30fa522..4cc1b84 100644
--- a/dependency-convergence.html
+++ b/dependency-convergence.html
@@ -824,7 +824,7 @@
         <div class="row">
             <p>Copyright &copy;2007&#x2013;2020
 <a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2020-12-30</li>
+All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2020-12-31</li>
 </p>
         </div>
         <p id="poweredBy" class="pull-right"><a href="http://maven.apache.org/" title="Built by Maven" class="poweredBy"><img class="builtBy" alt="Built by Maven" src="./images/logos/maven-feather.png" /></a>
diff --git a/dependency-info.html b/dependency-info.html
index 0a410eb..4056cb0 100644
--- a/dependency-info.html
+++ b/dependency-info.html
@@ -194,7 +194,7 @@
         <div class="row">
             <p>Copyright &copy;2007&#x2013;2020
 <a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2020-12-30</li>
+All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2020-12-31</li>
 </p>
         </div>
         <p id="poweredBy" class="pull-right"><a href="http://maven.apache.org/" title="Built by Maven" class="poweredBy"><img class="builtBy" alt="Built by Maven" src="./images/logos/maven-feather.png" /></a>
diff --git a/dependency-management.html b/dependency-management.html
index 6d58643..bc3999d 100644
--- a/dependency-management.html
+++ b/dependency-management.html
@@ -239,8 +239,8 @@
 <td><a class="externalLink" href="https://www.apache.org/licenses/LICENSE-2.0.txt">Apache License, Version 2.0</a></td></tr>
 <tr class="b">
 <td>commons-io</td>
-<td><a class="externalLink" href="http://commons.apache.org/proper/commons-io/">commons-io</a></td>
-<td>2.6</td>
+<td><a class="externalLink" href="https://commons.apache.org/proper/commons-io/">commons-io</a></td>
+<td>2.8.0</td>
 <td>-</td>
 <td>jar</td>
 <td><a class="externalLink" href="https://www.apache.org/licenses/LICENSE-2.0.txt">Apache License, Version 2.0</a></td></tr>
@@ -1019,7 +1019,7 @@
         <div class="row">
             <p>Copyright &copy;2007&#x2013;2020
 <a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2020-12-30</li>
+All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2020-12-31</li>
 </p>
         </div>
         <p id="poweredBy" class="pull-right"><a href="http://maven.apache.org/" title="Built by Maven" class="poweredBy"><img class="builtBy" alt="Built by Maven" src="./images/logos/maven-feather.png" /></a>
diff --git a/devapidocs/constant-values.html b/devapidocs/constant-values.html
index 065d03a..0f38094 100644
--- a/devapidocs/constant-values.html
+++ b/devapidocs/constant-values.html
@@ -21461,19 +21461,33 @@
 </tr>
 <tbody>
 <tr class="altColor">
+<td class="colFirst"><a name="org.apache.hadoop.hbase.regionserver.MetricsRegionServer.DEFAULT_SLOW_METRIC_TIME">
+<!--   -->
+</a><code>protected&nbsp;static&nbsp;final&nbsp;int</code></td>
+<td><code><a href="org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#DEFAULT_SLOW_METRIC_TIME">DEFAULT_SLOW_METRIC_TIME</a></code></td>
+<td class="colLast"><code>1000</code></td>
+</tr>
+<tr class="rowColor">
 <td class="colFirst"><a name="org.apache.hadoop.hbase.regionserver.MetricsRegionServer.RS_ENABLE_TABLE_METRICS_DEFAULT">
 <!--   -->
 </a><code>public&nbsp;static&nbsp;final&nbsp;boolean</code></td>
 <td><code><a href="org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#RS_ENABLE_TABLE_METRICS_DEFAULT">RS_ENABLE_TABLE_METRICS_DEFAULT</a></code></td>
 <td class="colLast"><code>true</code></td>
 </tr>
-<tr class="rowColor">
+<tr class="altColor">
 <td class="colFirst"><a name="org.apache.hadoop.hbase.regionserver.MetricsRegionServer.RS_ENABLE_TABLE_METRICS_KEY">
 <!--   -->
 </a><code>public&nbsp;static&nbsp;final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a></code></td>
 <td><code><a href="org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#RS_ENABLE_TABLE_METRICS_KEY">RS_ENABLE_TABLE_METRICS_KEY</a></code></td>
 <td class="colLast"><code>"hbase.regionserver.enable.table.latencies"</code></td>
 </tr>
+<tr class="rowColor">
+<td class="colFirst"><a name="org.apache.hadoop.hbase.regionserver.MetricsRegionServer.SLOW_METRIC_TIME">
+<!--   -->
+</a><code>public&nbsp;static&nbsp;final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a></code></td>
+<td><code><a href="org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#SLOW_METRIC_TIME">SLOW_METRIC_TIME</a></code></td>
+<td class="colLast"><code>"hbase.ipc.slow.metric.time"</code></td>
+</tr>
 </tbody>
 </table>
 </li>
diff --git a/devapidocs/index-all.html b/devapidocs/index-all.html
index 0bf6ef4..f2cf643 100644
--- a/devapidocs/index-all.html
+++ b/devapidocs/index-all.html
@@ -24844,6 +24844,8 @@
 <dd>&nbsp;</dd>
 <dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/HConstants.html#DEFAULT_SLOW_LOG_SYS_TABLE_ENABLED_KEY">DEFAULT_SLOW_LOG_SYS_TABLE_ENABLED_KEY</a></span> - Static variable in class org.apache.hadoop.hbase.<a href="org/apache/hadoop/hbase/HConstants.html" title="class in org.apache.hadoop.hbase">HConstants</a></dt>
 <dd>&nbsp;</dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#DEFAULT_SLOW_METRIC_TIME">DEFAULT_SLOW_METRIC_TIME</a></span> - Static variable in class org.apache.hadoop.hbase.regionserver.<a href="org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html" title="class in org.apache.hadoop.hbase.regionserver">MetricsRegionServer</a></dt>
+<dd>&nbsp;</dd>
 <dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/thrift/ThriftMetrics.html#DEFAULT_SLOW_RESPONSE_NANO_SEC">DEFAULT_SLOW_RESPONSE_NANO_SEC</a></span> - Static variable in class org.apache.hadoop.hbase.thrift.<a href="org/apache/hadoop/hbase/thrift/ThriftMetrics.html" title="class in org.apache.hadoop.hbase.thrift">ThriftMetrics</a></dt>
 <dd>&nbsp;</dd>
 <dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/regionserver/wal/AbstractFSWAL.html#DEFAULT_SLOW_SYNC_ROLL_INTERVAL_MS">DEFAULT_SLOW_SYNC_ROLL_INTERVAL_MS</a></span> - Static variable in class org.apache.hadoop.hbase.regionserver.wal.<a href="org/apache/hadoop/hbase/regionserver/wal/AbstractFSWAL.html" title="class in org.apache.hadoop.hbase.regionserver.wal">AbstractFSWAL</a></dt>
@@ -71921,6 +71923,8 @@
 <dd>&nbsp;</dd>
 <dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/io/hfile/HFileBlockIndex.html#LOG">LOG</a></span> - Static variable in class org.apache.hadoop.hbase.io.hfile.<a href="org/apache/hadoop/hbase/io/hfile/HFileBlockIndex.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileBlockIndex</a></dt>
 <dd>&nbsp;</dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/io/hfile/HFileInfo.html#LOG">LOG</a></span> - Static variable in class org.apache.hadoop.hbase.io.hfile.<a href="org/apache/hadoop/hbase/io/hfile/HFileInfo.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileInfo</a></dt>
+<dd>&nbsp;</dd>
 <dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/io/hfile/HFilePreadReader.html#LOG">LOG</a></span> - Static variable in class org.apache.hadoop.hbase.io.hfile.<a href="org/apache/hadoop/hbase/io/hfile/HFilePreadReader.html" title="class in org.apache.hadoop.hbase.io.hfile">HFilePreadReader</a></dt>
 <dd>&nbsp;</dd>
 <dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/io/hfile/HFilePrettyPrinter.html#LOG">LOG</a></span> - Static variable in class org.apache.hadoop.hbase.io.hfile.<a href="org/apache/hadoop/hbase/io/hfile/HFilePrettyPrinter.html" title="class in org.apache.hadoop.hbase.io.hfile">HFilePrettyPrinter</a></dt>
@@ -112473,6 +112477,8 @@ service.</div>
 <div class="block">hbase:slowlog table name - can be enabled
  with config - hbase.regionserver.slowlog.systable.enabled</div>
 </dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#SLOW_METRIC_TIME">SLOW_METRIC_TIME</a></span> - Static variable in class org.apache.hadoop.hbase.regionserver.<a href="org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html" title="class in org.apache.hadoop.hbase.regionserver">MetricsRegionServer</a></dt>
+<dd>&nbsp;</dd>
 <dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/regionserver/MetricsRegionServerSource.html#SLOW_PUT_DESC">SLOW_PUT_DESC</a></span> - Static variable in interface org.apache.hadoop.hbase.regionserver.<a href="org/apache/hadoop/hbase/regionserver/MetricsRegionServerSource.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerSource</a></dt>
 <dd>&nbsp;</dd>
 <dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/regionserver/MetricsRegionServerSource.html#SLOW_PUT_KEY">SLOW_PUT_KEY</a></span> - Static variable in interface org.apache.hadoop.hbase.regionserver.<a href="org/apache/hadoop/hbase/regionserver/MetricsRegionServerSource.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerSource</a></dt>
@@ -112562,6 +112568,8 @@ service.</div>
 </dd>
 <dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/regionserver/HRegionServer.html#slowLogTableOpsChore">slowLogTableOpsChore</a></span> - Variable in class org.apache.hadoop.hbase.regionserver.<a href="org/apache/hadoop/hbase/regionserver/HRegionServer.html" title="class in org.apache.hadoop.hbase.regionserver">HRegionServer</a></dt>
 <dd>&nbsp;</dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#slowMetricTime">slowMetricTime</a></span> - Variable in class org.apache.hadoop.hbase.regionserver.<a href="org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html" title="class in org.apache.hadoop.hbase.regionserver">MetricsRegionServer</a></dt>
+<dd>&nbsp;</dd>
 <dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/regionserver/MetricsRegionServerSourceImpl.html#slowPut">slowPut</a></span> - Variable in class org.apache.hadoop.hbase.regionserver.<a href="org/apache/hadoop/hbase/regionserver/MetricsRegionServerSourceImpl.html" title="class in org.apache.hadoop.hbase.regionserver">MetricsRegionServerSourceImpl</a></dt>
 <dd>&nbsp;</dd>
 <dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/thrift/ThriftMetrics.html#slowResponseTime">slowResponseTime</a></span> - Variable in class org.apache.hadoop.hbase.thrift.<a href="org/apache/hadoop/hbase/thrift/ThriftMetrics.html" title="class in org.apache.hadoop.hbase.thrift">ThriftMetrics</a></dt>
diff --git a/devapidocs/org/apache/hadoop/hbase/backup/package-tree.html b/devapidocs/org/apache/hadoop/hbase/backup/package-tree.html
index 761a9cc..18685bf 100644
--- a/devapidocs/org/apache/hadoop/hbase/backup/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/backup/package-tree.html
@@ -166,10 +166,10 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
 <ul>
+<li type="circle">org.apache.hadoop.hbase.backup.<a href="../../../../../org/apache/hadoop/hbase/backup/BackupType.html" title="enum in org.apache.hadoop.hbase.backup"><span class="typeNameLink">BackupType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.backup.<a href="../../../../../org/apache/hadoop/hbase/backup/BackupRestoreConstants.BackupCommand.html" title="enum in org.apache.hadoop.hbase.backup"><span class="typeNameLink">BackupRestoreConstants.BackupCommand</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.backup.<a href="../../../../../org/apache/hadoop/hbase/backup/BackupInfo.BackupPhase.html" title="enum in org.apache.hadoop.hbase.backup"><span class="typeNameLink">BackupInfo.BackupPhase</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.backup.<a href="../../../../../org/apache/hadoop/hbase/backup/BackupInfo.BackupState.html" title="enum in org.apache.hadoop.hbase.backup"><span class="typeNameLink">BackupInfo.BackupState</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.backup.<a href="../../../../../org/apache/hadoop/hbase/backup/BackupType.html" title="enum in org.apache.hadoop.hbase.backup"><span class="typeNameLink">BackupType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.backup.<a href="../../../../../org/apache/hadoop/hbase/backup/BackupInfo.BackupPhase.html" title="enum in org.apache.hadoop.hbase.backup"><span class="typeNameLink">BackupInfo.BackupPhase</span></a></li>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/chaos/package-tree.html b/devapidocs/org/apache/hadoop/hbase/chaos/package-tree.html
index b17377d..6095a20 100644
--- a/devapidocs/org/apache/hadoop/hbase/chaos/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/chaos/package-tree.html
@@ -103,8 +103,8 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
 <ul>
-<li type="circle">org.apache.hadoop.hbase.chaos.<a href="../../../../../org/apache/hadoop/hbase/chaos/ChaosService.ChaosServiceName.html" title="enum in org.apache.hadoop.hbase.chaos"><span class="typeNameLink">ChaosService.ChaosServiceName</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.chaos.<a href="../../../../../org/apache/hadoop/hbase/chaos/ChaosService.ExecutorAction.html" title="enum in org.apache.hadoop.hbase.chaos"><span class="typeNameLink">ChaosService.ExecutorAction</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.chaos.<a href="../../../../../org/apache/hadoop/hbase/chaos/ChaosService.ChaosServiceName.html" title="enum in org.apache.hadoop.hbase.chaos"><span class="typeNameLink">ChaosService.ChaosServiceName</span></a></li>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html b/devapidocs/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html
index 3bae02e..38d64a8 100644
--- a/devapidocs/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html
+++ b/devapidocs/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html
@@ -761,7 +761,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
 <ul class="blockList">
 <li class="blockList">
 <h4>logCallStack</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.228">logCallStack</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/StackTraceElement.html?is-external=true" title="class or interface in java.lang">StackTraceElement</a>[]&nbsp;stackTraceElements)</pre>
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.229">logCallStack</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/StackTraceElement.html?is-external=true" title="class or interface in java.lang">StackTraceElement</a>[]&nbsp;stackTraceElements)</pre>
 </li>
 </ul>
 <a name="getRegionLocator-org.apache.hadoop.hbase.TableName-">
@@ -770,7 +770,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
 <ul class="blockList">
 <li class="blockList">
 <h4>getRegionLocator</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/AsyncTableRegionLocator.html" title="interface in org.apache.hadoop.hbase.client">AsyncTableRegionLocator</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.239">getRegionLocator</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName)</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/AsyncTableRegionLocator.html" title="interface in org.apache.hadoop.hbase.client">AsyncTableRegionLocator</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.240">getRegionLocator</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName)</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnection.html#getRegionLocator-org.apache.hadoop.hbase.TableName-">AsyncConnection</a></code></span></div>
 <div class="block">Retrieve a AsyncRegionLocator implementation to inspect region information on a table. The
  returned AsyncRegionLocator is not thread-safe, so a new instance should be created for each
@@ -792,7 +792,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
 <ul class="blockList">
 <li class="blockList">
 <h4>clearRegionLocationCache</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.244">clearRegionLocationCache</a>()</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.245">clearRegionLocationCache</a>()</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnection.html#clearRegionLocationCache--">AsyncConnection</a></code></span></div>
 <div class="block">Clear all the entries in the region location cache, for all the tables.
  <p/>
@@ -812,7 +812,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
 <ul class="blockList">
 <li class="blockList">
 <h4>getLocator</h4>
-<pre><a href="../../../../../org/apache/hadoop/hbase/client/AsyncRegionLocator.html" title="class in org.apache.hadoop.hbase.client">AsyncRegionLocator</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.249">getLocator</a>()</pre>
+<pre><a href="../../../../../org/apache/hadoop/hbase/client/AsyncRegionLocator.html" title="class in org.apache.hadoop.hbase.client">AsyncRegionLocator</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.250">getLocator</a>()</pre>
 </li>
 </ul>
 <a name="getNonceGenerator--">
@@ -821,7 +821,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
 <ul class="blockList">
 <li class="blockList">
 <h4>getNonceGenerator</h4>
-<pre><a href="../../../../../org/apache/hadoop/hbase/client/NonceGenerator.html" title="interface in org.apache.hadoop.hbase.client">NonceGenerator</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.254">getNonceGenerator</a>()</pre>
+<pre><a href="../../../../../org/apache/hadoop/hbase/client/NonceGenerator.html" title="interface in org.apache.hadoop.hbase.client">NonceGenerator</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.255">getNonceGenerator</a>()</pre>
 </li>
 </ul>
 <a name="createRegionServerStub-org.apache.hadoop.hbase.ServerName-">
@@ -830,7 +830,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
 <ul class="blockList">
 <li class="blockList">
 <h4>createRegionServerStub</h4>
-<pre>private&nbsp;org.apache.hadoop.hbase.shaded.protobuf.generated.ClientProtos.ClientService.Interface&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.258">createRegionServerStub</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;serverName)
+<pre>private&nbsp;org.apache.hadoop.hbase.shaded.protobuf.generated.ClientProtos.ClientService.Interface&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.259">createRegionServerStub</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;serverName)
                                                                                                                throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <dl>
 <dt><span class="throwsLabel">Throws:</span></dt>
@@ -844,7 +844,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
 <ul class="blockList">
 <li class="blockList">
 <h4>getRegionServerStub</h4>
-<pre>org.apache.hadoop.hbase.shaded.protobuf.generated.ClientProtos.ClientService.Interface&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.262">getRegionServerStub</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;serverName)
+<pre>org.apache.hadoop.hbase.shaded.protobuf.generated.ClientProtos.ClientService.Interface&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.263">getRegionServerStub</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;serverName)
                                                                                                     throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <dl>
 <dt><span class="throwsLabel">Throws:</span></dt>
@@ -858,7 +858,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
 <ul class="blockList">
 <li class="blockList">
 <h4>createMasterStub</h4>
-<pre>private&nbsp;org.apache.hadoop.hbase.shaded.protobuf.generated.MasterProtos.MasterService.Interface&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.268">createMasterStub</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;serverName)
+<pre>private&nbsp;org.apache.hadoop.hbase.shaded.protobuf.generated.MasterProtos.MasterService.Interface&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.269">createMasterStub</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;serverName)
                                                                                                          throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <dl>
 <dt><span class="throwsLabel">Throws:</span></dt>
@@ -872,7 +872,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
 <ul class="blockList">
 <li class="blockList">
 <h4>createAdminServerStub</h4>
-<pre>private&nbsp;org.apache.hadoop.hbase.shaded.protobuf.generated.AdminProtos.AdminService.Interface&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.272">createAdminServerStub</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;serverName)
+<pre>private&nbsp;org.apache.hadoop.hbase.shaded.protobuf.generated.AdminProtos.AdminService.Interface&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.273">createAdminServerStub</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;serverName)
                                                                                                             throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <dl>
 <dt><span class="throwsLabel">Throws:</span></dt>
@@ -886,7 +886,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
 <ul class="blockList">
 <li class="blockList">
 <h4>getAdminStub</h4>
-<pre>org.apache.hadoop.hbase.shaded.protobuf.generated.AdminProtos.AdminService.Interface&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.276">getAdminStub</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;serverName)
+<pre>org.apache.hadoop.hbase.shaded.protobuf.generated.AdminProtos.AdminService.Interface&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.277">getAdminStub</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;serverName)
                                                                                            throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <dl>
 <dt><span class="throwsLabel">Throws:</span></dt>
@@ -900,7 +900,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
 <ul class="blockList">
 <li class="blockList">
 <h4>getMasterStub</h4>
-<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/CompletableFuture.html?is-external=true" title="class or interface in java.util.concurrent">CompletableFuture</a>&lt;org.apache.hadoop.hbase.shaded.protobuf.generated.MasterProtos.MasterService.Interface&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.282">getMasterStub</a>()</pre>
+<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/CompletableFuture.html?is-external=true" title="class or interface in java.util.concurrent">CompletableFuture</a>&lt;org.apache.hadoop.hbase.shaded.protobuf.generated.MasterProtos.MasterService.Interface&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.283">getMasterStub</a>()</pre>
 </li>
 </ul>
 <a name="getClusterId--">
@@ -909,7 +909,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
 <ul class="blockList">
 <li class="blockList">
 <h4>getClusterId</h4>
-<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.305">getClusterId</a>()</pre>
+<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.306">getClusterId</a>()</pre>
 </li>
 </ul>
 <a name="clearMasterStubCache-org.apache.hadoop.hbase.shaded.protobuf.generated.MasterProtos.MasterService.Interface-">
@@ -918,7 +918,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
 <ul class="blockList">
 <li class="blockList">
 <h4>clearMasterStubCache</h4>
-<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.314">clearMasterStubCache</a>(org.apache.hadoop.hbase.shaded.protobuf.generated.MasterProtos.MasterService.Interface&nbsp;stub)</pre>
+<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.315">clearMasterStubCache</a>(org.apache.hadoop.hbase.shaded.protobuf.generated.MasterProtos.MasterService.Interface&nbsp;stub)</pre>
 </li>
 </ul>
 <a name="getStatisticsTracker--">
@@ -927,7 +927,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
 <ul class="blockList">
 <li class="blockList">
 <h4>getStatisticsTracker</h4>
-<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Optional.html?is-external=true" title="class or interface in java.util">Optional</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/client/ServerStatisticTracker.html" title="class in org.apache.hadoop.hbase.client">ServerStatisticTracker</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.318">getStatisticsTracker</a>()</pre>
+<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Optional.html?is-external=true" title="class or interface in java.util">Optional</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/client/ServerStatisticTracker.html" title="class in org.apache.hadoop.hbase.client">ServerStatisticTracker</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.319">getStatisticsTracker</a>()</pre>
 </li>
 </ul>
 <a name="getBackoffPolicy--">
@@ -936,7 +936,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
 <ul class="blockList">
 <li class="blockList">
 <h4>getBackoffPolicy</h4>
-<pre><a href="../../../../../org/apache/hadoop/hbase/client/backoff/ClientBackoffPolicy.html" title="interface in org.apache.hadoop.hbase.client.backoff">ClientBackoffPolicy</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.322">getBackoffPolicy</a>()</pre>
+<pre><a href="../../../../../org/apache/hadoop/hbase/client/backoff/ClientBackoffPolicy.html" title="interface in org.apache.hadoop.hbase.client.backoff">ClientBackoffPolicy</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.323">getBackoffPolicy</a>()</pre>
 </li>
 </ul>
 <a name="getTableBuilder-org.apache.hadoop.hbase.TableName-">
@@ -945,7 +945,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
 <ul class="blockList">
 <li class="blockList">
 <h4>getTableBuilder</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/AsyncTableBuilder.html" title="interface in org.apache.hadoop.hbase.client">AsyncTableBuilder</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/client/AdvancedScanResultConsumer.html" title="interface in org.apache.hadoop.hbase.client">AdvancedScanResultConsumer</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.327">getTableBuilder</a>(<a href="../../../.. [...]
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/AsyncTableBuilder.html" title="interface in org.apache.hadoop.hbase.client">AsyncTableBuilder</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/client/AdvancedScanResultConsumer.html" title="interface in org.apache.hadoop.hbase.client">AdvancedScanResultConsumer</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.328">getTableBuilder</a>(<a href="../../../.. [...]
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnection.html#getTableBuilder-org.apache.hadoop.hbase.TableName-">AsyncConnection</a></code></span></div>
 <div class="block">Returns an <a href="../../../../../org/apache/hadoop/hbase/client/AsyncTableBuilder.html" title="interface in org.apache.hadoop.hbase.client"><code>AsyncTableBuilder</code></a> for creating <a href="../../../../../org/apache/hadoop/hbase/client/AsyncTable.html" title="interface in org.apache.hadoop.hbase.client"><code>AsyncTable</code></a>.
  <p>
@@ -965,7 +965,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
 <ul class="blockList">
 <li class="blockList">
 <h4>getTableBuilder</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/AsyncTableBuilder.html" title="interface in org.apache.hadoop.hbase.client">AsyncTableBuilder</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/client/ScanResultConsumer.html" title="interface in org.apache.hadoop.hbase.client">ScanResultConsumer</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.338">getTableBuilder</a>(<a href="../../../../../org/apache/h [...]
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/AsyncTableBuilder.html" title="interface in org.apache.hadoop.hbase.client">AsyncTableBuilder</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/client/ScanResultConsumer.html" title="interface in org.apache.hadoop.hbase.client">ScanResultConsumer</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.339">getTableBuilder</a>(<a href="../../../../../org/apache/h [...]
                                                              <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/ExecutorService.html?is-external=true" title="class or interface in java.util.concurrent">ExecutorService</a>&nbsp;pool)</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnection.html#getTableBuilder-org.apache.hadoop.hbase.TableName-java.util.concurrent.ExecutorService-">AsyncConnection</a></code></span></div>
 <div class="block">Returns an <a href="../../../../../org/apache/hadoop/hbase/client/AsyncTableBuilder.html" title="interface in org.apache.hadoop.hbase.client"><code>AsyncTableBuilder</code></a> for creating <a href="../../../../../org/apache/hadoop/hbase/client/AsyncTable.html" title="interface in org.apache.hadoop.hbase.client"><code>AsyncTable</code></a>.
@@ -987,7 +987,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
 <ul class="blockList">
 <li class="blockList">
 <h4>getAdminBuilder</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/AsyncAdminBuilder.html" title="interface in org.apache.hadoop.hbase.client">AsyncAdminBuilder</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.352">getAdminBuilder</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/AsyncAdminBuilder.html" title="interface in org.apache.hadoop.hbase.client">AsyncAdminBuilder</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.353">getAdminBuilder</a>()</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnection.html#getAdminBuilder--">AsyncConnection</a></code></span></div>
 <div class="block">Returns an <a href="../../../../../org/apache/hadoop/hbase/client/AsyncAdminBuilder.html" title="interface in org.apache.hadoop.hbase.client"><code>AsyncAdminBuilder</code></a> for creating <a href="../../../../../org/apache/hadoop/hbase/client/AsyncAdmin.html" title="interface in org.apache.hadoop.hbase.client"><code>AsyncAdmin</code></a>.
  <p>
@@ -1006,7 +1006,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
 <ul class="blockList">
 <li class="blockList">
 <h4>getAdminBuilder</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/AsyncAdminBuilder.html" title="interface in org.apache.hadoop.hbase.client">AsyncAdminBuilder</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.362">getAdminBuilder</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/ExecutorService.html?is-external=true" title="class or interface in java.util.concurrent">ExecutorService</a>&nbsp;pool)</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/AsyncAdminBuilder.html" title="interface in org.apache.hadoop.hbase.client">AsyncAdminBuilder</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.363">getAdminBuilder</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/ExecutorService.html?is-external=true" title="class or interface in java.util.concurrent">ExecutorService</a>&nbsp;pool)</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnection.html#getAdminBuilder-java.util.concurrent.ExecutorService-">AsyncConnection</a></code></span></div>
 <div class="block">Returns an <a href="../../../../../org/apache/hadoop/hbase/client/AsyncAdminBuilder.html" title="interface in org.apache.hadoop.hbase.client"><code>AsyncAdminBuilder</code></a> for creating <a href="../../../../../org/apache/hadoop/hbase/client/AsyncAdmin.html" title="interface in org.apache.hadoop.hbase.client"><code>AsyncAdmin</code></a>.</div>
 <dl>
@@ -1023,7 +1023,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
 <ul class="blockList">
 <li class="blockList">
 <h4>getBufferedMutatorBuilder</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/AsyncBufferedMutatorBuilder.html" title="interface in org.apache.hadoop.hbase.client">AsyncBufferedMutatorBuilder</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.374">getBufferedMutatorBuilder</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName)</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/AsyncBufferedMutatorBuilder.html" title="interface in org.apache.hadoop.hbase.client">AsyncBufferedMutatorBuilder</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.375">getBufferedMutatorBuilder</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName)</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnection.html#getBufferedMutatorBuilder-org.apache.hadoop.hbase.TableName-">AsyncConnection</a></code></span></div>
 <div class="block">Returns an <a href="../../../../../org/apache/hadoop/hbase/client/AsyncBufferedMutatorBuilder.html" title="interface in org.apache.hadoop.hbase.client"><code>AsyncBufferedMutatorBuilder</code></a> for creating <a href="../../../../../org/apache/hadoop/hbase/client/AsyncBufferedMutator.html" title="interface in org.apache.hadoop.hbase.client"><code>AsyncBufferedMutator</code></a>.</div>
 <dl>
@@ -1040,7 +1040,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
 <ul class="blockList">
 <li class="blockList">
 <h4>getBufferedMutatorBuilder</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/AsyncBufferedMutatorBuilder.html" title="interface in org.apache.hadoop.hbase.client">AsyncBufferedMutatorBuilder</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.379">getBufferedMutatorBuilder</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName,
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/AsyncBufferedMutatorBuilder.html" title="interface in org.apache.hadoop.hbase.client">AsyncBufferedMutatorBuilder</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.380">getBufferedMutatorBuilder</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName,
                                                              <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/ExecutorService.html?is-external=true" title="class or interface in java.util.concurrent">ExecutorService</a>&nbsp;pool)</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnection.html#getBufferedMutatorBuilder-org.apache.hadoop.hbase.TableName-java.util.concurrent.ExecutorService-">AsyncConnection</a></code></span></div>
 <div class="block">Returns an <a href="../../../../../org/apache/hadoop/hbase/client/AsyncBufferedMutatorBuilder.html" title="interface in org.apache.hadoop.hbase.client"><code>AsyncBufferedMutatorBuilder</code></a> for creating <a href="../../../../../org/apache/hadoop/hbase/client/AsyncBufferedMutator.html" title="interface in org.apache.hadoop.hbase.client"><code>AsyncBufferedMutator</code></a>.</div>
@@ -1059,7 +1059,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
 <ul class="blockList">
 <li class="blockList">
 <h4>toConnection</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.386">toConnection</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.387">toConnection</a>()</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnection.html#toConnection--">AsyncConnection</a></code></span></div>
 <div class="block">Convert this connection to a <a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client"><code>Connection</code></a>.
  <p/>
@@ -1077,7 +1077,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
 <ul class="blockList">
 <li class="blockList">
 <h4>getHbck</h4>
-<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/CompletableFuture.html?is-external=true" title="class or interface in java.util.concurrent">CompletableFuture</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/client/Hbck.html" title="interface in org.apache.hadoop.hbase.client">Hbck</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.403">getHbck</a>()</pre>
+<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/CompletableFuture.html?is-external=true" title="class or interface in java.util.concurrent">CompletableFuture</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/client/Hbck.html" title="interface in org.apache.hadoop.hbase.client">Hbck</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.404">getHbck</a>()</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnection.html#getHbck--">AsyncConnection</a></code></span></div>
 <div class="block">Retrieve an Hbck implementation to fix an HBase cluster. The returned Hbck is not guaranteed to
  be thread-safe. A new instance should be created by each thread. This is a lightweight
@@ -1100,7 +1100,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
 <ul class="blockList">
 <li class="blockList">
 <h4>getHbck</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/Hbck.html" title="interface in org.apache.hadoop.hbase.client">Hbck</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.420">getHbck</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;masterServer)
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/Hbck.html" title="interface in org.apache.hadoop.hbase.client">Hbck</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.421">getHbck</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;masterServer)
              throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnection.html#getHbck-org.apache.hadoop.hbase.ServerName-">AsyncConnection</a></code></span></div>
 <div class="block">Retrieve an Hbck implementation to fix an HBase cluster. The returned Hbck is not guaranteed to
@@ -1130,7 +1130,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
 <ul class="blockListLast">
 <li class="blockList">
 <h4>getConnectionMetrics</h4>
-<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Optional.html?is-external=true" title="class or interface in java.util">Optional</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/client/MetricsConnection.html" title="class in org.apache.hadoop.hbase.client">MetricsConnection</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.428">getConnectionMetrics</a>()</pre>
+<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Optional.html?is-external=true" title="class or interface in java.util">Optional</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/client/MetricsConnection.html" title="class in org.apache.hadoop.hbase.client">MetricsConnection</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.429">getConnectionMetrics</a>()</pre>
 </li>
 </ul>
 </li>
diff --git a/devapidocs/org/apache/hadoop/hbase/client/package-tree.html b/devapidocs/org/apache/hadoop/hbase/client/package-tree.html
index 67e0bb1..a58c7cb 100644
--- a/devapidocs/org/apache/hadoop/hbase/client/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/client/package-tree.html
@@ -455,23 +455,23 @@
 <ul>
 <li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/LogQueryFilter.Type.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">LogQueryFilter.Type</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/LogQueryFilter.FilterByOperator.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">LogQueryFilter.FilterByOperator</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/ServerType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">ServerType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/CatalogReplicaMode.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">CatalogReplicaMode</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/RequestController.ReturnCode.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">RequestController.ReturnCode</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/AsyncScanSingleRegionRpcRetryingCaller.ScanResumerState.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">AsyncScanSingleRegionRpcRetryingCaller.ScanResumerState</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/IsolationLevel.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">IsolationLevel</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/TableState.State.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">TableState.State</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/AbstractResponse.ResponseType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">AbstractResponse.ResponseType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/Consistency.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">Consistency</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/TableState.State.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">TableState.State</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/IsolationLevel.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">IsolationLevel</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/Durability.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">Durability</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/CompactionState.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">CompactionState</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/ServerType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">ServerType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/SnapshotType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">SnapshotType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/CatalogReplicaMode.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">CatalogReplicaMode</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/MasterSwitchType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">MasterSwitchType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/RegionLocateType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">RegionLocateType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/AsyncScanSingleRegionRpcRetryingCaller.ScanResumerState.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">AsyncScanSingleRegionRpcRetryingCaller.ScanResumerState</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/RequestController.ReturnCode.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">RequestController.ReturnCode</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/CompactType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">CompactType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/AsyncScanSingleRegionRpcRetryingCaller.ScanControllerState.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">AsyncScanSingleRegionRpcRetryingCaller.ScanControllerState</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/Durability.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">Durability</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/MobCompactPartitionPolicy.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">MobCompactPartitionPolicy</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/AbstractResponse.ResponseType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">AbstractResponse.ResponseType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/Scan.ReadType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">Scan.ReadType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/CompactType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">CompactType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/MasterSwitchType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">MasterSwitchType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/SnapshotType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">SnapshotType</span></a></li>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/coprocessor/package-tree.html b/devapidocs/org/apache/hadoop/hbase/coprocessor/package-tree.html
index b99c6c6..6b1ffff 100644
--- a/devapidocs/org/apache/hadoop/hbase/coprocessor/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/coprocessor/package-tree.html
@@ -181,8 +181,8 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
 <ul>
-<li type="circle">org.apache.hadoop.hbase.coprocessor.<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionObserver.MutationType.html" title="enum in org.apache.hadoop.hbase.coprocessor"><span class="typeNameLink">RegionObserver.MutationType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.coprocessor.<a href="../../../../../org/apache/hadoop/hbase/coprocessor/MetaTableMetrics.MetaTableOps.html" title="enum in org.apache.hadoop.hbase.coprocessor"><span class="typeNameLink">MetaTableMetrics.MetaTableOps</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.coprocessor.<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionObserver.MutationType.html" title="enum in org.apache.hadoop.hbase.coprocessor"><span class="typeNameLink">RegionObserver.MutationType</span></a></li>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/filter/package-tree.html b/devapidocs/org/apache/hadoop/hbase/filter/package-tree.html
index c00a7c6..42cd278 100644
--- a/devapidocs/org/apache/hadoop/hbase/filter/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/filter/package-tree.html
@@ -190,13 +190,13 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
 <ul>
+<li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/FuzzyRowFilter.SatisfiesCode.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">FuzzyRowFilter.SatisfiesCode</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/FilterWrapper.FilterRowRetCode.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">FilterWrapper.FilterRowRetCode</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/FilterList.Operator.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">FilterList.Operator</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/BitComparator.BitwiseOp.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">BitComparator.BitwiseOp</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/RegexStringComparator.EngineType.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">RegexStringComparator.EngineType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/FuzzyRowFilter.SatisfiesCode.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">FuzzyRowFilter.SatisfiesCode</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/FuzzyRowFilter.Order.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">FuzzyRowFilter.Order</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/Filter.ReturnCode.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">Filter.ReturnCode</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/FilterWrapper.FilterRowRetCode.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">FilterWrapper.FilterRowRetCode</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/FilterList.Operator.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">FilterList.Operator</span></a></li>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/hbtop/terminal/package-tree.html b/devapidocs/org/apache/hadoop/hbase/hbtop/terminal/package-tree.html
index 007e90f..b8f3866 100644
--- a/devapidocs/org/apache/hadoop/hbase/hbtop/terminal/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/hbtop/terminal/package-tree.html
@@ -107,8 +107,8 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
 <ul>
-<li type="circle">org.apache.hadoop.hbase.hbtop.terminal.<a href="../../../../../../org/apache/hadoop/hbase/hbtop/terminal/KeyPress.Type.html" title="enum in org.apache.hadoop.hbase.hbtop.terminal"><span class="typeNameLink">KeyPress.Type</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.hbtop.terminal.<a href="../../../../../../org/apache/hadoop/hbase/hbtop/terminal/Color.html" title="enum in org.apache.hadoop.hbase.hbtop.terminal"><span class="typeNameLink">Color</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.hbtop.terminal.<a href="../../../../../../org/apache/hadoop/hbase/hbtop/terminal/KeyPress.Type.html" title="enum in org.apache.hadoop.hbase.hbtop.terminal"><span class="typeNameLink">KeyPress.Type</span></a></li>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/http/package-tree.html b/devapidocs/org/apache/hadoop/hbase/http/package-tree.html
index f761cc1..085883a 100644
--- a/devapidocs/org/apache/hadoop/hbase/http/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/http/package-tree.html
@@ -140,9 +140,9 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
 <ul>
-<li type="circle">org.apache.hadoop.hbase.http.<a href="../../../../../org/apache/hadoop/hbase/http/ProfileServlet.Output.html" title="enum in org.apache.hadoop.hbase.http"><span class="typeNameLink">ProfileServlet.Output</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.http.<a href="../../../../../org/apache/hadoop/hbase/http/ProfileServlet.Event.html" title="enum in org.apache.hadoop.hbase.http"><span class="typeNameLink">ProfileServlet.Event</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.http.<a href="../../../../../org/apache/hadoop/hbase/http/HttpConfig.Policy.html" title="enum in org.apache.hadoop.hbase.http"><span class="typeNameLink">HttpConfig.Policy</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.http.<a href="../../../../../org/apache/hadoop/hbase/http/ProfileServlet.Event.html" title="enum in org.apache.hadoop.hbase.http"><span class="typeNameLink">ProfileServlet.Event</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.http.<a href="../../../../../org/apache/hadoop/hbase/http/ProfileServlet.Output.html" title="enum in org.apache.hadoop.hbase.http"><span class="typeNameLink">ProfileServlet.Output</span></a></li>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/io/hfile/HFile.html b/devapidocs/org/apache/hadoop/hbase/io/hfile/HFile.html
index be0fd90..e2d86e4 100644
--- a/devapidocs/org/apache/hadoop/hbase/io/hfile/HFile.html
+++ b/devapidocs/org/apache/hadoop/hbase/io/hfile/HFile.html
@@ -782,7 +782,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>createReader</h4>
-<pre>public static&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFile.Reader.html" title="interface in org.apache.hadoop.hbase.io.hfile">HFile.Reader</a>&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.525">createReader</a>(org.apache.hadoop.fs.FileSystem&nbsp;fs,
+<pre>public static&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFile.Reader.html" title="interface in org.apache.hadoop.hbase.io.hfile">HFile.Reader</a>&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.526">createReader</a>(org.apache.hadoop.fs.FileSystem&nbsp;fs,
                                         org.apache.hadoop.fs.Path&nbsp;path,
                                         org.apache.hadoop.conf.Configuration&nbsp;conf)
                                  throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
@@ -806,7 +806,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>createReader</h4>
-<pre>public static&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFile.Reader.html" title="interface in org.apache.hadoop.hbase.io.hfile">HFile.Reader</a>&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.543">createReader</a>(org.apache.hadoop.fs.FileSystem&nbsp;fs,
+<pre>public static&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFile.Reader.html" title="interface in org.apache.hadoop.hbase.io.hfile">HFile.Reader</a>&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.544">createReader</a>(org.apache.hadoop.fs.FileSystem&nbsp;fs,
                                         org.apache.hadoop.fs.Path&nbsp;path,
                                         <a href="../../../../../../org/apache/hadoop/hbase/io/hfile/CacheConfig.html" title="class in org.apache.hadoop.hbase.io.hfile">CacheConfig</a>&nbsp;cacheConf,
                                         boolean&nbsp;primaryReplicaReader,
@@ -834,7 +834,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>isHFileFormat</h4>
-<pre>public static&nbsp;boolean&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.568">isHFileFormat</a>(org.apache.hadoop.fs.FileSystem&nbsp;fs,
+<pre>public static&nbsp;boolean&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.569">isHFileFormat</a>(org.apache.hadoop.fs.FileSystem&nbsp;fs,
                                     org.apache.hadoop.fs.Path&nbsp;path)
                              throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block">Returns true if the specified file has a valid HFile Trailer.</div>
@@ -855,7 +855,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>isHFileFormat</h4>
-<pre>public static&nbsp;boolean&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.579">isHFileFormat</a>(org.apache.hadoop.fs.FileSystem&nbsp;fs,
+<pre>public static&nbsp;boolean&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.580">isHFileFormat</a>(org.apache.hadoop.fs.FileSystem&nbsp;fs,
                                     org.apache.hadoop.fs.FileStatus&nbsp;fileStatus)
                              throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block">Returns true if the specified file has a valid HFile Trailer.</div>
@@ -876,7 +876,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>getSupportedCompressionAlgorithms</h4>
-<pre>public static&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>[]&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.605">getSupportedCompressionAlgorithms</a>()</pre>
+<pre>public static&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>[]&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.606">getSupportedCompressionAlgorithms</a>()</pre>
 <div class="block">Get names of supported compression algorithms. The names are acceptable by
  HFile.Writer.</div>
 <dl>
@@ -897,7 +897,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>longToInt</h4>
-<pre>static&nbsp;int&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.614">longToInt</a>(long&nbsp;l)</pre>
+<pre>static&nbsp;int&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.615">longToInt</a>(long&nbsp;l)</pre>
 </li>
 </ul>
 <a name="getStoreFiles-org.apache.hadoop.fs.FileSystem-org.apache.hadoop.fs.Path-">
@@ -906,7 +906,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>getStoreFiles</h4>
-<pre>public static&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a>&lt;org.apache.hadoop.fs.Path&gt;&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.629">getStoreFiles</a>(org.apache.hadoop.fs.FileSystem&nbsp;fs,
+<pre>public static&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a>&lt;org.apache.hadoop.fs.Path&gt;&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.630">getStoreFiles</a>(org.apache.hadoop.fs.FileSystem&nbsp;fs,
                                                             org.apache.hadoop.fs.Path&nbsp;regionDir)
                                                      throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block">Returns all HFiles belonging to the given region directory. Could return an
@@ -928,7 +928,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>checkFormatVersion</h4>
-<pre>public static&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.656">checkFormatVersion</a>(int&nbsp;version)
+<pre>public static&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.657">checkFormatVersion</a>(int&nbsp;version)
                                throws <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/IllegalArgumentException.html?is-external=true" title="class or interface in java.lang">IllegalArgumentException</a></pre>
 <div class="block">Checks the given <a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFile.html" title="class in org.apache.hadoop.hbase.io.hfile"><code>HFile</code></a> format version, and throws an exception if
  invalid. Note that if the version number comes from an input file and has
@@ -948,7 +948,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>checkHFileVersion</h4>
-<pre>public static&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.666">checkHFileVersion</a>(org.apache.hadoop.conf.Configuration&nbsp;c)</pre>
+<pre>public static&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.667">checkHFileVersion</a>(org.apache.hadoop.conf.Configuration&nbsp;c)</pre>
 </li>
 </ul>
 <a name="main-java.lang.String:A-">
@@ -957,7 +957,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockListLast">
 <li class="blockList">
 <h4>main</h4>
-<pre>public static&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.677">main</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>[]&nbsp;args)
+<pre>public static&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.678">main</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>[]&nbsp;args)
                  throws <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Exception.html?is-external=true" title="class or interface in java.lang">Exception</a></pre>
 <dl>
 <dt><span class="throwsLabel">Throws:</span></dt>
diff --git a/devapidocs/org/apache/hadoop/hbase/io/hfile/HFileInfo.html b/devapidocs/org/apache/hadoop/hbase/io/hfile/HFileInfo.html
index 94378ad..3024499 100644
--- a/devapidocs/org/apache/hadoop/hbase/io/hfile/HFileInfo.html
+++ b/devapidocs/org/apache/hadoop/hbase/io/hfile/HFileInfo.html
@@ -114,7 +114,7 @@ var activeTableTab = "activeTableTab";
 <hr>
 <br>
 <pre>@InterfaceAudience.Private
-public class <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.64">HFileInfo</a>
+public class <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.68">HFileInfo</a>
 extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a>
 implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a>&lt;byte[],byte[]&gt;</pre>
 <div class="block">Metadata Map of attributes for HFile written out as HFile Trailer. Created by the Writer and
@@ -227,42 +227,46 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 </td>
 </tr>
 <tr class="rowColor">
+<td class="colFirst"><code>private static org.slf4j.Logger</code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileInfo.html#LOG">LOG</a></span></code>&nbsp;</td>
+</tr>
+<tr class="altColor">
 <td class="colFirst"><code>private <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a>&lt;byte[],byte[]&gt;</code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileInfo.html#map">map</a></span></code>&nbsp;</td>
 </tr>
-<tr class="altColor">
+<tr class="rowColor">
 <td class="colFirst"><code>(package private) static int</code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileInfo.html#MAX_MINOR_VERSION">MAX_MINOR_VERSION</a></span></code>
 <div class="block">Maximum minor version supported by this HFile format</div>
 </td>
 </tr>
-<tr class="rowColor">
+<tr class="altColor">
 <td class="colFirst"><code>static byte[]</code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileInfo.html#MAX_TAGS_LEN">MAX_TAGS_LEN</a></span></code>&nbsp;</td>
 </tr>
-<tr class="altColor">
+<tr class="rowColor">
 <td class="colFirst"><code>private <a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileBlockIndex.ByteArrayKeyBlockIndexReader.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileBlockIndex.ByteArrayKeyBlockIndexReader</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileInfo.html#metaIndexReader">metaIndexReader</a></span></code>&nbsp;</td>
 </tr>
-<tr class="rowColor">
+<tr class="altColor">
 <td class="colFirst"><code>private static int</code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileInfo.html#MIN_V2_MINOR_VERSION_WITH_PB">MIN_V2_MINOR_VERSION_WITH_PB</a></span></code>
 <div class="block">We can read files whose major version is v2 IFF their minor version is at least 3.</div>
 </td>
 </tr>
-<tr class="altColor">
+<tr class="rowColor">
 <td class="colFirst"><code>(package private) static <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileInfo.html#RESERVED_PREFIX">RESERVED_PREFIX</a></span></code>&nbsp;</td>
 </tr>
-<tr class="rowColor">
+<tr class="altColor">
 <td class="colFirst"><code>(package private) static byte[]</code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileInfo.html#RESERVED_PREFIX_BYTES">RESERVED_PREFIX_BYTES</a></span></code>&nbsp;</td>
 </tr>
-<tr class="altColor">
+<tr class="rowColor">
 <td class="colFirst"><code>(package private) static byte[]</code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileInfo.html#TAGS_COMPRESSED">TAGS_COMPRESSED</a></span></code>&nbsp;</td>
 </tr>
-<tr class="rowColor">
+<tr class="altColor">
 <td class="colFirst"><code>private <a href="../../../../../../org/apache/hadoop/hbase/io/hfile/FixedFileTrailer.html" title="class in org.apache.hadoop.hbase.io.hfile">FixedFileTrailer</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileInfo.html#trailer">trailer</a></span></code>&nbsp;</td>
 </tr>
@@ -532,13 +536,22 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <!--   -->
 </a>
 <h3>Field Detail</h3>
+<a name="LOG">
+<!--   -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>LOG</h4>
+<pre>private static final&nbsp;org.slf4j.Logger <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.70">LOG</a></pre>
+</li>
+</ul>
 <a name="RESERVED_PREFIX">
 <!--   -->
 </a>
 <ul class="blockList">
 <li class="blockList">
 <h4>RESERVED_PREFIX</h4>
-<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.65">RESERVED_PREFIX</a></pre>
+<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.72">RESERVED_PREFIX</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../../constant-values.html#org.apache.hadoop.hbase.io.hfile.HFileInfo.RESERVED_PREFIX">Constant Field Values</a></dd>
@@ -551,7 +564,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>RESERVED_PREFIX_BYTES</h4>
-<pre>static final&nbsp;byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.66">RESERVED_PREFIX_BYTES</a></pre>
+<pre>static final&nbsp;byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.73">RESERVED_PREFIX_BYTES</a></pre>
 </li>
 </ul>
 <a name="LASTKEY">
@@ -560,7 +573,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>LASTKEY</h4>
-<pre>static final&nbsp;byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.67">LASTKEY</a></pre>
+<pre>static final&nbsp;byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.74">LASTKEY</a></pre>
 </li>
 </ul>
 <a name="AVG_KEY_LEN">
@@ -569,7 +582,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>AVG_KEY_LEN</h4>
-<pre>static final&nbsp;byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.68">AVG_KEY_LEN</a></pre>
+<pre>static final&nbsp;byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.75">AVG_KEY_LEN</a></pre>
 </li>
 </ul>
 <a name="AVG_VALUE_LEN">
@@ -578,7 +591,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>AVG_VALUE_LEN</h4>
-<pre>static final&nbsp;byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.69">AVG_VALUE_LEN</a></pre>
+<pre>static final&nbsp;byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.76">AVG_VALUE_LEN</a></pre>
 </li>
 </ul>
 <a name="CREATE_TIME_TS">
@@ -587,7 +600,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>CREATE_TIME_TS</h4>
-<pre>static final&nbsp;byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.70">CREATE_TIME_TS</a></pre>
+<pre>static final&nbsp;byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.77">CREATE_TIME_TS</a></pre>
 </li>
 </ul>
 <a name="TAGS_COMPRESSED">
@@ -596,7 +609,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>TAGS_COMPRESSED</h4>
-<pre>static final&nbsp;byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.71">TAGS_COMPRESSED</a></pre>
+<pre>static final&nbsp;byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.78">TAGS_COMPRESSED</a></pre>
 </li>
 </ul>
 <a name="MAX_TAGS_LEN">
@@ -605,7 +618,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>MAX_TAGS_LEN</h4>
-<pre>public static final&nbsp;byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.72">MAX_TAGS_LEN</a></pre>
+<pre>public static final&nbsp;byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.79">MAX_TAGS_LEN</a></pre>
 </li>
 </ul>
 <a name="map">
@@ -614,7 +627,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>map</h4>
-<pre>private final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a>&lt;byte[],byte[]&gt; <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.73">map</a></pre>
+<pre>private final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a>&lt;byte[],byte[]&gt; <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.80">map</a></pre>
 </li>
 </ul>
 <a name="MIN_V2_MINOR_VERSION_WITH_PB">
@@ -623,7 +636,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>MIN_V2_MINOR_VERSION_WITH_PB</h4>
-<pre>private static final&nbsp;int <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.78">MIN_V2_MINOR_VERSION_WITH_PB</a></pre>
+<pre>private static final&nbsp;int <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.85">MIN_V2_MINOR_VERSION_WITH_PB</a></pre>
 <div class="block">We can read files whose major version is v2 IFF their minor version is at least 3.</div>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
@@ -637,7 +650,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>MAX_MINOR_VERSION</h4>
-<pre>static final&nbsp;int <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.83">MAX_MINOR_VERSION</a></pre>
+<pre>static final&nbsp;int <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.90">MAX_MINOR_VERSION</a></pre>
 <div class="block">Maximum minor version supported by this HFile format</div>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
@@ -651,7 +664,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>lastKeyCell</h4>
-<pre>private&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/Cell.html" title="interface in org.apache.hadoop.hbase">Cell</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.86">lastKeyCell</a></pre>
+<pre>private&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/Cell.html" title="interface in org.apache.hadoop.hbase">Cell</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.93">lastKeyCell</a></pre>
 <div class="block">Last key in the file. Filled in when we read in the file info</div>
 </li>
 </ul>
@@ -661,7 +674,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>avgKeyLen</h4>
-<pre>private&nbsp;int <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.88">avgKeyLen</a></pre>
+<pre>private&nbsp;int <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.95">avgKeyLen</a></pre>
 <div class="block">Average key length read from file info</div>
 </li>
 </ul>
@@ -671,7 +684,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>avgValueLen</h4>
-<pre>private&nbsp;int <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.90">avgValueLen</a></pre>
+<pre>private&nbsp;int <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.97">avgValueLen</a></pre>
 <div class="block">Average value length read from file info</div>
 </li>
 </ul>
@@ -681,7 +694,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>includesMemstoreTS</h4>
-<pre>private&nbsp;boolean <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.91">includesMemstoreTS</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.98">includesMemstoreTS</a></pre>
 </li>
 </ul>
 <a name="decodeMemstoreTS">
@@ -690,7 +703,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>decodeMemstoreTS</h4>
-<pre>private&nbsp;boolean <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.92">decodeMemstoreTS</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.99">decodeMemstoreTS</a></pre>
 </li>
 </ul>
 <a name="loadOnOpenBlocks">
@@ -699,7 +712,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>loadOnOpenBlocks</h4>
-<pre>private&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a>&lt;<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileBlock.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileBlock</a>&gt; <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.98">loadOnOpenBlocks</a></pre>
+<pre>private&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a>&lt;<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileBlock.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileBlock</a>&gt; <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.105">loadOnOpenBlocks</a></pre>
 <div class="block">Blocks read from the load-on-open section, excluding data root index, meta
  index, and file info.</div>
 </li>
@@ -710,7 +723,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>blockIter</h4>
-<pre>private&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileBlock.BlockIterator.html" title="interface in org.apache.hadoop.hbase.io.hfile">HFileBlock.BlockIterator</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.105">blockIter</a></pre>
+<pre>private&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileBlock.BlockIterator.html" title="interface in org.apache.hadoop.hbase.io.hfile">HFileBlock.BlockIterator</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.112">blockIter</a></pre>
 <div class="block">The iterator will track all blocks in load-on-open section, since we use the
  <a href="../../../../../../org/apache/hadoop/hbase/io/ByteBuffAllocator.html" title="class in org.apache.hadoop.hbase.io"><code>ByteBuffAllocator</code></a> to manage the ByteBuffers in block now,
  so we must ensure that deallocate all ByteBuffers in the end.</div>
@@ -722,7 +735,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>dataIndexReader</h4>
-<pre>private&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileBlockIndex.CellBasedKeyBlockIndexReader.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileBlockIndex.CellBasedKeyBlockIndexReader</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.107">dataIndexReader</a></pre>
+<pre>private&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileBlockIndex.CellBasedKeyBlockIndexReader.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileBlockIndex.CellBasedKeyBlockIndexReader</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.114">dataIndexReader</a></pre>
 </li>
 </ul>
 <a name="metaIndexReader">
@@ -731,7 +744,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>metaIndexReader</h4>
-<pre>private&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileBlockIndex.ByteArrayKeyBlockIndexReader.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileBlockIndex.ByteArrayKeyBlockIndexReader</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.108">metaIndexReader</a></pre>
+<pre>private&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileBlockIndex.ByteArrayKeyBlockIndexReader.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileBlockIndex.ByteArrayKeyBlockIndexReader</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.115">metaIndexReader</a></pre>
 </li>
 </ul>
 <a name="trailer">
@@ -740,7 +753,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>trailer</h4>
-<pre>private&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/FixedFileTrailer.html" title="class in org.apache.hadoop.hbase.io.hfile">FixedFileTrailer</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.110">trailer</a></pre>
+<pre>private&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/FixedFileTrailer.html" title="class in org.apache.hadoop.hbase.io.hfile">FixedFileTrailer</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.117">trailer</a></pre>
 </li>
 </ul>
 <a name="hfileContext">
@@ -749,7 +762,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockListLast">
 <li class="blockList">
 <h4>hfileContext</h4>
-<pre>private&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileContext.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileContext</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.111">hfileContext</a></pre>
+<pre>private&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileContext.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileContext</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.118">hfileContext</a></pre>
 </li>
 </ul>
 </li>
@@ -766,7 +779,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>HFileInfo</h4>
-<pre>public&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.113">HFileInfo</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.120">HFileInfo</a>()</pre>
 </li>
 </ul>
 <a name="HFileInfo-org.apache.hadoop.hbase.io.hfile.ReaderContext-org.apache.hadoop.conf.Configuration-">
@@ -775,7 +788,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockListLast">
 <li class="blockList">
 <h4>HFileInfo</h4>
-<pre>public&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.117">HFileInfo</a>(<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/ReaderContext.html" title="class in org.apache.hadoop.hbase.io.hfile">ReaderContext</a>&nbsp;context,
+<pre>public&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.124">HFileInfo</a>(<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/ReaderContext.html" title="class in org.apache.hadoop.hbase.io.hfile">ReaderContext</a>&nbsp;context,
                  org.apache.hadoop.conf.Configuration&nbsp;conf)
           throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <dl>
@@ -798,7 +811,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>append</h4>
-<pre>public&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileInfo.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileInfo</a>&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.133">append</a>(byte[]&nbsp;k,
+<pre>public&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileInfo.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileInfo</a>&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.140">append</a>(byte[]&nbsp;k,
                         byte[]&nbsp;v,
                         boolean&nbsp;checkPrefix)
                  throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
@@ -824,7 +837,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>isReservedFileInfoKey</h4>
-<pre>public static&nbsp;boolean&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.147">isReservedFileInfoKey</a>(byte[]&nbsp;key)</pre>
+<pre>public static&nbsp;boolean&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.154">isReservedFileInfoKey</a>(byte[]&nbsp;key)</pre>
 <div class="block">Return true if the given file info key is reserved for internal use.</div>
 </li>
 </ul>
@@ -834,7 +847,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>clear</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.152">clear</a>()</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.159">clear</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true#clear--" title="class or interface in java.util">clear</a></code>&nbsp;in interface&nbsp;<code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a>&lt;byte[],byte[]&gt;</code></dd>
@@ -847,7 +860,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>comparator</h4>
-<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Comparator.html?is-external=true" title="class or interface in java.util">Comparator</a>&lt;? super byte[]&gt;&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.157">comparator</a>()</pre>
+<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Comparator.html?is-external=true" title="class or interface in java.util">Comparator</a>&lt;? super byte[]&gt;&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.164">comparator</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true#comparator--" title="class or interface in java.util">comparator</a></code>&nbsp;in interface&nbsp;<code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a>&lt;byte[],byte[]&gt;</code></dd>
@@ -860,7 +873,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>containsKey</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.162">containsKey</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a>&nbsp;key)</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.169">containsKey</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a>&nbsp;key)</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true#containsKey-java.lang.Object-" title="class or interface in java.util">containsKey</a></code>&nbsp;in interface&nbsp;<code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a>&lt;byte[],byte[]&gt;</code></dd>
@@ -873,7 +886,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>containsValue</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.167">containsValue</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a>&nbsp;value)</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.174">containsValue</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a>&nbsp;value)</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true#containsValue-java.lang.Object-" title="class or interface in java.util">containsValue</a></code>&nbsp;in interface&nbsp;<code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a>&lt;byte[],byte[]&gt;</code></dd>
@@ -886,7 +899,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>entrySet</h4>
-<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a>&lt;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.Entry.html?is-external=true" title="class or interface in java.util">Map.Entry</a>&lt;byte[],byte[]&gt;&gt;&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.172">entrySet</a>()</pre>
+<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a>&lt;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.Entry.html?is-external=true" title="class or interface in java.util">Map.Entry</a>&lt;byte[],byte[]&gt;&gt;&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.179">entrySet</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true#entrySet--" title="class or interface in java.util">entrySet</a></code>&nbsp;in interface&nbsp;<code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a>&lt;byte[],byte[]&gt;</code></dd>
@@ -901,7 +914,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>equals</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.177">equals</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a>&nbsp;o)</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.184">equals</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a>&nbsp;o)</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true#equals-java.lang.Object-" title="class or interface in java.util">equals</a></code>&nbsp;in interface&nbsp;<code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a>&lt;byte[],byte[]&gt;</code></dd>
@@ -916,7 +929,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>firstKey</h4>
-<pre>public&nbsp;byte[]&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.182">firstKey</a>()</pre>
+<pre>public&nbsp;byte[]&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.189">firstKey</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true#firstKey--" title="class or interface in java.util">firstKey</a></code>&nbsp;in interface&nbsp;<code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a>&lt;byte[],byte[]&gt;</code></dd>
@@ -929,7 +942,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>get</h4>
-<pre>public&nbsp;byte[]&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.187">get</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a>&nbsp;key)</pre>
+<pre>public&nbsp;byte[]&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.194">get</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a>&nbsp;key)</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true#get-java.lang.Object-" title="class or interface in java.util">get</a></code>&nbsp;in interface&nbsp;<code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a>&lt;byte[],byte[]&gt;</code></dd>
@@ -942,7 +955,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>hashCode</h4>
-<pre>public&nbsp;int&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.192">hashCode</a>()</pre>
+<pre>public&nbsp;int&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.199">hashCode</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true#hashCode--" title="class or interface in java.util">hashCode</a></code>&nbsp;in interface&nbsp;<code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a>&lt;byte[],byte[]&gt;</code></dd>
@@ -957,7 +970,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>headMap</h4>
-<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a>&lt;byte[],byte[]&gt;&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.197">headMap</a>(byte[]&nbsp;toKey)</pre>
+<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a>&lt;byte[],byte[]&gt;&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.204">headMap</a>(byte[]&nbsp;toKey)</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true#headMap-K-" title="class or interface in java.util">headMap</a></code>&nbsp;in interface&nbsp;<code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a>&lt;byte[],byte[]&gt;</code></dd>
@@ -970,7 +983,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>isEmpty</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.202">isEmpty</a>()</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.209">isEmpty</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true#isEmpty--" title="class or interface in java.util">isEmpty</a></code>&nbsp;in interface&nbsp;<code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a>&lt;byte[],byte[]&gt;</code></dd>
@@ -983,7 +996,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>keySet</h4>
-<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a>&lt;byte[]&gt;&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.207">keySet</a>()</pre>
+<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a>&lt;byte[]&gt;&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.214">keySet</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true#keySet--" title="class or interface in java.util">keySet</a></code>&nbsp;in interface&nbsp;<code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a>&lt;byte[],byte[]&gt;</code></dd>
@@ -998,7 +1011,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>lastKey</h4>
-<pre>public&nbsp;byte[]&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.212">lastKey</a>()</pre>
+<pre>public&nbsp;byte[]&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.219">lastKey</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true#lastKey--" title="class or interface in java.util">lastKey</a></code>&nbsp;in interface&nbsp;<code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a>&lt;byte[],byte[]&gt;</code></dd>
@@ -1011,7 +1024,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>put</h4>
-<pre>public&nbsp;byte[]&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.217">put</a>(byte[]&nbsp;key,
+<pre>public&nbsp;byte[]&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.224">put</a>(byte[]&nbsp;key,
                   byte[]&nbsp;value)</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
@@ -1025,7 +1038,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>putAll</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.222">putAll</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a>&lt;? extends byte[],? extends byte[]&gt;&nbsp;m)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.229">putAll</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a>&lt;? extends byte[],? extends byte[]&gt;&nbsp;m)</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true#putAll-java.util.Map-" title="class or interface in java.util">putAll</a></code>&nbsp;in interface&nbsp;<code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a>&lt;byte[],byte[]&gt;</code></dd>
@@ -1038,7 +1051,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>remove</h4>
-<pre>public&nbsp;byte[]&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.227">remove</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a>&nbsp;key)</pre>
+<pre>public&nbsp;byte[]&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.234">remove</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a>&nbsp;key)</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true#remove-java.lang.Object-" title="class or interface in java.util">remove</a></code>&nbsp;in interface&nbsp;<code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a>&lt;byte[],byte[]&gt;</code></dd>
@@ -1051,7 +1064,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>size</h4>
-<pre>public&nbsp;int&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.232">size</a>()</pre>
+<pre>public&nbsp;int&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.239">size</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true#size--" title="class or interface in java.util">size</a></code>&nbsp;in interface&nbsp;<code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a>&lt;byte[],byte[]&gt;</code></dd>
@@ -1064,7 +1077,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>subMap</h4>
-<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a>&lt;byte[],byte[]&gt;&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.237">subMap</a>(byte[]&nbsp;fromKey,
+<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a>&lt;byte[],byte[]&gt;&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.244">subMap</a>(byte[]&nbsp;fromKey,
                                        byte[]&nbsp;toKey)</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
@@ -1078,7 +1091,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>tailMap</h4>
-<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a>&lt;byte[],byte[]&gt;&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.242">tailMap</a>(byte[]&nbsp;fromKey)</pre>
+<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a>&lt;byte[],byte[]&gt;&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.249">tailMap</a>(byte[]&nbsp;fromKey)</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true#tailMap-K-" title="class or interface in java.util">tailMap</a></code>&nbsp;in interface&nbsp;<code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a>&lt;byte[],byte[]&gt;</code></dd>
@@ -1091,7 +1104,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>values</h4>
-<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Collection.html?is-external=true" title="class or interface in java.util">Collection</a>&lt;byte[]&gt;&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.247">values</a>()</pre>
+<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Collection.html?is-external=true" title="class or interface in java.util">Collection</a>&lt;byte[]&gt;&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.254">values</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true#values--" title="class or interface in java.util">values</a></code>&nbsp;in interface&nbsp;<code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a>&lt;byte[],byte[]&gt;</code></dd>
@@ -1106,7 +1119,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>write</h4>
-<pre>void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.256">write</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/io/DataOutputStream.html?is-external=true" title="class or interface in java.io">DataOutputStream</a>&nbsp;out)
+<pre>void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.263">write</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/io/DataOutputStream.html?is-external=true" title="class or interface in java.io">DataOutputStream</a>&nbsp;out)
     throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block">Write out this instance on the passed in <code>out</code> stream.
  We write it as a protobuf.</div>
@@ -1124,7 +1137,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>read</h4>
-<pre>void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.273">read</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/io/DataInputStream.html?is-external=true" title="class or interface in java.io">DataInputStream</a>&nbsp;in)
+<pre>void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.280">read</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/io/DataInputStream.html?is-external=true" title="class or interface in java.io">DataInputStream</a>&nbsp;in)
    throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block">Populate this instance with what we find on the passed in <code>in</code> stream.
  Can deserialize protobuf of old Writables format.</div>
@@ -1142,7 +1155,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>parseWritable</h4>
-<pre>void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.309">parseWritable</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/io/DataInputStream.html?is-external=true" title="class or interface in java.io">DataInputStream</a>&nbsp;in)
+<pre>void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.316">parseWritable</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/io/DataInputStream.html?is-external=true" title="class or interface in java.io">DataInputStream</a>&nbsp;in)
             throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block">Now parse the old Writable format.  It was a list of Map entries.  Each map entry was a
  key and a value of a byte [].  The old map format had a byte before each entry that held
@@ -1160,7 +1173,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>parsePB</h4>
-<pre>void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.330">parsePB</a>(org.apache.hadoop.hbase.shaded.protobuf.generated.HFileProtos.FileInfoProto&nbsp;fip)</pre>
+<pre>void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.337">parsePB</a>(org.apache.hadoop.hbase.shaded.protobuf.generated.HFileProtos.FileInfoProto&nbsp;fip)</pre>
 <div class="block">Fill our map with content of the pb we read off disk</div>
 <dl>
 <dt><span class="paramLabel">Parameters:</span></dt>
@@ -1174,7 +1187,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>initTrailerAndContext</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.337">initTrailerAndContext</a>(<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/ReaderContext.html" title="class in org.apache.hadoop.hbase.io.hfile">ReaderContext</a>&nbsp;context,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.344">initTrailerAndContext</a>(<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/ReaderContext.html" title="class in org.apache.hadoop.hbase.io.hfile">ReaderContext</a>&nbsp;context,
                                   org.apache.hadoop.conf.Configuration&nbsp;conf)
                            throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <dl>
@@ -1189,7 +1202,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>initMetaAndIndex</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.356">initMetaAndIndex</a>(<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFile.Reader.html" title="interface in org.apache.hadoop.hbase.io.hfile">HFile.Reader</a>&nbsp;reader)
+<pre>public&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.364">initMetaAndIndex</a>(<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFile.Reader.html" title="interface in org.apache.hadoop.hbase.io.hfile">HFile.Reader</a>&nbsp;reader)
                       throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block">should be called after initTrailerAndContext</div>
 <dl>
@@ -1204,7 +1217,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>createHFileContext</h4>
-<pre>private&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileContext.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileContext</a>&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.391">createHFileContext</a>(org.apache.hadoop.fs.Path&nbsp;path,
+<pre>private&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileContext.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileContext</a>&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.400">createHFileContext</a>(org.apache.hadoop.fs.Path&nbsp;path,
                                         <a href="../../../../../../org/apache/hadoop/hbase/io/hfile/FixedFileTrailer.html" title="class in org.apache.hadoop.hbase.io.hfile">FixedFileTrailer</a>&nbsp;trailer,
                                         org.apache.hadoop.conf.Configuration&nbsp;conf)
                                  throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
@@ -1220,7 +1233,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>loadMetaInfo</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.417">loadMetaInfo</a>(<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileBlock.BlockIterator.html" title="interface in org.apache.hadoop.hbase.io.hfile">HFileBlock.BlockIterator</a>&nbsp;blockIter,
+<pre>private&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.426">loadMetaInfo</a>(<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileBlock.BlockIterator.html" title="interface in org.apache.hadoop.hbase.io.hfile">HFileBlock.BlockIterator</a>&nbsp;blockIter,
                           <a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileContext.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileContext</a>&nbsp;hfileContext)
                    throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <dl>
@@ -1235,7 +1248,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>checkFileVersion</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.451">checkFileVersion</a>(org.apache.hadoop.fs.Path&nbsp;path)</pre>
+<pre>private&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.460">checkFileVersion</a>(org.apache.hadoop.fs.Path&nbsp;path)</pre>
 <div class="block">File version check is a little sloppy. We read v3 files but can also read v2 files if their
  content has been pb'd; files written with 0.98.</div>
 </li>
@@ -1246,7 +1259,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>close</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.466">close</a>()</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.475">close</a>()</pre>
 </li>
 </ul>
 <a name="getMajorVersion--">
@@ -1255,7 +1268,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>getMajorVersion</h4>
-<pre>public&nbsp;int&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.472">getMajorVersion</a>()</pre>
+<pre>public&nbsp;int&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.481">getMajorVersion</a>()</pre>
 </li>
 </ul>
 <a name="setTrailer-org.apache.hadoop.hbase.io.hfile.FixedFileTrailer-">
@@ -1264,7 +1277,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>setTrailer</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.476">setTrailer</a>(<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/FixedFileTrailer.html" title="class in org.apache.hadoop.hbase.io.hfile">FixedFileTrailer</a>&nbsp;trailer)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.485">setTrailer</a>(<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/FixedFileTrailer.html" title="class in org.apache.hadoop.hbase.io.hfile">FixedFileTrailer</a>&nbsp;trailer)</pre>
 </li>
 </ul>
 <a name="getTrailer--">
@@ -1273,7 +1286,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>getTrailer</h4>
-<pre>public&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/FixedFileTrailer.html" title="class in org.apache.hadoop.hbase.io.hfile">FixedFileTrailer</a>&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.480">getTrailer</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/FixedFileTrailer.html" title="class in org.apache.hadoop.hbase.io.hfile">FixedFileTrailer</a>&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.489">getTrailer</a>()</pre>
 </li>
 </ul>
 <a name="getDataBlockIndexReader--">
@@ -1282,7 +1295,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>getDataBlockIndexReader</h4>
-<pre>public&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileBlockIndex.CellBasedKeyBlockIndexReader.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileBlockIndex.CellBasedKeyBlockIndexReader</a>&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.484">getDataBlockIndexReader</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileBlockIndex.CellBasedKeyBlockIndexReader.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileBlockIndex.CellBasedKeyBlockIndexReader</a>&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.493">getDataBlockIndexReader</a>()</pre>
 </li>
 </ul>
 <a name="getMetaBlockIndexReader--">
@@ -1291,7 +1304,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>getMetaBlockIndexReader</h4>
-<pre>public&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileBlockIndex.ByteArrayKeyBlockIndexReader.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileBlockIndex.ByteArrayKeyBlockIndexReader</a>&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.488">getMetaBlockIndexReader</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileBlockIndex.ByteArrayKeyBlockIndexReader.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileBlockIndex.ByteArrayKeyBlockIndexReader</a>&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.497">getMetaBlockIndexReader</a>()</pre>
 </li>
 </ul>
 <a name="getHFileContext--">
@@ -1300,7 +1313,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>getHFileContext</h4>
-<pre>public&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileContext.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileContext</a>&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.492">getHFileContext</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileContext.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileContext</a>&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.501">getHFileContext</a>()</pre>
 </li>
 </ul>
 <a name="getLoadOnOpenBlocks--">
@@ -1309,7 +1322,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>getLoadOnOpenBlocks</h4>
-<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a>&lt;<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileBlock.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileBlock</a>&gt;&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.496">getLoadOnOpenBlocks</a>()</pre>
+<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a>&lt;<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileBlock.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileBlock</a>&gt;&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.505">getLoadOnOpenBlocks</a>()</pre>
 </li>
 </ul>
 <a name="getLastKeyCell--">
@@ -1318,7 +1331,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>getLastKeyCell</h4>
-<pre>public&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/Cell.html" title="interface in org.apache.hadoop.hbase">Cell</a>&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.500">getLastKeyCell</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/Cell.html" title="interface in org.apache.hadoop.hbase">Cell</a>&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.509">getLastKeyCell</a>()</pre>
 </li>
 </ul>
 <a name="getAvgKeyLen--">
@@ -1327,7 +1340,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>getAvgKeyLen</h4>
-<pre>public&nbsp;int&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.504">getAvgKeyLen</a>()</pre>
+<pre>public&nbsp;int&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.513">getAvgKeyLen</a>()</pre>
 </li>
 </ul>
 <a name="getAvgValueLen--">
@@ -1336,7 +1349,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>getAvgValueLen</h4>
-<pre>public&nbsp;int&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.508">getAvgValueLen</a>()</pre>
+<pre>public&nbsp;int&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.517">getAvgValueLen</a>()</pre>
 </li>
 </ul>
 <a name="shouldIncludeMemStoreTS--">
@@ -1345,7 +1358,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockList">
 <li class="blockList">
 <h4>shouldIncludeMemStoreTS</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.512">shouldIncludeMemStoreTS</a>()</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.521">shouldIncludeMemStoreTS</a>()</pre>
 </li>
 </ul>
 <a name="isDecodeMemstoreTS--">
@@ -1354,7 +1367,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
 <ul class="blockListLast">
 <li class="blockList">
 <h4>isDecodeMemstoreTS</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.516">isDecodeMemstoreTS</a>()</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.525">isDecodeMemstoreTS</a>()</pre>
 </li>
 </ul>
 </li>
diff --git a/devapidocs/org/apache/hadoop/hbase/io/hfile/package-tree.html b/devapidocs/org/apache/hadoop/hbase/io/hfile/package-tree.html
index f5a5d60..5d4f16c 100644
--- a/devapidocs/org/apache/hadoop/hbase/io/hfile/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/io/hfile/package-tree.html
@@ -301,10 +301,10 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
 <ul>
-<li type="circle">org.apache.hadoop.hbase.io.hfile.<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/BlockPriority.html" title="enum in org.apache.hadoop.hbase.io.hfile"><span class="typeNameLink">BlockPriority</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.io.hfile.<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/BlockType.html" title="enum in org.apache.hadoop.hbase.io.hfile"><span class="typeNameLink">BlockType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.io.hfile.<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/BlockCacheFactory.ExternalBlockCaches.html" title="enum in org.apache.hadoop.hbase.io.hfile"><span class="typeNameLink">BlockCacheFactory.ExternalBlockCaches</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.io.hfile.<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/BlockType.html" title="enum in org.apache.hadoop.hbase.io.hfile"><span class="typeNameLink">BlockType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.io.hfile.<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/ReaderContext.ReaderType.html" title="enum in org.apache.hadoop.hbase.io.hfile"><span class="typeNameLink">ReaderContext.ReaderType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.io.hfile.<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/BlockPriority.html" title="enum in org.apache.hadoop.hbase.io.hfile"><span class="typeNameLink">BlockPriority</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.io.hfile.<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/BlockType.BlockCategory.html" title="enum in org.apache.hadoop.hbase.io.hfile"><span class="typeNameLink">BlockType.BlockCategory</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.io.hfile.<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileBlock.Writer.State.html" title="enum in org.apache.hadoop.hbase.io.hfile"><span class="typeNameLink">HFileBlock.Writer.State</span></a></li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/ipc/package-tree.html b/devapidocs/org/apache/hadoop/hbase/ipc/package-tree.html
index 17eaa68..e0d239b 100644
--- a/devapidocs/org/apache/hadoop/hbase/ipc/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/ipc/package-tree.html
@@ -356,9 +356,9 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
 <ul>
+<li type="circle">org.apache.hadoop.hbase.ipc.<a href="../../../../../org/apache/hadoop/hbase/ipc/BufferCallBeforeInitHandler.BufferCallAction.html" title="enum in org.apache.hadoop.hbase.ipc"><span class="typeNameLink">BufferCallBeforeInitHandler.BufferCallAction</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.ipc.<a href="../../../../../org/apache/hadoop/hbase/ipc/CallEvent.Type.html" title="enum in org.apache.hadoop.hbase.ipc"><span class="typeNameLink">CallEvent.Type</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.ipc.<a href="../../../../../org/apache/hadoop/hbase/ipc/MetricsHBaseServerSourceFactoryImpl.SourceStorage.html" title="enum in org.apache.hadoop.hbase.ipc"><span class="typeNameLink">MetricsHBaseServerSourceFactoryImpl.SourceStorage</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.ipc.<a href="../../../../../org/apache/hadoop/hbase/ipc/BufferCallBeforeInitHandler.BufferCallAction.html" title="enum in org.apache.hadoop.hbase.ipc"><span class="typeNameLink">BufferCallBeforeInitHandler.BufferCallAction</span></a></li>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/mapreduce/package-tree.html b/devapidocs/org/apache/hadoop/hbase/mapreduce/package-tree.html
index aeaab0b..4abc8b1 100644
--- a/devapidocs/org/apache/hadoop/hbase/mapreduce/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/mapreduce/package-tree.html
@@ -296,10 +296,10 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
 <ul>
-<li type="circle">org.apache.hadoop.hbase.mapreduce.<a href="../../../../../org/apache/hadoop/hbase/mapreduce/WALPlayer.Counter.html" title="enum in org.apache.hadoop.hbase.mapreduce"><span class="typeNameLink">WALPlayer.Counter</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.mapreduce.<a href="../../../../../org/apache/hadoop/hbase/mapreduce/RowCounter.RowCounterMapper.Counters.html" title="enum in org.apache.hadoop.hbase.mapreduce"><span class="typeNameLink">RowCounter.RowCounterMapper.Counters</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.mapreduce.<a href="../../../../../org/apache/hadoop/hbase/mapreduce/CellCounter.CellCounterMapper.Counters.html" title="enum in org.apache.hadoop.hbase.mapreduce"><span class="typeNameLink">CellCounter.CellCounterMapper.Counters</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.mapreduce.<a href="../../../../../org/apache/hadoop/hbase/mapreduce/WALPlayer.Counter.html" title="enum in org.apache.hadoop.hbase.mapreduce"><span class="typeNameLink">WALPlayer.Counter</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.mapreduce.<a href="../../../../../org/apache/hadoop/hbase/mapreduce/SyncTable.SyncMapper.Counter.html" title="enum in org.apache.hadoop.hbase.mapreduce"><span class="typeNameLink">SyncTable.SyncMapper.Counter</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.mapreduce.<a href="../../../../../org/apache/hadoop/hbase/mapreduce/RowCounter.RowCounterMapper.Counters.html" title="enum in org.apache.hadoop.hbase.mapreduce"><span class="typeNameLink">RowCounter.RowCounterMapper.Counters</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.mapreduce.<a href="../../../../../org/apache/hadoop/hbase/mapreduce/TableSplit.Version.html" title="enum in org.apache.hadoop.hbase.mapreduce"><span class="typeNameLink">TableSplit.Version</span></a></li>
 </ul>
 </li>
diff --git a/devapidocs/org/apache/hadoop/hbase/master/assignment/package-tree.html b/devapidocs/org/apache/hadoop/hbase/master/assignment/package-tree.html
index f8add9f..5c89e3f 100644
--- a/devapidocs/org/apache/hadoop/hbase/master/assignment/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/master/assignment/package-tree.html
@@ -151,8 +151,8 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
 <ul>
-<li type="circle">org.apache.hadoop.hbase.master.assignment.<a href="../../../../../../org/apache/hadoop/hbase/master/assignment/ServerState.html" title="enum in org.apache.hadoop.hbase.master.assignment"><span class="typeNameLink">ServerState</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.master.assignment.<a href="../../../../../../org/apache/hadoop/hbase/master/assignment/TransitRegionStateProcedure.TransitionType.html" title="enum in org.apache.hadoop.hbase.master.assignment"><span class="typeNameLink">TransitRegionStateProcedure.TransitionType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.master.assignment.<a href="../../../../../../org/apache/hadoop/hbase/master/assignment/ServerState.html" title="enum in org.apache.hadoop.hbase.master.assignment"><span class="typeNameLink">ServerState</span></a></li>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/master/balancer/package-tree.html b/devapidocs/org/apache/hadoop/hbase/master/balancer/package-tree.html
index 4aadbb8..39196e0 100644
--- a/devapidocs/org/apache/hadoop/hbase/master/balancer/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/master/balancer/package-tree.html
@@ -199,8 +199,8 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
 <ul>
-<li type="circle">org.apache.hadoop.hbase.master.balancer.<a href="../../../../../../org/apache/hadoop/hbase/master/balancer/BaseLoadBalancer.Cluster.Action.Type.html" title="enum in org.apache.hadoop.hbase.master.balancer"><span class="typeNameLink">BaseLoadBalancer.Cluster.Action.Type</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.master.balancer.<a href="../../../../../../org/apache/hadoop/hbase/master/balancer/BaseLoadBalancer.Cluster.LocalityType.html" title="enum in org.apache.hadoop.hbase.master.balancer"><span class="typeNameLink">BaseLoadBalancer.Cluster.LocalityType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.master.balancer.<a href="../../../../../../org/apache/hadoop/hbase/master/balancer/BaseLoadBalancer.Cluster.Action.Type.html" title="enum in org.apache.hadoop.hbase.master.balancer"><span class="typeNameLink">BaseLoadBalancer.Cluster.Action.Type</span></a></li>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/master/package-tree.html b/devapidocs/org/apache/hadoop/hbase/master/package-tree.html
index 2b5a13a..09e1c49 100644
--- a/devapidocs/org/apache/hadoop/hbase/master/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/master/package-tree.html
@@ -339,12 +339,12 @@
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
 <ul>
 <li type="circle">org.apache.hadoop.hbase.master.<a href="../../../../../org/apache/hadoop/hbase/master/MetaRegionLocationCache.ZNodeOpType.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">MetaRegionLocationCache.ZNodeOpType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.master.<a href="../../../../../org/apache/hadoop/hbase/master/SplitLogManager.TerminationStatus.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">SplitLogManager.TerminationStatus</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.master.<a href="../../../../../org/apache/hadoop/hbase/master/MetricsMasterSourceFactoryImpl.FactoryStorage.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">MetricsMasterSourceFactoryImpl.FactoryStorage</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.master.<a href="../../../../../org/apache/hadoop/hbase/master/MasterRpcServices.BalanceSwitchMode.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">MasterRpcServices.BalanceSwitchMode</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.master.<a href="../../../../../org/apache/hadoop/hbase/master/ServerManager.ServerLiveState.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">ServerManager.ServerLiveState</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.master.<a href="../../../../../org/apache/hadoop/hbase/master/RegionState.State.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">RegionState.State</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.master.<a href="../../../../../org/apache/hadoop/hbase/master/MasterRpcServices.BalanceSwitchMode.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">MasterRpcServices.BalanceSwitchMode</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.master.<a href="../../../../../org/apache/hadoop/hbase/master/SplitLogManager.ResubmitDirective.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">SplitLogManager.ResubmitDirective</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.master.<a href="../../../../../org/apache/hadoop/hbase/master/SplitLogManager.TerminationStatus.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">SplitLogManager.TerminationStatus</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.master.<a href="../../../../../org/apache/hadoop/hbase/master/RegionState.State.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">RegionState.State</span></a></li>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/master/procedure/package-tree.html b/devapidocs/org/apache/hadoop/hbase/master/procedure/package-tree.html
index 8452d19..eb466df 100644
--- a/devapidocs/org/apache/hadoop/hbase/master/procedure/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/master/procedure/package-tree.html
@@ -222,9 +222,9 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
 <ul>
+<li type="circle">org.apache.hadoop.hbase.master.procedure.<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/ServerProcedureInterface.ServerOperationType.html" title="enum in org.apache.hadoop.hbase.master.procedure"><span class="typeNameLink">ServerProcedureInterface.ServerOperationType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.master.procedure.<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/MetaProcedureInterface.MetaOperationType.html" title="enum in org.apache.hadoop.hbase.master.procedure"><span class="typeNameLink">MetaProcedureInterface.MetaOperationType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.master.procedure.<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/TableProcedureInterface.TableOperationType.html" title="enum in org.apache.hadoop.hbase.master.procedure"><span class="typeNameLink">TableProcedureInterface.TableOperationType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.master.procedure.<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/ServerProcedureInterface.ServerOperationType.html" title="enum in org.apache.hadoop.hbase.master.procedure"><span class="typeNameLink">ServerProcedureInterface.ServerOperationType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.master.procedure.<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/PeerProcedureInterface.PeerOperationType.html" title="enum in org.apache.hadoop.hbase.master.procedure"><span class="typeNameLink">PeerProcedureInterface.PeerOperationType</span></a></li>
 </ul>
 </li>
diff --git a/devapidocs/org/apache/hadoop/hbase/package-tree.html b/devapidocs/org/apache/hadoop/hbase/package-tree.html
index 2dc5582..5e18d58 100644
--- a/devapidocs/org/apache/hadoop/hbase/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/package-tree.html
@@ -433,19 +433,19 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
 <ul>
+<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/ClientMetaTableAccessor.QueryType.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">ClientMetaTableAccessor.QueryType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/Cell.Type.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">Cell.Type</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/ClusterMetrics.Option.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">ClusterMetrics.Option</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/Size.Unit.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">Size.Unit</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/CellBuilderType.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">CellBuilderType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/KeyValue.Type.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">KeyValue.Type</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/MemoryCompactionPolicy.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">MemoryCompactionPolicy</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/KeepDeletedCells.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">KeepDeletedCells</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/HConstants.OperationStatusCode.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">HConstants.OperationStatusCode</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/ClusterMetrics.Option.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">ClusterMetrics.Option</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/CompareOperator.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">CompareOperator</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/HealthChecker.HealthCheckerExitStatus.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">HealthChecker.HealthCheckerExitStatus</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/Coprocessor.State.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">Coprocessor.State</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/KeepDeletedCells.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">KeepDeletedCells</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/MemoryCompactionPolicy.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">MemoryCompactionPolicy</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/CellBuilderType.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">CellBuilderType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/Size.Unit.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">Size.Unit</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/Cell.Type.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">Cell.Type</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/ClientMetaTableAccessor.QueryType.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">ClientMetaTableAccessor.QueryType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/CompatibilitySingletonFactory.SingletonStorage.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">CompatibilitySingletonFactory.SingletonStorage</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/HealthChecker.HealthCheckerExitStatus.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">HealthChecker.HealthCheckerExitStatus</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/CompareOperator.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">CompareOperator</span></a></li>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/procedure2/package-tree.html b/devapidocs/org/apache/hadoop/hbase/procedure2/package-tree.html
index 2cc5efe..4debb4e 100644
--- a/devapidocs/org/apache/hadoop/hbase/procedure2/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/procedure2/package-tree.html
@@ -217,10 +217,10 @@
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
 <ul>
 <li type="circle">org.apache.hadoop.hbase.procedure2.<a href="../../../../../org/apache/hadoop/hbase/procedure2/StateMachineProcedure.Flow.html" title="enum in org.apache.hadoop.hbase.procedure2"><span class="typeNameLink">StateMachineProcedure.Flow</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.procedure2.<a href="../../../../../org/apache/hadoop/hbase/procedure2/Procedure.LockState.html" title="enum in org.apache.hadoop.hbase.procedure2"><span class="typeNameLink">Procedure.LockState</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.procedure2.<a href="../../../../../org/apache/hadoop/hbase/procedure2/LockedResourceType.html" title="enum in org.apache.hadoop.hbase.procedure2"><span class="typeNameLink">LockedResourceType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.procedure2.<a href="../../../../../org/apache/hadoop/hbase/procedure2/RootProcedureState.State.html" title="enum in org.apache.hadoop.hbase.procedure2"><span class="typeNameLink">RootProcedureState.State</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.procedure2.<a href="../../../../../org/apache/hadoop/hbase/procedure2/LockType.html" title="enum in org.apache.hadoop.hbase.procedure2"><span class="typeNameLink">LockType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.procedure2.<a href="../../../../../org/apache/hadoop/hbase/procedure2/RootProcedureState.State.html" title="enum in org.apache.hadoop.hbase.procedure2"><span class="typeNameLink">RootProcedureState.State</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.procedure2.<a href="../../../../../org/apache/hadoop/hbase/procedure2/LockedResourceType.html" title="enum in org.apache.hadoop.hbase.procedure2"><span class="typeNameLink">LockedResourceType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.procedure2.<a href="../../../../../org/apache/hadoop/hbase/procedure2/Procedure.LockState.html" title="enum in org.apache.hadoop.hbase.procedure2"><span class="typeNameLink">Procedure.LockState</span></a></li>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/procedure2/store/wal/package-tree.html b/devapidocs/org/apache/hadoop/hbase/procedure2/store/wal/package-tree.html
index 2525a0e..7b64815 100644
--- a/devapidocs/org/apache/hadoop/hbase/procedure2/store/wal/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/procedure2/store/wal/package-tree.html
@@ -133,8 +133,8 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
 <ul>
-<li type="circle">org.apache.hadoop.hbase.procedure2.store.wal.<a href="../../../../../../../org/apache/hadoop/hbase/procedure2/store/wal/WALProcedureStore.PushType.html" title="enum in org.apache.hadoop.hbase.procedure2.store.wal"><span class="typeNameLink">WALProcedureStore.PushType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.procedure2.store.wal.<a href="../../../../../../../org/apache/hadoop/hbase/procedure2/store/wal/ProcedureStoreTracker.DeleteState.html" title="enum in org.apache.hadoop.hbase.procedure2.store.wal"><span class="typeNameLink">ProcedureStoreTracker.DeleteState</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.procedure2.store.wal.<a href="../../../../../../../org/apache/hadoop/hbase/procedure2/store/wal/WALProcedureStore.PushType.html" title="enum in org.apache.hadoop.hbase.procedure2.store.wal"><span class="typeNameLink">WALProcedureStore.PushType</span></a></li>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/quotas/package-tree.html b/devapidocs/org/apache/hadoop/hbase/quotas/package-tree.html
index 9c84a1b..4fc5836 100644
--- a/devapidocs/org/apache/hadoop/hbase/quotas/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/quotas/package-tree.html
@@ -240,12 +240,12 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
 <ul>
-<li type="circle">org.apache.hadoop.hbase.quotas.<a href="../../../../../org/apache/hadoop/hbase/quotas/RpcThrottlingException.Type.html" title="enum in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">RpcThrottlingException.Type</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.quotas.<a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaScope.html" title="enum in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">QuotaScope</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.quotas.<a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota.OperationType.html" title="enum in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">OperationQuota.OperationType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.quotas.<a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html" title="enum in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">ThrottleType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.quotas.<a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaType.html" title="enum in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">QuotaType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.quotas.<a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota.OperationType.html" title="enum in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">OperationQuota.OperationType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.quotas.<a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaScope.html" title="enum in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">QuotaScope</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.quotas.<a href="../../../../../org/apache/hadoop/hbase/quotas/SpaceViolationPolicy.html" title="enum in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">SpaceViolationPolicy</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.quotas.<a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html" title="enum in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">ThrottleType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.quotas.<a href="../../../../../org/apache/hadoop/hbase/quotas/RpcThrottlingException.Type.html" title="enum in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">RpcThrottlingException.Type</span></a></li>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html b/devapidocs/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html
index f596899..5996c38 100644
--- a/devapidocs/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html
+++ b/devapidocs/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html
@@ -142,46 +142,58 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#bulkLoadTimer">bulkLoadTimer</a></span></code>&nbsp;</td>
 </tr>
 <tr class="rowColor">
+<td class="colFirst"><code>protected static int</code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#DEFAULT_SLOW_METRIC_TIME">DEFAULT_SLOW_METRIC_TIME</a></span></code>&nbsp;</td>
+</tr>
+<tr class="altColor">
 <td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/metrics/MetricRegistry.html" title="interface in org.apache.hadoop.hbase.metrics">MetricRegistry</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#metricRegistry">metricRegistry</a></span></code>&nbsp;</td>
 </tr>
-<tr class="altColor">
+<tr class="rowColor">
 <td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsTable.html" title="class in org.apache.hadoop.hbase.regionserver">MetricsTable</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#metricsTable">metricsTable</a></span></code>&nbsp;</td>
 </tr>
-<tr class="rowColor">
+<tr class="altColor">
 <td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerQuotaSource.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerQuotaSource</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#quotaSource">quotaSource</a></span></code>&nbsp;</td>
 </tr>
-<tr class="altColor">
+<tr class="rowColor">
 <td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerWrapper.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerWrapper</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#regionServerWrapper">regionServerWrapper</a></span></code>&nbsp;</td>
 </tr>
-<tr class="rowColor">
+<tr class="altColor">
 <td class="colFirst"><code>static boolean</code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#RS_ENABLE_TABLE_METRICS_DEFAULT">RS_ENABLE_TABLE_METRICS_DEFAULT</a></span></code>&nbsp;</td>
 </tr>
-<tr class="altColor">
+<tr class="rowColor">
 <td class="colFirst"><code>static <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#RS_ENABLE_TABLE_METRICS_KEY">RS_ENABLE_TABLE_METRICS_KEY</a></span></code>&nbsp;</td>
 </tr>
-<tr class="rowColor">
+<tr class="altColor">
 <td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/metrics/Meter.html" title="interface in org.apache.hadoop.hbase.metrics">Meter</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#serverReadQueryMeter">serverReadQueryMeter</a></span></code>&nbsp;</td>
 </tr>
-<tr class="altColor">
+<tr class="rowColor">
 <td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerSource.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerSource</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#serverSource">serverSource</a></span></code>&nbsp;</td>
 </tr>
-<tr class="rowColor">
+<tr class="altColor">
 <td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/metrics/Meter.html" title="interface in org.apache.hadoop.hbase.metrics">Meter</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#serverWriteQueryMeter">serverWriteQueryMeter</a></span></code>&nbsp;</td>
 </tr>
+<tr class="rowColor">
+<td class="colFirst"><code>static <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a></code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#SLOW_METRIC_TIME">SLOW_METRIC_TIME</a></span></code>&nbsp;</td>
+</tr>
 <tr class="altColor">
+<td class="colFirst"><code>protected long</code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#slowMetricTime">slowMetricTime</a></span></code>&nbsp;</td>
+</tr>
+<tr class="rowColor">
 <td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/regionserver/RegionServerTableMetrics.html" title="class in org.apache.hadoop.hbase.regionserver">RegionServerTableMetrics</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#tableMetrics">tableMetrics</a></span></code>&nbsp;</td>
 </tr>
-<tr class="rowColor">
+<tr class="altColor">
 <td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsUserAggregate.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsUserAggregate</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#userAggregate">userAggregate</a></span></code>&nbsp;</td>
 </tr>
@@ -415,13 +427,26 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 </dl>
 </li>
 </ul>
+<a name="SLOW_METRIC_TIME">
+<!--   -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>SLOW_METRIC_TIME</h4>
+<pre>public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.45">SLOW_METRIC_TIME</a></pre>
+<dl>
+<dt><span class="seeLabel">See Also:</span></dt>
+<dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.regionserver.MetricsRegionServer.SLOW_METRIC_TIME">Constant Field Values</a></dd>
+</dl>
+</li>
+</ul>
 <a name="serverSource">
 <!--   -->
 </a>
 <ul class="blockList">
 <li class="blockList">
 <h4>serverSource</h4>
-<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerSource.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerSource</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.45">serverSource</a></pre>
+<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerSource.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerSource</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.46">serverSource</a></pre>
 </li>
 </ul>
 <a name="regionServerWrapper">
@@ -430,7 +455,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>regionServerWrapper</h4>
-<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerWrapper.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerWrapper</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.46">regionServerWrapper</a></pre>
+<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerWrapper.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerWrapper</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.47">regionServerWrapper</a></pre>
 </li>
 </ul>
 <a name="tableMetrics">
@@ -439,7 +464,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>tableMetrics</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/RegionServerTableMetrics.html" title="class in org.apache.hadoop.hbase.regionserver">RegionServerTableMetrics</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.47">tableMetrics</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/RegionServerTableMetrics.html" title="class in org.apache.hadoop.hbase.regionserver">RegionServerTableMetrics</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.48">tableMetrics</a></pre>
 </li>
 </ul>
 <a name="metricsTable">
@@ -448,7 +473,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>metricsTable</h4>
-<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsTable.html" title="class in org.apache.hadoop.hbase.regionserver">MetricsTable</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.48">metricsTable</a></pre>
+<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsTable.html" title="class in org.apache.hadoop.hbase.regionserver">MetricsTable</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.49">metricsTable</a></pre>
 </li>
 </ul>
 <a name="quotaSource">
@@ -457,7 +482,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>quotaSource</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerQuotaSource.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerQuotaSource</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.49">quotaSource</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerQuotaSource.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerQuotaSource</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.50">quotaSource</a></pre>
 </li>
 </ul>
 <a name="userAggregate">
@@ -466,7 +491,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>userAggregate</h4>
-<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsUserAggregate.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsUserAggregate</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.50">userAggregate</a></pre>
+<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsUserAggregate.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsUserAggregate</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.51">userAggregate</a></pre>
 </li>
 </ul>
 <a name="metricRegistry">
@@ -475,7 +500,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>metricRegistry</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/metrics/MetricRegistry.html" title="interface in org.apache.hadoop.hbase.metrics">MetricRegistry</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.52">metricRegistry</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/metrics/MetricRegistry.html" title="interface in org.apache.hadoop.hbase.metrics">MetricRegistry</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.53">metricRegistry</a></pre>
 </li>
 </ul>
 <a name="bulkLoadTimer">
@@ -484,7 +509,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>bulkLoadTimer</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/metrics/Timer.html" title="interface in org.apache.hadoop.hbase.metrics">Timer</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.53">bulkLoadTimer</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/metrics/Timer.html" title="interface in org.apache.hadoop.hbase.metrics">Timer</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.54">bulkLoadTimer</a></pre>
 </li>
 </ul>
 <a name="serverReadQueryMeter">
@@ -493,16 +518,38 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>serverReadQueryMeter</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/metrics/Meter.html" title="interface in org.apache.hadoop.hbase.metrics">Meter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.54">serverReadQueryMeter</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/metrics/Meter.html" title="interface in org.apache.hadoop.hbase.metrics">Meter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.55">serverReadQueryMeter</a></pre>
 </li>
 </ul>
 <a name="serverWriteQueryMeter">
 <!--   -->
 </a>
-<ul class="blockListLast">
+<ul class="blockList">
 <li class="blockList">
 <h4>serverWriteQueryMeter</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/metrics/Meter.html" title="interface in org.apache.hadoop.hbase.metrics">Meter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.55">serverWriteQueryMeter</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/metrics/Meter.html" title="interface in org.apache.hadoop.hbase.metrics">Meter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.56">serverWriteQueryMeter</a></pre>
+</li>
+</ul>
+<a name="slowMetricTime">
+<!--   -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>slowMetricTime</h4>
+<pre>protected&nbsp;long <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.57">slowMetricTime</a></pre>
+</li>
+</ul>
+<a name="DEFAULT_SLOW_METRIC_TIME">
+<!--   -->
+</a>
+<ul class="blockListLast">
+<li class="blockList">
+<h4>DEFAULT_SLOW_METRIC_TIME</h4>
+<pre>protected static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.58">DEFAULT_SLOW_METRIC_TIME</a></pre>
+<dl>
+<dt><span class="seeLabel">See Also:</span></dt>
+<dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.regionserver.MetricsRegionServer.DEFAULT_SLOW_METRIC_TIME">Constant Field Values</a></dd>
+</dl>
 </li>
 </ul>
 </li>
@@ -519,7 +566,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>MetricsRegionServer</h4>
-<pre>public&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.57">MetricsRegionServer</a>(<a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerWrapper.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerWrapper</a>&nbsp;regionServerWrapper,
+<pre>public&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.60">MetricsRegionServer</a>(<a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerWrapper.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerWrapper</a>&nbsp;regionServerWrapper,
                            org.apache.hadoop.conf.Configuration&nbsp;conf,
                            <a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsTable.html" title="class in org.apache.hadoop.hbase.regionserver">MetricsTable</a>&nbsp;metricsTable)</pre>
 </li>
@@ -530,7 +577,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockListLast">
 <li class="blockList">
 <h4>MetricsRegionServer</h4>
-<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.76">MetricsRegionServer</a>(<a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerWrapper.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerWrapper</a>&nbsp;regionServerWrapper,
+<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.80">MetricsRegionServer</a>(<a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerWrapper.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerWrapper</a>&nbsp;regionServerWrapper,
                     <a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerSource.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerSource</a>&nbsp;serverSource,
                     <a href="../../../../../org/apache/hadoop/hbase/regionserver/RegionServerTableMetrics.html" title="class in org.apache.hadoop.hbase.regionserver">RegionServerTableMetrics</a>&nbsp;tableMetrics,
                     <a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsTable.html" title="class in org.apache.hadoop.hbase.regionserver">MetricsTable</a>&nbsp;metricsTable,
@@ -551,7 +598,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>createTableMetrics</h4>
-<pre>static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/RegionServerTableMetrics.html" title="class in org.apache.hadoop.hbase.regionserver">RegionServerTableMetrics</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.89">createTableMetrics</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)</pre>
+<pre>static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/RegionServerTableMetrics.html" title="class in org.apache.hadoop.hbase.regionserver">RegionServerTableMetrics</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.93">createTableMetrics</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)</pre>
 <div class="block">Creates an instance of <a href="../../../../../org/apache/hadoop/hbase/regionserver/RegionServerTableMetrics.html" title="class in org.apache.hadoop.hbase.regionserver"><code>RegionServerTableMetrics</code></a> only if the feature is enabled.</div>
 </li>
 </ul>
@@ -561,7 +608,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>getMetricsSource</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerSource.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerSource</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.96">getMetricsSource</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerSource.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerSource</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.100">getMetricsSource</a>()</pre>
 </li>
 </ul>
 <a name="getMetricsUserAggregate--">
@@ -570,7 +617,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>getMetricsUserAggregate</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsUserAggregate.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsUserAggregate</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.100">getMetricsUserAggregate</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsUserAggregate.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsUserAggregate</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.104">getMetricsUserAggregate</a>()</pre>
 </li>
 </ul>
 <a name="getRegionServerWrapper--">
@@ -579,7 +626,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>getRegionServerWrapper</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerWrapper.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerWrapper</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.104">getRegionServerWrapper</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerWrapper.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerWrapper</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.108">getRegionServerWrapper</a>()</pre>
 </li>
 </ul>
 <a name="updatePutBatch-org.apache.hadoop.hbase.TableName-long-">
@@ -588,7 +635,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>updatePutBatch</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.108">updatePutBatch</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tn,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.112">updatePutBatch</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tn,
                            long&nbsp;t)</pre>
 </li>
 </ul>
@@ -598,7 +645,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>updatePut</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.118">updatePut</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tn,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.122">updatePut</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tn,
                       long&nbsp;t)</pre>
 </li>
 </ul>
@@ -608,7 +655,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>updateDelete</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.126">updateDelete</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tn,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.130">updateDelete</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tn,
                          long&nbsp;t)</pre>
 </li>
 </ul>
@@ -618,7 +665,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>updateDeleteBatch</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.134">updateDeleteBatch</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tn,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.138">updateDeleteBatch</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tn,
                               long&nbsp;t)</pre>
 </li>
 </ul>
@@ -628,7 +675,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>updateCheckAndDelete</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.144">updateCheckAndDelete</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tn,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.148">updateCheckAndDelete</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tn,
                                  long&nbsp;t)</pre>
 </li>
 </ul>
@@ -638,7 +685,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>updateCheckAndPut</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.151">updateCheckAndPut</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tn,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.155">updateCheckAndPut</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tn,
                               long&nbsp;t)</pre>
 </li>
 </ul>
@@ -648,7 +695,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>updateCheckAndMutate</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.158">updateCheckAndMutate</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tn,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.162">updateCheckAndMutate</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tn,
                                  long&nbsp;t)</pre>
 </li>
 </ul>
@@ -658,7 +705,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>updateGet</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.165">updateGet</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tn,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.169">updateGet</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tn,
                       long&nbsp;t)</pre>
 </li>
 </ul>
@@ -668,7 +715,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>updateIncrement</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.176">updateIncrement</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tn,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.180">updateIncrement</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tn,
                             long&nbsp;t)</pre>
 </li>
 </ul>
@@ -678,7 +725,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>updateAppend</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.187">updateAppend</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tn,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.191">updateAppend</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tn,
                          long&nbsp;t)</pre>
 </li>
 </ul>
@@ -688,7 +735,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>updateReplay</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.198">updateReplay</a>(long&nbsp;t)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.202">updateReplay</a>(long&nbsp;t)</pre>
 </li>
 </ul>
 <a name="updateScanSize-org.apache.hadoop.hbase.TableName-long-">
@@ -697,7 +744,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>updateScanSize</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.203">updateScanSize</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tn,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.207">updateScanSize</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tn,
                            long&nbsp;scanSize)</pre>
 </li>
 </ul>
@@ -707,7 +754,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>updateScanTime</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.210">updateScanTime</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tn,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.214">updateScanTime</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tn,
                            long&nbsp;t)</pre>
 </li>
 </ul>
@@ -717,7 +764,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>updateSplitTime</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.218">updateSplitTime</a>(long&nbsp;t)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.222">updateSplitTime</a>(long&nbsp;t)</pre>
 </li>
 </ul>
 <a name="incrSplitRequest--">
@@ -726,7 +773,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>incrSplitRequest</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.222">incrSplitRequest</a>()</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.226">incrSplitRequest</a>()</pre>
 </li>
 </ul>
 <a name="incrSplitSuccess--">
@@ -735,7 +782,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>incrSplitSuccess</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.226">incrSplitSuccess</a>()</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.230">incrSplitSuccess</a>()</pre>
 </li>
 </ul>
 <a name="updateFlush-java.lang.String-long-long-long-">
@@ -744,7 +791,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>updateFlush</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.230">updateFlush</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;table,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.234">updateFlush</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;table,
                         long&nbsp;t,
                         long&nbsp;memstoreSize,
                         long&nbsp;fileSize)</pre>
@@ -756,7 +803,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>updateCompaction</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.243">updateCompaction</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;table,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.247">updateCompaction</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;table,
                              boolean&nbsp;isMajor,
                              long&nbsp;t,
                              int&nbsp;inputFileCount,
@@ -771,7 +818,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>updateBulkLoad</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.260">updateBulkLoad</a>(long&nbsp;millis)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.264">updateBulkLoad</a>(long&nbsp;millis)</pre>
 </li>
 </ul>
 <a name="incrementNumRegionSizeReportsSent-long-">
@@ -780,7 +827,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>incrementNumRegionSizeReportsSent</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.267">incrementNumRegionSizeReportsSent</a>(long&nbsp;numReportsSent)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.271">incrementNumRegionSizeReportsSent</a>(long&nbsp;numReportsSent)</pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerQuotaSource.html#incrementNumRegionSizeReportsSent-long-"><code>MetricsRegionServerQuotaSource.incrementNumRegionSizeReportsSent(long)</code></a></dd>
@@ -793,7 +840,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>incrementRegionSizeReportingChoreTime</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.274">incrementRegionSizeReportingChoreTime</a>(long&nbsp;time)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.278">incrementRegionSizeReportingChoreTime</a>(long&nbsp;time)</pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerQuotaSource.html#incrementRegionSizeReportingChoreTime-long-"><code>MetricsRegionServerQuotaSource.incrementRegionSizeReportingChoreTime(long)</code></a></dd>
@@ -806,7 +853,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>updateReadQueryMeter</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.278">updateReadQueryMeter</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tn,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.282">updateReadQueryMeter</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tn,
                                  long&nbsp;count)</pre>
 </li>
 </ul>
@@ -816,7 +863,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>updateReadQueryMeter</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.285">updateReadQueryMeter</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tn)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.289">updateReadQueryMeter</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tn)</pre>
 </li>
 </ul>
 <a name="updateWriteQueryMeter-org.apache.hadoop.hbase.TableName-long-">
@@ -825,7 +872,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>updateWriteQueryMeter</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.292">updateWriteQueryMeter</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tn,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.296">updateWriteQueryMeter</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tn,
                                   long&nbsp;count)</pre>
 </li>
 </ul>
@@ -835,7 +882,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockListLast">
 <li class="blockList">
 <h4>updateWriteQueryMeter</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.299">updateWriteQueryMeter</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tn)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.303">updateWriteQueryMeter</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tn)</pre>
 </li>
 </ul>
 </li>
diff --git a/devapidocs/org/apache/hadoop/hbase/regionserver/ScannerContext.LimitScope.html b/devapidocs/org/apache/hadoop/hbase/regionserver/ScannerContext.LimitScope.html
index 5ff38e2..ddb0c5f 100644
--- a/devapidocs/org/apache/hadoop/hbase/regionserver/ScannerContext.LimitScope.html
+++ b/devapidocs/org/apache/hadoop/hbase/regionserver/ScannerContext.LimitScope.html
@@ -300,7 +300,7 @@ the order they are declared.</div>
 <ul class="blockList">
 <li class="blockList">
 <h4>values</h4>
-<pre>public static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/ScannerContext.LimitScope.html" title="enum in org.apache.hadoop.hbase.regionserver">ScannerContext.LimitScope</a>[]&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/ScannerContext.LimitScope.html#line.88">values</a>()</pre>
+<pre>public static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/ScannerContext.LimitScope.html" title="enum in org.apache.hadoop.hbase.regionserver">ScannerContext.LimitScope</a>[]&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/ScannerContext.LimitScope.html#line.89">values</a>()</pre>
 <div class="block">Returns an array containing the constants of this enum type, in
 the order they are declared.  This method may be used to iterate
 over the constants as follows:
@@ -320,7 +320,7 @@ for (ScannerContext.LimitScope c : ScannerContext.LimitScope.values())
 <ul class="blockList">
 <li class="blockList">
 <h4>valueOf</h4>
-<pre>public static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/ScannerContext.LimitScope.html" title="enum in org.apache.hadoop.hbase.regionserver">ScannerContext.LimitScope</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/ScannerContext.LimitScope.html#line.88">valueOf</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;name)</pre>
+<pre>public static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/ScannerContext.LimitScope.html" title="enum in org.apache.hadoop.hbase.regionserver">ScannerContext.LimitScope</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/ScannerContext.LimitScope.html#line.89">valueOf</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;name)</pre>
 <div class="block">Returns the enum constant of this type with the specified name.
 The string must match <i>exactly</i> an identifier used to declare an
 enum constant in this type.  (Extraneous whitespace characters are 
diff --git a/devapidocs/org/apache/hadoop/hbase/regionserver/ScannerContext.NextState.html b/devapidocs/org/apache/hadoop/hbase/regionserver/ScannerContext.NextState.html
index 43bd1f4..1fa8a69 100644
--- a/devapidocs/org/apache/hadoop/hbase/regionserver/ScannerContext.NextState.html
+++ b/devapidocs/org/apache/hadoop/hbase/regionserver/ScannerContext.NextState.html
@@ -372,7 +372,7 @@ the order they are declared.</div>
 <ul class="blockList">
 <li class="blockList">
 <h4>values</h4>
-<pre>public static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/ScannerContext.NextState.html" title="enum in org.apache.hadoop.hbase.regionserver">ScannerContext.NextState</a>[]&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/ScannerContext.NextState.html#line.88">values</a>()</pre>
+<pre>public static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/ScannerContext.NextState.html" title="enum in org.apache.hadoop.hbase.regionserver">ScannerContext.NextState</a>[]&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/ScannerContext.NextState.html#line.89">values</a>()</pre>
 <div class="block">Returns an array containing the constants of this enum type, in
 the order they are declared.  This method may be used to iterate
 over the constants as follows:
@@ -392,7 +392,7 @@ for (ScannerContext.NextState c : ScannerContext.NextState.values())
 <ul class="blockList">
 <li class="blockList">
 <h4>valueOf</h4>
-<pre>public static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/ScannerContext.NextState.html" title="enum in org.apache.hadoop.hbase.regionserver">ScannerContext.NextState</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/ScannerContext.NextState.html#line.88">valueOf</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;name)</pre>
+<pre>public static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/ScannerContext.NextState.html" title="enum in org.apache.hadoop.hbase.regionserver">ScannerContext.NextState</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/ScannerContext.NextState.html#line.89">valueOf</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;name)</pre>
 <div class="block">Returns the enum constant of this type with the specified name.
 The string must match <i>exactly</i> an identifier used to declare an
 enum constant in this type.  (Extraneous whitespace characters are 
diff --git a/devapidocs/org/apache/hadoop/hbase/regionserver/package-tree.html b/devapidocs/org/apache/hadoop/hbase/regionserver/package-tree.html
index 5363cef..4454e11 100644
--- a/devapidocs/org/apache/hadoop/hbase/regionserver/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/regionserver/package-tree.html
@@ -732,20 +732,20 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
 <ul>
-<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/ScannerContext.LimitScope.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">ScannerContext.LimitScope</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerSourceFactoryImpl.FactoryStorage.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">MetricsRegionServerSourceFactoryImpl.FactoryStorage</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/DefaultHeapMemoryTuner.StepDirection.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">DefaultHeapMemoryTuner.StepDirection</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/ScannerContext.NextState.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">ScannerContext.NextState</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/CompactingMemStore.IndexType.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">CompactingMemStore.IndexType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/ChunkCreator.ChunkType.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">ChunkCreator.ChunkType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/BloomType.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">BloomType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/SplitLogWorker.TaskExecutor.Status.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">SplitLogWorker.TaskExecutor.Status</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/MemStoreCompactionStrategy.Action.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">MemStoreCompactionStrategy.Action</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/TimeRangeTracker.Type.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">TimeRangeTracker.Type</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/Region.Operation.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">Region.Operation</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/ScanType.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">ScanType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/HRegion.FlushResult.Result.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">HRegion.FlushResult.Result</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/ScannerContext.LimitScope.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">ScannerContext.LimitScope</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/BloomType.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">BloomType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/SplitLogWorker.TaskExecutor.Status.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">SplitLogWorker.TaskExecutor.Status</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/DefaultHeapMemoryTuner.StepDirection.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">DefaultHeapMemoryTuner.StepDirection</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/ScanType.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">ScanType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/ChunkCreator.ChunkType.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">ChunkCreator.ChunkType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/ScannerContext.NextState.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">ScannerContext.NextState</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/FlushType.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">FlushType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/CompactingMemStore.IndexType.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">CompactingMemStore.IndexType</span></a></li>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/regionserver/querymatcher/package-tree.html b/devapidocs/org/apache/hadoop/hbase/regionserver/querymatcher/package-tree.html
index bd7348f..ba24945 100644
--- a/devapidocs/org/apache/hadoop/hbase/regionserver/querymatcher/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/regionserver/querymatcher/package-tree.html
@@ -130,9 +130,9 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
 <ul>
-<li type="circle">org.apache.hadoop.hbase.regionserver.querymatcher.<a href="../../../../../../org/apache/hadoop/hbase/regionserver/querymatcher/StripeCompactionScanQueryMatcher.DropDeletesInOutput.html" title="enum in org.apache.hadoop.hbase.regionserver.querymatcher"><span class="typeNameLink">StripeCompactionScanQueryMatcher.DropDeletesInOutput</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.regionserver.querymatcher.<a href="../../../../../../org/apache/hadoop/hbase/regionserver/querymatcher/ScanQueryMatcher.MatchCode.html" title="enum in org.apache.hadoop.hbase.regionserver.querymatcher"><span class="typeNameLink">ScanQueryMatcher.MatchCode</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.regionserver.querymatcher.<a href="../../../../../../org/apache/hadoop/hbase/regionserver/querymatcher/DeleteTracker.DeleteResult.html" title="enum in org.apache.hadoop.hbase.regionserver.querymatcher"><span class="typeNameLink">DeleteTracker.DeleteResult</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.querymatcher.<a href="../../../../../../org/apache/hadoop/hbase/regionserver/querymatcher/StripeCompactionScanQueryMatcher.DropDeletesInOutput.html" title="enum in org.apache.hadoop.hbase.regionserver.querymatcher"><span class="typeNameLink">StripeCompactionScanQueryMatcher.DropDeletesInOutput</span></a></li>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/regionserver/wal/package-tree.html b/devapidocs/org/apache/hadoop/hbase/regionserver/wal/package-tree.html
index 2dc717e..e12604b 100644
--- a/devapidocs/org/apache/hadoop/hbase/regionserver/wal/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/regionserver/wal/package-tree.html
@@ -247,10 +247,10 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
 <ul>
-<li type="circle">org.apache.hadoop.hbase.regionserver.wal.<a href="../../../../../../org/apache/hadoop/hbase/regionserver/wal/ProtobufLogReader.WALHdrResult.html" title="enum in org.apache.hadoop.hbase.regionserver.wal"><span class="typeNameLink">ProtobufLogReader.WALHdrResult</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.regionserver.wal.<a href="../../../../../../org/apache/hadoop/hbase/regionserver/wal/CompressionContext.DictionaryIndex.html" title="enum in org.apache.hadoop.hbase.regionserver.wal"><span class="typeNameLink">CompressionContext.DictionaryIndex</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.regionserver.wal.<a href="../../../../../../org/apache/hadoop/hbase/regionserver/wal/RingBufferTruck.Type.html" title="enum in org.apache.hadoop.hbase.regionserver.wal"><span class="typeNameLink">RingBufferTruck.Type</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.regionserver.wal.<a href="../../../../../../org/apache/hadoop/hbase/regionserver/wal/WALActionsListener.RollRequestReason.html" title="enum in org.apache.hadoop.hbase.regionserver.wal"><span class="typeNameLink">WALActionsListener.RollRequestReason</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.wal.<a href="../../../../../../org/apache/hadoop/hbase/regionserver/wal/ProtobufLogReader.WALHdrResult.html" title="enum in org.apache.hadoop.hbase.regionserver.wal"><span class="typeNameLink">ProtobufLogReader.WALHdrResult</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.wal.<a href="../../../../../../org/apache/hadoop/hbase/regionserver/wal/CompressionContext.DictionaryIndex.html" title="enum in org.apache.hadoop.hbase.regionserver.wal"><span class="typeNameLink">CompressionContext.DictionaryIndex</span></a></li>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/replication/package-tree.html b/devapidocs/org/apache/hadoop/hbase/replication/package-tree.html
index 57a9d42..f3a4541 100644
--- a/devapidocs/org/apache/hadoop/hbase/replication/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/replication/package-tree.html
@@ -175,8 +175,8 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
 <ul>
-<li type="circle">org.apache.hadoop.hbase.replication.<a href="../../../../../org/apache/hadoop/hbase/replication/SyncReplicationState.html" title="enum in org.apache.hadoop.hbase.replication"><span class="typeNameLink">SyncReplicationState</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.replication.<a href="../../../../../org/apache/hadoop/hbase/replication/ReplicationPeer.PeerState.html" title="enum in org.apache.hadoop.hbase.replication"><span class="typeNameLink">ReplicationPeer.PeerState</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.replication.<a href="../../../../../org/apache/hadoop/hbase/replication/SyncReplicationState.html" title="enum in org.apache.hadoop.hbase.replication"><span class="typeNameLink">SyncReplicationState</span></a></li>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/security/access/package-tree.html b/devapidocs/org/apache/hadoop/hbase/security/access/package-tree.html
index 072a22b..5a0ed3b 100644
--- a/devapidocs/org/apache/hadoop/hbase/security/access/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/security/access/package-tree.html
@@ -162,12 +162,12 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
 <ul>
-<li type="circle">org.apache.hadoop.hbase.security.access.<a href="../../../../../../org/apache/hadoop/hbase/security/access/AccessController.OpType.html" title="enum in org.apache.hadoop.hbase.security.access"><span class="typeNameLink">AccessController.OpType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.security.access.<a href="../../../../../../org/apache/hadoop/hbase/security/access/AccessControlFilter.Strategy.html" title="enum in org.apache.hadoop.hbase.security.access"><span class="typeNameLink">AccessControlFilter.Strategy</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.security.access.<a href="../../../../../../org/apache/hadoop/hbase/security/access/Permission.Action.html" title="enum in org.apache.hadoop.hbase.security.access"><span class="typeNameLink">Permission.Action</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.security.access.<a href="../../../../../../org/apache/hadoop/hbase/security/access/Permission.Scope.html" title="enum in org.apache.hadoop.hbase.security.access"><span class="typeNameLink">Permission.Scope</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.security.access.<a href="../../../../../../org/apache/hadoop/hbase/security/access/SnapshotScannerHDFSAclHelper.HDFSAclOperation.OperationType.html" title="enum in org.apache.hadoop.hbase.security.access"><span class="typeNameLink">SnapshotScannerHDFSAclHelper.HDFSAclOperation.OperationType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.security.access.<a href="../../../../../../org/apache/hadoop/hbase/security/access/Permission.Scope.html" title="enum in org.apache.hadoop.hbase.security.access"><span class="typeNameLink">Permission.Scope</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.security.access.<a href="../../../../../../org/apache/hadoop/hbase/security/access/SnapshotScannerHDFSAclHelper.HDFSAclOperation.AclType.html" title="enum in org.apache.hadoop.hbase.security.access"><span class="typeNameLink">SnapshotScannerHDFSAclHelper.HDFSAclOperation.AclType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.security.access.<a href="../../../../../../org/apache/hadoop/hbase/security/access/AccessController.OpType.html" title="enum in org.apache.hadoop.hbase.security.access"><span class="typeNameLink">AccessController.OpType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.security.access.<a href="../../../../../../org/apache/hadoop/hbase/security/access/AccessControlFilter.Strategy.html" title="enum in org.apache.hadoop.hbase.security.access"><span class="typeNameLink">AccessControlFilter.Strategy</span></a></li>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/security/package-tree.html b/devapidocs/org/apache/hadoop/hbase/security/package-tree.html
index 76d4bcb..c060011 100644
--- a/devapidocs/org/apache/hadoop/hbase/security/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/security/package-tree.html
@@ -189,9 +189,9 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
 <ul>
-<li type="circle">org.apache.hadoop.hbase.security.<a href="../../../../../org/apache/hadoop/hbase/security/SaslUtil.QualityOfProtection.html" title="enum in org.apache.hadoop.hbase.security"><span class="typeNameLink">SaslUtil.QualityOfProtection</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.security.<a href="../../../../../org/apache/hadoop/hbase/security/SaslStatus.html" title="enum in org.apache.hadoop.hbase.security"><span class="typeNameLink">SaslStatus</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.security.<a href="../../../../../org/apache/hadoop/hbase/security/AuthMethod.html" title="enum in org.apache.hadoop.hbase.security"><span class="typeNameLink">AuthMethod</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.security.<a href="../../../../../org/apache/hadoop/hbase/security/SaslUtil.QualityOfProtection.html" title="enum in org.apache.hadoop.hbase.security"><span class="typeNameLink">SaslUtil.QualityOfProtection</span></a></li>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/thrift/package-tree.html b/devapidocs/org/apache/hadoop/hbase/thrift/package-tree.html
index 60fa9ee..1cc1670 100644
--- a/devapidocs/org/apache/hadoop/hbase/thrift/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/thrift/package-tree.html
@@ -211,9 +211,9 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
 <ul>
-<li type="circle">org.apache.hadoop.hbase.thrift.<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftMetrics.ThriftServerType.html" title="enum in org.apache.hadoop.hbase.thrift"><span class="typeNameLink">ThriftMetrics.ThriftServerType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.thrift.<a href="../../../../../org/apache/hadoop/hbase/thrift/ImplType.html" title="enum in org.apache.hadoop.hbase.thrift"><span class="typeNameLink">ImplType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.thrift.<a href="../../../../../org/apache/hadoop/hbase/thrift/MetricsThriftServerSourceFactoryImpl.FactoryStorage.html" title="enum in org.apache.hadoop.hbase.thrift"><span class="typeNameLink">MetricsThriftServerSourceFactoryImpl.FactoryStorage</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.thrift.<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftMetrics.ThriftServerType.html" title="enum in org.apache.hadoop.hbase.thrift"><span class="typeNameLink">ThriftMetrics.ThriftServerType</span></a></li>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html
index 0e8f092..cc09fc4 100644
--- a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html
+++ b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html
@@ -117,7 +117,7 @@ var activeTableTab = "activeTableTab";
 </dl>
 <hr>
 <br>
-<pre>class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1850">HBaseFsck.CheckRegionConsistencyWorkItem</a>
+<pre>class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1851">HBaseFsck.CheckRegionConsistencyWorkItem</a>
 extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a>
 implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/Callable.html?is-external=true" title="class or interface in java.util.concurrent">Callable</a>&lt;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Void.html?is-external=true" title="class or interface in java.lang">Void</a>&gt;</pre>
 </li>
@@ -211,7 +211,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
 <ul class="blockList">
 <li class="blockList">
 <h4>key</h4>
-<pre>private final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html#line.1851">key</a></pre>
+<pre>private final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html#line.1852">key</a></pre>
 </li>
 </ul>
 <a name="hbi">
@@ -220,7 +220,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
 <ul class="blockListLast">
 <li class="blockList">
 <h4>hbi</h4>
-<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html#line.1852">hbi</a></pre>
+<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html#line.1853">hbi</a></pre>
 </li>
 </ul>
 </li>
@@ -237,7 +237,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
 <ul class="blockListLast">
 <li class="blockList">
 <h4>CheckRegionConsistencyWorkItem</h4>
-<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html#line.1854">CheckRegionConsistencyWorkItem</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;key,
+<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html#line.1855">CheckRegionConsistencyWorkItem</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;key,
                                <a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;hbi)</pre>
 </li>
 </ul>
@@ -255,7 +255,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
 <ul class="blockListLast">
 <li class="blockList">
 <h4>call</h4>
-<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Void.html?is-external=true" title="class or interface in java.lang">Void</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html#line.1860">call</a>()
+<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Void.html?is-external=true" title="class or interface in java.lang">Void</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html#line.1861">call</a>()
           throws <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Exception.html?is-external=true" title="class or interface in java.lang">Exception</a></pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
diff --git a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html
index b52179f..7995d1c 100644
--- a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html
+++ b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html
@@ -117,7 +117,7 @@ var activeTableTab = "activeTableTab";
 </dl>
 <hr>
 <br>
-<pre>private static class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.406">HBaseFsck.FileLockCallable</a>
+<pre>private static class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.407">HBaseFsck.FileLockCallable</a>
 extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a>
 implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/Callable.html?is-external=true" title="class or interface in java.util.concurrent">Callable</a>&lt;org.apache.hadoop.fs.FSDataOutputStream&gt;</pre>
 </li>
@@ -225,7 +225,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
 <ul class="blockList">
 <li class="blockList">
 <h4>retryCounter</h4>
-<pre><a href="../../../../../org/apache/hadoop/hbase/util/RetryCounter.html" title="class in org.apache.hadoop.hbase.util">RetryCounter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.407">retryCounter</a></pre>
+<pre><a href="../../../../../org/apache/hadoop/hbase/util/RetryCounter.html" title="class in org.apache.hadoop.hbase.util">RetryCounter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.408">retryCounter</a></pre>
 </li>
 </ul>
 <a name="conf">
@@ -234,7 +234,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
 <ul class="blockList">
 <li class="blockList">
 <h4>conf</h4>
-<pre>private final&nbsp;org.apache.hadoop.conf.Configuration <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.408">conf</a></pre>
+<pre>private final&nbsp;org.apache.hadoop.conf.Configuration <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.409">conf</a></pre>
 </li>
 </ul>
 <a name="hbckLockPath">
@@ -243,7 +243,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
 <ul class="blockListLast">
 <li class="blockList">
 <h4>hbckLockPath</h4>
-<pre>private&nbsp;org.apache.hadoop.fs.Path <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.409">hbckLockPath</a></pre>
+<pre>private&nbsp;org.apache.hadoop.fs.Path <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.410">hbckLockPath</a></pre>
 </li>
 </ul>
 </li>
@@ -260,7 +260,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
 <ul class="blockListLast">
 <li class="blockList">
 <h4>FileLockCallable</h4>
-<pre>public&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.411">FileLockCallable</a>(org.apache.hadoop.conf.Configuration&nbsp;conf,
+<pre>public&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.412">FileLockCallable</a>(org.apache.hadoop.conf.Configuration&nbsp;conf,
                         <a href="../../../../../org/apache/hadoop/hbase/util/RetryCounter.html" title="class in org.apache.hadoop.hbase.util">RetryCounter</a>&nbsp;retryCounter)</pre>
 </li>
 </ul>
@@ -278,7 +278,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
 <ul class="blockList">
 <li class="blockList">
 <h4>getHbckLockPath</h4>
-<pre>org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.419">getHbckLockPath</a>()</pre>
+<pre>org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.420">getHbckLockPath</a>()</pre>
 <dl>
 <dt><span class="returnLabel">Returns:</span></dt>
 <dd>Will be <code>null</code> unless you call <a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#call--"><code>call()</code></a></dd>
@@ -291,7 +291,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
 <ul class="blockList">
 <li class="blockList">
 <h4>call</h4>
-<pre>public&nbsp;org.apache.hadoop.fs.FSDataOutputStream&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.424">call</a>()
+<pre>public&nbsp;org.apache.hadoop.fs.FSDataOutputStream&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.425">call</a>()
                                              throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
@@ -307,7 +307,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
 <ul class="blockListLast">
 <li class="blockList">
 <h4>createFileWithRetries</h4>
-<pre>private&nbsp;org.apache.hadoop.fs.FSDataOutputStream&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.449">createFileWithRetries</a>(org.apache.hadoop.fs.FileSystem&nbsp;fs,
+<pre>private&nbsp;org.apache.hadoop.fs.FSDataOutputStream&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.450">createFileWithRetries</a>(org.apache.hadoop.fs.FileSystem&nbsp;fs,
                                                                       org.apache.hadoop.fs.Path&nbsp;hbckLockFilePath,
                                                                       org.apache.hadoop.fs.permission.FsPermission&nbsp;defaultPerms)
                                                                throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
diff --git a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.HBaseFsckTool.html b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.HBaseFsckTool.html
index 5e953c4..bc4b681 100644
--- a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.HBaseFsckTool.html
+++ b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.HBaseFsckTool.html
@@ -122,7 +122,7 @@ var activeTableTab = "activeTableTab";
 </dl>
 <hr>
 <br>
-<pre>static class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3613">HBaseFsck.HBaseFsckTool</a>
+<pre>static class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3614">HBaseFsck.HBaseFsckTool</a>
 extends org.apache.hadoop.conf.Configured
 implements org.apache.hadoop.util.Tool</pre>
 <div class="block">This is a Tool wrapper that gathers -Dxxx=yyy configuration settings from the command line.</div>
@@ -207,7 +207,7 @@ implements org.apache.hadoop.util.Tool</pre>
 <ul class="blockListLast">
 <li class="blockList">
 <h4>HBaseFsckTool</h4>
-<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.HBaseFsckTool.html#line.3614">HBaseFsckTool</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)</pre>
+<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.HBaseFsckTool.html#line.3615">HBaseFsckTool</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)</pre>
 </li>
 </ul>
 </li>
@@ -224,7 +224,7 @@ implements org.apache.hadoop.util.Tool</pre>
 <ul class="blockListLast">
 <li class="blockList">
 <h4>run</h4>
-<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.HBaseFsckTool.html#line.3616">run</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>[]&nbsp;args)
+<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.HBaseFsckTool.html#line.3617">run</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>[]&nbsp;args)
         throws <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Exception.html?is-external=true" title="class or interface in java.lang">Exception</a></pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
diff --git a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html
index f388e15..2e92ec5 100644
--- a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html
+++ b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html
@@ -117,7 +117,7 @@ var activeTableTab = "activeTableTab";
 </dl>
 <hr>
 <br>
-<pre>static class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2878">HBaseFsck.PrintingErrorReporter</a>
+<pre>static class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2879">HBaseFsck.PrintingErrorReporter</a>
 extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a>
 implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a></pre>
 </li>
@@ -301,7 +301,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
 <ul class="blockList">
 <li class="blockList">
 <h4>errorCount</h4>
-<pre>public&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2879">errorCount</a></pre>
+<pre>public&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2880">errorCount</a></pre>
 </li>
 </ul>
 <a name="showProgress">
@@ -310,7 +310,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
 <ul class="blockList">
 <li class="blockList">
 <h4>showProgress</h4>
-<pre>private&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2880">showProgress</a></pre>
+<pre>private&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2881">showProgress</a></pre>
 </li>
 </ul>
 <a name="progressThreshold">
@@ -319,7 +319,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
 <ul class="blockList">
 <li class="blockList">
 <h4>progressThreshold</h4>
-<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2882">progressThreshold</a></pre>
+<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2883">progressThreshold</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.util.HBaseFsck.PrintingErrorReporter.progressThreshold">Constant Field Values</a></dd>
@@ -332,7 +332,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
 <ul class="blockList">
 <li class="blockList">
 <h4>errorTables</h4>
-<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="class in org.apache.hadoop.hbase.util">HbckTableInfo</a>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2884">errorTables</a></pre>
+<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="class in org.apache.hadoop.hbase.util">HbckTableInfo</a>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2885">errorTables</a></pre>
 </li>
 </ul>
 <a name="errorList">
@@ -341,7 +341,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
 <ul class="blockListLast">
 <li class="blockList">
 <h4>errorList</h4>
-<pre>private&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/ArrayList.html?is-external=true" title="class or interface in java.util">ArrayList</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.ERROR_CODE.html" title="enum in org.apache.hadoop.hbase.util">HbckErrorReporter.ERROR_CODE</a>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2887">errorList</a></pre>
+<pre>private&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/ArrayList.html?is-external=true" title="class or interface in java.util">ArrayList</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.ERROR_CODE.html" title="enum in org.apache.hadoop.hbase.util">HbckErrorReporter.ERROR_CODE</a>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2888">errorList</a></pre>
 </li>
 </ul>
 </li>
@@ -358,7 +358,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
 <ul class="blockListLast">
 <li class="blockList">
 <h4>PrintingErrorReporter</h4>
-<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2878">PrintingErrorReporter</a>()</pre>
+<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2879">PrintingErrorReporter</a>()</pre>
 </li>
 </ul>
 </li>
@@ -375,7 +375,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
 <ul class="blockList">
 <li class="blockList">
 <h4>clear</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2890">clear</a>()</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2891">clear</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html#clear--">clear</a></code>&nbsp;in interface&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a></code></dd>
@@ -388,7 +388,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
 <ul class="blockList">
 <li class="blockList">
 <h4>reportError</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2897">reportError</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.ERROR_CODE.html" title="enum in org.apache.hadoop.hbase.util">HbckErrorReporter.ERROR_CODE</a>&nbsp;errorCode,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2898">reportError</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.ERROR_CODE.html" title="enum in org.apache.hadoop.hbase.util">HbckErrorReporter.ERROR_CODE</a>&nbsp;errorCode,
                         <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;message)</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
@@ -402,7 +402,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
 <ul class="blockList">
 <li class="blockList">
 <h4>reportError</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2912">reportError</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.ERROR_CODE.html" title="enum in org.apache.hadoop.hbase.util">HbckErrorReporter.ERROR_CODE</a>&nbsp;errorCode,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2913">reportError</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.ERROR_CODE.html" title="enum in org.apache.hadoop.hbase.util">HbckErrorReporter.ERROR_CODE</a>&nbsp;errorCode,
                         <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;message,
                         <a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="class in org.apache.hadoop.hbase.util">HbckTableInfo</a>&nbsp;table)</pre>
 <dl>
@@ -417,7 +417,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
 <ul class="blockList">
 <li class="blockList">
 <h4>reportError</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2919">reportError</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.ERROR_CODE.html" title="enum in org.apache.hadoop.hbase.util">HbckErrorReporter.ERROR_CODE</a>&nbsp;errorCode,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2920">reportError</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.ERROR_CODE.html" title="enum in org.apache.hadoop.hbase.util">HbckErrorReporter.ERROR_CODE</a>&nbsp;errorCode,
                         <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;message,
                         <a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="class in org.apache.hadoop.hbase.util">HbckTableInfo</a>&nbsp;table,
                         <a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;info)</pre>
@@ -433,7 +433,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
 <ul class="blockList">
 <li class="blockList">
 <h4>reportError</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2927">reportError</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.ERROR_CODE.html" title="enum in org.apache.hadoop.hbase.util">HbckErrorReporter.ERROR_CODE</a>&nbsp;errorCode,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2928">reportError</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.ERROR_CODE.html" title="enum in org.apache.hadoop.hbase.util">HbckErrorReporter.ERROR_CODE</a>&nbsp;errorCode,
                         <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;message,
                         <a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="class in org.apache.hadoop.hbase.util">HbckTableInfo</a>&nbsp;table,
                         <a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;info1,
@@ -450,7 +450,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
 <ul class="blockList">
 <li class="blockList">
 <h4>reportError</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2936">reportError</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;message)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2937">reportError</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;message)</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html#reportError-java.lang.String-">reportError</a></code>&nbsp;in interface&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a></code></dd>
@@ -463,7 +463,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
 <ul class="blockList">
 <li class="blockList">
 <h4>report</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2946">report</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;message)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2947">report</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;message)</pre>
 <div class="block">Report error information, but do not increment the error count.  Intended for cases
  where the actual error would have been reported previously.</div>
 <dl>
@@ -480,7 +480,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
 <ul class="blockList">
 <li class="blockList">
 <h4>summarize</h4>
-<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2954">summarize</a>()</pre>
+<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2955">summarize</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html#summarize--">summarize</a></code>&nbsp;in interface&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a></code></dd>
@@ -493,7 +493,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
 <ul class="blockList">
 <li class="blockList">
 <h4>getErrorList</h4>
-<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/ArrayList.html?is-external=true" title="class or interface in java.util">ArrayList</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.ERROR_CODE.html" title="enum in org.apache.hadoop.hbase.util">HbckErrorReporter.ERROR_CODE</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2967">getErrorList</a>()</pre>
+<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/ArrayList.html?is-external=true" title="class or interface in java.util">ArrayList</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.ERROR_CODE.html" title="enum in org.apache.hadoop.hbase.util">HbckErrorReporter.ERROR_CODE</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2968">getErrorList</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html#getErrorList--">getErrorList</a></code>&nbsp;in interface&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a></code></dd>
@@ -506,7 +506,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
 <ul class="blockList">
 <li class="blockList">
 <h4>print</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2972">print</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;message)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2973">print</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;message)</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html#print-java.lang.String-">print</a></code>&nbsp;in interface&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a></code></dd>
@@ -519,7 +519,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
 <ul class="blockList">
 <li class="blockList">
 <h4>tableHasErrors</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2979">tableHasErrors</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="class in org.apache.hadoop.hbase.util">HbckTableInfo</a>&nbsp;table)</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2980">tableHasErrors</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="class in org.apache.hadoop.hbase.util">HbckTableInfo</a>&nbsp;table)</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html#tableHasErrors-org.apache.hadoop.hbase.util.HbckTableInfo-">tableHasErrors</a></code>&nbsp;in interface&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a></code></dd>
@@ -532,7 +532,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
 <ul class="blockList">
 <li class="blockList">
 <h4>resetErrors</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2984">resetErrors</a>()</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2985">resetErrors</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html#resetErrors--">resetErrors</a></code>&nbsp;in interface&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a></code></dd>
@@ -545,7 +545,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
 <ul class="blockList">
 <li class="blockList">
 <h4>detail</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2989">detail</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;message)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2990">detail</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;message)</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html#detail-java.lang.String-">detail</a></code>&nbsp;in interface&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a></code></dd>
@@ -558,7 +558,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
 <ul class="blockListLast">
 <li class="blockList">
 <h4>progress</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2997">progress</a>()</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2998">progress</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html#progress--">progress</a></code>&nbsp;in interface&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a></code></dd>
diff --git a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html
index 6fc1a1a..2ecfec2 100644
--- a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html
+++ b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html
@@ -113,7 +113,7 @@ var activeTableTab = "activeTableTab";
 </dl>
 <hr>
 <br>
-<pre>private static class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.872">HBaseFsck.RegionBoundariesInformation</a>
+<pre>private static class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.873">HBaseFsck.RegionBoundariesInformation</a>
 extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a></pre>
 </li>
 </ul>
@@ -219,7 +219,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>regionName</h4>
-<pre>public&nbsp;byte[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.873">regionName</a></pre>
+<pre>public&nbsp;byte[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.874">regionName</a></pre>
 </li>
 </ul>
 <a name="metaFirstKey">
@@ -228,7 +228,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>metaFirstKey</h4>
-<pre>public&nbsp;byte[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.874">metaFirstKey</a></pre>
+<pre>public&nbsp;byte[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.875">metaFirstKey</a></pre>
 </li>
 </ul>
 <a name="metaLastKey">
@@ -237,7 +237,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>metaLastKey</h4>
-<pre>public&nbsp;byte[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.875">metaLastKey</a></pre>
+<pre>public&nbsp;byte[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.876">metaLastKey</a></pre>
 </li>
 </ul>
 <a name="storesFirstKey">
@@ -246,7 +246,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>storesFirstKey</h4>
-<pre>public&nbsp;byte[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.876">storesFirstKey</a></pre>
+<pre>public&nbsp;byte[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.877">storesFirstKey</a></pre>
 </li>
 </ul>
 <a name="storesLastKey">
@@ -255,7 +255,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockListLast">
 <li class="blockList">
 <h4>storesLastKey</h4>
-<pre>public&nbsp;byte[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.877">storesLastKey</a></pre>
+<pre>public&nbsp;byte[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.878">storesLastKey</a></pre>
 </li>
 </ul>
 </li>
@@ -272,7 +272,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockListLast">
 <li class="blockList">
 <h4>RegionBoundariesInformation</h4>
-<pre>private&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.872">RegionBoundariesInformation</a>()</pre>
+<pre>private&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.873">RegionBoundariesInformation</a>()</pre>
 </li>
 </ul>
 </li>
@@ -289,7 +289,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockListLast">
 <li class="blockList">
 <h4>toString</h4>
-<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.879">toString</a>()</pre>
+<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.880">toString</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Overrides:</span></dt>
 <dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#toString--" title="class or interface in java.lang">toString</a></code>&nbsp;in class&nbsp;<code><a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a></code></dd>
diff --git a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsDir.html b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsDir.html
index 4c5ca4cc..2f9447b 100644
--- a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsDir.html
+++ b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsDir.html
@@ -117,7 +117,7 @@ var activeTableTab = "activeTableTab";
 </dl>
 <hr>
 <br>
-<pre>class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3072">HBaseFsck.WorkItemHdfsDir</a>
+<pre>class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3073">HBaseFsck.WorkItemHdfsDir</a>
 extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a>
 implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/Callable.html?is-external=true" title="class or interface in java.util.concurrent">Callable</a>&lt;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Void.html?is-external=true" title="class or interface in java.lang">Void</a>&gt;</pre>
 <div class="block">Contact hdfs and get all information about specified table directory into
@@ -218,7 +218,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
 <ul class="blockList">
 <li class="blockList">
 <h4>tableDir</h4>
-<pre>private&nbsp;org.apache.hadoop.fs.FileStatus <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsDir.html#line.3073">tableDir</a></pre>
+<pre>private&nbsp;org.apache.hadoop.fs.FileStatus <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsDir.html#line.3074">tableDir</a></pre>
 </li>
 </ul>
 <a name="errors">
@@ -227,7 +227,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
 <ul class="blockList">
 <li class="blockList">
 <h4>errors</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsDir.html#line.3074">errors</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsDir.html#line.3075">errors</a></pre>
 </li>
 </ul>
 <a name="fs">
@@ -236,7 +236,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
 <ul class="blockListLast">
 <li class="blockList">
 <h4>fs</h4>
-<pre>private&nbsp;org.apache.hadoop.fs.FileSystem <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsDir.html#line.3075">fs</a></pre>
+<pre>private&nbsp;org.apache.hadoop.fs.FileSystem <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsDir.html#line.3076">fs</a></pre>
 </li>
 </ul>
 </li>
@@ -253,7 +253,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
 <ul class="blockListLast">
 <li class="blockList">
 <h4>WorkItemHdfsDir</h4>
-<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsDir.html#line.3077">WorkItemHdfsDir</a>(org.apache.hadoop.fs.FileSystem&nbsp;fs,
+<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsDir.html#line.3078">WorkItemHdfsDir</a>(org.apache.hadoop.fs.FileSystem&nbsp;fs,
                 <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a>&nbsp;errors,
                 org.apache.hadoop.fs.FileStatus&nbsp;status)</pre>
 </li>
@@ -272,7 +272,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
 <ul class="blockListLast">
 <li class="blockList">
 <h4>call</h4>
-<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Void.html?is-external=true" title="class or interface in java.lang">Void</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsDir.html#line.3084">call</a>()
+<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Void.html?is-external=true" title="class or interface in java.lang">Void</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsDir.html#line.3085">call</a>()
           throws <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a>,
                  <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/ExecutionException.html?is-external=true" title="class or interface in java.util.concurrent">ExecutionException</a></pre>
 <dl>
diff --git a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsRegionInfo.html b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsRegionInfo.html
index 429ad98..1fe8acf 100644
--- a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsRegionInfo.html
+++ b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsRegionInfo.html
@@ -117,7 +117,7 @@ var activeTableTab = "activeTableTab";
 </dl>
 <hr>
 <br>
-<pre>static class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3191">HBaseFsck.WorkItemHdfsRegionInfo</a>
+<pre>static class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3192">HBaseFsck.WorkItemHdfsRegionInfo</a>
 extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a>
 implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/Callable.html?is-external=true" title="class or interface in java.util.concurrent">Callable</a>&lt;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Void.html?is-external=true" title="class or interface in java.lang">Void</a>&gt;</pre>
 <div class="block">Contact hdfs and get all information about specified table directory into
@@ -218,7 +218,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
 <ul class="blockList">
 <li class="blockList">
 <h4>hbi</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsRegionInfo.html#line.3192">hbi</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsRegionInfo.html#line.3193">hbi</a></pre>
 </li>
 </ul>
 <a name="hbck">
@@ -227,7 +227,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
 <ul class="blockList">
 <li class="blockList">
 <h4>hbck</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.html" title="class in org.apache.hadoop.hbase.util">HBaseFsck</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsRegionInfo.html#line.3193">hbck</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.html" title="class in org.apache.hadoop.hbase.util">HBaseFsck</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsRegionInfo.html#line.3194">hbck</a></pre>
 </li>
 </ul>
 <a name="errors">
@@ -236,7 +236,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
 <ul class="blockListLast">
 <li class="blockList">
 <h4>errors</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsRegionInfo.html#line.3194">errors</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsRegionInfo.html#line.3195">errors</a></pre>
 </li>
 </ul>
 </li>
@@ -253,7 +253,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
 <ul class="blockListLast">
 <li class="blockList">
 <h4>WorkItemHdfsRegionInfo</h4>
-<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsRegionInfo.html#line.3196">WorkItemHdfsRegionInfo</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;hbi,
+<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsRegionInfo.html#line.3197">WorkItemHdfsRegionInfo</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;hbi,
                        <a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.html" title="class in org.apache.hadoop.hbase.util">HBaseFsck</a>&nbsp;hbck,
                        <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a>&nbsp;errors)</pre>
 </li>
@@ -272,7 +272,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
 <ul class="blockListLast">
 <li class="blockList">
 <h4>call</h4>
-<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Void.html?is-external=true" title="class or interface in java.lang">Void</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsRegionInfo.html#line.3203">call</a>()
+<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Void.html?is-external=true" title="class or interface in java.lang">Void</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsRegionInfo.html#line.3204">call</a>()
           throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
diff --git a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemOverlapMerge.html b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemOverlapMerge.html
index 209d18c..19f0cd2 100644
--- a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemOverlapMerge.html
+++ b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemOverlapMerge.html
@@ -117,7 +117,7 @@ var activeTableTab = "activeTableTab";
 </dl>
 <hr>
 <br>
-<pre>static class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2565">HBaseFsck.WorkItemOverlapMerge</a>
+<pre>static class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2566">HBaseFsck.WorkItemOverlapMerge</a>
 extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a>
 implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/Callable.html?is-external=true" title="class or interface in java.util.concurrent">Callable</a>&lt;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Void.html?is-external=true" title="class or interface in java.lang">Void</a>&gt;</pre>
 </li>
@@ -211,7 +211,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
 <ul class="blockList">
 <li class="blockList">
 <h4>handler</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/hbck/TableIntegrityErrorHandler.html" title="interface in org.apache.hadoop.hbase.util.hbck">TableIntegrityErrorHandler</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemOverlapMerge.html#line.2566">handler</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/hbck/TableIntegrityErrorHandler.html" title="interface in org.apache.hadoop.hbase.util.hbck">TableIntegrityErrorHandler</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemOverlapMerge.html#line.2567">handler</a></pre>
 </li>
 </ul>
 <a name="overlapgroup">
@@ -220,7 +220,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
 <ul class="blockListLast">
 <li class="blockList">
 <h4>overlapgroup</h4>
-<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Collection.html?is-external=true" title="class or interface in java.util">Collection</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemOverlapMerge.html#line.2567">overlapgroup</a></pre>
+<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Collection.html?is-external=true" title="class or interface in java.util">Collection</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemOverlapMerge.html#line.2568">overlapgroup</a></pre>
 </li>
 </ul>
 </li>
@@ -237,7 +237,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
 <ul class="blockListLast">
 <li class="blockList">
 <h4>WorkItemOverlapMerge</h4>
-<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemOverlapMerge.html#line.2569">WorkItemOverlapMerge</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Collection.html?is-external=true" title="class or interface in java.util">Collection</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&gt;&nbsp;overlapgroup,
+<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemOverlapMerge.html#line.2570">WorkItemOverlapMerge</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Collection.html?is-external=true" title="class or interface in java.util">Collection</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&gt;&nbsp;overlapgroup,
                      <a href="../../../../../org/apache/hadoop/hbase/util/hbck/TableIntegrityErrorHandler.html" title="interface in org.apache.hadoop.hbase.util.hbck">TableIntegrityErrorHandler</a>&nbsp;handler)</pre>
 </li>
 </ul>
@@ -255,7 +255,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
 <ul class="blockListLast">
 <li class="blockList">
 <h4>call</h4>
-<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Void.html?is-external=true" title="class or interface in java.lang">Void</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemOverlapMerge.html#line.2576">call</a>()
+<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Void.html?is-external=true" title="class or interface in java.lang">Void</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemOverlapMerge.html#line.2577">call</a>()
           throws <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Exception.html?is-external=true" title="class or interface in java.lang">Exception</a></pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
diff --git a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html
index ca1bb2d..1fdd1b4 100644
--- a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html
+++ b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html
@@ -117,7 +117,7 @@ var activeTableTab = "activeTableTab";
 </dl>
 <hr>
 <br>
-<pre>static class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3010">HBaseFsck.WorkItemRegion</a>
+<pre>static class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3011">HBaseFsck.WorkItemRegion</a>
 extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a>
 implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/Callable.html?is-external=true" title="class or interface in java.util.concurrent">Callable</a>&lt;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Void.html?is-external=true" title="class or interface in java.lang">Void</a>&gt;</pre>
 <div class="block">Contact a region server and get all information from it</div>
@@ -226,7 +226,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
 <ul class="blockList">
 <li class="blockList">
 <h4>hbck</h4>
-<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.html" title="class in org.apache.hadoop.hbase.util">HBaseFsck</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html#line.3011">hbck</a></pre>
+<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.html" title="class in org.apache.hadoop.hbase.util">HBaseFsck</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html#line.3012">hbck</a></pre>
 </li>
 </ul>
 <a name="rsinfo">
@@ -235,7 +235,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
 <ul class="blockList">
 <li class="blockList">
 <h4>rsinfo</h4>
-<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html#line.3012">rsinfo</a></pre>
+<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html#line.3013">rsinfo</a></pre>
 </li>
 </ul>
 <a name="errors">
@@ -244,7 +244,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
 <ul class="blockList">
 <li class="blockList">
 <h4>errors</h4>
-<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html#line.3013">errors</a></pre>
+<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html#line.3014">errors</a></pre>
 </li>
 </ul>
 <a name="connection">
@@ -253,7 +253,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
 <ul class="blockListLast">
 <li class="blockList">
 <h4>connection</h4>
-<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html#line.3014">connection</a></pre>
+<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html#line.3015">connection</a></pre>
 </li>
 </ul>
 </li>
@@ -270,7 +270,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
 <ul class="blockListLast">
 <li class="blockList">
 <h4>WorkItemRegion</h4>
-<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html#line.3016">WorkItemRegion</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.html" title="class in org.apache.hadoop.hbase.util">HBaseFsck</a>&nbsp;hbck,
+<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html#line.3017">WorkItemRegion</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.html" title="class in org.apache.hadoop.hbase.util">HBaseFsck</a>&nbsp;hbck,
                <a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;info,
                <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a>&nbsp;errors,
                <a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a>&nbsp;connection)</pre>
@@ -290,7 +290,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
 <ul class="blockList">
 <li class="blockList">
 <h4>call</h4>
-<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Void.html?is-external=true" title="class or interface in java.lang">Void</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html#line.3025">call</a>()
+<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Void.html?is-external=true" title="class or interface in java.lang">Void</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html#line.3026">call</a>()
           throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
@@ -306,7 +306,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
 <ul class="blockListLast">
 <li class="blockList">
 <h4>filterRegions</h4>
-<pre>private&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/client/RegionInfo.html" title="interface in org.apache.hadoop.hbase.client">RegionInfo</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html#line.3056">filterRegions</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Lis [...]
+<pre>private&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/client/RegionInfo.html" title="interface in org.apache.hadoop.hbase.client">RegionInfo</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html#line.3057">filterRegions</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Lis [...]
 </li>
 </ul>
 </li>
diff --git a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.html b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.html
index ef96ea4..8ba46ca 100644
--- a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.html
+++ b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.html
@@ -124,7 +124,7 @@ var activeTableTab = "activeTableTab";
 <pre><a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Deprecated.html?is-external=true" title="class or interface in java.lang">@Deprecated</a>
  @InterfaceAudience.LimitedPrivate(value="Tools")
  @InterfaceStability.Evolving
-public class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.202">HBaseFsck</a>
+public class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.203">HBaseFsck</a>
 extends org.apache.hadoop.conf.Configured
 implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.html?is-external=true" title="class or interface in java.io">Closeable</a></pre>
 <div class="block">HBaseFsck (hbck) is a tool for checking and repairing region consistency and
@@ -1675,7 +1675,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>DEFAULT_TIME_LAG</h4>
-<pre>public static final&nbsp;long <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.203">DEFAULT_TIME_LAG</a></pre>
+<pre>public static final&nbsp;long <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.204">DEFAULT_TIME_LAG</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
@@ -1689,7 +1689,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>DEFAULT_SLEEP_BEFORE_RERUN</h4>
-<pre>public static final&nbsp;long <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.204">DEFAULT_SLEEP_BEFORE_RERUN</a></pre>
+<pre>public static final&nbsp;long <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.205">DEFAULT_SLEEP_BEFORE_RERUN</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
@@ -1703,7 +1703,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>MAX_NUM_THREADS</h4>
-<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.205">MAX_NUM_THREADS</a></pre>
+<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.206">MAX_NUM_THREADS</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
@@ -1717,7 +1717,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>rsSupportsOffline</h4>
-<pre>private static&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.206">rsSupportsOffline</a></pre>
+<pre>private static&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.207">rsSupportsOffline</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -1727,7 +1727,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>DEFAULT_OVERLAPS_TO_SIDELINE</h4>
-<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.207">DEFAULT_OVERLAPS_TO_SIDELINE</a></pre>
+<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.208">DEFAULT_OVERLAPS_TO_SIDELINE</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
@@ -1741,7 +1741,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>DEFAULT_MAX_MERGE</h4>
-<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.208">DEFAULT_MAX_MERGE</a></pre>
+<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.209">DEFAULT_MAX_MERGE</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
@@ -1756,7 +1756,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <li class="blockList">
 <h4>HBCK_LOCK_FILE</h4>
 <pre>@InterfaceAudience.Private
-public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.215">HBCK_LOCK_FILE</a></pre>
+public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.216">HBCK_LOCK_FILE</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Here is where hbase-1.x used to default the lock for hbck1.
  It puts in place a lock when it goes to write/make changes.</div>
@@ -1772,7 +1772,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>DEFAULT_MAX_LOCK_FILE_ATTEMPTS</h4>
-<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.216">DEFAULT_MAX_LOCK_FILE_ATTEMPTS</a></pre>
+<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.217">DEFAULT_MAX_LOCK_FILE_ATTEMPTS</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
@@ -1786,7 +1786,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>DEFAULT_LOCK_FILE_ATTEMPT_SLEEP_INTERVAL</h4>
-<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.217">DEFAULT_LOCK_FILE_ATTEMPT_SLEEP_INTERVAL</a></pre>
+<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.218">DEFAULT_LOCK_FILE_ATTEMPT_SLEEP_INTERVAL</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
@@ -1800,7 +1800,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>DEFAULT_LOCK_FILE_ATTEMPT_MAX_SLEEP_TIME</h4>
-<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.218">DEFAULT_LOCK_FILE_ATTEMPT_MAX_SLEEP_TIME</a></pre>
+<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.219">DEFAULT_LOCK_FILE_ATTEMPT_MAX_SLEEP_TIME</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
@@ -1814,7 +1814,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>DEFAULT_WAIT_FOR_LOCK_TIMEOUT</h4>
-<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.223">DEFAULT_WAIT_FOR_LOCK_TIMEOUT</a></pre>
+<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.224">DEFAULT_WAIT_FOR_LOCK_TIMEOUT</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
@@ -1828,7 +1828,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>DEFAULT_MAX_CREATE_ZNODE_ATTEMPTS</h4>
-<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.224">DEFAULT_MAX_CREATE_ZNODE_ATTEMPTS</a></pre>
+<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.225">DEFAULT_MAX_CREATE_ZNODE_ATTEMPTS</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
@@ -1842,7 +1842,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>DEFAULT_CREATE_ZNODE_ATTEMPT_SLEEP_INTERVAL</h4>
-<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.225">DEFAULT_CREATE_ZNODE_ATTEMPT_SLEEP_INTERVAL</a></pre>
+<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.226">DEFAULT_CREATE_ZNODE_ATTEMPT_SLEEP_INTERVAL</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
@@ -1856,7 +1856,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>DEFAULT_CREATE_ZNODE_ATTEMPT_MAX_SLEEP_TIME</h4>
-<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.226">DEFAULT_CREATE_ZNODE_ATTEMPT_MAX_SLEEP_TIME</a></pre>
+<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.227">DEFAULT_CREATE_ZNODE_ATTEMPT_MAX_SLEEP_TIME</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
@@ -1870,7 +1870,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>LOG</h4>
-<pre>private static final&nbsp;org.slf4j.Logger <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.231">LOG</a></pre>
+<pre>private static final&nbsp;org.slf4j.Logger <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.232">LOG</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Internal resources</div>
 </li>
@@ -1881,7 +1881,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>status</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/ClusterMetrics.html" title="interface in org.apache.hadoop.hbase">ClusterMetrics</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.232">status</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/ClusterMetrics.html" title="interface in org.apache.hadoop.hbase">ClusterMetrics</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.233">status</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -1891,7 +1891,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>connection</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.233">connection</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.234">connection</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -1901,7 +1901,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>admin</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/Admin.html" title="interface in org.apache.hadoop.hbase.client">Admin</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.234">admin</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/Admin.html" title="interface in org.apache.hadoop.hbase.client">Admin</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.235">admin</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -1911,7 +1911,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>meta</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/Table.html" title="interface in org.apache.hadoop.hbase.client">Table</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.235">meta</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/Table.html" title="interface in org.apache.hadoop.hbase.client">Table</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.236">meta</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -1921,7 +1921,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>executor</h4>
-<pre>protected&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/ExecutorService.html?is-external=true" title="class or interface in java.util.concurrent">ExecutorService</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.237">executor</a></pre>
+<pre>protected&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/ExecutorService.html?is-external=true" title="class or interface in java.util.concurrent">ExecutorService</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.238">executor</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -1931,7 +1931,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>startMillis</h4>
-<pre>private&nbsp;long <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.238">startMillis</a></pre>
+<pre>private&nbsp;long <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.239">startMillis</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -1941,7 +1941,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>hfcc</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/hbck/HFileCorruptionChecker.html" title="class in org.apache.hadoop.hbase.util.hbck">HFileCorruptionChecker</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.239">hfcc</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/hbck/HFileCorruptionChecker.html" title="class in org.apache.hadoop.hbase.util.hbck">HFileCorruptionChecker</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.240">hfcc</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -1951,7 +1951,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>retcode</h4>
-<pre>private&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.240">retcode</a></pre>
+<pre>private&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.241">retcode</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -1961,7 +1961,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>HBCK_LOCK_PATH</h4>
-<pre>private&nbsp;org.apache.hadoop.fs.Path <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.241">HBCK_LOCK_PATH</a></pre>
+<pre>private&nbsp;org.apache.hadoop.fs.Path <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.242">HBCK_LOCK_PATH</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -1971,7 +1971,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>hbckOutFd</h4>
-<pre>private&nbsp;org.apache.hadoop.fs.FSDataOutputStream <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.242">hbckOutFd</a></pre>
+<pre>private&nbsp;org.apache.hadoop.fs.FSDataOutputStream <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.243">hbckOutFd</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -1981,7 +1981,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>hbckLockCleanup</h4>
-<pre>private final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/atomic/AtomicBoolean.html?is-external=true" title="class or interface in java.util.concurrent.atomic">AtomicBoolean</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.246">hbckLockCleanup</a></pre>
+<pre>private final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/atomic/AtomicBoolean.html?is-external=true" title="class or interface in java.util.concurrent.atomic">AtomicBoolean</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.247">hbckLockCleanup</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -1991,7 +1991,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>unsupportedOptionsInV2</h4>
-<pre>private static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a>&lt;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.249">unsupportedOptionsInV2</a></pre>
+<pre>private static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a>&lt;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.250">unsupportedOptionsInV2</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2001,7 +2001,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>details</h4>
-<pre>private static&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.257">details</a></pre>
+<pre>private static&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.258">details</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Options</div>
 </li>
@@ -2012,7 +2012,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>timelag</h4>
-<pre>private&nbsp;long <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.258">timelag</a></pre>
+<pre>private&nbsp;long <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.259">timelag</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2022,7 +2022,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>forceExclusive</h4>
-<pre>private static&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.259">forceExclusive</a></pre>
+<pre>private static&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.260">forceExclusive</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2032,7 +2032,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>fixAssignments</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.260">fixAssignments</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.261">fixAssignments</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2042,7 +2042,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>fixMeta</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.261">fixMeta</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.262">fixMeta</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2052,7 +2052,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>checkHdfs</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.262">checkHdfs</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.263">checkHdfs</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2062,7 +2062,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>fixHdfsHoles</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.263">fixHdfsHoles</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.264">fixHdfsHoles</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2072,7 +2072,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>fixHdfsOverlaps</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.264">fixHdfsOverlaps</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.265">fixHdfsOverlaps</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2082,7 +2082,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>fixHdfsOrphans</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.265">fixHdfsOrphans</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.266">fixHdfsOrphans</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2092,7 +2092,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>fixTableOrphans</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.266">fixTableOrphans</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.267">fixTableOrphans</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2102,7 +2102,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>fixVersionFile</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.267">fixVersionFile</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.268">fixVersionFile</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2112,7 +2112,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>fixSplitParents</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.268">fixSplitParents</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.269">fixSplitParents</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2122,7 +2122,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>removeParents</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.269">removeParents</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.270">removeParents</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2132,7 +2132,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>fixReferenceFiles</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.270">fixReferenceFiles</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.271">fixReferenceFiles</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2142,7 +2142,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>fixHFileLinks</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.271">fixHFileLinks</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.272">fixHFileLinks</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2152,7 +2152,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>fixEmptyMetaCells</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.272">fixEmptyMetaCells</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.273">fixEmptyMetaCells</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2162,7 +2162,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>fixReplication</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.273">fixReplication</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.274">fixReplication</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2172,7 +2172,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>cleanReplicationBarrier</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.274">cleanReplicationBarrier</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.275">cleanReplicationBarrier</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2182,7 +2182,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>fixAny</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.275">fixAny</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.276">fixAny</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2192,7 +2192,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>tablesIncluded</h4>
-<pre>private&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.279">tablesIncluded</a></pre>
+<pre>private&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.280">tablesIncluded</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2202,7 +2202,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>cleanReplicationBarrierTable</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.280">cleanReplicationBarrierTable</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.281">cleanReplicationBarrierTable</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2212,7 +2212,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>maxMerge</h4>
-<pre>private&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.281">maxMerge</a></pre>
+<pre>private&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.282">maxMerge</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2222,7 +2222,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>maxOverlapsToSideline</h4>
-<pre>private&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.283">maxOverlapsToSideline</a></pre>
+<pre>private&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.284">maxOverlapsToSideline</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2232,7 +2232,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>sidelineBigOverlaps</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.284">sidelineBigOverlaps</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.285">sidelineBigOverlaps</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2242,7 +2242,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>sidelineDir</h4>
-<pre>private&nbsp;org.apache.hadoop.fs.Path <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.285">sidelineDir</a></pre>
+<pre>private&nbsp;org.apache.hadoop.fs.Path <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.286">sidelineDir</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2252,7 +2252,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>rerun</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.287">rerun</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.288">rerun</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2262,7 +2262,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>summary</h4>
-<pre>private static&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.288">summary</a></pre>
+<pre>private static&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.289">summary</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2272,7 +2272,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>checkMetaOnly</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.289">checkMetaOnly</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.290">checkMetaOnly</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2282,7 +2282,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>checkRegionBoundaries</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.290">checkRegionBoundaries</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.291">checkRegionBoundaries</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2292,7 +2292,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>ignorePreCheckPermission</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.291">ignorePreCheckPermission</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.292">ignorePreCheckPermission</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2302,7 +2302,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>errors</h4>
-<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.296">errors</a></pre>
+<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.297">errors</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">State</div>
 </li>
@@ -2313,7 +2313,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>fixes</h4>
-<pre>int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.297">fixes</a></pre>
+<pre>int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.298">fixes</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2323,7 +2323,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>regionInfoMap</h4>
-<pre>private&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/TreeMap.html?is-external=true" title="class or interface in java.util">TreeMap</a>&lt;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>,<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&gt; <a href="../../../../../src-html/org/apach [...]
+<pre>private&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/TreeMap.html?is-external=true" title="class or interface in java.util">TreeMap</a>&lt;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>,<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&gt; <a href="../../../../../src-html/org/apach [...]
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">This map contains the state of all hbck items.  It maps from encoded region
  name to HbckRegionInfo structure.  The information contained in HbckRegionInfo is used
@@ -2336,7 +2336,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>emptyRegionInfoQualifiers</h4>
-<pre>private&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.306">emptyRegionInfoQualifiers</a></pre>
+<pre>private&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.307">emptyRegionInfoQualifiers</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2346,7 +2346,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>tablesInfo</h4>
-<pre>private&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>,<a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="class in org.apache.hadoop.hbase.util">HbckTableInfo</a>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/util/H [...]
+<pre>private&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>,<a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="class in org.apache.hadoop.hbase.util">HbckTableInfo</a>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/util/H [...]
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">This map from Tablename -> TableInfo contains the structures necessary to
  detect table consistency problems (holes, dupes, overlaps).  It is sorted
@@ -2364,7 +2364,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>orphanHdfsDirs</h4>
-<pre>private&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.323">orphanHdfsDirs</a></pre>
+<pre>private&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.324">orphanHdfsDirs</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">When initially looking at HDFS, we attempt to find any orphaned data.</div>
 </li>
@@ -2375,7 +2375,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>orphanTableDirs</h4>
-<pre>private&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>,<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a>&lt;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-e [...]
+<pre>private&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>,<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a>&lt;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-e [...]
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2385,7 +2385,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>tableStates</h4>
-<pre>private&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>,<a href="../../../../../org/apache/hadoop/hbase/client/TableState.html" title="class in org.apache.hadoop.hbase.client">TableState</a>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html# [...]
+<pre>private&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>,<a href="../../../../../org/apache/hadoop/hbase/client/TableState.html" title="class in org.apache.hadoop.hbase.client">TableState</a>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html# [...]
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2395,7 +2395,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>lockFileRetryCounterFactory</h4>
-<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/RetryCounterFactory.html" title="class in org.apache.hadoop.hbase.util">RetryCounterFactory</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.327">lockFileRetryCounterFactory</a></pre>
+<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/RetryCounterFactory.html" title="class in org.apache.hadoop.hbase.util">RetryCounterFactory</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.328">lockFileRetryCounterFactory</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2405,7 +2405,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>createZNodeRetryCounterFactory</h4>
-<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/RetryCounterFactory.html" title="class in org.apache.hadoop.hbase.util">RetryCounterFactory</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.328">createZNodeRetryCounterFactory</a></pre>
+<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/RetryCounterFactory.html" title="class in org.apache.hadoop.hbase.util">RetryCounterFactory</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.329">createZNodeRetryCounterFactory</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2415,7 +2415,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>skippedRegions</h4>
-<pre>private&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>,<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a>&lt;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-e [...]
+<pre>private&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>,<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a>&lt;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-e [...]
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2425,7 +2425,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>zkw</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/zookeeper/ZKWatcher.html" title="class in org.apache.hadoop.hbase.zookeeper">ZKWatcher</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.332">zkw</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/zookeeper/ZKWatcher.html" title="class in org.apache.hadoop.hbase.zookeeper">ZKWatcher</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.333">zkw</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2435,7 +2435,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>hbckEphemeralNodePath</h4>
-<pre>private&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.333">hbckEphemeralNodePath</a></pre>
+<pre>private&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.334">hbckEphemeralNodePath</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2445,7 +2445,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockListLast">
 <li class="blockList">
 <h4>hbckZodeCreated</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.334">hbckZodeCreated</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.335">hbckZodeCreated</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2463,7 +2463,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>HBaseFsck</h4>
-<pre>public&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.343">HBaseFsck</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)
+<pre>public&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.344">HBaseFsck</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)
           throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
                  <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/ClassNotFoundException.html?is-external=true" title="class or interface in java.lang">ClassNotFoundException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
@@ -2485,7 +2485,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockListLast">
 <li class="blockList">
 <h4>HBaseFsck</h4>
-<pre>public&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.364">HBaseFsck</a>(org.apache.hadoop.conf.Configuration&nbsp;conf,
+<pre>public&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.365">HBaseFsck</a>(org.apache.hadoop.conf.Configuration&nbsp;conf,
                  <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/ExecutorService.html?is-external=true" title="class or interface in java.util.concurrent">ExecutorService</a>&nbsp;exec)
           throws <a href="../../../../../org/apache/hadoop/hbase/MasterNotRunningException.html" title="class in org.apache.hadoop.hbase">MasterNotRunningException</a>,
                  <a href="../../../../../org/apache/hadoop/hbase/ZooKeeperConnectionException.html" title="class in org.apache.hadoop.hbase">ZooKeeperConnectionException</a>,
@@ -2518,7 +2518,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>createThreadPool</h4>
-<pre>private static&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/ExecutorService.html?is-external=true" title="class or interface in java.util.concurrent">ExecutorService</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.347">createThreadPool</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)</pre>
+<pre>private static&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/ExecutorService.html?is-external=true" title="class or interface in java.util.concurrent">ExecutorService</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.348">createThreadPool</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2528,7 +2528,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>createLockRetryCounterFactory</h4>
-<pre>public static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/RetryCounterFactory.html" title="class in org.apache.hadoop.hbase.util">RetryCounterFactory</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.377">createLockRetryCounterFactory</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)</pre>
+<pre>public static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/RetryCounterFactory.html" title="class in org.apache.hadoop.hbase.util">RetryCounterFactory</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.378">createLockRetryCounterFactory</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <dl>
 <dt><span class="returnLabel">Returns:</span></dt>
@@ -2542,7 +2542,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <ul class="blockList">
 <li class="blockList">
 <h4>createZnodeRetryCounterFactory</h4>
-<pre>private static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/RetryCounterFactory.html" title="class in org.apache.hadoop.hbase.util">RetryCounterFactory</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.389">createZnodeRetryCounterFactory</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)</pre>
+<pre>private static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/RetryCounterFactory.html" title="class in org.apache.hadoop.hbase.util">RetryCounterFactory</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.390">createZnodeRetryCounterFactory</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <dl>
 <dt><span class="returnLabel">Returns:</span></dt>
@@ -2557,7 +2557,7 @@ public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java
 <li class="blockList">
 <h4>getTmpDir</h4>
 <pre>@InterfaceAudience.Private
-public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.402">getTmpDir</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)
+public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.403">getTmpDir</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)
                                                                       throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <dl>
@@ -2574,7 +2574,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>checkAndMarkRunningHbck</h4>
-<pre>public static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/Pair.html" title="class in org.apache.hadoop.hbase.util">Pair</a>&lt;org.apache.hadoop.fs.Path,org.apache.hadoop.fs.FSDataOutputStream&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.483">checkAndMarkRunningHbck</a>(org.apache.hadoop.conf.Configuration&nbsp;conf,
+<pre>public static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/Pair.html" title="class in org.apache.hadoop.hbase.util">Pair</a>&lt;org.apache.hadoop.fs.Path,org.apache.hadoop.fs.FSDataOutputStream&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.484">checkAndMarkRunningHbck</a>(org.apache.hadoop.conf.Configuration&nbsp;conf,
                                                                                                               <a href="../../../../../org/apache/hadoop/hbase/util/RetryCounter.html" title="class in org.apache.hadoop.hbase.util">RetryCounter</a>&nbsp;retryCounter)
                                                                                                        throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
@@ -2593,7 +2593,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>unlockHbck</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.509">unlockHbck</a>()</pre>
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.510">unlockHbck</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2603,7 +2603,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>connect</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.540">connect</a>()
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.541">connect</a>()
              throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">To repair region consistency, one must call connect() in order to repair
@@ -2620,7 +2620,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>loadDeployedRegions</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.586">loadDeployedRegions</a>()
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.587">loadDeployedRegions</a>()
                           throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
                                  <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
@@ -2638,7 +2638,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>clearState</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.636">clearState</a>()</pre>
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.637">clearState</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Clear the current state of hbck.</div>
 </li>
@@ -2649,7 +2649,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>offlineHdfsIntegrityRepair</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.653">offlineHdfsIntegrityRepair</a>()
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.654">offlineHdfsIntegrityRepair</a>()
                                 throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
                                        <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
@@ -2669,7 +2669,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>onlineConsistencyRepair</h4>
-<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.689">onlineConsistencyRepair</a>()
+<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.690">onlineConsistencyRepair</a>()
                             throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
                                    org.apache.zookeeper.KeeperException,
                                    <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a></pre>
@@ -2694,7 +2694,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>setMasterInMaintenanceMode</h4>
-<pre>private&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.755">setMasterInMaintenanceMode</a>()
+<pre>private&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.756">setMasterInMaintenanceMode</a>()
                                     throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">This method maintains an ephemeral znode. If the creation fails we return false or throw
@@ -2713,7 +2713,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>cleanupHbckZnode</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.786">cleanupHbckZnode</a>()</pre>
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.787">cleanupHbckZnode</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2723,7 +2723,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>onlineHbck</h4>
-<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.804">onlineHbck</a>()
+<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.805">onlineHbck</a>()
                throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
                       org.apache.zookeeper.KeeperException,
                       <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a>,
@@ -2747,7 +2747,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>keyOnly</h4>
-<pre>public static&nbsp;byte[]&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.845">keyOnly</a>(byte[]&nbsp;b)</pre>
+<pre>public static&nbsp;byte[]&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.846">keyOnly</a>(byte[]&nbsp;b)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2757,7 +2757,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>close</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.855">close</a>()
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.856">close</a>()
            throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <dl>
@@ -2776,7 +2776,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>checkRegionBoundaries</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.888">checkRegionBoundaries</a>()</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.889">checkRegionBoundaries</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2786,7 +2786,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>adoptHdfsOrphans</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.973">adoptHdfsOrphans</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Collection.html?is-external=true" title="class or interface in java.util">Collection</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&gt;&nbsp;orphanHdfsDirs)
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.974">adoptHdfsOrphans</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Collection.html?is-external=true" title="class or interface in java.util">Collection</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&gt;&nbsp;orphanHdfsDirs)
                        throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Iterates through the list of all orphan/invalid regiondirs.</div>
@@ -2802,7 +2802,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>adoptHdfsOrphan</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.990">adoptHdfsOrphan</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;hi)
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.991">adoptHdfsOrphan</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;hi)
                       throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Orphaned regions are regions without a .regioninfo file in them.  We "adopt"
@@ -2824,7 +2824,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>restoreHdfsIntegrity</h4>
-<pre>private&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1082">restoreHdfsIntegrity</a>()
+<pre>private&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1083">restoreHdfsIntegrity</a>()
                           throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
                                  <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
@@ -2847,7 +2847,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>offlineReferenceFileRepair</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1130">offlineReferenceFileRepair</a>()
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1131">offlineReferenceFileRepair</a>()
                                  throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
                                         <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
@@ -2870,7 +2870,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>offlineHLinkFileRepair</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1184">offlineHLinkFileRepair</a>()
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1185">offlineHLinkFileRepair</a>()
                              throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
                                     <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
@@ -2890,7 +2890,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>sidelineFile</h4>
-<pre>private&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1231">sidelineFile</a>(org.apache.hadoop.fs.FileSystem&nbsp;fs,
+<pre>private&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1232">sidelineFile</a>(org.apache.hadoop.fs.FileSystem&nbsp;fs,
                              org.apache.hadoop.fs.Path&nbsp;hbaseRoot,
                              org.apache.hadoop.fs.Path&nbsp;path)
                       throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
@@ -2907,7 +2907,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>reportEmptyMetaCells</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1249">reportEmptyMetaCells</a>()</pre>
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1250">reportEmptyMetaCells</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">TODO -- need to add tests for this.</div>
 </li>
@@ -2918,7 +2918,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>reportTablesInFlux</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1262">reportTablesInFlux</a>()</pre>
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1263">reportTablesInFlux</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">TODO -- need to add tests for this.</div>
 </li>
@@ -2929,7 +2929,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>getErrors</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1279">getErrors</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1280">getErrors</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2939,7 +2939,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>loadHdfsRegionInfos</h4>
-<pre>private&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>,<a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="class in org.apache.hadoop.hbase.util">HbckTableInfo</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/u [...]
+<pre>private&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>,<a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="class in org.apache.hadoop.hbase.util">HbckTableInfo</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/u [...]
                                                         throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
                                                                <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
@@ -2957,7 +2957,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>getColumnFamilyList</h4>
-<pre>private&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a>&lt;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1372">getColumnFamilyList</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is [...]
+<pre>private&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a>&lt;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1373">getColumnFamilyList</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is [...]
                                         <a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;hbi)
                                  throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
@@ -2979,7 +2979,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>fabricateTableInfo</h4>
-<pre>private&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1391">fabricateTableInfo</a>(<a href="../../../../../org/apache/hadoop/hbase/util/FSTableDescriptors.html" title="class in org.apache.hadoop.hbase.util">FSTableDescriptors</a>&nbsp;fstd,
+<pre>private&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1392">fabricateTableInfo</a>(<a href="../../../../../org/apache/hadoop/hbase/util/FSTableDescriptors.html" title="class in org.apache.hadoop.hbase.util">FSTableDescriptors</a>&nbsp;fstd,
                                    <a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName,
                                    <a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a>&lt;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&gt;&nbsp;columns)
                             throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
@@ -3000,7 +3000,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>fixEmptyMetaCells</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1406">fixEmptyMetaCells</a>()
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1407">fixEmptyMetaCells</a>()
                        throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">To fix the empty REGIONINFO_QUALIFIER rows from hbase:meta <br></div>
@@ -3016,7 +3016,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>fixOrphanTables</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1426">fixOrphanTables</a>()
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1427">fixOrphanTables</a>()
                      throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">To fix orphan table by creating a .tableinfo file under tableDir <br>
@@ -3037,7 +3037,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>logParallelMerge</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1482">logParallelMerge</a>()</pre>
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1483">logParallelMerge</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Log an appropriate message about whether or not overlapping merges are computed in parallel.</div>
 </li>
@@ -3048,7 +3048,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>checkHdfsIntegrity</h4>
-<pre>private&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>,<a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="class in org.apache.hadoop.hbase.util">HbckTableInfo</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/u [...]
+<pre>private&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>,<a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="class in org.apache.hadoop.hbase.util">HbckTableInfo</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/u [...]
                                                               boolean&nbsp;fixOverlaps)
                                                        throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
@@ -3064,7 +3064,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>getSidelineDir</h4>
-<pre>org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1512">getSidelineDir</a>()
+<pre>org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1513">getSidelineDir</a>()
                                   throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <dl>
@@ -3079,7 +3079,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>sidelineRegionDir</h4>
-<pre>org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1525">sidelineRegionDir</a>(org.apache.hadoop.fs.FileSystem&nbsp;fs,
+<pre>org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1526">sidelineRegionDir</a>(org.apache.hadoop.fs.FileSystem&nbsp;fs,
                                             <a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;hi)
                                      throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
@@ -3096,7 +3096,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>sidelineRegionDir</h4>
-<pre>org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1537">sidelineRegionDir</a>(org.apache.hadoop.fs.FileSystem&nbsp;fs,
+<pre>org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1538">sidelineRegionDir</a>(org.apache.hadoop.fs.FileSystem&nbsp;fs,
                                             <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;parentDir,
                                             <a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;hi)
                                      throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
@@ -3119,7 +3119,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>loadTableStates</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1612">loadTableStates</a>()
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1613">loadTableStates</a>()
                       throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Load the list of disabled tables in ZK into local set.</div>
@@ -3136,7 +3136,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>isTableDisabled</h4>
-<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1626">isTableDisabled</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName)</pre>
+<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1627">isTableDisabled</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Check if the specified region's table is disabled.</div>
 <dl>
@@ -3151,7 +3151,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>loadHdfsRegionDirs</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1636">loadHdfsRegionDirs</a>()
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1637">loadHdfsRegionDirs</a>()
                         throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
                                <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
@@ -3170,7 +3170,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>recordMetaRegion</h4>
-<pre>private&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1694">recordMetaRegion</a>()
+<pre>private&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1695">recordMetaRegion</a>()
                           throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Record the location of the hbase:meta region as found in ZooKeeper.</div>
@@ -3186,7 +3186,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>createZooKeeperWatcher</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/zookeeper/ZKWatcher.html" title="class in org.apache.hadoop.hbase.zookeeper">ZKWatcher</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1730">createZooKeeperWatcher</a>()
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/zookeeper/ZKWatcher.html" title="class in org.apache.hadoop.hbase.zookeeper">ZKWatcher</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1731">createZooKeeperWatcher</a>()
                                   throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <dl>
@@ -3201,7 +3201,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>processRegionServers</h4>
-<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1751">processRegionServers</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Collection.html?is-external=true" title="class or interface in java.util">Collection</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&gt;&nbsp;regionServerList)
+<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1752">processRegionServers</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Collection.html?is-external=true" title="class or interface in java.util">Collection</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&gt;&nbsp;regionServerList)
                    throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
                           <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
@@ -3221,7 +3221,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>checkAndFixConsistency</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1779">checkAndFixConsistency</a>()
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1780">checkAndFixConsistency</a>()
                              throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
                                     org.apache.zookeeper.KeeperException,
                                     <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a></pre>
@@ -3241,7 +3241,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>checkRegionConsistencyConcurrently</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1824">checkRegionConsistencyConcurrently</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html" title="class in org.apache.hadoop.hbase.util">HBaseFsck.CheckRegionConsistencyWorkItem</a>&gt;&n [...]
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1825">checkRegionConsistencyConcurrently</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html" title="class in org.apache.hadoop.hbase.util">HBaseFsck.CheckRegionConsistencyWorkItem</a>&gt;&n [...]
                                          throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
                                                 org.apache.zookeeper.KeeperException,
                                                 <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a></pre>
@@ -3261,7 +3261,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>addSkippedRegion</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1878">addSkippedRegion</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;hbi)</pre>
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1879">addSkippedRegion</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;hbi)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3271,7 +3271,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>checkAndFixTableStates</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1892">checkAndFixTableStates</a>()
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1893">checkAndFixTableStates</a>()
                              throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Check and fix table states, assumes full info available:
@@ -3289,7 +3289,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>preCheckPermission</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1934">preCheckPermission</a>()
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1935">preCheckPermission</a>()
                          throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <dl>
@@ -3304,7 +3304,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>deleteMetaRegion</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1960">deleteMetaRegion</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;hi)
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1961">deleteMetaRegion</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;hi)
                        throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Deletes region from meta table</div>
@@ -3320,7 +3320,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>deleteMetaRegion</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1967">deleteMetaRegion</a>(byte[]&nbsp;metaKey)
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1968">deleteMetaRegion</a>(byte[]&nbsp;metaKey)
                        throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Deletes region from meta table</div>
@@ -3336,7 +3336,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>resetSplitParent</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1976">resetSplitParent</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;hi)
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1977">resetSplitParent</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;hi)
                        throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Reset the split parent region info in meta table</div>
@@ -3352,7 +3352,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>offline</h4>
-<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2001">offline</a>(byte[]&nbsp;regionName)
+<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2002">offline</a>(byte[]&nbsp;regionName)
       throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">This backwards-compatibility wrapper for permanently offlining a region
@@ -3373,7 +3373,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>closeRegion</h4>
-<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2042">closeRegion</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;hi)
+<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2043">closeRegion</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;hi)
           throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
                  <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
@@ -3400,7 +3400,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>undeployRegions</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2090">undeployRegions</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;hi)
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2091">undeployRegions</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;hi)
                       throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
                              <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
@@ -3417,7 +3417,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>undeployRegionsForHbi</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2111">undeployRegionsForHbi</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;hi)
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2112">undeployRegionsForHbi</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;hi)
                             throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
                                    <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
@@ -3434,7 +3434,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>tryAssignmentRepair</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2125">tryAssignmentRepair</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;hbi,
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2126">tryAssignmentRepair</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;hbi,
                                  <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;msg)
                           throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
                                  org.apache.zookeeper.KeeperException,
@@ -3454,7 +3454,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>checkRegionConsistency</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2161">checkRegionConsistency</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;key,
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2162">checkRegionConsistency</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;key,
                                     <a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;hbi)
                              throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
                                     org.apache.zookeeper.KeeperException,
@@ -3475,7 +3475,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>checkIntegrity</h4>
-<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>,<a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="class in org.apache.hadoop.hbase.util">HbckTableInfo</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck [...]
+<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>,<a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="class in org.apache.hadoop.hbase.util">HbckTableInfo</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck [...]
                                            throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Checks tables integrity. Goes over all regions and scans the tables.
@@ -3493,7 +3493,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>loadTableInfosForTablesWithNoRegion</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2473">loadTableInfosForTablesWithNoRegion</a>()
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2474">loadTableInfosForTablesWithNoRegion</a>()
                                           throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Loads table info's for tables that may not have been included, since there are no
@@ -3510,7 +3510,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>mergeRegionDirs</h4>
-<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2493">mergeRegionDirs</a>(org.apache.hadoop.fs.Path&nbsp;targetRegionDir,
+<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2494">mergeRegionDirs</a>(org.apache.hadoop.fs.Path&nbsp;targetRegionDir,
                            <a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;contained)
                     throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
@@ -3529,7 +3529,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>getTables</h4>
-<pre><a href="../../../../../org/apache/hadoop/hbase/client/TableDescriptor.html" title="interface in org.apache.hadoop.hbase.client">TableDescriptor</a>[]&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2591">getTables</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/atomic/AtomicInteger.html?is-external=true" title="class or interface in java.util.concurrent.atomic">AtomicInteger</a>&nbsp;numSkipped)</pre>
+<pre><a href="../../../../../org/apache/hadoop/hbase/client/TableDescriptor.html" title="interface in org.apache.hadoop.hbase.client">TableDescriptor</a>[]&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2592">getTables</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/atomic/AtomicInteger.html?is-external=true" title="class or interface in java.util.concurrent.atomic">AtomicInteger</a>&nbsp;numSkipped)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Return a list of user-space table names whose metadata have not been
  modified in the last few milliseconds specified by timelag
@@ -3550,7 +3550,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>getTableDescriptors</h4>
-<pre><a href="../../../../../org/apache/hadoop/hbase/client/TableDescriptor.html" title="interface in org.apache.hadoop.hbase.client">TableDescriptor</a>[]&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2612">getTableDescriptors</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class i [...]
+<pre><a href="../../../../../org/apache/hadoop/hbase/client/TableDescriptor.html" title="interface in org.apache.hadoop.hbase.client">TableDescriptor</a>[]&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2613">getTableDescriptors</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class i [...]
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3560,7 +3560,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>getOrCreateInfo</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2629">getOrCreateInfo</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;name)</pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2630">getOrCreateInfo</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;name)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Gets the entry in regionInfo corresponding to the the given encoded
  region name. If the region has not been seen yet, a new entry is added
@@ -3573,7 +3573,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>checkAndFixReplication</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2638">checkAndFixReplication</a>()
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2639">checkAndFixReplication</a>()
                              throws <a href="../../../../../org/apache/hadoop/hbase/replication/ReplicationException.html" title="class in org.apache.hadoop.hbase.replication">ReplicationException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <dl>
@@ -3588,7 +3588,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>checkMetaRegion</h4>
-<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2657">checkMetaRegion</a>()
+<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2658">checkMetaRegion</a>()
                  throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
                         org.apache.zookeeper.KeeperException,
                         <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a></pre>
@@ -3611,7 +3611,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>unassignMetaReplica</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2712">unassignMetaReplica</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;hi)
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2713">unassignMetaReplica</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;hi)
                           throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
                                  <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a>,
                                  org.apache.zookeeper.KeeperException</pre>
@@ -3630,7 +3630,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>assignMetaReplica</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2719">assignMetaReplica</a>(int&nbsp;replicaId)
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2720">assignMetaReplica</a>(int&nbsp;replicaId)
                         throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
                                org.apache.zookeeper.KeeperException,
                                <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a></pre>
@@ -3649,7 +3649,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>loadMetaEntries</h4>
-<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2738">loadMetaEntries</a>()
+<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2739">loadMetaEntries</a>()
                  throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Scan hbase:meta, adding all regions found to the regionInfo map.</div>
@@ -3665,7 +3665,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>printTableSummary</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2835">printTableSummary</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>,<a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="clas [...]
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2836">printTableSummary</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>,<a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="clas [...]
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Prints summary of all tables found on the system.</div>
 </li>
@@ -3676,7 +3676,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>getErrorReporter</h4>
-<pre>static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2870">getErrorReporter</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)
+<pre>static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2871">getErrorReporter</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)
                                    throws <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/ClassNotFoundException.html?is-external=true" title="class or interface in java.lang">ClassNotFoundException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <dl>
@@ -3691,7 +3691,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>setDisplayFullReport</h4>
-<pre>public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3234">setDisplayFullReport</a>()</pre>
+<pre>public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3235">setDisplayFullReport</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Display the full report from fsck. This displays all live and dead region
  servers, and all known regions.</div>
@@ -3703,7 +3703,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>shouldDisplayFullReport</h4>
-<pre>public static&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3238">shouldDisplayFullReport</a>()</pre>
+<pre>public static&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3239">shouldDisplayFullReport</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3713,7 +3713,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>setForceExclusive</h4>
-<pre>public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3245">setForceExclusive</a>()</pre>
+<pre>public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3246">setForceExclusive</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Set exclusive mode.</div>
 </li>
@@ -3724,7 +3724,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>isExclusive</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3252">isExclusive</a>()</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3253">isExclusive</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Only one instance of hbck can modify HBase at a time.</div>
 </li>
@@ -3735,7 +3735,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>setSummary</h4>
-<pre>static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3260">setSummary</a>()</pre>
+<pre>static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3261">setSummary</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Set summary mode.
  Print only summary of the tables and status (OK or INCONSISTENT)</div>
@@ -3747,7 +3747,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>setCheckMetaOnly</h4>
-<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3268">setCheckMetaOnly</a>()</pre>
+<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3269">setCheckMetaOnly</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Set hbase:meta check mode.
  Print only info about hbase:meta table deployment/state</div>
@@ -3759,7 +3759,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>setRegionBoundariesCheck</h4>
-<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3275">setRegionBoundariesCheck</a>()</pre>
+<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3276">setRegionBoundariesCheck</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Set region boundaries check mode.</div>
 </li>
@@ -3770,7 +3770,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>setFixReplication</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3282">setFixReplication</a>(boolean&nbsp;shouldFix)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3283">setFixReplication</a>(boolean&nbsp;shouldFix)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Set replication fix mode.</div>
 </li>
@@ -3781,7 +3781,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>setCleanReplicationBarrier</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3287">setCleanReplicationBarrier</a>(boolean&nbsp;shouldClean)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3288">setCleanReplicationBarrier</a>(boolean&nbsp;shouldClean)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3791,7 +3791,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>setShouldRerun</h4>
-<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3297">setShouldRerun</a>()</pre>
+<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3298">setShouldRerun</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Check if we should rerun fsck again. This checks if we've tried to
  fix something and we should rerun fsck tool again.
@@ -3805,7 +3805,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>shouldRerun</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3301">shouldRerun</a>()</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3302">shouldRerun</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3815,7 +3815,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>setFixAssignments</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3309">setFixAssignments</a>(boolean&nbsp;shouldFix)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3310">setFixAssignments</a>(boolean&nbsp;shouldFix)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Fix inconsistencies found by fsck. This should try to fix errors (if any)
  found by fsck utility.</div>
@@ -3827,7 +3827,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>shouldFixAssignments</h4>
-<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3314">shouldFixAssignments</a>()</pre>
+<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3315">shouldFixAssignments</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3837,7 +3837,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>setFixMeta</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3318">setFixMeta</a>(boolean&nbsp;shouldFix)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3319">setFixMeta</a>(boolean&nbsp;shouldFix)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3847,7 +3847,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>shouldFixMeta</h4>
-<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3323">shouldFixMeta</a>()</pre>
+<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3324">shouldFixMeta</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3857,7 +3857,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>setFixEmptyMetaCells</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3327">setFixEmptyMetaCells</a>(boolean&nbsp;shouldFix)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3328">setFixEmptyMetaCells</a>(boolean&nbsp;shouldFix)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3867,7 +3867,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>shouldFixEmptyMetaCells</h4>
-<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3332">shouldFixEmptyMetaCells</a>()</pre>
+<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3333">shouldFixEmptyMetaCells</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3877,7 +3877,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>setCheckHdfs</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3336">setCheckHdfs</a>(boolean&nbsp;checking)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3337">setCheckHdfs</a>(boolean&nbsp;checking)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3887,7 +3887,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>shouldCheckHdfs</h4>
-<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3340">shouldCheckHdfs</a>()</pre>
+<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3341">shouldCheckHdfs</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3897,7 +3897,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>setFixHdfsHoles</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3344">setFixHdfsHoles</a>(boolean&nbsp;shouldFix)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3345">setFixHdfsHoles</a>(boolean&nbsp;shouldFix)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3907,7 +3907,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>shouldFixHdfsHoles</h4>
-<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3349">shouldFixHdfsHoles</a>()</pre>
+<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3350">shouldFixHdfsHoles</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3917,7 +3917,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>setFixTableOrphans</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3353">setFixTableOrphans</a>(boolean&nbsp;shouldFix)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3354">setFixTableOrphans</a>(boolean&nbsp;shouldFix)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3927,7 +3927,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>shouldFixTableOrphans</h4>
-<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3358">shouldFixTableOrphans</a>()</pre>
+<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3359">shouldFixTableOrphans</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3937,7 +3937,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>setFixHdfsOverlaps</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3362">setFixHdfsOverlaps</a>(boolean&nbsp;shouldFix)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3363">setFixHdfsOverlaps</a>(boolean&nbsp;shouldFix)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3947,7 +3947,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>shouldFixHdfsOverlaps</h4>
-<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3367">shouldFixHdfsOverlaps</a>()</pre>
+<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3368">shouldFixHdfsOverlaps</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3957,7 +3957,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>setFixHdfsOrphans</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3371">setFixHdfsOrphans</a>(boolean&nbsp;shouldFix)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3372">setFixHdfsOrphans</a>(boolean&nbsp;shouldFix)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3967,7 +3967,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>shouldFixHdfsOrphans</h4>
-<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3376">shouldFixHdfsOrphans</a>()</pre>
+<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3377">shouldFixHdfsOrphans</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3977,7 +3977,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>setFixVersionFile</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3380">setFixVersionFile</a>(boolean&nbsp;shouldFix)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3381">setFixVersionFile</a>(boolean&nbsp;shouldFix)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3987,7 +3987,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>shouldFixVersionFile</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3385">shouldFixVersionFile</a>()</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3386">shouldFixVersionFile</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3997,7 +3997,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>setSidelineBigOverlaps</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3389">setSidelineBigOverlaps</a>(boolean&nbsp;sbo)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3390">setSidelineBigOverlaps</a>(boolean&nbsp;sbo)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4007,7 +4007,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>shouldSidelineBigOverlaps</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3393">shouldSidelineBigOverlaps</a>()</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3394">shouldSidelineBigOverlaps</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4017,7 +4017,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>setFixSplitParents</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3397">setFixSplitParents</a>(boolean&nbsp;shouldFix)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3398">setFixSplitParents</a>(boolean&nbsp;shouldFix)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4027,7 +4027,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>setRemoveParents</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3402">setRemoveParents</a>(boolean&nbsp;shouldFix)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3403">setRemoveParents</a>(boolean&nbsp;shouldFix)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4037,7 +4037,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>shouldFixSplitParents</h4>
-<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3407">shouldFixSplitParents</a>()</pre>
+<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3408">shouldFixSplitParents</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4047,7 +4047,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>shouldRemoveParents</h4>
-<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3411">shouldRemoveParents</a>()</pre>
+<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3412">shouldRemoveParents</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4057,7 +4057,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>setFixReferenceFiles</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3415">setFixReferenceFiles</a>(boolean&nbsp;shouldFix)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3416">setFixReferenceFiles</a>(boolean&nbsp;shouldFix)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4067,7 +4067,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>shouldFixReferenceFiles</h4>
-<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3420">shouldFixReferenceFiles</a>()</pre>
+<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3421">shouldFixReferenceFiles</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4077,7 +4077,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>setFixHFileLinks</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3424">setFixHFileLinks</a>(boolean&nbsp;shouldFix)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3425">setFixHFileLinks</a>(boolean&nbsp;shouldFix)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4087,7 +4087,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>shouldFixHFileLinks</h4>
-<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3429">shouldFixHFileLinks</a>()</pre>
+<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3430">shouldFixHFileLinks</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4097,7 +4097,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>shouldIgnorePreCheckPermission</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3433">shouldIgnorePreCheckPermission</a>()</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3434">shouldIgnorePreCheckPermission</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4107,7 +4107,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>setIgnorePreCheckPermission</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3437">setIgnorePreCheckPermission</a>(boolean&nbsp;ignorePreCheckPermission)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3438">setIgnorePreCheckPermission</a>(boolean&nbsp;ignorePreCheckPermission)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4117,7 +4117,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>setMaxMerge</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3444">setMaxMerge</a>(int&nbsp;mm)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3445">setMaxMerge</a>(int&nbsp;mm)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <dl>
 <dt><span class="paramLabel">Parameters:</span></dt>
@@ -4131,7 +4131,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>getMaxMerge</h4>
-<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3448">getMaxMerge</a>()</pre>
+<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3449">getMaxMerge</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4141,7 +4141,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>setMaxOverlapsToSideline</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3452">setMaxOverlapsToSideline</a>(int&nbsp;mo)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3453">setMaxOverlapsToSideline</a>(int&nbsp;mo)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4151,7 +4151,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>getMaxOverlapsToSideline</h4>
-<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3456">getMaxOverlapsToSideline</a>()</pre>
+<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3457">getMaxOverlapsToSideline</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4161,7 +4161,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>isTableIncluded</h4>
-<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3464">isTableIncluded</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;table)</pre>
+<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3465">isTableIncluded</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;table)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Only check/fix tables specified by the list,
  Empty list means all tables are included.</div>
@@ -4173,7 +4173,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>includeTable</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3468">includeTable</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;table)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3469">includeTable</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;table)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4183,7 +4183,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>getIncludedTables</h4>
-<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3472">getIncludedTables</a>()</pre>
+<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3473">getIncludedTables</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4193,7 +4193,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>setTimeLag</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3481">setTimeLag</a>(long&nbsp;seconds)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3482">setTimeLag</a>(long&nbsp;seconds)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">We are interested in only those tables that have not changed their state in
  hbase:meta during the last few seconds specified by hbase.admin.fsck.timelag</div>
@@ -4209,7 +4209,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>setSidelineDir</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3489">setSidelineDir</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;sidelineDir)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3490">setSidelineDir</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;sidelineDir)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <dl>
 <dt><span class="paramLabel">Parameters:</span></dt>
@@ -4223,7 +4223,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>createHFileCorruptionChecker</h4>
-<pre>protected&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/hbck/HFileCorruptionChecker.html" title="class in org.apache.hadoop.hbase.util.hbck">HFileCorruptionChecker</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3493">createHFileCorruptionChecker</a>(boolean&nbsp;sidelineCorruptHFiles)
+<pre>protected&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/hbck/HFileCorruptionChecker.html" title="class in org.apache.hadoop.hbase.util.hbck">HFileCorruptionChecker</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3494">createHFileCorruptionChecker</a>(boolean&nbsp;sidelineCorruptHFiles)
                                                        throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <dl>
@@ -4238,7 +4238,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>getHFilecorruptionChecker</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/hbck/HFileCorruptionChecker.html" title="class in org.apache.hadoop.hbase.util.hbck">HFileCorruptionChecker</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3497">getHFilecorruptionChecker</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/hbck/HFileCorruptionChecker.html" title="class in org.apache.hadoop.hbase.util.hbck">HFileCorruptionChecker</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3498">getHFilecorruptionChecker</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4248,7 +4248,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>setHFileCorruptionChecker</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3501">setHFileCorruptionChecker</a>(<a href="../../../../../org/apache/hadoop/hbase/util/hbck/HFileCorruptionChecker.html" title="class in org.apache.hadoop.hbase.util.hbck">HFileCorruptionChecker</a>&nbsp;hfcc)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3502">setHFileCorruptionChecker</a>(<a href="../../../../../org/apache/hadoop/hbase/util/hbck/HFileCorruptionChecker.html" title="class in org.apache.hadoop.hbase.util.hbck">HFileCorruptionChecker</a>&nbsp;hfcc)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4258,7 +4258,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>setRetCode</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3505">setRetCode</a>(int&nbsp;code)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3506">setRetCode</a>(int&nbsp;code)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4268,7 +4268,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>getRetCode</h4>
-<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3509">getRetCode</a>()</pre>
+<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3510">getRetCode</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4278,7 +4278,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>printUsageAndExit</h4>
-<pre>protected&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.html" title="class in org.apache.hadoop.hbase.util">HBaseFsck</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3513">printUsageAndExit</a>()</pre>
+<pre>protected&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.html" title="class in org.apache.hadoop.hbase.util">HBaseFsck</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3514">printUsageAndExit</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4288,7 +4288,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>main</h4>
-<pre>public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3600">main</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>[]&nbsp;args)
+<pre>public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3601">main</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>[]&nbsp;args)
                  throws <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Exception.html?is-external=true" title="class or interface in java.lang">Exception</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Main program</div>
@@ -4306,7 +4306,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>exec</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.html" title="class in org.apache.hadoop.hbase.util">HBaseFsck</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3624">exec</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/ExecutorService.html?is-external=true" title="class or interface in java.util.concurrent">ExecutorService</a>&nbsp;exec,
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.html" title="class in org.apache.hadoop.hbase.util">HBaseFsck</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3625">exec</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/ExecutorService.html?is-external=true" title="class or interface in java.util.concurrent">ExecutorService</a>&nbsp;exec,
                       <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>[]&nbsp;args)
                throws org.apache.zookeeper.KeeperException,
                       <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
@@ -4328,7 +4328,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>isOptionsSupported</h4>
-<pre>private&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3853">isOptionsSupported</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>[]&nbsp;args)</pre>
+<pre>private&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3854">isOptionsSupported</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>[]&nbsp;args)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4338,7 +4338,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>setCleanReplicationBarrierTable</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3870">setCleanReplicationBarrierTable</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;cleanReplicationBarrierTable)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3871">setCleanReplicationBarrierTable</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;cleanReplicationBarrierTable)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4348,7 +4348,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>cleanReplicationBarrier</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3874">cleanReplicationBarrier</a>()
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3875">cleanReplicationBarrier</a>()
                              throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <dl>
@@ -4363,7 +4363,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>debugLsr</h4>
-<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3952">debugLsr</a>(org.apache.hadoop.fs.Path&nbsp;p)
+<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3953">debugLsr</a>(org.apache.hadoop.fs.Path&nbsp;p)
        throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">ls -r for debugging purposes</div>
@@ -4379,7 +4379,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockList">
 <li class="blockList">
 <h4>debugLsr</h4>
-<pre>public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3959">debugLsr</a>(org.apache.hadoop.conf.Configuration&nbsp;conf,
+<pre>public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3960">debugLsr</a>(org.apache.hadoop.conf.Configuration&nbsp;conf,
                             org.apache.hadoop.fs.Path&nbsp;p)
                      throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
@@ -4396,7 +4396,7 @@ public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-ht
 <ul class="blockListLast">
 <li class="blockList">
 <h4>debugLsr</h4>
-<pre>public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3967">debugLsr</a>(org.apache.hadoop.conf.Configuration&nbsp;conf,
+<pre>public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3968">debugLsr</a>(org.apache.hadoop.conf.Configuration&nbsp;conf,
                             org.apache.hadoop.fs.Path&nbsp;p,
                             <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a>&nbsp;errors)
                      throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
diff --git a/devapidocs/org/apache/hadoop/hbase/util/package-tree.html b/devapidocs/org/apache/hadoop/hbase/util/package-tree.html
index ce1456b..5538cd5 100644
--- a/devapidocs/org/apache/hadoop/hbase/util/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/util/package-tree.html
@@ -534,15 +534,15 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
 <ul>
+<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/Order.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">Order</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/PoolMap.PoolType.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">PoolMap.PoolType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.ERROR_CODE.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">HbckErrorReporter.ERROR_CODE</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/Bytes.LexicographicalComparerHolder.UnsafeComparer.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">Bytes.LexicographicalComparerHolder.UnsafeComparer</span></a> (implements org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/Bytes.Comparer.html" title="interface in org.apache.hadoop.hbase.util">Bytes.Comparer</a>&lt;T&gt;)</li>
+<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/IdReadWriteLockWithObjectPool.ReferenceType.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">IdReadWriteLockWithObjectPool.ReferenceType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/PrettyPrinter.Unit.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">PrettyPrinter.Unit</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/Bytes.LexicographicalComparerHolder.PureJavaComparer.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">Bytes.LexicographicalComparerHolder.PureJavaComparer</span></a> (implements org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/Bytes.Comparer.html" title="interface in org.apache.hadoop.hbase.util">Bytes.Comparer</a>&lt;T&gt;)</li>
 <li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/ChecksumType.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">ChecksumType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.ERROR_CODE.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">HbckErrorReporter.ERROR_CODE</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/DNS.ServerType.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">DNS.ServerType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/PoolMap.PoolType.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">PoolMap.PoolType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/IdReadWriteLockWithObjectPool.ReferenceType.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">IdReadWriteLockWithObjectPool.ReferenceType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/Order.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">Order</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/Bytes.LexicographicalComparerHolder.UnsafeComparer.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">Bytes.LexicographicalComparerHolder.UnsafeComparer</span></a> (implements org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/Bytes.Comparer.html" title="interface in org.apache.hadoop.hbase.util">Bytes.Comparer</a>&lt;T&gt;)</li>
+<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/Bytes.LexicographicalComparerHolder.PureJavaComparer.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">Bytes.LexicographicalComparerHolder.PureJavaComparer</span></a> (implements org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/Bytes.Comparer.html" title="interface in org.apache.hadoop.hbase.util">Bytes.Comparer</a>&lt;T&gt;)</li>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/wal/package-tree.html b/devapidocs/org/apache/hadoop/hbase/wal/package-tree.html
index 188279e..3a77775 100644
--- a/devapidocs/org/apache/hadoop/hbase/wal/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/wal/package-tree.html
@@ -198,8 +198,8 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
 <ul>
-<li type="circle">org.apache.hadoop.hbase.wal.<a href="../../../../../org/apache/hadoop/hbase/wal/RegionGroupingProvider.Strategies.html" title="enum in org.apache.hadoop.hbase.wal"><span class="typeNameLink">RegionGroupingProvider.Strategies</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.wal.<a href="../../../../../org/apache/hadoop/hbase/wal/WALFactory.Providers.html" title="enum in org.apache.hadoop.hbase.wal"><span class="typeNameLink">WALFactory.Providers</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.wal.<a href="../../../../../org/apache/hadoop/hbase/wal/RegionGroupingProvider.Strategies.html" title="enum in org.apache.hadoop.hbase.wal"><span class="typeNameLink">RegionGroupingProvider.Strategies</span></a></li>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html b/devapidocs/src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html
index 84ca66a..864ae8a 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html
@@ -220,223 +220,224 @@
 <span class="sourceLineNo">212</span>    if(LOG.isDebugEnabled()){<a name="line.212"></a>
 <span class="sourceLineNo">213</span>      logCallStack(Thread.currentThread().getStackTrace());<a name="line.213"></a>
 <span class="sourceLineNo">214</span>    }<a name="line.214"></a>
-<span class="sourceLineNo">215</span>    IOUtils.closeQuietly(clusterStatusListener);<a name="line.215"></a>
-<span class="sourceLineNo">216</span>    IOUtils.closeQuietly(rpcClient);<a name="line.216"></a>
-<span class="sourceLineNo">217</span>    IOUtils.closeQuietly(registry);<a name="line.217"></a>
-<span class="sourceLineNo">218</span>    if (choreService != null) {<a name="line.218"></a>
-<span class="sourceLineNo">219</span>      choreService.shutdown();<a name="line.219"></a>
-<span class="sourceLineNo">220</span>    }<a name="line.220"></a>
-<span class="sourceLineNo">221</span>    metrics.ifPresent(MetricsConnection::shutdown);<a name="line.221"></a>
-<span class="sourceLineNo">222</span>    ConnectionOverAsyncConnection c = this.conn;<a name="line.222"></a>
-<span class="sourceLineNo">223</span>    if (c != null) {<a name="line.223"></a>
-<span class="sourceLineNo">224</span>      c.closePool();<a name="line.224"></a>
-<span class="sourceLineNo">225</span>    }<a name="line.225"></a>
-<span class="sourceLineNo">226</span>  }<a name="line.226"></a>
-<span class="sourceLineNo">227</span><a name="line.227"></a>
-<span class="sourceLineNo">228</span>  private void logCallStack(StackTraceElement[] stackTraceElements) {<a name="line.228"></a>
-<span class="sourceLineNo">229</span>    StringBuilder stackBuilder = new StringBuilder("Call stack:");<a name="line.229"></a>
-<span class="sourceLineNo">230</span>    for (StackTraceElement element : stackTraceElements) {<a name="line.230"></a>
-<span class="sourceLineNo">231</span>      stackBuilder.append("\n    at ");<a name="line.231"></a>
-<span class="sourceLineNo">232</span>      stackBuilder.append(element);<a name="line.232"></a>
-<span class="sourceLineNo">233</span>    }<a name="line.233"></a>
-<span class="sourceLineNo">234</span>    stackBuilder.append("\n");<a name="line.234"></a>
-<span class="sourceLineNo">235</span>    LOG.debug(stackBuilder.toString());<a name="line.235"></a>
-<span class="sourceLineNo">236</span>  }<a name="line.236"></a>
-<span class="sourceLineNo">237</span><a name="line.237"></a>
-<span class="sourceLineNo">238</span>  @Override<a name="line.238"></a>
-<span class="sourceLineNo">239</span>  public AsyncTableRegionLocator getRegionLocator(TableName tableName) {<a name="line.239"></a>
-<span class="sourceLineNo">240</span>    return new AsyncTableRegionLocatorImpl(tableName, this);<a name="line.240"></a>
-<span class="sourceLineNo">241</span>  }<a name="line.241"></a>
-<span class="sourceLineNo">242</span><a name="line.242"></a>
-<span class="sourceLineNo">243</span>  @Override<a name="line.243"></a>
-<span class="sourceLineNo">244</span>  public void clearRegionLocationCache() {<a name="line.244"></a>
-<span class="sourceLineNo">245</span>    locator.clearCache();<a name="line.245"></a>
-<span class="sourceLineNo">246</span>  }<a name="line.246"></a>
-<span class="sourceLineNo">247</span><a name="line.247"></a>
-<span class="sourceLineNo">248</span>  // we will override this method for testing retry caller, so do not remove this method.<a name="line.248"></a>
-<span class="sourceLineNo">249</span>  AsyncRegionLocator getLocator() {<a name="line.249"></a>
-<span class="sourceLineNo">250</span>    return locator;<a name="line.250"></a>
-<span class="sourceLineNo">251</span>  }<a name="line.251"></a>
-<span class="sourceLineNo">252</span><a name="line.252"></a>
-<span class="sourceLineNo">253</span>  // ditto<a name="line.253"></a>
-<span class="sourceLineNo">254</span>  NonceGenerator getNonceGenerator() {<a name="line.254"></a>
-<span class="sourceLineNo">255</span>    return nonceGenerator;<a name="line.255"></a>
-<span class="sourceLineNo">256</span>  }<a name="line.256"></a>
-<span class="sourceLineNo">257</span><a name="line.257"></a>
-<span class="sourceLineNo">258</span>  private ClientService.Interface createRegionServerStub(ServerName serverName) throws IOException {<a name="line.258"></a>
-<span class="sourceLineNo">259</span>    return ClientService.newStub(rpcClient.createRpcChannel(serverName, user, rpcTimeout));<a name="line.259"></a>
-<span class="sourceLineNo">260</span>  }<a name="line.260"></a>
-<span class="sourceLineNo">261</span><a name="line.261"></a>
-<span class="sourceLineNo">262</span>  ClientService.Interface getRegionServerStub(ServerName serverName) throws IOException {<a name="line.262"></a>
-<span class="sourceLineNo">263</span>    return ConcurrentMapUtils.computeIfAbsentEx(rsStubs,<a name="line.263"></a>
-<span class="sourceLineNo">264</span>      getStubKey(ClientService.getDescriptor().getName(), serverName),<a name="line.264"></a>
-<span class="sourceLineNo">265</span>      () -&gt; createRegionServerStub(serverName));<a name="line.265"></a>
-<span class="sourceLineNo">266</span>  }<a name="line.266"></a>
-<span class="sourceLineNo">267</span><a name="line.267"></a>
-<span class="sourceLineNo">268</span>  private MasterService.Interface createMasterStub(ServerName serverName) throws IOException {<a name="line.268"></a>
-<span class="sourceLineNo">269</span>    return MasterService.newStub(rpcClient.createRpcChannel(serverName, user, rpcTimeout));<a name="line.269"></a>
-<span class="sourceLineNo">270</span>  }<a name="line.270"></a>
-<span class="sourceLineNo">271</span><a name="line.271"></a>
-<span class="sourceLineNo">272</span>  private AdminService.Interface createAdminServerStub(ServerName serverName) throws IOException {<a name="line.272"></a>
-<span class="sourceLineNo">273</span>    return AdminService.newStub(rpcClient.createRpcChannel(serverName, user, rpcTimeout));<a name="line.273"></a>
-<span class="sourceLineNo">274</span>  }<a name="line.274"></a>
-<span class="sourceLineNo">275</span><a name="line.275"></a>
-<span class="sourceLineNo">276</span>  AdminService.Interface getAdminStub(ServerName serverName) throws IOException {<a name="line.276"></a>
-<span class="sourceLineNo">277</span>    return ConcurrentMapUtils.computeIfAbsentEx(adminSubs,<a name="line.277"></a>
-<span class="sourceLineNo">278</span>      getStubKey(AdminService.getDescriptor().getName(), serverName),<a name="line.278"></a>
-<span class="sourceLineNo">279</span>      () -&gt; createAdminServerStub(serverName));<a name="line.279"></a>
-<span class="sourceLineNo">280</span>  }<a name="line.280"></a>
-<span class="sourceLineNo">281</span><a name="line.281"></a>
-<span class="sourceLineNo">282</span>  CompletableFuture&lt;MasterService.Interface&gt; getMasterStub() {<a name="line.282"></a>
-<span class="sourceLineNo">283</span>    return ConnectionUtils.getOrFetch(masterStub, masterStubMakeFuture, false, () -&gt; {<a name="line.283"></a>
-<span class="sourceLineNo">284</span>      CompletableFuture&lt;MasterService.Interface&gt; future = new CompletableFuture&lt;&gt;();<a name="line.284"></a>
-<span class="sourceLineNo">285</span>      addListener(registry.getActiveMaster(), (addr, error) -&gt; {<a name="line.285"></a>
-<span class="sourceLineNo">286</span>        if (error != null) {<a name="line.286"></a>
-<span class="sourceLineNo">287</span>          future.completeExceptionally(error);<a name="line.287"></a>
-<span class="sourceLineNo">288</span>        } else if (addr == null) {<a name="line.288"></a>
-<span class="sourceLineNo">289</span>          future.completeExceptionally(new MasterNotRunningException(<a name="line.289"></a>
-<span class="sourceLineNo">290</span>            "ZooKeeper available but no active master location found"));<a name="line.290"></a>
-<span class="sourceLineNo">291</span>        } else {<a name="line.291"></a>
-<span class="sourceLineNo">292</span>          LOG.debug("The fetched master address is {}", addr);<a name="line.292"></a>
-<span class="sourceLineNo">293</span>          try {<a name="line.293"></a>
-<span class="sourceLineNo">294</span>            future.complete(createMasterStub(addr));<a name="line.294"></a>
-<span class="sourceLineNo">295</span>          } catch (IOException e) {<a name="line.295"></a>
-<span class="sourceLineNo">296</span>            future.completeExceptionally(e);<a name="line.296"></a>
-<span class="sourceLineNo">297</span>          }<a name="line.297"></a>
-<span class="sourceLineNo">298</span>        }<a name="line.298"></a>
-<span class="sourceLineNo">299</span><a name="line.299"></a>
-<span class="sourceLineNo">300</span>      });<a name="line.300"></a>
-<span class="sourceLineNo">301</span>      return future;<a name="line.301"></a>
-<span class="sourceLineNo">302</span>    }, stub -&gt; true, "master stub");<a name="line.302"></a>
-<span class="sourceLineNo">303</span>  }<a name="line.303"></a>
-<span class="sourceLineNo">304</span><a name="line.304"></a>
-<span class="sourceLineNo">305</span>  String getClusterId() {<a name="line.305"></a>
-<span class="sourceLineNo">306</span>    try {<a name="line.306"></a>
-<span class="sourceLineNo">307</span>      return registry.getClusterId().get();<a name="line.307"></a>
-<span class="sourceLineNo">308</span>    } catch (InterruptedException | ExecutionException e) {<a name="line.308"></a>
-<span class="sourceLineNo">309</span>      LOG.error("Error fetching cluster ID: ", e);<a name="line.309"></a>
-<span class="sourceLineNo">310</span>    }<a name="line.310"></a>
-<span class="sourceLineNo">311</span>    return null;<a name="line.311"></a>
-<span class="sourceLineNo">312</span>  }<a name="line.312"></a>
-<span class="sourceLineNo">313</span><a name="line.313"></a>
-<span class="sourceLineNo">314</span>  void clearMasterStubCache(MasterService.Interface stub) {<a name="line.314"></a>
-<span class="sourceLineNo">315</span>    masterStub.compareAndSet(stub, null);<a name="line.315"></a>
-<span class="sourceLineNo">316</span>  }<a name="line.316"></a>
-<span class="sourceLineNo">317</span><a name="line.317"></a>
-<span class="sourceLineNo">318</span>  Optional&lt;ServerStatisticTracker&gt; getStatisticsTracker() {<a name="line.318"></a>
-<span class="sourceLineNo">319</span>    return stats;<a name="line.319"></a>
-<span class="sourceLineNo">320</span>  }<a name="line.320"></a>
-<span class="sourceLineNo">321</span><a name="line.321"></a>
-<span class="sourceLineNo">322</span>  ClientBackoffPolicy getBackoffPolicy() {<a name="line.322"></a>
-<span class="sourceLineNo">323</span>    return backoffPolicy;<a name="line.323"></a>
-<span class="sourceLineNo">324</span>  }<a name="line.324"></a>
-<span class="sourceLineNo">325</span><a name="line.325"></a>
-<span class="sourceLineNo">326</span>  @Override<a name="line.326"></a>
-<span class="sourceLineNo">327</span>  public AsyncTableBuilder&lt;AdvancedScanResultConsumer&gt; getTableBuilder(TableName tableName) {<a name="line.327"></a>
-<span class="sourceLineNo">328</span>    return new AsyncTableBuilderBase&lt;AdvancedScanResultConsumer&gt;(tableName, connConf) {<a name="line.328"></a>
-<span class="sourceLineNo">329</span><a name="line.329"></a>
-<span class="sourceLineNo">330</span>      @Override<a name="line.330"></a>
-<span class="sourceLineNo">331</span>      public AsyncTable&lt;AdvancedScanResultConsumer&gt; build() {<a name="line.331"></a>
-<span class="sourceLineNo">332</span>        return new RawAsyncTableImpl(AsyncConnectionImpl.this, RETRY_TIMER, this);<a name="line.332"></a>
-<span class="sourceLineNo">333</span>      }<a name="line.333"></a>
-<span class="sourceLineNo">334</span>    };<a name="line.334"></a>
-<span class="sourceLineNo">335</span>  }<a name="line.335"></a>
-<span class="sourceLineNo">336</span><a name="line.336"></a>
-<span class="sourceLineNo">337</span>  @Override<a name="line.337"></a>
-<span class="sourceLineNo">338</span>  public AsyncTableBuilder&lt;ScanResultConsumer&gt; getTableBuilder(TableName tableName,<a name="line.338"></a>
-<span class="sourceLineNo">339</span>      ExecutorService pool) {<a name="line.339"></a>
-<span class="sourceLineNo">340</span>    return new AsyncTableBuilderBase&lt;ScanResultConsumer&gt;(tableName, connConf) {<a name="line.340"></a>
-<span class="sourceLineNo">341</span><a name="line.341"></a>
-<span class="sourceLineNo">342</span>      @Override<a name="line.342"></a>
-<span class="sourceLineNo">343</span>      public AsyncTable&lt;ScanResultConsumer&gt; build() {<a name="line.343"></a>
-<span class="sourceLineNo">344</span>        RawAsyncTableImpl rawTable =<a name="line.344"></a>
-<span class="sourceLineNo">345</span>          new RawAsyncTableImpl(AsyncConnectionImpl.this, RETRY_TIMER, this);<a name="line.345"></a>
-<span class="sourceLineNo">346</span>        return new AsyncTableImpl(AsyncConnectionImpl.this, rawTable, pool);<a name="line.346"></a>
-<span class="sourceLineNo">347</span>      }<a name="line.347"></a>
-<span class="sourceLineNo">348</span>    };<a name="line.348"></a>
-<span class="sourceLineNo">349</span>  }<a name="line.349"></a>
-<span class="sourceLineNo">350</span><a name="line.350"></a>
-<span class="sourceLineNo">351</span>  @Override<a name="line.351"></a>
-<span class="sourceLineNo">352</span>  public AsyncAdminBuilder getAdminBuilder() {<a name="line.352"></a>
-<span class="sourceLineNo">353</span>    return new AsyncAdminBuilderBase(connConf) {<a name="line.353"></a>
-<span class="sourceLineNo">354</span>      @Override<a name="line.354"></a>
-<span class="sourceLineNo">355</span>      public AsyncAdmin build() {<a name="line.355"></a>
-<span class="sourceLineNo">356</span>        return new RawAsyncHBaseAdmin(AsyncConnectionImpl.this, RETRY_TIMER, this);<a name="line.356"></a>
-<span class="sourceLineNo">357</span>      }<a name="line.357"></a>
-<span class="sourceLineNo">358</span>    };<a name="line.358"></a>
-<span class="sourceLineNo">359</span>  }<a name="line.359"></a>
-<span class="sourceLineNo">360</span><a name="line.360"></a>
-<span class="sourceLineNo">361</span>  @Override<a name="line.361"></a>
-<span class="sourceLineNo">362</span>  public AsyncAdminBuilder getAdminBuilder(ExecutorService pool) {<a name="line.362"></a>
-<span class="sourceLineNo">363</span>    return new AsyncAdminBuilderBase(connConf) {<a name="line.363"></a>
-<span class="sourceLineNo">364</span>      @Override<a name="line.364"></a>
-<span class="sourceLineNo">365</span>      public AsyncAdmin build() {<a name="line.365"></a>
-<span class="sourceLineNo">366</span>        RawAsyncHBaseAdmin rawAdmin =<a name="line.366"></a>
-<span class="sourceLineNo">367</span>          new RawAsyncHBaseAdmin(AsyncConnectionImpl.this, RETRY_TIMER, this);<a name="line.367"></a>
-<span class="sourceLineNo">368</span>        return new AsyncHBaseAdmin(rawAdmin, pool);<a name="line.368"></a>
-<span class="sourceLineNo">369</span>      }<a name="line.369"></a>
-<span class="sourceLineNo">370</span>    };<a name="line.370"></a>
-<span class="sourceLineNo">371</span>  }<a name="line.371"></a>
-<span class="sourceLineNo">372</span><a name="line.372"></a>
-<span class="sourceLineNo">373</span>  @Override<a name="line.373"></a>
-<span class="sourceLineNo">374</span>  public AsyncBufferedMutatorBuilder getBufferedMutatorBuilder(TableName tableName) {<a name="line.374"></a>
-<span class="sourceLineNo">375</span>    return new AsyncBufferedMutatorBuilderImpl(connConf, getTableBuilder(tableName), RETRY_TIMER);<a name="line.375"></a>
-<span class="sourceLineNo">376</span>  }<a name="line.376"></a>
-<span class="sourceLineNo">377</span><a name="line.377"></a>
-<span class="sourceLineNo">378</span>  @Override<a name="line.378"></a>
-<span class="sourceLineNo">379</span>  public AsyncBufferedMutatorBuilder getBufferedMutatorBuilder(TableName tableName,<a name="line.379"></a>
-<span class="sourceLineNo">380</span>      ExecutorService pool) {<a name="line.380"></a>
-<span class="sourceLineNo">381</span>    return new AsyncBufferedMutatorBuilderImpl(connConf, getTableBuilder(tableName, pool),<a name="line.381"></a>
-<span class="sourceLineNo">382</span>      RETRY_TIMER);<a name="line.382"></a>
-<span class="sourceLineNo">383</span>  }<a name="line.383"></a>
-<span class="sourceLineNo">384</span><a name="line.384"></a>
-<span class="sourceLineNo">385</span>  @Override<a name="line.385"></a>
-<span class="sourceLineNo">386</span>  public Connection toConnection() {<a name="line.386"></a>
-<span class="sourceLineNo">387</span>    ConnectionOverAsyncConnection c = this.conn;<a name="line.387"></a>
-<span class="sourceLineNo">388</span>    if (c != null) {<a name="line.388"></a>
-<span class="sourceLineNo">389</span>      return c;<a name="line.389"></a>
-<span class="sourceLineNo">390</span>    }<a name="line.390"></a>
-<span class="sourceLineNo">391</span>    synchronized (this) {<a name="line.391"></a>
-<span class="sourceLineNo">392</span>      c = this.conn;<a name="line.392"></a>
-<span class="sourceLineNo">393</span>      if (c != null) {<a name="line.393"></a>
-<span class="sourceLineNo">394</span>        return c;<a name="line.394"></a>
-<span class="sourceLineNo">395</span>      }<a name="line.395"></a>
-<span class="sourceLineNo">396</span>      c = new ConnectionOverAsyncConnection(this);<a name="line.396"></a>
-<span class="sourceLineNo">397</span>      this.conn = c;<a name="line.397"></a>
-<span class="sourceLineNo">398</span>    }<a name="line.398"></a>
-<span class="sourceLineNo">399</span>    return c;<a name="line.399"></a>
-<span class="sourceLineNo">400</span>  }<a name="line.400"></a>
-<span class="sourceLineNo">401</span><a name="line.401"></a>
-<span class="sourceLineNo">402</span>  @Override<a name="line.402"></a>
-<span class="sourceLineNo">403</span>  public CompletableFuture&lt;Hbck&gt; getHbck() {<a name="line.403"></a>
-<span class="sourceLineNo">404</span>    CompletableFuture&lt;Hbck&gt; future = new CompletableFuture&lt;&gt;();<a name="line.404"></a>
-<span class="sourceLineNo">405</span>    addListener(registry.getActiveMaster(), (sn, error) -&gt; {<a name="line.405"></a>
-<span class="sourceLineNo">406</span>      if (error != null) {<a name="line.406"></a>
-<span class="sourceLineNo">407</span>        future.completeExceptionally(error);<a name="line.407"></a>
-<span class="sourceLineNo">408</span>      } else {<a name="line.408"></a>
-<span class="sourceLineNo">409</span>        try {<a name="line.409"></a>
-<span class="sourceLineNo">410</span>          future.complete(getHbck(sn));<a name="line.410"></a>
-<span class="sourceLineNo">411</span>        } catch (IOException e) {<a name="line.411"></a>
-<span class="sourceLineNo">412</span>          future.completeExceptionally(e);<a name="line.412"></a>
-<span class="sourceLineNo">413</span>        }<a name="line.413"></a>
-<span class="sourceLineNo">414</span>      }<a name="line.414"></a>
-<span class="sourceLineNo">415</span>    });<a name="line.415"></a>
-<span class="sourceLineNo">416</span>    return future;<a name="line.416"></a>
-<span class="sourceLineNo">417</span>  }<a name="line.417"></a>
-<span class="sourceLineNo">418</span><a name="line.418"></a>
-<span class="sourceLineNo">419</span>  @Override<a name="line.419"></a>
-<span class="sourceLineNo">420</span>  public Hbck getHbck(ServerName masterServer) throws IOException {<a name="line.420"></a>
-<span class="sourceLineNo">421</span>    // we will not create a new connection when creating a new protobuf stub, and for hbck there<a name="line.421"></a>
-<span class="sourceLineNo">422</span>    // will be no performance consideration, so for simplification we will create a new stub every<a name="line.422"></a>
-<span class="sourceLineNo">423</span>    // time instead of caching the stub here.<a name="line.423"></a>
-<span class="sourceLineNo">424</span>    return new HBaseHbck(MasterProtos.HbckService.newBlockingStub(<a name="line.424"></a>
-<span class="sourceLineNo">425</span>      rpcClient.createBlockingRpcChannel(masterServer, user, rpcTimeout)), rpcControllerFactory);<a name="line.425"></a>
-<span class="sourceLineNo">426</span>  }<a name="line.426"></a>
-<span class="sourceLineNo">427</span><a name="line.427"></a>
-<span class="sourceLineNo">428</span>  Optional&lt;MetricsConnection&gt; getConnectionMetrics() {<a name="line.428"></a>
-<span class="sourceLineNo">429</span>    return metrics;<a name="line.429"></a>
-<span class="sourceLineNo">430</span>  }<a name="line.430"></a>
-<span class="sourceLineNo">431</span>}<a name="line.431"></a>
+<span class="sourceLineNo">215</span>    IOUtils.closeQuietly(clusterStatusListener,<a name="line.215"></a>
+<span class="sourceLineNo">216</span>      e -&gt; LOG.warn("failed to close clusterStatusListener", e));<a name="line.216"></a>
+<span class="sourceLineNo">217</span>    IOUtils.closeQuietly(rpcClient, e -&gt; LOG.warn("failed to close rpcClient", e));<a name="line.217"></a>
+<span class="sourceLineNo">218</span>    IOUtils.closeQuietly(registry, e -&gt; LOG.warn("failed to close registry", e));<a name="line.218"></a>
+<span class="sourceLineNo">219</span>    if (choreService != null) {<a name="line.219"></a>
+<span class="sourceLineNo">220</span>      choreService.shutdown();<a name="line.220"></a>
+<span class="sourceLineNo">221</span>    }<a name="line.221"></a>
+<span class="sourceLineNo">222</span>    metrics.ifPresent(MetricsConnection::shutdown);<a name="line.222"></a>
+<span class="sourceLineNo">223</span>    ConnectionOverAsyncConnection c = this.conn;<a name="line.223"></a>
+<span class="sourceLineNo">224</span>    if (c != null) {<a name="line.224"></a>
+<span class="sourceLineNo">225</span>      c.closePool();<a name="line.225"></a>
+<span class="sourceLineNo">226</span>    }<a name="line.226"></a>
+<span class="sourceLineNo">227</span>  }<a name="line.227"></a>
+<span class="sourceLineNo">228</span><a name="line.228"></a>
+<span class="sourceLineNo">229</span>  private void logCallStack(StackTraceElement[] stackTraceElements) {<a name="line.229"></a>
+<span class="sourceLineNo">230</span>    StringBuilder stackBuilder = new StringBuilder("Call stack:");<a name="line.230"></a>
+<span class="sourceLineNo">231</span>    for (StackTraceElement element : stackTraceElements) {<a name="line.231"></a>
+<span class="sourceLineNo">232</span>      stackBuilder.append("\n    at ");<a name="line.232"></a>
+<span class="sourceLineNo">233</span>      stackBuilder.append(element);<a name="line.233"></a>
+<span class="sourceLineNo">234</span>    }<a name="line.234"></a>
+<span class="sourceLineNo">235</span>    stackBuilder.append("\n");<a name="line.235"></a>
+<span class="sourceLineNo">236</span>    LOG.debug(stackBuilder.toString());<a name="line.236"></a>
+<span class="sourceLineNo">237</span>  }<a name="line.237"></a>
+<span class="sourceLineNo">238</span><a name="line.238"></a>
+<span class="sourceLineNo">239</span>  @Override<a name="line.239"></a>
+<span class="sourceLineNo">240</span>  public AsyncTableRegionLocator getRegionLocator(TableName tableName) {<a name="line.240"></a>
+<span class="sourceLineNo">241</span>    return new AsyncTableRegionLocatorImpl(tableName, this);<a name="line.241"></a>
+<span class="sourceLineNo">242</span>  }<a name="line.242"></a>
+<span class="sourceLineNo">243</span><a name="line.243"></a>
+<span class="sourceLineNo">244</span>  @Override<a name="line.244"></a>
+<span class="sourceLineNo">245</span>  public void clearRegionLocationCache() {<a name="line.245"></a>
+<span class="sourceLineNo">246</span>    locator.clearCache();<a name="line.246"></a>
+<span class="sourceLineNo">247</span>  }<a name="line.247"></a>
+<span class="sourceLineNo">248</span><a name="line.248"></a>
+<span class="sourceLineNo">249</span>  // we will override this method for testing retry caller, so do not remove this method.<a name="line.249"></a>
+<span class="sourceLineNo">250</span>  AsyncRegionLocator getLocator() {<a name="line.250"></a>
+<span class="sourceLineNo">251</span>    return locator;<a name="line.251"></a>
+<span class="sourceLineNo">252</span>  }<a name="line.252"></a>
+<span class="sourceLineNo">253</span><a name="line.253"></a>
+<span class="sourceLineNo">254</span>  // ditto<a name="line.254"></a>
+<span class="sourceLineNo">255</span>  NonceGenerator getNonceGenerator() {<a name="line.255"></a>
+<span class="sourceLineNo">256</span>    return nonceGenerator;<a name="line.256"></a>
+<span class="sourceLineNo">257</span>  }<a name="line.257"></a>
+<span class="sourceLineNo">258</span><a name="line.258"></a>
+<span class="sourceLineNo">259</span>  private ClientService.Interface createRegionServerStub(ServerName serverName) throws IOException {<a name="line.259"></a>
+<span class="sourceLineNo">260</span>    return ClientService.newStub(rpcClient.createRpcChannel(serverName, user, rpcTimeout));<a name="line.260"></a>
+<span class="sourceLineNo">261</span>  }<a name="line.261"></a>
+<span class="sourceLineNo">262</span><a name="line.262"></a>
+<span class="sourceLineNo">263</span>  ClientService.Interface getRegionServerStub(ServerName serverName) throws IOException {<a name="line.263"></a>
+<span class="sourceLineNo">264</span>    return ConcurrentMapUtils.computeIfAbsentEx(rsStubs,<a name="line.264"></a>
+<span class="sourceLineNo">265</span>      getStubKey(ClientService.getDescriptor().getName(), serverName),<a name="line.265"></a>
+<span class="sourceLineNo">266</span>      () -&gt; createRegionServerStub(serverName));<a name="line.266"></a>
+<span class="sourceLineNo">267</span>  }<a name="line.267"></a>
+<span class="sourceLineNo">268</span><a name="line.268"></a>
+<span class="sourceLineNo">269</span>  private MasterService.Interface createMasterStub(ServerName serverName) throws IOException {<a name="line.269"></a>
+<span class="sourceLineNo">270</span>    return MasterService.newStub(rpcClient.createRpcChannel(serverName, user, rpcTimeout));<a name="line.270"></a>
+<span class="sourceLineNo">271</span>  }<a name="line.271"></a>
+<span class="sourceLineNo">272</span><a name="line.272"></a>
+<span class="sourceLineNo">273</span>  private AdminService.Interface createAdminServerStub(ServerName serverName) throws IOException {<a name="line.273"></a>
+<span class="sourceLineNo">274</span>    return AdminService.newStub(rpcClient.createRpcChannel(serverName, user, rpcTimeout));<a name="line.274"></a>
+<span class="sourceLineNo">275</span>  }<a name="line.275"></a>
+<span class="sourceLineNo">276</span><a name="line.276"></a>
+<span class="sourceLineNo">277</span>  AdminService.Interface getAdminStub(ServerName serverName) throws IOException {<a name="line.277"></a>
+<span class="sourceLineNo">278</span>    return ConcurrentMapUtils.computeIfAbsentEx(adminSubs,<a name="line.278"></a>
+<span class="sourceLineNo">279</span>      getStubKey(AdminService.getDescriptor().getName(), serverName),<a name="line.279"></a>
+<span class="sourceLineNo">280</span>      () -&gt; createAdminServerStub(serverName));<a name="line.280"></a>
+<span class="sourceLineNo">281</span>  }<a name="line.281"></a>
+<span class="sourceLineNo">282</span><a name="line.282"></a>
+<span class="sourceLineNo">283</span>  CompletableFuture&lt;MasterService.Interface&gt; getMasterStub() {<a name="line.283"></a>
+<span class="sourceLineNo">284</span>    return ConnectionUtils.getOrFetch(masterStub, masterStubMakeFuture, false, () -&gt; {<a name="line.284"></a>
+<span class="sourceLineNo">285</span>      CompletableFuture&lt;MasterService.Interface&gt; future = new CompletableFuture&lt;&gt;();<a name="line.285"></a>
+<span class="sourceLineNo">286</span>      addListener(registry.getActiveMaster(), (addr, error) -&gt; {<a name="line.286"></a>
+<span class="sourceLineNo">287</span>        if (error != null) {<a name="line.287"></a>
+<span class="sourceLineNo">288</span>          future.completeExceptionally(error);<a name="line.288"></a>
+<span class="sourceLineNo">289</span>        } else if (addr == null) {<a name="line.289"></a>
+<span class="sourceLineNo">290</span>          future.completeExceptionally(new MasterNotRunningException(<a name="line.290"></a>
+<span class="sourceLineNo">291</span>            "ZooKeeper available but no active master location found"));<a name="line.291"></a>
+<span class="sourceLineNo">292</span>        } else {<a name="line.292"></a>
+<span class="sourceLineNo">293</span>          LOG.debug("The fetched master address is {}", addr);<a name="line.293"></a>
+<span class="sourceLineNo">294</span>          try {<a name="line.294"></a>
+<span class="sourceLineNo">295</span>            future.complete(createMasterStub(addr));<a name="line.295"></a>
+<span class="sourceLineNo">296</span>          } catch (IOException e) {<a name="line.296"></a>
+<span class="sourceLineNo">297</span>            future.completeExceptionally(e);<a name="line.297"></a>
+<span class="sourceLineNo">298</span>          }<a name="line.298"></a>
+<span class="sourceLineNo">299</span>        }<a name="line.299"></a>
+<span class="sourceLineNo">300</span><a name="line.300"></a>
+<span class="sourceLineNo">301</span>      });<a name="line.301"></a>
+<span class="sourceLineNo">302</span>      return future;<a name="line.302"></a>
+<span class="sourceLineNo">303</span>    }, stub -&gt; true, "master stub");<a name="line.303"></a>
+<span class="sourceLineNo">304</span>  }<a name="line.304"></a>
+<span class="sourceLineNo">305</span><a name="line.305"></a>
+<span class="sourceLineNo">306</span>  String getClusterId() {<a name="line.306"></a>
+<span class="sourceLineNo">307</span>    try {<a name="line.307"></a>
+<span class="sourceLineNo">308</span>      return registry.getClusterId().get();<a name="line.308"></a>
+<span class="sourceLineNo">309</span>    } catch (InterruptedException | ExecutionException e) {<a name="line.309"></a>
+<span class="sourceLineNo">310</span>      LOG.error("Error fetching cluster ID: ", e);<a name="line.310"></a>
+<span class="sourceLineNo">311</span>    }<a name="line.311"></a>
+<span class="sourceLineNo">312</span>    return null;<a name="line.312"></a>
+<span class="sourceLineNo">313</span>  }<a name="line.313"></a>
+<span class="sourceLineNo">314</span><a name="line.314"></a>
+<span class="sourceLineNo">315</span>  void clearMasterStubCache(MasterService.Interface stub) {<a name="line.315"></a>
+<span class="sourceLineNo">316</span>    masterStub.compareAndSet(stub, null);<a name="line.316"></a>
+<span class="sourceLineNo">317</span>  }<a name="line.317"></a>
+<span class="sourceLineNo">318</span><a name="line.318"></a>
+<span class="sourceLineNo">319</span>  Optional&lt;ServerStatisticTracker&gt; getStatisticsTracker() {<a name="line.319"></a>
+<span class="sourceLineNo">320</span>    return stats;<a name="line.320"></a>
+<span class="sourceLineNo">321</span>  }<a name="line.321"></a>
+<span class="sourceLineNo">322</span><a name="line.322"></a>
+<span class="sourceLineNo">323</span>  ClientBackoffPolicy getBackoffPolicy() {<a name="line.323"></a>
+<span class="sourceLineNo">324</span>    return backoffPolicy;<a name="line.324"></a>
+<span class="sourceLineNo">325</span>  }<a name="line.325"></a>
+<span class="sourceLineNo">326</span><a name="line.326"></a>
+<span class="sourceLineNo">327</span>  @Override<a name="line.327"></a>
+<span class="sourceLineNo">328</span>  public AsyncTableBuilder&lt;AdvancedScanResultConsumer&gt; getTableBuilder(TableName tableName) {<a name="line.328"></a>
+<span class="sourceLineNo">329</span>    return new AsyncTableBuilderBase&lt;AdvancedScanResultConsumer&gt;(tableName, connConf) {<a name="line.329"></a>
+<span class="sourceLineNo">330</span><a name="line.330"></a>
+<span class="sourceLineNo">331</span>      @Override<a name="line.331"></a>
+<span class="sourceLineNo">332</span>      public AsyncTable&lt;AdvancedScanResultConsumer&gt; build() {<a name="line.332"></a>
+<span class="sourceLineNo">333</span>        return new RawAsyncTableImpl(AsyncConnectionImpl.this, RETRY_TIMER, this);<a name="line.333"></a>
+<span class="sourceLineNo">334</span>      }<a name="line.334"></a>
+<span class="sourceLineNo">335</span>    };<a name="line.335"></a>
+<span class="sourceLineNo">336</span>  }<a name="line.336"></a>
+<span class="sourceLineNo">337</span><a name="line.337"></a>
+<span class="sourceLineNo">338</span>  @Override<a name="line.338"></a>
+<span class="sourceLineNo">339</span>  public AsyncTableBuilder&lt;ScanResultConsumer&gt; getTableBuilder(TableName tableName,<a name="line.339"></a>
+<span class="sourceLineNo">340</span>      ExecutorService pool) {<a name="line.340"></a>
+<span class="sourceLineNo">341</span>    return new AsyncTableBuilderBase&lt;ScanResultConsumer&gt;(tableName, connConf) {<a name="line.341"></a>
+<span class="sourceLineNo">342</span><a name="line.342"></a>
+<span class="sourceLineNo">343</span>      @Override<a name="line.343"></a>
+<span class="sourceLineNo">344</span>      public AsyncTable&lt;ScanResultConsumer&gt; build() {<a name="line.344"></a>
+<span class="sourceLineNo">345</span>        RawAsyncTableImpl rawTable =<a name="line.345"></a>
+<span class="sourceLineNo">346</span>          new RawAsyncTableImpl(AsyncConnectionImpl.this, RETRY_TIMER, this);<a name="line.346"></a>
+<span class="sourceLineNo">347</span>        return new AsyncTableImpl(AsyncConnectionImpl.this, rawTable, pool);<a name="line.347"></a>
+<span class="sourceLineNo">348</span>      }<a name="line.348"></a>
+<span class="sourceLineNo">349</span>    };<a name="line.349"></a>
+<span class="sourceLineNo">350</span>  }<a name="line.350"></a>
+<span class="sourceLineNo">351</span><a name="line.351"></a>
+<span class="sourceLineNo">352</span>  @Override<a name="line.352"></a>
+<span class="sourceLineNo">353</span>  public AsyncAdminBuilder getAdminBuilder() {<a name="line.353"></a>
+<span class="sourceLineNo">354</span>    return new AsyncAdminBuilderBase(connConf) {<a name="line.354"></a>
+<span class="sourceLineNo">355</span>      @Override<a name="line.355"></a>
+<span class="sourceLineNo">356</span>      public AsyncAdmin build() {<a name="line.356"></a>
+<span class="sourceLineNo">357</span>        return new RawAsyncHBaseAdmin(AsyncConnectionImpl.this, RETRY_TIMER, this);<a name="line.357"></a>
+<span class="sourceLineNo">358</span>      }<a name="line.358"></a>
+<span class="sourceLineNo">359</span>    };<a name="line.359"></a>
+<span class="sourceLineNo">360</span>  }<a name="line.360"></a>
+<span class="sourceLineNo">361</span><a name="line.361"></a>
+<span class="sourceLineNo">362</span>  @Override<a name="line.362"></a>
+<span class="sourceLineNo">363</span>  public AsyncAdminBuilder getAdminBuilder(ExecutorService pool) {<a name="line.363"></a>
+<span class="sourceLineNo">364</span>    return new AsyncAdminBuilderBase(connConf) {<a name="line.364"></a>
+<span class="sourceLineNo">365</span>      @Override<a name="line.365"></a>
+<span class="sourceLineNo">366</span>      public AsyncAdmin build() {<a name="line.366"></a>
+<span class="sourceLineNo">367</span>        RawAsyncHBaseAdmin rawAdmin =<a name="line.367"></a>
+<span class="sourceLineNo">368</span>          new RawAsyncHBaseAdmin(AsyncConnectionImpl.this, RETRY_TIMER, this);<a name="line.368"></a>
+<span class="sourceLineNo">369</span>        return new AsyncHBaseAdmin(rawAdmin, pool);<a name="line.369"></a>
+<span class="sourceLineNo">370</span>      }<a name="line.370"></a>
+<span class="sourceLineNo">371</span>    };<a name="line.371"></a>
+<span class="sourceLineNo">372</span>  }<a name="line.372"></a>
+<span class="sourceLineNo">373</span><a name="line.373"></a>
+<span class="sourceLineNo">374</span>  @Override<a name="line.374"></a>
+<span class="sourceLineNo">375</span>  public AsyncBufferedMutatorBuilder getBufferedMutatorBuilder(TableName tableName) {<a name="line.375"></a>
+<span class="sourceLineNo">376</span>    return new AsyncBufferedMutatorBuilderImpl(connConf, getTableBuilder(tableName), RETRY_TIMER);<a name="line.376"></a>
+<span class="sourceLineNo">377</span>  }<a name="line.377"></a>
+<span class="sourceLineNo">378</span><a name="line.378"></a>
+<span class="sourceLineNo">379</span>  @Override<a name="line.379"></a>
+<span class="sourceLineNo">380</span>  public AsyncBufferedMutatorBuilder getBufferedMutatorBuilder(TableName tableName,<a name="line.380"></a>
+<span class="sourceLineNo">381</span>      ExecutorService pool) {<a name="line.381"></a>
+<span class="sourceLineNo">382</span>    return new AsyncBufferedMutatorBuilderImpl(connConf, getTableBuilder(tableName, pool),<a name="line.382"></a>
+<span class="sourceLineNo">383</span>      RETRY_TIMER);<a name="line.383"></a>
+<span class="sourceLineNo">384</span>  }<a name="line.384"></a>
+<span class="sourceLineNo">385</span><a name="line.385"></a>
+<span class="sourceLineNo">386</span>  @Override<a name="line.386"></a>
+<span class="sourceLineNo">387</span>  public Connection toConnection() {<a name="line.387"></a>
+<span class="sourceLineNo">388</span>    ConnectionOverAsyncConnection c = this.conn;<a name="line.388"></a>
+<span class="sourceLineNo">389</span>    if (c != null) {<a name="line.389"></a>
+<span class="sourceLineNo">390</span>      return c;<a name="line.390"></a>
+<span class="sourceLineNo">391</span>    }<a name="line.391"></a>
+<span class="sourceLineNo">392</span>    synchronized (this) {<a name="line.392"></a>
+<span class="sourceLineNo">393</span>      c = this.conn;<a name="line.393"></a>
+<span class="sourceLineNo">394</span>      if (c != null) {<a name="line.394"></a>
+<span class="sourceLineNo">395</span>        return c;<a name="line.395"></a>
+<span class="sourceLineNo">396</span>      }<a name="line.396"></a>
+<span class="sourceLineNo">397</span>      c = new ConnectionOverAsyncConnection(this);<a name="line.397"></a>
+<span class="sourceLineNo">398</span>      this.conn = c;<a name="line.398"></a>
+<span class="sourceLineNo">399</span>    }<a name="line.399"></a>
+<span class="sourceLineNo">400</span>    return c;<a name="line.400"></a>
+<span class="sourceLineNo">401</span>  }<a name="line.401"></a>
+<span class="sourceLineNo">402</span><a name="line.402"></a>
+<span class="sourceLineNo">403</span>  @Override<a name="line.403"></a>
+<span class="sourceLineNo">404</span>  public CompletableFuture&lt;Hbck&gt; getHbck() {<a name="line.404"></a>
+<span class="sourceLineNo">405</span>    CompletableFuture&lt;Hbck&gt; future = new CompletableFuture&lt;&gt;();<a name="line.405"></a>
+<span class="sourceLineNo">406</span>    addListener(registry.getActiveMaster(), (sn, error) -&gt; {<a name="line.406"></a>
+<span class="sourceLineNo">407</span>      if (error != null) {<a name="line.407"></a>
+<span class="sourceLineNo">408</span>        future.completeExceptionally(error);<a name="line.408"></a>
+<span class="sourceLineNo">409</span>      } else {<a name="line.409"></a>
+<span class="sourceLineNo">410</span>        try {<a name="line.410"></a>
+<span class="sourceLineNo">411</span>          future.complete(getHbck(sn));<a name="line.411"></a>
+<span class="sourceLineNo">412</span>        } catch (IOException e) {<a name="line.412"></a>
+<span class="sourceLineNo">413</span>          future.completeExceptionally(e);<a name="line.413"></a>
+<span class="sourceLineNo">414</span>        }<a name="line.414"></a>
+<span class="sourceLineNo">415</span>      }<a name="line.415"></a>
+<span class="sourceLineNo">416</span>    });<a name="line.416"></a>
+<span class="sourceLineNo">417</span>    return future;<a name="line.417"></a>
+<span class="sourceLineNo">418</span>  }<a name="line.418"></a>
+<span class="sourceLineNo">419</span><a name="line.419"></a>
+<span class="sourceLineNo">420</span>  @Override<a name="line.420"></a>
+<span class="sourceLineNo">421</span>  public Hbck getHbck(ServerName masterServer) throws IOException {<a name="line.421"></a>
+<span class="sourceLineNo">422</span>    // we will not create a new connection when creating a new protobuf stub, and for hbck there<a name="line.422"></a>
+<span class="sourceLineNo">423</span>    // will be no performance consideration, so for simplification we will create a new stub every<a name="line.423"></a>
+<span class="sourceLineNo">424</span>    // time instead of caching the stub here.<a name="line.424"></a>
+<span class="sourceLineNo">425</span>    return new HBaseHbck(MasterProtos.HbckService.newBlockingStub(<a name="line.425"></a>
+<span class="sourceLineNo">426</span>      rpcClient.createBlockingRpcChannel(masterServer, user, rpcTimeout)), rpcControllerFactory);<a name="line.426"></a>
+<span class="sourceLineNo">427</span>  }<a name="line.427"></a>
+<span class="sourceLineNo">428</span><a name="line.428"></a>
+<span class="sourceLineNo">429</span>  Optional&lt;MetricsConnection&gt; getConnectionMetrics() {<a name="line.429"></a>
+<span class="sourceLineNo">430</span>    return metrics;<a name="line.430"></a>
+<span class="sourceLineNo">431</span>  }<a name="line.431"></a>
+<span class="sourceLineNo">432</span>}<a name="line.432"></a>
 
 
 
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/client/example/AsyncClientExample.html b/devapidocs/src-html/org/apache/hadoop/hbase/client/example/AsyncClientExample.html
index 71fb0fa..4077dec 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/client/example/AsyncClientExample.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/client/example/AsyncClientExample.html
@@ -119,7 +119,7 @@
 <span class="sourceLineNo">111</span>    CompletableFuture&lt;Void&gt; closeFuture = new CompletableFuture&lt;&gt;();<a name="line.111"></a>
 <span class="sourceLineNo">112</span>    addListener(f, (conn, error) -&gt; {<a name="line.112"></a>
 <span class="sourceLineNo">113</span>      if (error == null) {<a name="line.113"></a>
-<span class="sourceLineNo">114</span>        IOUtils.closeQuietly(conn);<a name="line.114"></a>
+<span class="sourceLineNo">114</span>        IOUtils.closeQuietly(conn, e -&gt; LOG.warn("failed to close conn", e));<a name="line.114"></a>
 <span class="sourceLineNo">115</span>      }<a name="line.115"></a>
 <span class="sourceLineNo">116</span>      closeFuture.complete(null);<a name="line.116"></a>
 <span class="sourceLineNo">117</span>    });<a name="line.117"></a>
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/io/FSDataInputStreamWrapper.ReadStatistics.html b/devapidocs/src-html/org/apache/hadoop/hbase/io/FSDataInputStreamWrapper.ReadStatistics.html
index 029218b..9100a21 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/io/FSDataInputStreamWrapper.ReadStatistics.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/io/FSDataInputStreamWrapper.ReadStatistics.html
@@ -29,17 +29,17 @@
 <span class="sourceLineNo">021</span>import java.io.IOException;<a name="line.21"></a>
 <span class="sourceLineNo">022</span>import java.io.InputStream;<a name="line.22"></a>
 <span class="sourceLineNo">023</span>import java.util.concurrent.atomic.AtomicInteger;<a name="line.23"></a>
-<span class="sourceLineNo">024</span><a name="line.24"></a>
-<span class="sourceLineNo">025</span>import org.apache.commons.io.IOUtils;<a name="line.25"></a>
-<span class="sourceLineNo">026</span>import org.apache.hadoop.fs.CanUnbuffer;<a name="line.26"></a>
-<span class="sourceLineNo">027</span>import org.apache.hadoop.fs.FSDataInputStream;<a name="line.27"></a>
-<span class="sourceLineNo">028</span>import org.apache.hadoop.fs.FileSystem;<a name="line.28"></a>
-<span class="sourceLineNo">029</span>import org.apache.hadoop.fs.Path;<a name="line.29"></a>
-<span class="sourceLineNo">030</span>import org.apache.hadoop.hbase.fs.HFileSystem;<a name="line.30"></a>
-<span class="sourceLineNo">031</span>import org.apache.hadoop.hdfs.client.HdfsDataInputStream;<a name="line.31"></a>
-<span class="sourceLineNo">032</span>import org.apache.yetus.audience.InterfaceAudience;<a name="line.32"></a>
-<span class="sourceLineNo">033</span>import org.slf4j.Logger;<a name="line.33"></a>
-<span class="sourceLineNo">034</span>import org.slf4j.LoggerFactory;<a name="line.34"></a>
+<span class="sourceLineNo">024</span>import org.apache.hadoop.fs.CanUnbuffer;<a name="line.24"></a>
+<span class="sourceLineNo">025</span>import org.apache.hadoop.fs.FSDataInputStream;<a name="line.25"></a>
+<span class="sourceLineNo">026</span>import org.apache.hadoop.fs.FileSystem;<a name="line.26"></a>
+<span class="sourceLineNo">027</span>import org.apache.hadoop.fs.Path;<a name="line.27"></a>
+<span class="sourceLineNo">028</span>import org.apache.hadoop.hbase.fs.HFileSystem;<a name="line.28"></a>
+<span class="sourceLineNo">029</span>import org.apache.hadoop.hdfs.client.HdfsDataInputStream;<a name="line.29"></a>
+<span class="sourceLineNo">030</span>import org.apache.yetus.audience.InterfaceAudience;<a name="line.30"></a>
+<span class="sourceLineNo">031</span>import org.slf4j.Logger;<a name="line.31"></a>
+<span class="sourceLineNo">032</span>import org.slf4j.LoggerFactory;<a name="line.32"></a>
+<span class="sourceLineNo">033</span><a name="line.33"></a>
+<span class="sourceLineNo">034</span>import org.apache.hbase.thirdparty.com.google.common.io.Closeables;<a name="line.34"></a>
 <span class="sourceLineNo">035</span><a name="line.35"></a>
 <span class="sourceLineNo">036</span>/**<a name="line.36"></a>
 <span class="sourceLineNo">037</span> * Wrapper for input stream(s) that takes care of the interaction of FS and HBase checksums,<a name="line.37"></a>
@@ -297,11 +297,11 @@
 <span class="sourceLineNo">289</span>    }<a name="line.289"></a>
 <span class="sourceLineNo">290</span>    updateInputStreamStatistics(this.streamNoFsChecksum);<a name="line.290"></a>
 <span class="sourceLineNo">291</span>    // we do not care about the close exception as it is for reading, no data loss issue.<a name="line.291"></a>
-<span class="sourceLineNo">292</span>    IOUtils.closeQuietly(streamNoFsChecksum);<a name="line.292"></a>
+<span class="sourceLineNo">292</span>    Closeables.closeQuietly(streamNoFsChecksum);<a name="line.292"></a>
 <span class="sourceLineNo">293</span><a name="line.293"></a>
 <span class="sourceLineNo">294</span><a name="line.294"></a>
 <span class="sourceLineNo">295</span>    updateInputStreamStatistics(stream);<a name="line.295"></a>
-<span class="sourceLineNo">296</span>    IOUtils.closeQuietly(stream);<a name="line.296"></a>
+<span class="sourceLineNo">296</span>    Closeables.closeQuietly(stream);<a name="line.296"></a>
 <span class="sourceLineNo">297</span>  }<a name="line.297"></a>
 <span class="sourceLineNo">298</span><a name="line.298"></a>
 <span class="sourceLineNo">299</span>  public HFileSystem getHfs() {<a name="line.299"></a>
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/io/FSDataInputStreamWrapper.html b/devapidocs/src-html/org/apache/hadoop/hbase/io/FSDataInputStreamWrapper.html
index 029218b..9100a21 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/io/FSDataInputStreamWrapper.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/io/FSDataInputStreamWrapper.html
@@ -29,17 +29,17 @@
 <span class="sourceLineNo">021</span>import java.io.IOException;<a name="line.21"></a>
 <span class="sourceLineNo">022</span>import java.io.InputStream;<a name="line.22"></a>
 <span class="sourceLineNo">023</span>import java.util.concurrent.atomic.AtomicInteger;<a name="line.23"></a>
-<span class="sourceLineNo">024</span><a name="line.24"></a>
-<span class="sourceLineNo">025</span>import org.apache.commons.io.IOUtils;<a name="line.25"></a>
-<span class="sourceLineNo">026</span>import org.apache.hadoop.fs.CanUnbuffer;<a name="line.26"></a>
-<span class="sourceLineNo">027</span>import org.apache.hadoop.fs.FSDataInputStream;<a name="line.27"></a>
-<span class="sourceLineNo">028</span>import org.apache.hadoop.fs.FileSystem;<a name="line.28"></a>
-<span class="sourceLineNo">029</span>import org.apache.hadoop.fs.Path;<a name="line.29"></a>
-<span class="sourceLineNo">030</span>import org.apache.hadoop.hbase.fs.HFileSystem;<a name="line.30"></a>
-<span class="sourceLineNo">031</span>import org.apache.hadoop.hdfs.client.HdfsDataInputStream;<a name="line.31"></a>
-<span class="sourceLineNo">032</span>import org.apache.yetus.audience.InterfaceAudience;<a name="line.32"></a>
-<span class="sourceLineNo">033</span>import org.slf4j.Logger;<a name="line.33"></a>
-<span class="sourceLineNo">034</span>import org.slf4j.LoggerFactory;<a name="line.34"></a>
+<span class="sourceLineNo">024</span>import org.apache.hadoop.fs.CanUnbuffer;<a name="line.24"></a>
+<span class="sourceLineNo">025</span>import org.apache.hadoop.fs.FSDataInputStream;<a name="line.25"></a>
+<span class="sourceLineNo">026</span>import org.apache.hadoop.fs.FileSystem;<a name="line.26"></a>
+<span class="sourceLineNo">027</span>import org.apache.hadoop.fs.Path;<a name="line.27"></a>
+<span class="sourceLineNo">028</span>import org.apache.hadoop.hbase.fs.HFileSystem;<a name="line.28"></a>
+<span class="sourceLineNo">029</span>import org.apache.hadoop.hdfs.client.HdfsDataInputStream;<a name="line.29"></a>
+<span class="sourceLineNo">030</span>import org.apache.yetus.audience.InterfaceAudience;<a name="line.30"></a>
+<span class="sourceLineNo">031</span>import org.slf4j.Logger;<a name="line.31"></a>
+<span class="sourceLineNo">032</span>import org.slf4j.LoggerFactory;<a name="line.32"></a>
+<span class="sourceLineNo">033</span><a name="line.33"></a>
+<span class="sourceLineNo">034</span>import org.apache.hbase.thirdparty.com.google.common.io.Closeables;<a name="line.34"></a>
 <span class="sourceLineNo">035</span><a name="line.35"></a>
 <span class="sourceLineNo">036</span>/**<a name="line.36"></a>
 <span class="sourceLineNo">037</span> * Wrapper for input stream(s) that takes care of the interaction of FS and HBase checksums,<a name="line.37"></a>
@@ -297,11 +297,11 @@
 <span class="sourceLineNo">289</span>    }<a name="line.289"></a>
 <span class="sourceLineNo">290</span>    updateInputStreamStatistics(this.streamNoFsChecksum);<a name="line.290"></a>
 <span class="sourceLineNo">291</span>    // we do not care about the close exception as it is for reading, no data loss issue.<a name="line.291"></a>
-<span class="sourceLineNo">292</span>    IOUtils.closeQuietly(streamNoFsChecksum);<a name="line.292"></a>
+<span class="sourceLineNo">292</span>    Closeables.closeQuietly(streamNoFsChecksum);<a name="line.292"></a>
 <span class="sourceLineNo">293</span><a name="line.293"></a>
 <span class="sourceLineNo">294</span><a name="line.294"></a>
 <span class="sourceLineNo">295</span>    updateInputStreamStatistics(stream);<a name="line.295"></a>
-<span class="sourceLineNo">296</span>    IOUtils.closeQuietly(stream);<a name="line.296"></a>
+<span class="sourceLineNo">296</span>    Closeables.closeQuietly(stream);<a name="line.296"></a>
 <span class="sourceLineNo">297</span>  }<a name="line.297"></a>
 <span class="sourceLineNo">298</span><a name="line.298"></a>
 <span class="sourceLineNo">299</span>  public HFileSystem getHfs() {<a name="line.299"></a>
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.CachingBlockReader.html b/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.CachingBlockReader.html
index a82ba7f..2a91d20 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.CachingBlockReader.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.CachingBlockReader.html
@@ -513,180 +513,181 @@
 <span class="sourceLineNo">505</span>          throw new IllegalArgumentException("Invalid HFile version " + trailer.getMajorVersion());<a name="line.505"></a>
 <span class="sourceLineNo">506</span>      }<a name="line.506"></a>
 <span class="sourceLineNo">507</span>    } catch (Throwable t) {<a name="line.507"></a>
-<span class="sourceLineNo">508</span>      IOUtils.closeQuietly(context.getInputStreamWrapper());<a name="line.508"></a>
-<span class="sourceLineNo">509</span>      throw new CorruptHFileException("Problem reading HFile Trailer from file "<a name="line.509"></a>
-<span class="sourceLineNo">510</span>          + context.getFilePath(), t);<a name="line.510"></a>
-<span class="sourceLineNo">511</span>    } finally {<a name="line.511"></a>
-<span class="sourceLineNo">512</span>      context.getInputStreamWrapper().unbuffer();<a name="line.512"></a>
-<span class="sourceLineNo">513</span>    }<a name="line.513"></a>
-<span class="sourceLineNo">514</span>  }<a name="line.514"></a>
-<span class="sourceLineNo">515</span><a name="line.515"></a>
-<span class="sourceLineNo">516</span>  /**<a name="line.516"></a>
-<span class="sourceLineNo">517</span>   * Creates reader with cache configuration disabled<a name="line.517"></a>
-<span class="sourceLineNo">518</span>   * @param fs filesystem<a name="line.518"></a>
-<span class="sourceLineNo">519</span>   * @param path Path to file to read<a name="line.519"></a>
-<span class="sourceLineNo">520</span>   * @param conf Configuration<a name="line.520"></a>
-<span class="sourceLineNo">521</span>   * @return an active Reader instance<a name="line.521"></a>
-<span class="sourceLineNo">522</span>   * @throws IOException Will throw a CorruptHFileException<a name="line.522"></a>
-<span class="sourceLineNo">523</span>   *   (DoNotRetryIOException subtype) if hfile is corrupt/invalid.<a name="line.523"></a>
-<span class="sourceLineNo">524</span>   */<a name="line.524"></a>
-<span class="sourceLineNo">525</span>  public static Reader createReader(FileSystem fs, Path path, Configuration conf)<a name="line.525"></a>
-<span class="sourceLineNo">526</span>      throws IOException {<a name="line.526"></a>
-<span class="sourceLineNo">527</span>    // The primaryReplicaReader is mainly used for constructing block cache key, so if we do not use<a name="line.527"></a>
-<span class="sourceLineNo">528</span>    // block cache then it is OK to set it as any value. We use true here.<a name="line.528"></a>
-<span class="sourceLineNo">529</span>    return createReader(fs, path, CacheConfig.DISABLED, true, conf);<a name="line.529"></a>
-<span class="sourceLineNo">530</span>  }<a name="line.530"></a>
-<span class="sourceLineNo">531</span><a name="line.531"></a>
-<span class="sourceLineNo">532</span>  /**<a name="line.532"></a>
-<span class="sourceLineNo">533</span>   * @param fs filesystem<a name="line.533"></a>
-<span class="sourceLineNo">534</span>   * @param path Path to file to read<a name="line.534"></a>
-<span class="sourceLineNo">535</span>   * @param cacheConf This must not be null. @see<a name="line.535"></a>
-<span class="sourceLineNo">536</span>   *          {@link org.apache.hadoop.hbase.io.hfile.CacheConfig#CacheConfig(Configuration)}<a name="line.536"></a>
-<span class="sourceLineNo">537</span>   * @param primaryReplicaReader true if this is a reader for primary replica<a name="line.537"></a>
-<span class="sourceLineNo">538</span>   * @param conf Configuration<a name="line.538"></a>
-<span class="sourceLineNo">539</span>   * @return an active Reader instance<a name="line.539"></a>
-<span class="sourceLineNo">540</span>   * @throws IOException Will throw a CorruptHFileException (DoNotRetryIOException subtype) if hfile<a name="line.540"></a>
-<span class="sourceLineNo">541</span>   *           is corrupt/invalid.<a name="line.541"></a>
-<span class="sourceLineNo">542</span>   */<a name="line.542"></a>
-<span class="sourceLineNo">543</span>  public static Reader createReader(FileSystem fs, Path path, CacheConfig cacheConf,<a name="line.543"></a>
-<span class="sourceLineNo">544</span>      boolean primaryReplicaReader, Configuration conf) throws IOException {<a name="line.544"></a>
-<span class="sourceLineNo">545</span>    Preconditions.checkNotNull(cacheConf, "Cannot create Reader with null CacheConf");<a name="line.545"></a>
-<span class="sourceLineNo">546</span>    FSDataInputStreamWrapper stream = new FSDataInputStreamWrapper(fs, path);<a name="line.546"></a>
-<span class="sourceLineNo">547</span>    ReaderContext context = new ReaderContextBuilder()<a name="line.547"></a>
-<span class="sourceLineNo">548</span>        .withFilePath(path)<a name="line.548"></a>
-<span class="sourceLineNo">549</span>        .withInputStreamWrapper(stream)<a name="line.549"></a>
-<span class="sourceLineNo">550</span>        .withFileSize(fs.getFileStatus(path).getLen())<a name="line.550"></a>
-<span class="sourceLineNo">551</span>        .withFileSystem(stream.getHfs())<a name="line.551"></a>
-<span class="sourceLineNo">552</span>        .withPrimaryReplicaReader(primaryReplicaReader)<a name="line.552"></a>
-<span class="sourceLineNo">553</span>        .withReaderType(ReaderType.PREAD)<a name="line.553"></a>
-<span class="sourceLineNo">554</span>        .build();<a name="line.554"></a>
-<span class="sourceLineNo">555</span>    HFileInfo fileInfo = new HFileInfo(context, conf);<a name="line.555"></a>
-<span class="sourceLineNo">556</span>    Reader reader = createReader(context, fileInfo, cacheConf, conf);<a name="line.556"></a>
-<span class="sourceLineNo">557</span>    fileInfo.initMetaAndIndex(reader);<a name="line.557"></a>
-<span class="sourceLineNo">558</span>    return reader;<a name="line.558"></a>
-<span class="sourceLineNo">559</span>  }<a name="line.559"></a>
-<span class="sourceLineNo">560</span><a name="line.560"></a>
-<span class="sourceLineNo">561</span>  /**<a name="line.561"></a>
-<span class="sourceLineNo">562</span>   * Returns true if the specified file has a valid HFile Trailer.<a name="line.562"></a>
-<span class="sourceLineNo">563</span>   * @param fs filesystem<a name="line.563"></a>
-<span class="sourceLineNo">564</span>   * @param path Path to file to verify<a name="line.564"></a>
-<span class="sourceLineNo">565</span>   * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.565"></a>
-<span class="sourceLineNo">566</span>   * @throws IOException if failed to read from the underlying stream<a name="line.566"></a>
-<span class="sourceLineNo">567</span>   */<a name="line.567"></a>
-<span class="sourceLineNo">568</span>  public static boolean isHFileFormat(final FileSystem fs, final Path path) throws IOException {<a name="line.568"></a>
-<span class="sourceLineNo">569</span>    return isHFileFormat(fs, fs.getFileStatus(path));<a name="line.569"></a>
-<span class="sourceLineNo">570</span>  }<a name="line.570"></a>
-<span class="sourceLineNo">571</span><a name="line.571"></a>
-<span class="sourceLineNo">572</span>  /**<a name="line.572"></a>
-<span class="sourceLineNo">573</span>   * Returns true if the specified file has a valid HFile Trailer.<a name="line.573"></a>
-<span class="sourceLineNo">574</span>   * @param fs filesystem<a name="line.574"></a>
-<span class="sourceLineNo">575</span>   * @param fileStatus the file to verify<a name="line.575"></a>
-<span class="sourceLineNo">576</span>   * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.576"></a>
-<span class="sourceLineNo">577</span>   * @throws IOException if failed to read from the underlying stream<a name="line.577"></a>
-<span class="sourceLineNo">578</span>   */<a name="line.578"></a>
-<span class="sourceLineNo">579</span>  public static boolean isHFileFormat(final FileSystem fs, final FileStatus fileStatus)<a name="line.579"></a>
-<span class="sourceLineNo">580</span>      throws IOException {<a name="line.580"></a>
-<span class="sourceLineNo">581</span>    final Path path = fileStatus.getPath();<a name="line.581"></a>
-<span class="sourceLineNo">582</span>    final long size = fileStatus.getLen();<a name="line.582"></a>
-<span class="sourceLineNo">583</span>    try (FSDataInputStreamWrapper fsdis = new FSDataInputStreamWrapper(fs, path)) {<a name="line.583"></a>
-<span class="sourceLineNo">584</span>      boolean isHBaseChecksum = fsdis.shouldUseHBaseChecksum();<a name="line.584"></a>
-<span class="sourceLineNo">585</span>      assert !isHBaseChecksum; // Initially we must read with FS checksum.<a name="line.585"></a>
-<span class="sourceLineNo">586</span>      FixedFileTrailer.readFromStream(fsdis.getStream(isHBaseChecksum), size);<a name="line.586"></a>
-<span class="sourceLineNo">587</span>      return true;<a name="line.587"></a>
-<span class="sourceLineNo">588</span>    } catch (IllegalArgumentException e) {<a name="line.588"></a>
-<span class="sourceLineNo">589</span>      return false;<a name="line.589"></a>
-<span class="sourceLineNo">590</span>    }<a name="line.590"></a>
-<span class="sourceLineNo">591</span>  }<a name="line.591"></a>
-<span class="sourceLineNo">592</span><a name="line.592"></a>
-<span class="sourceLineNo">593</span>  /**<a name="line.593"></a>
-<span class="sourceLineNo">594</span>   * Get names of supported compression algorithms. The names are acceptable by<a name="line.594"></a>
-<span class="sourceLineNo">595</span>   * HFile.Writer.<a name="line.595"></a>
-<span class="sourceLineNo">596</span>   *<a name="line.596"></a>
-<span class="sourceLineNo">597</span>   * @return Array of strings, each represents a supported compression<a name="line.597"></a>
-<span class="sourceLineNo">598</span>   *         algorithm. Currently, the following compression algorithms are<a name="line.598"></a>
-<span class="sourceLineNo">599</span>   *         supported.<a name="line.599"></a>
-<span class="sourceLineNo">600</span>   *         &lt;ul&gt;<a name="line.600"></a>
-<span class="sourceLineNo">601</span>   *         &lt;li&gt;"none" - No compression.<a name="line.601"></a>
-<span class="sourceLineNo">602</span>   *         &lt;li&gt;"gz" - GZIP compression.<a name="line.602"></a>
-<span class="sourceLineNo">603</span>   *         &lt;/ul&gt;<a name="line.603"></a>
-<span class="sourceLineNo">604</span>   */<a name="line.604"></a>
-<span class="sourceLineNo">605</span>  public static String[] getSupportedCompressionAlgorithms() {<a name="line.605"></a>
-<span class="sourceLineNo">606</span>    return Compression.getSupportedAlgorithms();<a name="line.606"></a>
-<span class="sourceLineNo">607</span>  }<a name="line.607"></a>
-<span class="sourceLineNo">608</span><a name="line.608"></a>
-<span class="sourceLineNo">609</span>  // Utility methods.<a name="line.609"></a>
-<span class="sourceLineNo">610</span>  /*<a name="line.610"></a>
-<span class="sourceLineNo">611</span>   * @param l Long to convert to an int.<a name="line.611"></a>
-<span class="sourceLineNo">612</span>   * @return &lt;code&gt;l&lt;/code&gt; cast as an int.<a name="line.612"></a>
-<span class="sourceLineNo">613</span>   */<a name="line.613"></a>
-<span class="sourceLineNo">614</span>  static int longToInt(final long l) {<a name="line.614"></a>
-<span class="sourceLineNo">615</span>    // Expecting the size() of a block not exceeding 4GB. Assuming the<a name="line.615"></a>
-<span class="sourceLineNo">616</span>    // size() will wrap to negative integer if it exceeds 2GB (From tfile).<a name="line.616"></a>
-<span class="sourceLineNo">617</span>    return (int)(l &amp; 0x00000000ffffffffL);<a name="line.617"></a>
-<span class="sourceLineNo">618</span>  }<a name="line.618"></a>
-<span class="sourceLineNo">619</span><a name="line.619"></a>
-<span class="sourceLineNo">620</span>  /**<a name="line.620"></a>
-<span class="sourceLineNo">621</span>   * Returns all HFiles belonging to the given region directory. Could return an<a name="line.621"></a>
-<span class="sourceLineNo">622</span>   * empty list.<a name="line.622"></a>
-<span class="sourceLineNo">623</span>   *<a name="line.623"></a>
-<span class="sourceLineNo">624</span>   * @param fs  The file system reference.<a name="line.624"></a>
-<span class="sourceLineNo">625</span>   * @param regionDir  The region directory to scan.<a name="line.625"></a>
-<span class="sourceLineNo">626</span>   * @return The list of files found.<a name="line.626"></a>
-<span class="sourceLineNo">627</span>   * @throws IOException When scanning the files fails.<a name="line.627"></a>
-<span class="sourceLineNo">628</span>   */<a name="line.628"></a>
-<span class="sourceLineNo">629</span>  public static List&lt;Path&gt; getStoreFiles(FileSystem fs, Path regionDir)<a name="line.629"></a>
-<span class="sourceLineNo">630</span>      throws IOException {<a name="line.630"></a>
-<span class="sourceLineNo">631</span>    List&lt;Path&gt; regionHFiles = new ArrayList&lt;&gt;();<a name="line.631"></a>
-<span class="sourceLineNo">632</span>    PathFilter dirFilter = new FSUtils.DirFilter(fs);<a name="line.632"></a>
-<span class="sourceLineNo">633</span>    FileStatus[] familyDirs = fs.listStatus(regionDir, dirFilter);<a name="line.633"></a>
-<span class="sourceLineNo">634</span>    for(FileStatus dir : familyDirs) {<a name="line.634"></a>
-<span class="sourceLineNo">635</span>      FileStatus[] files = fs.listStatus(dir.getPath());<a name="line.635"></a>
-<span class="sourceLineNo">636</span>      for (FileStatus file : files) {<a name="line.636"></a>
-<span class="sourceLineNo">637</span>        if (!file.isDirectory() &amp;&amp;<a name="line.637"></a>
-<span class="sourceLineNo">638</span>            (!file.getPath().toString().contains(HConstants.HREGION_OLDLOGDIR_NAME)) &amp;&amp;<a name="line.638"></a>
-<span class="sourceLineNo">639</span>            (!file.getPath().toString().contains(HConstants.RECOVERED_EDITS_DIR))) {<a name="line.639"></a>
-<span class="sourceLineNo">640</span>          regionHFiles.add(file.getPath());<a name="line.640"></a>
-<span class="sourceLineNo">641</span>        }<a name="line.641"></a>
-<span class="sourceLineNo">642</span>      }<a name="line.642"></a>
-<span class="sourceLineNo">643</span>    }<a name="line.643"></a>
-<span class="sourceLineNo">644</span>    return regionHFiles;<a name="line.644"></a>
-<span class="sourceLineNo">645</span>  }<a name="line.645"></a>
-<span class="sourceLineNo">646</span><a name="line.646"></a>
-<span class="sourceLineNo">647</span>  /**<a name="line.647"></a>
-<span class="sourceLineNo">648</span>   * Checks the given {@link HFile} format version, and throws an exception if<a name="line.648"></a>
-<span class="sourceLineNo">649</span>   * invalid. Note that if the version number comes from an input file and has<a name="line.649"></a>
-<span class="sourceLineNo">650</span>   * not been verified, the caller needs to re-throw an {@link IOException} to<a name="line.650"></a>
-<span class="sourceLineNo">651</span>   * indicate that this is not a software error, but corrupted input.<a name="line.651"></a>
-<span class="sourceLineNo">652</span>   *<a name="line.652"></a>
-<span class="sourceLineNo">653</span>   * @param version an HFile version<a name="line.653"></a>
-<span class="sourceLineNo">654</span>   * @throws IllegalArgumentException if the version is invalid<a name="line.654"></a>
-<span class="sourceLineNo">655</span>   */<a name="line.655"></a>
-<span class="sourceLineNo">656</span>  public static void checkFormatVersion(int version)<a name="line.656"></a>
-<span class="sourceLineNo">657</span>      throws IllegalArgumentException {<a name="line.657"></a>
-<span class="sourceLineNo">658</span>    if (version &lt; MIN_FORMAT_VERSION || version &gt; MAX_FORMAT_VERSION) {<a name="line.658"></a>
-<span class="sourceLineNo">659</span>      throw new IllegalArgumentException("Invalid HFile version: " + version<a name="line.659"></a>
-<span class="sourceLineNo">660</span>          + " (expected to be " + "between " + MIN_FORMAT_VERSION + " and "<a name="line.660"></a>
-<span class="sourceLineNo">661</span>          + MAX_FORMAT_VERSION + ")");<a name="line.661"></a>
-<span class="sourceLineNo">662</span>    }<a name="line.662"></a>
-<span class="sourceLineNo">663</span>  }<a name="line.663"></a>
-<span class="sourceLineNo">664</span><a name="line.664"></a>
+<span class="sourceLineNo">508</span>      IOUtils.closeQuietly(context.getInputStreamWrapper(),<a name="line.508"></a>
+<span class="sourceLineNo">509</span>        e -&gt; LOG.warn("failed to close input stream wrapper", e));<a name="line.509"></a>
+<span class="sourceLineNo">510</span>      throw new CorruptHFileException("Problem reading HFile Trailer from file "<a name="line.510"></a>
+<span class="sourceLineNo">511</span>          + context.getFilePath(), t);<a name="line.511"></a>
+<span class="sourceLineNo">512</span>    } finally {<a name="line.512"></a>
+<span class="sourceLineNo">513</span>      context.getInputStreamWrapper().unbuffer();<a name="line.513"></a>
+<span class="sourceLineNo">514</span>    }<a name="line.514"></a>
+<span class="sourceLineNo">515</span>  }<a name="line.515"></a>
+<span class="sourceLineNo">516</span><a name="line.516"></a>
+<span class="sourceLineNo">517</span>  /**<a name="line.517"></a>
+<span class="sourceLineNo">518</span>   * Creates reader with cache configuration disabled<a name="line.518"></a>
+<span class="sourceLineNo">519</span>   * @param fs filesystem<a name="line.519"></a>
+<span class="sourceLineNo">520</span>   * @param path Path to file to read<a name="line.520"></a>
+<span class="sourceLineNo">521</span>   * @param conf Configuration<a name="line.521"></a>
+<span class="sourceLineNo">522</span>   * @return an active Reader instance<a name="line.522"></a>
+<span class="sourceLineNo">523</span>   * @throws IOException Will throw a CorruptHFileException<a name="line.523"></a>
+<span class="sourceLineNo">524</span>   *   (DoNotRetryIOException subtype) if hfile is corrupt/invalid.<a name="line.524"></a>
+<span class="sourceLineNo">525</span>   */<a name="line.525"></a>
+<span class="sourceLineNo">526</span>  public static Reader createReader(FileSystem fs, Path path, Configuration conf)<a name="line.526"></a>
+<span class="sourceLineNo">527</span>      throws IOException {<a name="line.527"></a>
+<span class="sourceLineNo">528</span>    // The primaryReplicaReader is mainly used for constructing block cache key, so if we do not use<a name="line.528"></a>
+<span class="sourceLineNo">529</span>    // block cache then it is OK to set it as any value. We use true here.<a name="line.529"></a>
+<span class="sourceLineNo">530</span>    return createReader(fs, path, CacheConfig.DISABLED, true, conf);<a name="line.530"></a>
+<span class="sourceLineNo">531</span>  }<a name="line.531"></a>
+<span class="sourceLineNo">532</span><a name="line.532"></a>
+<span class="sourceLineNo">533</span>  /**<a name="line.533"></a>
+<span class="sourceLineNo">534</span>   * @param fs filesystem<a name="line.534"></a>
+<span class="sourceLineNo">535</span>   * @param path Path to file to read<a name="line.535"></a>
+<span class="sourceLineNo">536</span>   * @param cacheConf This must not be null. @see<a name="line.536"></a>
+<span class="sourceLineNo">537</span>   *          {@link org.apache.hadoop.hbase.io.hfile.CacheConfig#CacheConfig(Configuration)}<a name="line.537"></a>
+<span class="sourceLineNo">538</span>   * @param primaryReplicaReader true if this is a reader for primary replica<a name="line.538"></a>
+<span class="sourceLineNo">539</span>   * @param conf Configuration<a name="line.539"></a>
+<span class="sourceLineNo">540</span>   * @return an active Reader instance<a name="line.540"></a>
+<span class="sourceLineNo">541</span>   * @throws IOException Will throw a CorruptHFileException (DoNotRetryIOException subtype) if hfile<a name="line.541"></a>
+<span class="sourceLineNo">542</span>   *           is corrupt/invalid.<a name="line.542"></a>
+<span class="sourceLineNo">543</span>   */<a name="line.543"></a>
+<span class="sourceLineNo">544</span>  public static Reader createReader(FileSystem fs, Path path, CacheConfig cacheConf,<a name="line.544"></a>
+<span class="sourceLineNo">545</span>      boolean primaryReplicaReader, Configuration conf) throws IOException {<a name="line.545"></a>
+<span class="sourceLineNo">546</span>    Preconditions.checkNotNull(cacheConf, "Cannot create Reader with null CacheConf");<a name="line.546"></a>
+<span class="sourceLineNo">547</span>    FSDataInputStreamWrapper stream = new FSDataInputStreamWrapper(fs, path);<a name="line.547"></a>
+<span class="sourceLineNo">548</span>    ReaderContext context = new ReaderContextBuilder()<a name="line.548"></a>
+<span class="sourceLineNo">549</span>        .withFilePath(path)<a name="line.549"></a>
+<span class="sourceLineNo">550</span>        .withInputStreamWrapper(stream)<a name="line.550"></a>
+<span class="sourceLineNo">551</span>        .withFileSize(fs.getFileStatus(path).getLen())<a name="line.551"></a>
+<span class="sourceLineNo">552</span>        .withFileSystem(stream.getHfs())<a name="line.552"></a>
+<span class="sourceLineNo">553</span>        .withPrimaryReplicaReader(primaryReplicaReader)<a name="line.553"></a>
+<span class="sourceLineNo">554</span>        .withReaderType(ReaderType.PREAD)<a name="line.554"></a>
+<span class="sourceLineNo">555</span>        .build();<a name="line.555"></a>
+<span class="sourceLineNo">556</span>    HFileInfo fileInfo = new HFileInfo(context, conf);<a name="line.556"></a>
+<span class="sourceLineNo">557</span>    Reader reader = createReader(context, fileInfo, cacheConf, conf);<a name="line.557"></a>
+<span class="sourceLineNo">558</span>    fileInfo.initMetaAndIndex(reader);<a name="line.558"></a>
+<span class="sourceLineNo">559</span>    return reader;<a name="line.559"></a>
+<span class="sourceLineNo">560</span>  }<a name="line.560"></a>
+<span class="sourceLineNo">561</span><a name="line.561"></a>
+<span class="sourceLineNo">562</span>  /**<a name="line.562"></a>
+<span class="sourceLineNo">563</span>   * Returns true if the specified file has a valid HFile Trailer.<a name="line.563"></a>
+<span class="sourceLineNo">564</span>   * @param fs filesystem<a name="line.564"></a>
+<span class="sourceLineNo">565</span>   * @param path Path to file to verify<a name="line.565"></a>
+<span class="sourceLineNo">566</span>   * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.566"></a>
+<span class="sourceLineNo">567</span>   * @throws IOException if failed to read from the underlying stream<a name="line.567"></a>
+<span class="sourceLineNo">568</span>   */<a name="line.568"></a>
+<span class="sourceLineNo">569</span>  public static boolean isHFileFormat(final FileSystem fs, final Path path) throws IOException {<a name="line.569"></a>
+<span class="sourceLineNo">570</span>    return isHFileFormat(fs, fs.getFileStatus(path));<a name="line.570"></a>
+<span class="sourceLineNo">571</span>  }<a name="line.571"></a>
+<span class="sourceLineNo">572</span><a name="line.572"></a>
+<span class="sourceLineNo">573</span>  /**<a name="line.573"></a>
+<span class="sourceLineNo">574</span>   * Returns true if the specified file has a valid HFile Trailer.<a name="line.574"></a>
+<span class="sourceLineNo">575</span>   * @param fs filesystem<a name="line.575"></a>
+<span class="sourceLineNo">576</span>   * @param fileStatus the file to verify<a name="line.576"></a>
+<span class="sourceLineNo">577</span>   * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.577"></a>
+<span class="sourceLineNo">578</span>   * @throws IOException if failed to read from the underlying stream<a name="line.578"></a>
+<span class="sourceLineNo">579</span>   */<a name="line.579"></a>
+<span class="sourceLineNo">580</span>  public static boolean isHFileFormat(final FileSystem fs, final FileStatus fileStatus)<a name="line.580"></a>
+<span class="sourceLineNo">581</span>      throws IOException {<a name="line.581"></a>
+<span class="sourceLineNo">582</span>    final Path path = fileStatus.getPath();<a name="line.582"></a>
+<span class="sourceLineNo">583</span>    final long size = fileStatus.getLen();<a name="line.583"></a>
+<span class="sourceLineNo">584</span>    try (FSDataInputStreamWrapper fsdis = new FSDataInputStreamWrapper(fs, path)) {<a name="line.584"></a>
+<span class="sourceLineNo">585</span>      boolean isHBaseChecksum = fsdis.shouldUseHBaseChecksum();<a name="line.585"></a>
+<span class="sourceLineNo">586</span>      assert !isHBaseChecksum; // Initially we must read with FS checksum.<a name="line.586"></a>
+<span class="sourceLineNo">587</span>      FixedFileTrailer.readFromStream(fsdis.getStream(isHBaseChecksum), size);<a name="line.587"></a>
+<span class="sourceLineNo">588</span>      return true;<a name="line.588"></a>
+<span class="sourceLineNo">589</span>    } catch (IllegalArgumentException e) {<a name="line.589"></a>
+<span class="sourceLineNo">590</span>      return false;<a name="line.590"></a>
+<span class="sourceLineNo">591</span>    }<a name="line.591"></a>
+<span class="sourceLineNo">592</span>  }<a name="line.592"></a>
+<span class="sourceLineNo">593</span><a name="line.593"></a>
+<span class="sourceLineNo">594</span>  /**<a name="line.594"></a>
+<span class="sourceLineNo">595</span>   * Get names of supported compression algorithms. The names are acceptable by<a name="line.595"></a>
+<span class="sourceLineNo">596</span>   * HFile.Writer.<a name="line.596"></a>
+<span class="sourceLineNo">597</span>   *<a name="line.597"></a>
+<span class="sourceLineNo">598</span>   * @return Array of strings, each represents a supported compression<a name="line.598"></a>
+<span class="sourceLineNo">599</span>   *         algorithm. Currently, the following compression algorithms are<a name="line.599"></a>
+<span class="sourceLineNo">600</span>   *         supported.<a name="line.600"></a>
+<span class="sourceLineNo">601</span>   *         &lt;ul&gt;<a name="line.601"></a>
+<span class="sourceLineNo">602</span>   *         &lt;li&gt;"none" - No compression.<a name="line.602"></a>
+<span class="sourceLineNo">603</span>   *         &lt;li&gt;"gz" - GZIP compression.<a name="line.603"></a>
+<span class="sourceLineNo">604</span>   *         &lt;/ul&gt;<a name="line.604"></a>
+<span class="sourceLineNo">605</span>   */<a name="line.605"></a>
+<span class="sourceLineNo">606</span>  public static String[] getSupportedCompressionAlgorithms() {<a name="line.606"></a>
+<span class="sourceLineNo">607</span>    return Compression.getSupportedAlgorithms();<a name="line.607"></a>
+<span class="sourceLineNo">608</span>  }<a name="line.608"></a>
+<span class="sourceLineNo">609</span><a name="line.609"></a>
+<span class="sourceLineNo">610</span>  // Utility methods.<a name="line.610"></a>
+<span class="sourceLineNo">611</span>  /*<a name="line.611"></a>
+<span class="sourceLineNo">612</span>   * @param l Long to convert to an int.<a name="line.612"></a>
+<span class="sourceLineNo">613</span>   * @return &lt;code&gt;l&lt;/code&gt; cast as an int.<a name="line.613"></a>
+<span class="sourceLineNo">614</span>   */<a name="line.614"></a>
+<span class="sourceLineNo">615</span>  static int longToInt(final long l) {<a name="line.615"></a>
+<span class="sourceLineNo">616</span>    // Expecting the size() of a block not exceeding 4GB. Assuming the<a name="line.616"></a>
+<span class="sourceLineNo">617</span>    // size() will wrap to negative integer if it exceeds 2GB (From tfile).<a name="line.617"></a>
+<span class="sourceLineNo">618</span>    return (int)(l &amp; 0x00000000ffffffffL);<a name="line.618"></a>
+<span class="sourceLineNo">619</span>  }<a name="line.619"></a>
+<span class="sourceLineNo">620</span><a name="line.620"></a>
+<span class="sourceLineNo">621</span>  /**<a name="line.621"></a>
+<span class="sourceLineNo">622</span>   * Returns all HFiles belonging to the given region directory. Could return an<a name="line.622"></a>
+<span class="sourceLineNo">623</span>   * empty list.<a name="line.623"></a>
+<span class="sourceLineNo">624</span>   *<a name="line.624"></a>
+<span class="sourceLineNo">625</span>   * @param fs  The file system reference.<a name="line.625"></a>
+<span class="sourceLineNo">626</span>   * @param regionDir  The region directory to scan.<a name="line.626"></a>
+<span class="sourceLineNo">627</span>   * @return The list of files found.<a name="line.627"></a>
+<span class="sourceLineNo">628</span>   * @throws IOException When scanning the files fails.<a name="line.628"></a>
+<span class="sourceLineNo">629</span>   */<a name="line.629"></a>
+<span class="sourceLineNo">630</span>  public static List&lt;Path&gt; getStoreFiles(FileSystem fs, Path regionDir)<a name="line.630"></a>
+<span class="sourceLineNo">631</span>      throws IOException {<a name="line.631"></a>
+<span class="sourceLineNo">632</span>    List&lt;Path&gt; regionHFiles = new ArrayList&lt;&gt;();<a name="line.632"></a>
+<span class="sourceLineNo">633</span>    PathFilter dirFilter = new FSUtils.DirFilter(fs);<a name="line.633"></a>
+<span class="sourceLineNo">634</span>    FileStatus[] familyDirs = fs.listStatus(regionDir, dirFilter);<a name="line.634"></a>
+<span class="sourceLineNo">635</span>    for(FileStatus dir : familyDirs) {<a name="line.635"></a>
+<span class="sourceLineNo">636</span>      FileStatus[] files = fs.listStatus(dir.getPath());<a name="line.636"></a>
+<span class="sourceLineNo">637</span>      for (FileStatus file : files) {<a name="line.637"></a>
+<span class="sourceLineNo">638</span>        if (!file.isDirectory() &amp;&amp;<a name="line.638"></a>
+<span class="sourceLineNo">639</span>            (!file.getPath().toString().contains(HConstants.HREGION_OLDLOGDIR_NAME)) &amp;&amp;<a name="line.639"></a>
+<span class="sourceLineNo">640</span>            (!file.getPath().toString().contains(HConstants.RECOVERED_EDITS_DIR))) {<a name="line.640"></a>
+<span class="sourceLineNo">641</span>          regionHFiles.add(file.getPath());<a name="line.641"></a>
+<span class="sourceLineNo">642</span>        }<a name="line.642"></a>
+<span class="sourceLineNo">643</span>      }<a name="line.643"></a>
+<span class="sourceLineNo">644</span>    }<a name="line.644"></a>
+<span class="sourceLineNo">645</span>    return regionHFiles;<a name="line.645"></a>
+<span class="sourceLineNo">646</span>  }<a name="line.646"></a>
+<span class="sourceLineNo">647</span><a name="line.647"></a>
+<span class="sourceLineNo">648</span>  /**<a name="line.648"></a>
+<span class="sourceLineNo">649</span>   * Checks the given {@link HFile} format version, and throws an exception if<a name="line.649"></a>
+<span class="sourceLineNo">650</span>   * invalid. Note that if the version number comes from an input file and has<a name="line.650"></a>
+<span class="sourceLineNo">651</span>   * not been verified, the caller needs to re-throw an {@link IOException} to<a name="line.651"></a>
+<span class="sourceLineNo">652</span>   * indicate that this is not a software error, but corrupted input.<a name="line.652"></a>
+<span class="sourceLineNo">653</span>   *<a name="line.653"></a>
+<span class="sourceLineNo">654</span>   * @param version an HFile version<a name="line.654"></a>
+<span class="sourceLineNo">655</span>   * @throws IllegalArgumentException if the version is invalid<a name="line.655"></a>
+<span class="sourceLineNo">656</span>   */<a name="line.656"></a>
+<span class="sourceLineNo">657</span>  public static void checkFormatVersion(int version)<a name="line.657"></a>
+<span class="sourceLineNo">658</span>      throws IllegalArgumentException {<a name="line.658"></a>
+<span class="sourceLineNo">659</span>    if (version &lt; MIN_FORMAT_VERSION || version &gt; MAX_FORMAT_VERSION) {<a name="line.659"></a>
+<span class="sourceLineNo">660</span>      throw new IllegalArgumentException("Invalid HFile version: " + version<a name="line.660"></a>
+<span class="sourceLineNo">661</span>          + " (expected to be " + "between " + MIN_FORMAT_VERSION + " and "<a name="line.661"></a>
+<span class="sourceLineNo">662</span>          + MAX_FORMAT_VERSION + ")");<a name="line.662"></a>
+<span class="sourceLineNo">663</span>    }<a name="line.663"></a>
+<span class="sourceLineNo">664</span>  }<a name="line.664"></a>
 <span class="sourceLineNo">665</span><a name="line.665"></a>
-<span class="sourceLineNo">666</span>  public static void checkHFileVersion(final Configuration c) {<a name="line.666"></a>
-<span class="sourceLineNo">667</span>    int version = c.getInt(FORMAT_VERSION_KEY, MAX_FORMAT_VERSION);<a name="line.667"></a>
-<span class="sourceLineNo">668</span>    if (version &lt; MAX_FORMAT_VERSION || version &gt; MAX_FORMAT_VERSION) {<a name="line.668"></a>
-<span class="sourceLineNo">669</span>      throw new IllegalArgumentException("The setting for " + FORMAT_VERSION_KEY +<a name="line.669"></a>
-<span class="sourceLineNo">670</span>        " (in your hbase-*.xml files) is " + version + " which does not match " +<a name="line.670"></a>
-<span class="sourceLineNo">671</span>        MAX_FORMAT_VERSION +<a name="line.671"></a>
-<span class="sourceLineNo">672</span>        "; are you running with a configuration from an older or newer hbase install (an " +<a name="line.672"></a>
-<span class="sourceLineNo">673</span>        "incompatible hbase-default.xml or hbase-site.xml on your CLASSPATH)?");<a name="line.673"></a>
-<span class="sourceLineNo">674</span>    }<a name="line.674"></a>
-<span class="sourceLineNo">675</span>  }<a name="line.675"></a>
-<span class="sourceLineNo">676</span><a name="line.676"></a>
-<span class="sourceLineNo">677</span>  public static void main(String[] args) throws Exception {<a name="line.677"></a>
-<span class="sourceLineNo">678</span>    // delegate to preserve old behavior<a name="line.678"></a>
-<span class="sourceLineNo">679</span>    HFilePrettyPrinter.main(args);<a name="line.679"></a>
-<span class="sourceLineNo">680</span>  }<a name="line.680"></a>
-<span class="sourceLineNo">681</span>}<a name="line.681"></a>
+<span class="sourceLineNo">666</span><a name="line.666"></a>
+<span class="sourceLineNo">667</span>  public static void checkHFileVersion(final Configuration c) {<a name="line.667"></a>
+<span class="sourceLineNo">668</span>    int version = c.getInt(FORMAT_VERSION_KEY, MAX_FORMAT_VERSION);<a name="line.668"></a>
+<span class="sourceLineNo">669</span>    if (version &lt; MAX_FORMAT_VERSION || version &gt; MAX_FORMAT_VERSION) {<a name="line.669"></a>
+<span class="sourceLineNo">670</span>      throw new IllegalArgumentException("The setting for " + FORMAT_VERSION_KEY +<a name="line.670"></a>
+<span class="sourceLineNo">671</span>        " (in your hbase-*.xml files) is " + version + " which does not match " +<a name="line.671"></a>
+<span class="sourceLineNo">672</span>        MAX_FORMAT_VERSION +<a name="line.672"></a>
+<span class="sourceLineNo">673</span>        "; are you running with a configuration from an older or newer hbase install (an " +<a name="line.673"></a>
+<span class="sourceLineNo">674</span>        "incompatible hbase-default.xml or hbase-site.xml on your CLASSPATH)?");<a name="line.674"></a>
+<span class="sourceLineNo">675</span>    }<a name="line.675"></a>
+<span class="sourceLineNo">676</span>  }<a name="line.676"></a>
+<span class="sourceLineNo">677</span><a name="line.677"></a>
+<span class="sourceLineNo">678</span>  public static void main(String[] args) throws Exception {<a name="line.678"></a>
+<span class="sourceLineNo">679</span>    // delegate to preserve old behavior<a name="line.679"></a>
+<span class="sourceLineNo">680</span>    HFilePrettyPrinter.main(args);<a name="line.680"></a>
+<span class="sourceLineNo">681</span>  }<a name="line.681"></a>
+<span class="sourceLineNo">682</span>}<a name="line.682"></a>
 
 
 
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.Reader.html b/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.Reader.html
index a82ba7f..2a91d20 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.Reader.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.Reader.html
@@ -513,180 +513,181 @@
 <span class="sourceLineNo">505</span>          throw new IllegalArgumentException("Invalid HFile version " + trailer.getMajorVersion());<a name="line.505"></a>
 <span class="sourceLineNo">506</span>      }<a name="line.506"></a>
 <span class="sourceLineNo">507</span>    } catch (Throwable t) {<a name="line.507"></a>
-<span class="sourceLineNo">508</span>      IOUtils.closeQuietly(context.getInputStreamWrapper());<a name="line.508"></a>
-<span class="sourceLineNo">509</span>      throw new CorruptHFileException("Problem reading HFile Trailer from file "<a name="line.509"></a>
-<span class="sourceLineNo">510</span>          + context.getFilePath(), t);<a name="line.510"></a>
-<span class="sourceLineNo">511</span>    } finally {<a name="line.511"></a>
-<span class="sourceLineNo">512</span>      context.getInputStreamWrapper().unbuffer();<a name="line.512"></a>
-<span class="sourceLineNo">513</span>    }<a name="line.513"></a>
-<span class="sourceLineNo">514</span>  }<a name="line.514"></a>
-<span class="sourceLineNo">515</span><a name="line.515"></a>
-<span class="sourceLineNo">516</span>  /**<a name="line.516"></a>
-<span class="sourceLineNo">517</span>   * Creates reader with cache configuration disabled<a name="line.517"></a>
-<span class="sourceLineNo">518</span>   * @param fs filesystem<a name="line.518"></a>
-<span class="sourceLineNo">519</span>   * @param path Path to file to read<a name="line.519"></a>
-<span class="sourceLineNo">520</span>   * @param conf Configuration<a name="line.520"></a>
-<span class="sourceLineNo">521</span>   * @return an active Reader instance<a name="line.521"></a>
-<span class="sourceLineNo">522</span>   * @throws IOException Will throw a CorruptHFileException<a name="line.522"></a>
-<span class="sourceLineNo">523</span>   *   (DoNotRetryIOException subtype) if hfile is corrupt/invalid.<a name="line.523"></a>
-<span class="sourceLineNo">524</span>   */<a name="line.524"></a>
-<span class="sourceLineNo">525</span>  public static Reader createReader(FileSystem fs, Path path, Configuration conf)<a name="line.525"></a>
-<span class="sourceLineNo">526</span>      throws IOException {<a name="line.526"></a>
-<span class="sourceLineNo">527</span>    // The primaryReplicaReader is mainly used for constructing block cache key, so if we do not use<a name="line.527"></a>
-<span class="sourceLineNo">528</span>    // block cache then it is OK to set it as any value. We use true here.<a name="line.528"></a>
-<span class="sourceLineNo">529</span>    return createReader(fs, path, CacheConfig.DISABLED, true, conf);<a name="line.529"></a>
-<span class="sourceLineNo">530</span>  }<a name="line.530"></a>
-<span class="sourceLineNo">531</span><a name="line.531"></a>
-<span class="sourceLineNo">532</span>  /**<a name="line.532"></a>
-<span class="sourceLineNo">533</span>   * @param fs filesystem<a name="line.533"></a>
-<span class="sourceLineNo">534</span>   * @param path Path to file to read<a name="line.534"></a>
-<span class="sourceLineNo">535</span>   * @param cacheConf This must not be null. @see<a name="line.535"></a>
-<span class="sourceLineNo">536</span>   *          {@link org.apache.hadoop.hbase.io.hfile.CacheConfig#CacheConfig(Configuration)}<a name="line.536"></a>
-<span class="sourceLineNo">537</span>   * @param primaryReplicaReader true if this is a reader for primary replica<a name="line.537"></a>
-<span class="sourceLineNo">538</span>   * @param conf Configuration<a name="line.538"></a>
-<span class="sourceLineNo">539</span>   * @return an active Reader instance<a name="line.539"></a>
-<span class="sourceLineNo">540</span>   * @throws IOException Will throw a CorruptHFileException (DoNotRetryIOException subtype) if hfile<a name="line.540"></a>
-<span class="sourceLineNo">541</span>   *           is corrupt/invalid.<a name="line.541"></a>
-<span class="sourceLineNo">542</span>   */<a name="line.542"></a>
-<span class="sourceLineNo">543</span>  public static Reader createReader(FileSystem fs, Path path, CacheConfig cacheConf,<a name="line.543"></a>
-<span class="sourceLineNo">544</span>      boolean primaryReplicaReader, Configuration conf) throws IOException {<a name="line.544"></a>
-<span class="sourceLineNo">545</span>    Preconditions.checkNotNull(cacheConf, "Cannot create Reader with null CacheConf");<a name="line.545"></a>
-<span class="sourceLineNo">546</span>    FSDataInputStreamWrapper stream = new FSDataInputStreamWrapper(fs, path);<a name="line.546"></a>
-<span class="sourceLineNo">547</span>    ReaderContext context = new ReaderContextBuilder()<a name="line.547"></a>
-<span class="sourceLineNo">548</span>        .withFilePath(path)<a name="line.548"></a>
-<span class="sourceLineNo">549</span>        .withInputStreamWrapper(stream)<a name="line.549"></a>
-<span class="sourceLineNo">550</span>        .withFileSize(fs.getFileStatus(path).getLen())<a name="line.550"></a>
-<span class="sourceLineNo">551</span>        .withFileSystem(stream.getHfs())<a name="line.551"></a>
-<span class="sourceLineNo">552</span>        .withPrimaryReplicaReader(primaryReplicaReader)<a name="line.552"></a>
-<span class="sourceLineNo">553</span>        .withReaderType(ReaderType.PREAD)<a name="line.553"></a>
-<span class="sourceLineNo">554</span>        .build();<a name="line.554"></a>
-<span class="sourceLineNo">555</span>    HFileInfo fileInfo = new HFileInfo(context, conf);<a name="line.555"></a>
-<span class="sourceLineNo">556</span>    Reader reader = createReader(context, fileInfo, cacheConf, conf);<a name="line.556"></a>
-<span class="sourceLineNo">557</span>    fileInfo.initMetaAndIndex(reader);<a name="line.557"></a>
-<span class="sourceLineNo">558</span>    return reader;<a name="line.558"></a>
-<span class="sourceLineNo">559</span>  }<a name="line.559"></a>
-<span class="sourceLineNo">560</span><a name="line.560"></a>
-<span class="sourceLineNo">561</span>  /**<a name="line.561"></a>
-<span class="sourceLineNo">562</span>   * Returns true if the specified file has a valid HFile Trailer.<a name="line.562"></a>
-<span class="sourceLineNo">563</span>   * @param fs filesystem<a name="line.563"></a>
-<span class="sourceLineNo">564</span>   * @param path Path to file to verify<a name="line.564"></a>
-<span class="sourceLineNo">565</span>   * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.565"></a>
-<span class="sourceLineNo">566</span>   * @throws IOException if failed to read from the underlying stream<a name="line.566"></a>
-<span class="sourceLineNo">567</span>   */<a name="line.567"></a>
-<span class="sourceLineNo">568</span>  public static boolean isHFileFormat(final FileSystem fs, final Path path) throws IOException {<a name="line.568"></a>
-<span class="sourceLineNo">569</span>    return isHFileFormat(fs, fs.getFileStatus(path));<a name="line.569"></a>
-<span class="sourceLineNo">570</span>  }<a name="line.570"></a>
-<span class="sourceLineNo">571</span><a name="line.571"></a>
-<span class="sourceLineNo">572</span>  /**<a name="line.572"></a>
-<span class="sourceLineNo">573</span>   * Returns true if the specified file has a valid HFile Trailer.<a name="line.573"></a>
-<span class="sourceLineNo">574</span>   * @param fs filesystem<a name="line.574"></a>
-<span class="sourceLineNo">575</span>   * @param fileStatus the file to verify<a name="line.575"></a>
-<span class="sourceLineNo">576</span>   * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.576"></a>
-<span class="sourceLineNo">577</span>   * @throws IOException if failed to read from the underlying stream<a name="line.577"></a>
-<span class="sourceLineNo">578</span>   */<a name="line.578"></a>
-<span class="sourceLineNo">579</span>  public static boolean isHFileFormat(final FileSystem fs, final FileStatus fileStatus)<a name="line.579"></a>
-<span class="sourceLineNo">580</span>      throws IOException {<a name="line.580"></a>
-<span class="sourceLineNo">581</span>    final Path path = fileStatus.getPath();<a name="line.581"></a>
-<span class="sourceLineNo">582</span>    final long size = fileStatus.getLen();<a name="line.582"></a>
-<span class="sourceLineNo">583</span>    try (FSDataInputStreamWrapper fsdis = new FSDataInputStreamWrapper(fs, path)) {<a name="line.583"></a>
-<span class="sourceLineNo">584</span>      boolean isHBaseChecksum = fsdis.shouldUseHBaseChecksum();<a name="line.584"></a>
-<span class="sourceLineNo">585</span>      assert !isHBaseChecksum; // Initially we must read with FS checksum.<a name="line.585"></a>
-<span class="sourceLineNo">586</span>      FixedFileTrailer.readFromStream(fsdis.getStream(isHBaseChecksum), size);<a name="line.586"></a>
-<span class="sourceLineNo">587</span>      return true;<a name="line.587"></a>
-<span class="sourceLineNo">588</span>    } catch (IllegalArgumentException e) {<a name="line.588"></a>
-<span class="sourceLineNo">589</span>      return false;<a name="line.589"></a>
-<span class="sourceLineNo">590</span>    }<a name="line.590"></a>
-<span class="sourceLineNo">591</span>  }<a name="line.591"></a>
-<span class="sourceLineNo">592</span><a name="line.592"></a>
-<span class="sourceLineNo">593</span>  /**<a name="line.593"></a>
-<span class="sourceLineNo">594</span>   * Get names of supported compression algorithms. The names are acceptable by<a name="line.594"></a>
-<span class="sourceLineNo">595</span>   * HFile.Writer.<a name="line.595"></a>
-<span class="sourceLineNo">596</span>   *<a name="line.596"></a>
-<span class="sourceLineNo">597</span>   * @return Array of strings, each represents a supported compression<a name="line.597"></a>
-<span class="sourceLineNo">598</span>   *         algorithm. Currently, the following compression algorithms are<a name="line.598"></a>
-<span class="sourceLineNo">599</span>   *         supported.<a name="line.599"></a>
-<span class="sourceLineNo">600</span>   *         &lt;ul&gt;<a name="line.600"></a>
-<span class="sourceLineNo">601</span>   *         &lt;li&gt;"none" - No compression.<a name="line.601"></a>
-<span class="sourceLineNo">602</span>   *         &lt;li&gt;"gz" - GZIP compression.<a name="line.602"></a>
-<span class="sourceLineNo">603</span>   *         &lt;/ul&gt;<a name="line.603"></a>
-<span class="sourceLineNo">604</span>   */<a name="line.604"></a>
-<span class="sourceLineNo">605</span>  public static String[] getSupportedCompressionAlgorithms() {<a name="line.605"></a>
-<span class="sourceLineNo">606</span>    return Compression.getSupportedAlgorithms();<a name="line.606"></a>
-<span class="sourceLineNo">607</span>  }<a name="line.607"></a>
-<span class="sourceLineNo">608</span><a name="line.608"></a>
-<span class="sourceLineNo">609</span>  // Utility methods.<a name="line.609"></a>
-<span class="sourceLineNo">610</span>  /*<a name="line.610"></a>
-<span class="sourceLineNo">611</span>   * @param l Long to convert to an int.<a name="line.611"></a>
-<span class="sourceLineNo">612</span>   * @return &lt;code&gt;l&lt;/code&gt; cast as an int.<a name="line.612"></a>
-<span class="sourceLineNo">613</span>   */<a name="line.613"></a>
-<span class="sourceLineNo">614</span>  static int longToInt(final long l) {<a name="line.614"></a>
-<span class="sourceLineNo">615</span>    // Expecting the size() of a block not exceeding 4GB. Assuming the<a name="line.615"></a>
-<span class="sourceLineNo">616</span>    // size() will wrap to negative integer if it exceeds 2GB (From tfile).<a name="line.616"></a>
-<span class="sourceLineNo">617</span>    return (int)(l &amp; 0x00000000ffffffffL);<a name="line.617"></a>
-<span class="sourceLineNo">618</span>  }<a name="line.618"></a>
-<span class="sourceLineNo">619</span><a name="line.619"></a>
-<span class="sourceLineNo">620</span>  /**<a name="line.620"></a>
-<span class="sourceLineNo">621</span>   * Returns all HFiles belonging to the given region directory. Could return an<a name="line.621"></a>
-<span class="sourceLineNo">622</span>   * empty list.<a name="line.622"></a>
-<span class="sourceLineNo">623</span>   *<a name="line.623"></a>
-<span class="sourceLineNo">624</span>   * @param fs  The file system reference.<a name="line.624"></a>
-<span class="sourceLineNo">625</span>   * @param regionDir  The region directory to scan.<a name="line.625"></a>
-<span class="sourceLineNo">626</span>   * @return The list of files found.<a name="line.626"></a>
-<span class="sourceLineNo">627</span>   * @throws IOException When scanning the files fails.<a name="line.627"></a>
-<span class="sourceLineNo">628</span>   */<a name="line.628"></a>
-<span class="sourceLineNo">629</span>  public static List&lt;Path&gt; getStoreFiles(FileSystem fs, Path regionDir)<a name="line.629"></a>
-<span class="sourceLineNo">630</span>      throws IOException {<a name="line.630"></a>
-<span class="sourceLineNo">631</span>    List&lt;Path&gt; regionHFiles = new ArrayList&lt;&gt;();<a name="line.631"></a>
-<span class="sourceLineNo">632</span>    PathFilter dirFilter = new FSUtils.DirFilter(fs);<a name="line.632"></a>
-<span class="sourceLineNo">633</span>    FileStatus[] familyDirs = fs.listStatus(regionDir, dirFilter);<a name="line.633"></a>
-<span class="sourceLineNo">634</span>    for(FileStatus dir : familyDirs) {<a name="line.634"></a>
-<span class="sourceLineNo">635</span>      FileStatus[] files = fs.listStatus(dir.getPath());<a name="line.635"></a>
-<span class="sourceLineNo">636</span>      for (FileStatus file : files) {<a name="line.636"></a>
-<span class="sourceLineNo">637</span>        if (!file.isDirectory() &amp;&amp;<a name="line.637"></a>
-<span class="sourceLineNo">638</span>            (!file.getPath().toString().contains(HConstants.HREGION_OLDLOGDIR_NAME)) &amp;&amp;<a name="line.638"></a>
-<span class="sourceLineNo">639</span>            (!file.getPath().toString().contains(HConstants.RECOVERED_EDITS_DIR))) {<a name="line.639"></a>
-<span class="sourceLineNo">640</span>          regionHFiles.add(file.getPath());<a name="line.640"></a>
-<span class="sourceLineNo">641</span>        }<a name="line.641"></a>
-<span class="sourceLineNo">642</span>      }<a name="line.642"></a>
-<span class="sourceLineNo">643</span>    }<a name="line.643"></a>
-<span class="sourceLineNo">644</span>    return regionHFiles;<a name="line.644"></a>
-<span class="sourceLineNo">645</span>  }<a name="line.645"></a>
-<span class="sourceLineNo">646</span><a name="line.646"></a>
-<span class="sourceLineNo">647</span>  /**<a name="line.647"></a>
-<span class="sourceLineNo">648</span>   * Checks the given {@link HFile} format version, and throws an exception if<a name="line.648"></a>
-<span class="sourceLineNo">649</span>   * invalid. Note that if the version number comes from an input file and has<a name="line.649"></a>
-<span class="sourceLineNo">650</span>   * not been verified, the caller needs to re-throw an {@link IOException} to<a name="line.650"></a>
-<span class="sourceLineNo">651</span>   * indicate that this is not a software error, but corrupted input.<a name="line.651"></a>
-<span class="sourceLineNo">652</span>   *<a name="line.652"></a>
-<span class="sourceLineNo">653</span>   * @param version an HFile version<a name="line.653"></a>
-<span class="sourceLineNo">654</span>   * @throws IllegalArgumentException if the version is invalid<a name="line.654"></a>
-<span class="sourceLineNo">655</span>   */<a name="line.655"></a>
-<span class="sourceLineNo">656</span>  public static void checkFormatVersion(int version)<a name="line.656"></a>
-<span class="sourceLineNo">657</span>      throws IllegalArgumentException {<a name="line.657"></a>
-<span class="sourceLineNo">658</span>    if (version &lt; MIN_FORMAT_VERSION || version &gt; MAX_FORMAT_VERSION) {<a name="line.658"></a>
-<span class="sourceLineNo">659</span>      throw new IllegalArgumentException("Invalid HFile version: " + version<a name="line.659"></a>
-<span class="sourceLineNo">660</span>          + " (expected to be " + "between " + MIN_FORMAT_VERSION + " and "<a name="line.660"></a>
-<span class="sourceLineNo">661</span>          + MAX_FORMAT_VERSION + ")");<a name="line.661"></a>
-<span class="sourceLineNo">662</span>    }<a name="line.662"></a>
-<span class="sourceLineNo">663</span>  }<a name="line.663"></a>
-<span class="sourceLineNo">664</span><a name="line.664"></a>
+<span class="sourceLineNo">508</span>      IOUtils.closeQuietly(context.getInputStreamWrapper(),<a name="line.508"></a>
+<span class="sourceLineNo">509</span>        e -&gt; LOG.warn("failed to close input stream wrapper", e));<a name="line.509"></a>
+<span class="sourceLineNo">510</span>      throw new CorruptHFileException("Problem reading HFile Trailer from file "<a name="line.510"></a>
+<span class="sourceLineNo">511</span>          + context.getFilePath(), t);<a name="line.511"></a>
+<span class="sourceLineNo">512</span>    } finally {<a name="line.512"></a>
+<span class="sourceLineNo">513</span>      context.getInputStreamWrapper().unbuffer();<a name="line.513"></a>
+<span class="sourceLineNo">514</span>    }<a name="line.514"></a>
+<span class="sourceLineNo">515</span>  }<a name="line.515"></a>
+<span class="sourceLineNo">516</span><a name="line.516"></a>
+<span class="sourceLineNo">517</span>  /**<a name="line.517"></a>
+<span class="sourceLineNo">518</span>   * Creates reader with cache configuration disabled<a name="line.518"></a>
+<span class="sourceLineNo">519</span>   * @param fs filesystem<a name="line.519"></a>
+<span class="sourceLineNo">520</span>   * @param path Path to file to read<a name="line.520"></a>
+<span class="sourceLineNo">521</span>   * @param conf Configuration<a name="line.521"></a>
+<span class="sourceLineNo">522</span>   * @return an active Reader instance<a name="line.522"></a>
+<span class="sourceLineNo">523</span>   * @throws IOException Will throw a CorruptHFileException<a name="line.523"></a>
+<span class="sourceLineNo">524</span>   *   (DoNotRetryIOException subtype) if hfile is corrupt/invalid.<a name="line.524"></a>
+<span class="sourceLineNo">525</span>   */<a name="line.525"></a>
+<span class="sourceLineNo">526</span>  public static Reader createReader(FileSystem fs, Path path, Configuration conf)<a name="line.526"></a>
+<span class="sourceLineNo">527</span>      throws IOException {<a name="line.527"></a>
+<span class="sourceLineNo">528</span>    // The primaryReplicaReader is mainly used for constructing block cache key, so if we do not use<a name="line.528"></a>
+<span class="sourceLineNo">529</span>    // block cache then it is OK to set it as any value. We use true here.<a name="line.529"></a>
+<span class="sourceLineNo">530</span>    return createReader(fs, path, CacheConfig.DISABLED, true, conf);<a name="line.530"></a>
+<span class="sourceLineNo">531</span>  }<a name="line.531"></a>
+<span class="sourceLineNo">532</span><a name="line.532"></a>
+<span class="sourceLineNo">533</span>  /**<a name="line.533"></a>
+<span class="sourceLineNo">534</span>   * @param fs filesystem<a name="line.534"></a>
+<span class="sourceLineNo">535</span>   * @param path Path to file to read<a name="line.535"></a>
+<span class="sourceLineNo">536</span>   * @param cacheConf This must not be null. @see<a name="line.536"></a>
+<span class="sourceLineNo">537</span>   *          {@link org.apache.hadoop.hbase.io.hfile.CacheConfig#CacheConfig(Configuration)}<a name="line.537"></a>
+<span class="sourceLineNo">538</span>   * @param primaryReplicaReader true if this is a reader for primary replica<a name="line.538"></a>
+<span class="sourceLineNo">539</span>   * @param conf Configuration<a name="line.539"></a>
+<span class="sourceLineNo">540</span>   * @return an active Reader instance<a name="line.540"></a>
+<span class="sourceLineNo">541</span>   * @throws IOException Will throw a CorruptHFileException (DoNotRetryIOException subtype) if hfile<a name="line.541"></a>
+<span class="sourceLineNo">542</span>   *           is corrupt/invalid.<a name="line.542"></a>
+<span class="sourceLineNo">543</span>   */<a name="line.543"></a>
+<span class="sourceLineNo">544</span>  public static Reader createReader(FileSystem fs, Path path, CacheConfig cacheConf,<a name="line.544"></a>
+<span class="sourceLineNo">545</span>      boolean primaryReplicaReader, Configuration conf) throws IOException {<a name="line.545"></a>
+<span class="sourceLineNo">546</span>    Preconditions.checkNotNull(cacheConf, "Cannot create Reader with null CacheConf");<a name="line.546"></a>
+<span class="sourceLineNo">547</span>    FSDataInputStreamWrapper stream = new FSDataInputStreamWrapper(fs, path);<a name="line.547"></a>
+<span class="sourceLineNo">548</span>    ReaderContext context = new ReaderContextBuilder()<a name="line.548"></a>
+<span class="sourceLineNo">549</span>        .withFilePath(path)<a name="line.549"></a>
+<span class="sourceLineNo">550</span>        .withInputStreamWrapper(stream)<a name="line.550"></a>
+<span class="sourceLineNo">551</span>        .withFileSize(fs.getFileStatus(path).getLen())<a name="line.551"></a>
+<span class="sourceLineNo">552</span>        .withFileSystem(stream.getHfs())<a name="line.552"></a>
+<span class="sourceLineNo">553</span>        .withPrimaryReplicaReader(primaryReplicaReader)<a name="line.553"></a>
+<span class="sourceLineNo">554</span>        .withReaderType(ReaderType.PREAD)<a name="line.554"></a>
+<span class="sourceLineNo">555</span>        .build();<a name="line.555"></a>
+<span class="sourceLineNo">556</span>    HFileInfo fileInfo = new HFileInfo(context, conf);<a name="line.556"></a>
+<span class="sourceLineNo">557</span>    Reader reader = createReader(context, fileInfo, cacheConf, conf);<a name="line.557"></a>
+<span class="sourceLineNo">558</span>    fileInfo.initMetaAndIndex(reader);<a name="line.558"></a>
+<span class="sourceLineNo">559</span>    return reader;<a name="line.559"></a>
+<span class="sourceLineNo">560</span>  }<a name="line.560"></a>
+<span class="sourceLineNo">561</span><a name="line.561"></a>
+<span class="sourceLineNo">562</span>  /**<a name="line.562"></a>
+<span class="sourceLineNo">563</span>   * Returns true if the specified file has a valid HFile Trailer.<a name="line.563"></a>
+<span class="sourceLineNo">564</span>   * @param fs filesystem<a name="line.564"></a>
+<span class="sourceLineNo">565</span>   * @param path Path to file to verify<a name="line.565"></a>
+<span class="sourceLineNo">566</span>   * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.566"></a>
+<span class="sourceLineNo">567</span>   * @throws IOException if failed to read from the underlying stream<a name="line.567"></a>
+<span class="sourceLineNo">568</span>   */<a name="line.568"></a>
+<span class="sourceLineNo">569</span>  public static boolean isHFileFormat(final FileSystem fs, final Path path) throws IOException {<a name="line.569"></a>
+<span class="sourceLineNo">570</span>    return isHFileFormat(fs, fs.getFileStatus(path));<a name="line.570"></a>
+<span class="sourceLineNo">571</span>  }<a name="line.571"></a>
+<span class="sourceLineNo">572</span><a name="line.572"></a>
+<span class="sourceLineNo">573</span>  /**<a name="line.573"></a>
+<span class="sourceLineNo">574</span>   * Returns true if the specified file has a valid HFile Trailer.<a name="line.574"></a>
+<span class="sourceLineNo">575</span>   * @param fs filesystem<a name="line.575"></a>
+<span class="sourceLineNo">576</span>   * @param fileStatus the file to verify<a name="line.576"></a>
+<span class="sourceLineNo">577</span>   * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.577"></a>
+<span class="sourceLineNo">578</span>   * @throws IOException if failed to read from the underlying stream<a name="line.578"></a>
+<span class="sourceLineNo">579</span>   */<a name="line.579"></a>
+<span class="sourceLineNo">580</span>  public static boolean isHFileFormat(final FileSystem fs, final FileStatus fileStatus)<a name="line.580"></a>
+<span class="sourceLineNo">581</span>      throws IOException {<a name="line.581"></a>
+<span class="sourceLineNo">582</span>    final Path path = fileStatus.getPath();<a name="line.582"></a>
+<span class="sourceLineNo">583</span>    final long size = fileStatus.getLen();<a name="line.583"></a>
+<span class="sourceLineNo">584</span>    try (FSDataInputStreamWrapper fsdis = new FSDataInputStreamWrapper(fs, path)) {<a name="line.584"></a>
+<span class="sourceLineNo">585</span>      boolean isHBaseChecksum = fsdis.shouldUseHBaseChecksum();<a name="line.585"></a>
+<span class="sourceLineNo">586</span>      assert !isHBaseChecksum; // Initially we must read with FS checksum.<a name="line.586"></a>
+<span class="sourceLineNo">587</span>      FixedFileTrailer.readFromStream(fsdis.getStream(isHBaseChecksum), size);<a name="line.587"></a>
+<span class="sourceLineNo">588</span>      return true;<a name="line.588"></a>
+<span class="sourceLineNo">589</span>    } catch (IllegalArgumentException e) {<a name="line.589"></a>
+<span class="sourceLineNo">590</span>      return false;<a name="line.590"></a>
+<span class="sourceLineNo">591</span>    }<a name="line.591"></a>
+<span class="sourceLineNo">592</span>  }<a name="line.592"></a>
+<span class="sourceLineNo">593</span><a name="line.593"></a>
+<span class="sourceLineNo">594</span>  /**<a name="line.594"></a>
+<span class="sourceLineNo">595</span>   * Get names of supported compression algorithms. The names are acceptable by<a name="line.595"></a>
+<span class="sourceLineNo">596</span>   * HFile.Writer.<a name="line.596"></a>
+<span class="sourceLineNo">597</span>   *<a name="line.597"></a>
+<span class="sourceLineNo">598</span>   * @return Array of strings, each represents a supported compression<a name="line.598"></a>
+<span class="sourceLineNo">599</span>   *         algorithm. Currently, the following compression algorithms are<a name="line.599"></a>
+<span class="sourceLineNo">600</span>   *         supported.<a name="line.600"></a>
+<span class="sourceLineNo">601</span>   *         &lt;ul&gt;<a name="line.601"></a>
+<span class="sourceLineNo">602</span>   *         &lt;li&gt;"none" - No compression.<a name="line.602"></a>
+<span class="sourceLineNo">603</span>   *         &lt;li&gt;"gz" - GZIP compression.<a name="line.603"></a>
+<span class="sourceLineNo">604</span>   *         &lt;/ul&gt;<a name="line.604"></a>
+<span class="sourceLineNo">605</span>   */<a name="line.605"></a>
+<span class="sourceLineNo">606</span>  public static String[] getSupportedCompressionAlgorithms() {<a name="line.606"></a>
+<span class="sourceLineNo">607</span>    return Compression.getSupportedAlgorithms();<a name="line.607"></a>
+<span class="sourceLineNo">608</span>  }<a name="line.608"></a>
+<span class="sourceLineNo">609</span><a name="line.609"></a>
+<span class="sourceLineNo">610</span>  // Utility methods.<a name="line.610"></a>
+<span class="sourceLineNo">611</span>  /*<a name="line.611"></a>
+<span class="sourceLineNo">612</span>   * @param l Long to convert to an int.<a name="line.612"></a>
+<span class="sourceLineNo">613</span>   * @return &lt;code&gt;l&lt;/code&gt; cast as an int.<a name="line.613"></a>
+<span class="sourceLineNo">614</span>   */<a name="line.614"></a>
+<span class="sourceLineNo">615</span>  static int longToInt(final long l) {<a name="line.615"></a>
+<span class="sourceLineNo">616</span>    // Expecting the size() of a block not exceeding 4GB. Assuming the<a name="line.616"></a>
+<span class="sourceLineNo">617</span>    // size() will wrap to negative integer if it exceeds 2GB (From tfile).<a name="line.617"></a>
+<span class="sourceLineNo">618</span>    return (int)(l &amp; 0x00000000ffffffffL);<a name="line.618"></a>
+<span class="sourceLineNo">619</span>  }<a name="line.619"></a>
+<span class="sourceLineNo">620</span><a name="line.620"></a>
+<span class="sourceLineNo">621</span>  /**<a name="line.621"></a>
+<span class="sourceLineNo">622</span>   * Returns all HFiles belonging to the given region directory. Could return an<a name="line.622"></a>
+<span class="sourceLineNo">623</span>   * empty list.<a name="line.623"></a>
+<span class="sourceLineNo">624</span>   *<a name="line.624"></a>
+<span class="sourceLineNo">625</span>   * @param fs  The file system reference.<a name="line.625"></a>
+<span class="sourceLineNo">626</span>   * @param regionDir  The region directory to scan.<a name="line.626"></a>
+<span class="sourceLineNo">627</span>   * @return The list of files found.<a name="line.627"></a>
+<span class="sourceLineNo">628</span>   * @throws IOException When scanning the files fails.<a name="line.628"></a>
+<span class="sourceLineNo">629</span>   */<a name="line.629"></a>
+<span class="sourceLineNo">630</span>  public static List&lt;Path&gt; getStoreFiles(FileSystem fs, Path regionDir)<a name="line.630"></a>
+<span class="sourceLineNo">631</span>      throws IOException {<a name="line.631"></a>
+<span class="sourceLineNo">632</span>    List&lt;Path&gt; regionHFiles = new ArrayList&lt;&gt;();<a name="line.632"></a>
+<span class="sourceLineNo">633</span>    PathFilter dirFilter = new FSUtils.DirFilter(fs);<a name="line.633"></a>
+<span class="sourceLineNo">634</span>    FileStatus[] familyDirs = fs.listStatus(regionDir, dirFilter);<a name="line.634"></a>
+<span class="sourceLineNo">635</span>    for(FileStatus dir : familyDirs) {<a name="line.635"></a>
+<span class="sourceLineNo">636</span>      FileStatus[] files = fs.listStatus(dir.getPath());<a name="line.636"></a>
+<span class="sourceLineNo">637</span>      for (FileStatus file : files) {<a name="line.637"></a>
+<span class="sourceLineNo">638</span>        if (!file.isDirectory() &amp;&amp;<a name="line.638"></a>
+<span class="sourceLineNo">639</span>            (!file.getPath().toString().contains(HConstants.HREGION_OLDLOGDIR_NAME)) &amp;&amp;<a name="line.639"></a>
+<span class="sourceLineNo">640</span>            (!file.getPath().toString().contains(HConstants.RECOVERED_EDITS_DIR))) {<a name="line.640"></a>
+<span class="sourceLineNo">641</span>          regionHFiles.add(file.getPath());<a name="line.641"></a>
+<span class="sourceLineNo">642</span>        }<a name="line.642"></a>
+<span class="sourceLineNo">643</span>      }<a name="line.643"></a>
+<span class="sourceLineNo">644</span>    }<a name="line.644"></a>
+<span class="sourceLineNo">645</span>    return regionHFiles;<a name="line.645"></a>
+<span class="sourceLineNo">646</span>  }<a name="line.646"></a>
+<span class="sourceLineNo">647</span><a name="line.647"></a>
+<span class="sourceLineNo">648</span>  /**<a name="line.648"></a>
+<span class="sourceLineNo">649</span>   * Checks the given {@link HFile} format version, and throws an exception if<a name="line.649"></a>
+<span class="sourceLineNo">650</span>   * invalid. Note that if the version number comes from an input file and has<a name="line.650"></a>
+<span class="sourceLineNo">651</span>   * not been verified, the caller needs to re-throw an {@link IOException} to<a name="line.651"></a>
+<span class="sourceLineNo">652</span>   * indicate that this is not a software error, but corrupted input.<a name="line.652"></a>
+<span class="sourceLineNo">653</span>   *<a name="line.653"></a>
+<span class="sourceLineNo">654</span>   * @param version an HFile version<a name="line.654"></a>
+<span class="sourceLineNo">655</span>   * @throws IllegalArgumentException if the version is invalid<a name="line.655"></a>
+<span class="sourceLineNo">656</span>   */<a name="line.656"></a>
+<span class="sourceLineNo">657</span>  public static void checkFormatVersion(int version)<a name="line.657"></a>
+<span class="sourceLineNo">658</span>      throws IllegalArgumentException {<a name="line.658"></a>
+<span class="sourceLineNo">659</span>    if (version &lt; MIN_FORMAT_VERSION || version &gt; MAX_FORMAT_VERSION) {<a name="line.659"></a>
+<span class="sourceLineNo">660</span>      throw new IllegalArgumentException("Invalid HFile version: " + version<a name="line.660"></a>
+<span class="sourceLineNo">661</span>          + " (expected to be " + "between " + MIN_FORMAT_VERSION + " and "<a name="line.661"></a>
+<span class="sourceLineNo">662</span>          + MAX_FORMAT_VERSION + ")");<a name="line.662"></a>
+<span class="sourceLineNo">663</span>    }<a name="line.663"></a>
+<span class="sourceLineNo">664</span>  }<a name="line.664"></a>
 <span class="sourceLineNo">665</span><a name="line.665"></a>
-<span class="sourceLineNo">666</span>  public static void checkHFileVersion(final Configuration c) {<a name="line.666"></a>
-<span class="sourceLineNo">667</span>    int version = c.getInt(FORMAT_VERSION_KEY, MAX_FORMAT_VERSION);<a name="line.667"></a>
-<span class="sourceLineNo">668</span>    if (version &lt; MAX_FORMAT_VERSION || version &gt; MAX_FORMAT_VERSION) {<a name="line.668"></a>
-<span class="sourceLineNo">669</span>      throw new IllegalArgumentException("The setting for " + FORMAT_VERSION_KEY +<a name="line.669"></a>
-<span class="sourceLineNo">670</span>        " (in your hbase-*.xml files) is " + version + " which does not match " +<a name="line.670"></a>
-<span class="sourceLineNo">671</span>        MAX_FORMAT_VERSION +<a name="line.671"></a>
-<span class="sourceLineNo">672</span>        "; are you running with a configuration from an older or newer hbase install (an " +<a name="line.672"></a>
-<span class="sourceLineNo">673</span>        "incompatible hbase-default.xml or hbase-site.xml on your CLASSPATH)?");<a name="line.673"></a>
-<span class="sourceLineNo">674</span>    }<a name="line.674"></a>
-<span class="sourceLineNo">675</span>  }<a name="line.675"></a>
-<span class="sourceLineNo">676</span><a name="line.676"></a>
-<span class="sourceLineNo">677</span>  public static void main(String[] args) throws Exception {<a name="line.677"></a>
-<span class="sourceLineNo">678</span>    // delegate to preserve old behavior<a name="line.678"></a>
-<span class="sourceLineNo">679</span>    HFilePrettyPrinter.main(args);<a name="line.679"></a>
-<span class="sourceLineNo">680</span>  }<a name="line.680"></a>
-<span class="sourceLineNo">681</span>}<a name="line.681"></a>
+<span class="sourceLineNo">666</span><a name="line.666"></a>
+<span class="sourceLineNo">667</span>  public static void checkHFileVersion(final Configuration c) {<a name="line.667"></a>
+<span class="sourceLineNo">668</span>    int version = c.getInt(FORMAT_VERSION_KEY, MAX_FORMAT_VERSION);<a name="line.668"></a>
+<span class="sourceLineNo">669</span>    if (version &lt; MAX_FORMAT_VERSION || version &gt; MAX_FORMAT_VERSION) {<a name="line.669"></a>
+<span class="sourceLineNo">670</span>      throw new IllegalArgumentException("The setting for " + FORMAT_VERSION_KEY +<a name="line.670"></a>
+<span class="sourceLineNo">671</span>        " (in your hbase-*.xml files) is " + version + " which does not match " +<a name="line.671"></a>
+<span class="sourceLineNo">672</span>        MAX_FORMAT_VERSION +<a name="line.672"></a>
+<span class="sourceLineNo">673</span>        "; are you running with a configuration from an older or newer hbase install (an " +<a name="line.673"></a>
+<span class="sourceLineNo">674</span>        "incompatible hbase-default.xml or hbase-site.xml on your CLASSPATH)?");<a name="line.674"></a>
+<span class="sourceLineNo">675</span>    }<a name="line.675"></a>
+<span class="sourceLineNo">676</span>  }<a name="line.676"></a>
+<span class="sourceLineNo">677</span><a name="line.677"></a>
+<span class="sourceLineNo">678</span>  public static void main(String[] args) throws Exception {<a name="line.678"></a>
+<span class="sourceLineNo">679</span>    // delegate to preserve old behavior<a name="line.679"></a>
+<span class="sourceLineNo">680</span>    HFilePrettyPrinter.main(args);<a name="line.680"></a>
+<span class="sourceLineNo">681</span>  }<a name="line.681"></a>
+<span class="sourceLineNo">682</span>}<a name="line.682"></a>
 
 
 
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.Writer.html b/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.Writer.html
index a82ba7f..2a91d20 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.Writer.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.Writer.html
@@ -513,180 +513,181 @@
 <span class="sourceLineNo">505</span>          throw new IllegalArgumentException("Invalid HFile version " + trailer.getMajorVersion());<a name="line.505"></a>
 <span class="sourceLineNo">506</span>      }<a name="line.506"></a>
 <span class="sourceLineNo">507</span>    } catch (Throwable t) {<a name="line.507"></a>
-<span class="sourceLineNo">508</span>      IOUtils.closeQuietly(context.getInputStreamWrapper());<a name="line.508"></a>
-<span class="sourceLineNo">509</span>      throw new CorruptHFileException("Problem reading HFile Trailer from file "<a name="line.509"></a>
-<span class="sourceLineNo">510</span>          + context.getFilePath(), t);<a name="line.510"></a>
-<span class="sourceLineNo">511</span>    } finally {<a name="line.511"></a>
-<span class="sourceLineNo">512</span>      context.getInputStreamWrapper().unbuffer();<a name="line.512"></a>
-<span class="sourceLineNo">513</span>    }<a name="line.513"></a>
-<span class="sourceLineNo">514</span>  }<a name="line.514"></a>
-<span class="sourceLineNo">515</span><a name="line.515"></a>
-<span class="sourceLineNo">516</span>  /**<a name="line.516"></a>
-<span class="sourceLineNo">517</span>   * Creates reader with cache configuration disabled<a name="line.517"></a>
-<span class="sourceLineNo">518</span>   * @param fs filesystem<a name="line.518"></a>
-<span class="sourceLineNo">519</span>   * @param path Path to file to read<a name="line.519"></a>
-<span class="sourceLineNo">520</span>   * @param conf Configuration<a name="line.520"></a>
-<span class="sourceLineNo">521</span>   * @return an active Reader instance<a name="line.521"></a>
-<span class="sourceLineNo">522</span>   * @throws IOException Will throw a CorruptHFileException<a name="line.522"></a>
-<span class="sourceLineNo">523</span>   *   (DoNotRetryIOException subtype) if hfile is corrupt/invalid.<a name="line.523"></a>
-<span class="sourceLineNo">524</span>   */<a name="line.524"></a>
-<span class="sourceLineNo">525</span>  public static Reader createReader(FileSystem fs, Path path, Configuration conf)<a name="line.525"></a>
-<span class="sourceLineNo">526</span>      throws IOException {<a name="line.526"></a>
-<span class="sourceLineNo">527</span>    // The primaryReplicaReader is mainly used for constructing block cache key, so if we do not use<a name="line.527"></a>
-<span class="sourceLineNo">528</span>    // block cache then it is OK to set it as any value. We use true here.<a name="line.528"></a>
-<span class="sourceLineNo">529</span>    return createReader(fs, path, CacheConfig.DISABLED, true, conf);<a name="line.529"></a>
-<span class="sourceLineNo">530</span>  }<a name="line.530"></a>
-<span class="sourceLineNo">531</span><a name="line.531"></a>
-<span class="sourceLineNo">532</span>  /**<a name="line.532"></a>
-<span class="sourceLineNo">533</span>   * @param fs filesystem<a name="line.533"></a>
-<span class="sourceLineNo">534</span>   * @param path Path to file to read<a name="line.534"></a>
-<span class="sourceLineNo">535</span>   * @param cacheConf This must not be null. @see<a name="line.535"></a>
-<span class="sourceLineNo">536</span>   *          {@link org.apache.hadoop.hbase.io.hfile.CacheConfig#CacheConfig(Configuration)}<a name="line.536"></a>
-<span class="sourceLineNo">537</span>   * @param primaryReplicaReader true if this is a reader for primary replica<a name="line.537"></a>
-<span class="sourceLineNo">538</span>   * @param conf Configuration<a name="line.538"></a>
-<span class="sourceLineNo">539</span>   * @return an active Reader instance<a name="line.539"></a>
-<span class="sourceLineNo">540</span>   * @throws IOException Will throw a CorruptHFileException (DoNotRetryIOException subtype) if hfile<a name="line.540"></a>
-<span class="sourceLineNo">541</span>   *           is corrupt/invalid.<a name="line.541"></a>
-<span class="sourceLineNo">542</span>   */<a name="line.542"></a>
-<span class="sourceLineNo">543</span>  public static Reader createReader(FileSystem fs, Path path, CacheConfig cacheConf,<a name="line.543"></a>
-<span class="sourceLineNo">544</span>      boolean primaryReplicaReader, Configuration conf) throws IOException {<a name="line.544"></a>
-<span class="sourceLineNo">545</span>    Preconditions.checkNotNull(cacheConf, "Cannot create Reader with null CacheConf");<a name="line.545"></a>
-<span class="sourceLineNo">546</span>    FSDataInputStreamWrapper stream = new FSDataInputStreamWrapper(fs, path);<a name="line.546"></a>
-<span class="sourceLineNo">547</span>    ReaderContext context = new ReaderContextBuilder()<a name="line.547"></a>
-<span class="sourceLineNo">548</span>        .withFilePath(path)<a name="line.548"></a>
-<span class="sourceLineNo">549</span>        .withInputStreamWrapper(stream)<a name="line.549"></a>
-<span class="sourceLineNo">550</span>        .withFileSize(fs.getFileStatus(path).getLen())<a name="line.550"></a>
-<span class="sourceLineNo">551</span>        .withFileSystem(stream.getHfs())<a name="line.551"></a>
-<span class="sourceLineNo">552</span>        .withPrimaryReplicaReader(primaryReplicaReader)<a name="line.552"></a>
-<span class="sourceLineNo">553</span>        .withReaderType(ReaderType.PREAD)<a name="line.553"></a>
-<span class="sourceLineNo">554</span>        .build();<a name="line.554"></a>
-<span class="sourceLineNo">555</span>    HFileInfo fileInfo = new HFileInfo(context, conf);<a name="line.555"></a>
-<span class="sourceLineNo">556</span>    Reader reader = createReader(context, fileInfo, cacheConf, conf);<a name="line.556"></a>
-<span class="sourceLineNo">557</span>    fileInfo.initMetaAndIndex(reader);<a name="line.557"></a>
-<span class="sourceLineNo">558</span>    return reader;<a name="line.558"></a>
-<span class="sourceLineNo">559</span>  }<a name="line.559"></a>
-<span class="sourceLineNo">560</span><a name="line.560"></a>
-<span class="sourceLineNo">561</span>  /**<a name="line.561"></a>
-<span class="sourceLineNo">562</span>   * Returns true if the specified file has a valid HFile Trailer.<a name="line.562"></a>
-<span class="sourceLineNo">563</span>   * @param fs filesystem<a name="line.563"></a>
-<span class="sourceLineNo">564</span>   * @param path Path to file to verify<a name="line.564"></a>
-<span class="sourceLineNo">565</span>   * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.565"></a>
-<span class="sourceLineNo">566</span>   * @throws IOException if failed to read from the underlying stream<a name="line.566"></a>
-<span class="sourceLineNo">567</span>   */<a name="line.567"></a>
-<span class="sourceLineNo">568</span>  public static boolean isHFileFormat(final FileSystem fs, final Path path) throws IOException {<a name="line.568"></a>
-<span class="sourceLineNo">569</span>    return isHFileFormat(fs, fs.getFileStatus(path));<a name="line.569"></a>
-<span class="sourceLineNo">570</span>  }<a name="line.570"></a>
-<span class="sourceLineNo">571</span><a name="line.571"></a>
-<span class="sourceLineNo">572</span>  /**<a name="line.572"></a>
-<span class="sourceLineNo">573</span>   * Returns true if the specified file has a valid HFile Trailer.<a name="line.573"></a>
-<span class="sourceLineNo">574</span>   * @param fs filesystem<a name="line.574"></a>
-<span class="sourceLineNo">575</span>   * @param fileStatus the file to verify<a name="line.575"></a>
-<span class="sourceLineNo">576</span>   * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.576"></a>
-<span class="sourceLineNo">577</span>   * @throws IOException if failed to read from the underlying stream<a name="line.577"></a>
-<span class="sourceLineNo">578</span>   */<a name="line.578"></a>
-<span class="sourceLineNo">579</span>  public static boolean isHFileFormat(final FileSystem fs, final FileStatus fileStatus)<a name="line.579"></a>
-<span class="sourceLineNo">580</span>      throws IOException {<a name="line.580"></a>
-<span class="sourceLineNo">581</span>    final Path path = fileStatus.getPath();<a name="line.581"></a>
-<span class="sourceLineNo">582</span>    final long size = fileStatus.getLen();<a name="line.582"></a>
-<span class="sourceLineNo">583</span>    try (FSDataInputStreamWrapper fsdis = new FSDataInputStreamWrapper(fs, path)) {<a name="line.583"></a>
-<span class="sourceLineNo">584</span>      boolean isHBaseChecksum = fsdis.shouldUseHBaseChecksum();<a name="line.584"></a>
-<span class="sourceLineNo">585</span>      assert !isHBaseChecksum; // Initially we must read with FS checksum.<a name="line.585"></a>
-<span class="sourceLineNo">586</span>      FixedFileTrailer.readFromStream(fsdis.getStream(isHBaseChecksum), size);<a name="line.586"></a>
-<span class="sourceLineNo">587</span>      return true;<a name="line.587"></a>
-<span class="sourceLineNo">588</span>    } catch (IllegalArgumentException e) {<a name="line.588"></a>
-<span class="sourceLineNo">589</span>      return false;<a name="line.589"></a>
-<span class="sourceLineNo">590</span>    }<a name="line.590"></a>
-<span class="sourceLineNo">591</span>  }<a name="line.591"></a>
-<span class="sourceLineNo">592</span><a name="line.592"></a>
-<span class="sourceLineNo">593</span>  /**<a name="line.593"></a>
-<span class="sourceLineNo">594</span>   * Get names of supported compression algorithms. The names are acceptable by<a name="line.594"></a>
-<span class="sourceLineNo">595</span>   * HFile.Writer.<a name="line.595"></a>
-<span class="sourceLineNo">596</span>   *<a name="line.596"></a>
-<span class="sourceLineNo">597</span>   * @return Array of strings, each represents a supported compression<a name="line.597"></a>
-<span class="sourceLineNo">598</span>   *         algorithm. Currently, the following compression algorithms are<a name="line.598"></a>
-<span class="sourceLineNo">599</span>   *         supported.<a name="line.599"></a>
-<span class="sourceLineNo">600</span>   *         &lt;ul&gt;<a name="line.600"></a>
-<span class="sourceLineNo">601</span>   *         &lt;li&gt;"none" - No compression.<a name="line.601"></a>
-<span class="sourceLineNo">602</span>   *         &lt;li&gt;"gz" - GZIP compression.<a name="line.602"></a>
-<span class="sourceLineNo">603</span>   *         &lt;/ul&gt;<a name="line.603"></a>
-<span class="sourceLineNo">604</span>   */<a name="line.604"></a>
-<span class="sourceLineNo">605</span>  public static String[] getSupportedCompressionAlgorithms() {<a name="line.605"></a>
-<span class="sourceLineNo">606</span>    return Compression.getSupportedAlgorithms();<a name="line.606"></a>
-<span class="sourceLineNo">607</span>  }<a name="line.607"></a>
-<span class="sourceLineNo">608</span><a name="line.608"></a>
-<span class="sourceLineNo">609</span>  // Utility methods.<a name="line.609"></a>
-<span class="sourceLineNo">610</span>  /*<a name="line.610"></a>
-<span class="sourceLineNo">611</span>   * @param l Long to convert to an int.<a name="line.611"></a>
-<span class="sourceLineNo">612</span>   * @return &lt;code&gt;l&lt;/code&gt; cast as an int.<a name="line.612"></a>
-<span class="sourceLineNo">613</span>   */<a name="line.613"></a>
-<span class="sourceLineNo">614</span>  static int longToInt(final long l) {<a name="line.614"></a>
-<span class="sourceLineNo">615</span>    // Expecting the size() of a block not exceeding 4GB. Assuming the<a name="line.615"></a>
-<span class="sourceLineNo">616</span>    // size() will wrap to negative integer if it exceeds 2GB (From tfile).<a name="line.616"></a>
-<span class="sourceLineNo">617</span>    return (int)(l &amp; 0x00000000ffffffffL);<a name="line.617"></a>
-<span class="sourceLineNo">618</span>  }<a name="line.618"></a>
-<span class="sourceLineNo">619</span><a name="line.619"></a>
-<span class="sourceLineNo">620</span>  /**<a name="line.620"></a>
-<span class="sourceLineNo">621</span>   * Returns all HFiles belonging to the given region directory. Could return an<a name="line.621"></a>
-<span class="sourceLineNo">622</span>   * empty list.<a name="line.622"></a>
-<span class="sourceLineNo">623</span>   *<a name="line.623"></a>
-<span class="sourceLineNo">624</span>   * @param fs  The file system reference.<a name="line.624"></a>
-<span class="sourceLineNo">625</span>   * @param regionDir  The region directory to scan.<a name="line.625"></a>
-<span class="sourceLineNo">626</span>   * @return The list of files found.<a name="line.626"></a>
-<span class="sourceLineNo">627</span>   * @throws IOException When scanning the files fails.<a name="line.627"></a>
-<span class="sourceLineNo">628</span>   */<a name="line.628"></a>
-<span class="sourceLineNo">629</span>  public static List&lt;Path&gt; getStoreFiles(FileSystem fs, Path regionDir)<a name="line.629"></a>
-<span class="sourceLineNo">630</span>      throws IOException {<a name="line.630"></a>
-<span class="sourceLineNo">631</span>    List&lt;Path&gt; regionHFiles = new ArrayList&lt;&gt;();<a name="line.631"></a>
-<span class="sourceLineNo">632</span>    PathFilter dirFilter = new FSUtils.DirFilter(fs);<a name="line.632"></a>
-<span class="sourceLineNo">633</span>    FileStatus[] familyDirs = fs.listStatus(regionDir, dirFilter);<a name="line.633"></a>
-<span class="sourceLineNo">634</span>    for(FileStatus dir : familyDirs) {<a name="line.634"></a>
-<span class="sourceLineNo">635</span>      FileStatus[] files = fs.listStatus(dir.getPath());<a name="line.635"></a>
-<span class="sourceLineNo">636</span>      for (FileStatus file : files) {<a name="line.636"></a>
-<span class="sourceLineNo">637</span>        if (!file.isDirectory() &amp;&amp;<a name="line.637"></a>
-<span class="sourceLineNo">638</span>            (!file.getPath().toString().contains(HConstants.HREGION_OLDLOGDIR_NAME)) &amp;&amp;<a name="line.638"></a>
-<span class="sourceLineNo">639</span>            (!file.getPath().toString().contains(HConstants.RECOVERED_EDITS_DIR))) {<a name="line.639"></a>
-<span class="sourceLineNo">640</span>          regionHFiles.add(file.getPath());<a name="line.640"></a>
-<span class="sourceLineNo">641</span>        }<a name="line.641"></a>
-<span class="sourceLineNo">642</span>      }<a name="line.642"></a>
-<span class="sourceLineNo">643</span>    }<a name="line.643"></a>
-<span class="sourceLineNo">644</span>    return regionHFiles;<a name="line.644"></a>
-<span class="sourceLineNo">645</span>  }<a name="line.645"></a>
-<span class="sourceLineNo">646</span><a name="line.646"></a>
-<span class="sourceLineNo">647</span>  /**<a name="line.647"></a>
-<span class="sourceLineNo">648</span>   * Checks the given {@link HFile} format version, and throws an exception if<a name="line.648"></a>
-<span class="sourceLineNo">649</span>   * invalid. Note that if the version number comes from an input file and has<a name="line.649"></a>
-<span class="sourceLineNo">650</span>   * not been verified, the caller needs to re-throw an {@link IOException} to<a name="line.650"></a>
-<span class="sourceLineNo">651</span>   * indicate that this is not a software error, but corrupted input.<a name="line.651"></a>
-<span class="sourceLineNo">652</span>   *<a name="line.652"></a>
-<span class="sourceLineNo">653</span>   * @param version an HFile version<a name="line.653"></a>
-<span class="sourceLineNo">654</span>   * @throws IllegalArgumentException if the version is invalid<a name="line.654"></a>
-<span class="sourceLineNo">655</span>   */<a name="line.655"></a>
-<span class="sourceLineNo">656</span>  public static void checkFormatVersion(int version)<a name="line.656"></a>
-<span class="sourceLineNo">657</span>      throws IllegalArgumentException {<a name="line.657"></a>
-<span class="sourceLineNo">658</span>    if (version &lt; MIN_FORMAT_VERSION || version &gt; MAX_FORMAT_VERSION) {<a name="line.658"></a>
-<span class="sourceLineNo">659</span>      throw new IllegalArgumentException("Invalid HFile version: " + version<a name="line.659"></a>
-<span class="sourceLineNo">660</span>          + " (expected to be " + "between " + MIN_FORMAT_VERSION + " and "<a name="line.660"></a>
-<span class="sourceLineNo">661</span>          + MAX_FORMAT_VERSION + ")");<a name="line.661"></a>
-<span class="sourceLineNo">662</span>    }<a name="line.662"></a>
-<span class="sourceLineNo">663</span>  }<a name="line.663"></a>
-<span class="sourceLineNo">664</span><a name="line.664"></a>
+<span class="sourceLineNo">508</span>      IOUtils.closeQuietly(context.getInputStreamWrapper(),<a name="line.508"></a>
+<span class="sourceLineNo">509</span>        e -&gt; LOG.warn("failed to close input stream wrapper", e));<a name="line.509"></a>
+<span class="sourceLineNo">510</span>      throw new CorruptHFileException("Problem reading HFile Trailer from file "<a name="line.510"></a>
+<span class="sourceLineNo">511</span>          + context.getFilePath(), t);<a name="line.511"></a>
+<span class="sourceLineNo">512</span>    } finally {<a name="line.512"></a>
+<span class="sourceLineNo">513</span>      context.getInputStreamWrapper().unbuffer();<a name="line.513"></a>
+<span class="sourceLineNo">514</span>    }<a name="line.514"></a>
+<span class="sourceLineNo">515</span>  }<a name="line.515"></a>
+<span class="sourceLineNo">516</span><a name="line.516"></a>
+<span class="sourceLineNo">517</span>  /**<a name="line.517"></a>
+<span class="sourceLineNo">518</span>   * Creates reader with cache configuration disabled<a name="line.518"></a>
+<span class="sourceLineNo">519</span>   * @param fs filesystem<a name="line.519"></a>
+<span class="sourceLineNo">520</span>   * @param path Path to file to read<a name="line.520"></a>
+<span class="sourceLineNo">521</span>   * @param conf Configuration<a name="line.521"></a>
+<span class="sourceLineNo">522</span>   * @return an active Reader instance<a name="line.522"></a>
+<span class="sourceLineNo">523</span>   * @throws IOException Will throw a CorruptHFileException<a name="line.523"></a>
+<span class="sourceLineNo">524</span>   *   (DoNotRetryIOException subtype) if hfile is corrupt/invalid.<a name="line.524"></a>
+<span class="sourceLineNo">525</span>   */<a name="line.525"></a>
+<span class="sourceLineNo">526</span>  public static Reader createReader(FileSystem fs, Path path, Configuration conf)<a name="line.526"></a>
+<span class="sourceLineNo">527</span>      throws IOException {<a name="line.527"></a>
+<span class="sourceLineNo">528</span>    // The primaryReplicaReader is mainly used for constructing block cache key, so if we do not use<a name="line.528"></a>
+<span class="sourceLineNo">529</span>    // block cache then it is OK to set it as any value. We use true here.<a name="line.529"></a>
+<span class="sourceLineNo">530</span>    return createReader(fs, path, CacheConfig.DISABLED, true, conf);<a name="line.530"></a>
+<span class="sourceLineNo">531</span>  }<a name="line.531"></a>
+<span class="sourceLineNo">532</span><a name="line.532"></a>
+<span class="sourceLineNo">533</span>  /**<a name="line.533"></a>
+<span class="sourceLineNo">534</span>   * @param fs filesystem<a name="line.534"></a>
+<span class="sourceLineNo">535</span>   * @param path Path to file to read<a name="line.535"></a>
+<span class="sourceLineNo">536</span>   * @param cacheConf This must not be null. @see<a name="line.536"></a>
+<span class="sourceLineNo">537</span>   *          {@link org.apache.hadoop.hbase.io.hfile.CacheConfig#CacheConfig(Configuration)}<a name="line.537"></a>
+<span class="sourceLineNo">538</span>   * @param primaryReplicaReader true if this is a reader for primary replica<a name="line.538"></a>
+<span class="sourceLineNo">539</span>   * @param conf Configuration<a name="line.539"></a>
+<span class="sourceLineNo">540</span>   * @return an active Reader instance<a name="line.540"></a>
+<span class="sourceLineNo">541</span>   * @throws IOException Will throw a CorruptHFileException (DoNotRetryIOException subtype) if hfile<a name="line.541"></a>
+<span class="sourceLineNo">542</span>   *           is corrupt/invalid.<a name="line.542"></a>
+<span class="sourceLineNo">543</span>   */<a name="line.543"></a>
+<span class="sourceLineNo">544</span>  public static Reader createReader(FileSystem fs, Path path, CacheConfig cacheConf,<a name="line.544"></a>
+<span class="sourceLineNo">545</span>      boolean primaryReplicaReader, Configuration conf) throws IOException {<a name="line.545"></a>
+<span class="sourceLineNo">546</span>    Preconditions.checkNotNull(cacheConf, "Cannot create Reader with null CacheConf");<a name="line.546"></a>
+<span class="sourceLineNo">547</span>    FSDataInputStreamWrapper stream = new FSDataInputStreamWrapper(fs, path);<a name="line.547"></a>
+<span class="sourceLineNo">548</span>    ReaderContext context = new ReaderContextBuilder()<a name="line.548"></a>
+<span class="sourceLineNo">549</span>        .withFilePath(path)<a name="line.549"></a>
+<span class="sourceLineNo">550</span>        .withInputStreamWrapper(stream)<a name="line.550"></a>
+<span class="sourceLineNo">551</span>        .withFileSize(fs.getFileStatus(path).getLen())<a name="line.551"></a>
+<span class="sourceLineNo">552</span>        .withFileSystem(stream.getHfs())<a name="line.552"></a>
+<span class="sourceLineNo">553</span>        .withPrimaryReplicaReader(primaryReplicaReader)<a name="line.553"></a>
+<span class="sourceLineNo">554</span>        .withReaderType(ReaderType.PREAD)<a name="line.554"></a>
+<span class="sourceLineNo">555</span>        .build();<a name="line.555"></a>
+<span class="sourceLineNo">556</span>    HFileInfo fileInfo = new HFileInfo(context, conf);<a name="line.556"></a>
+<span class="sourceLineNo">557</span>    Reader reader = createReader(context, fileInfo, cacheConf, conf);<a name="line.557"></a>
+<span class="sourceLineNo">558</span>    fileInfo.initMetaAndIndex(reader);<a name="line.558"></a>
+<span class="sourceLineNo">559</span>    return reader;<a name="line.559"></a>
+<span class="sourceLineNo">560</span>  }<a name="line.560"></a>
+<span class="sourceLineNo">561</span><a name="line.561"></a>
+<span class="sourceLineNo">562</span>  /**<a name="line.562"></a>
+<span class="sourceLineNo">563</span>   * Returns true if the specified file has a valid HFile Trailer.<a name="line.563"></a>
+<span class="sourceLineNo">564</span>   * @param fs filesystem<a name="line.564"></a>
+<span class="sourceLineNo">565</span>   * @param path Path to file to verify<a name="line.565"></a>
+<span class="sourceLineNo">566</span>   * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.566"></a>
+<span class="sourceLineNo">567</span>   * @throws IOException if failed to read from the underlying stream<a name="line.567"></a>
+<span class="sourceLineNo">568</span>   */<a name="line.568"></a>
+<span class="sourceLineNo">569</span>  public static boolean isHFileFormat(final FileSystem fs, final Path path) throws IOException {<a name="line.569"></a>
+<span class="sourceLineNo">570</span>    return isHFileFormat(fs, fs.getFileStatus(path));<a name="line.570"></a>
+<span class="sourceLineNo">571</span>  }<a name="line.571"></a>
+<span class="sourceLineNo">572</span><a name="line.572"></a>
+<span class="sourceLineNo">573</span>  /**<a name="line.573"></a>
+<span class="sourceLineNo">574</span>   * Returns true if the specified file has a valid HFile Trailer.<a name="line.574"></a>
+<span class="sourceLineNo">575</span>   * @param fs filesystem<a name="line.575"></a>
+<span class="sourceLineNo">576</span>   * @param fileStatus the file to verify<a name="line.576"></a>
+<span class="sourceLineNo">577</span>   * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.577"></a>
+<span class="sourceLineNo">578</span>   * @throws IOException if failed to read from the underlying stream<a name="line.578"></a>
+<span class="sourceLineNo">579</span>   */<a name="line.579"></a>
+<span class="sourceLineNo">580</span>  public static boolean isHFileFormat(final FileSystem fs, final FileStatus fileStatus)<a name="line.580"></a>
+<span class="sourceLineNo">581</span>      throws IOException {<a name="line.581"></a>
+<span class="sourceLineNo">582</span>    final Path path = fileStatus.getPath();<a name="line.582"></a>
+<span class="sourceLineNo">583</span>    final long size = fileStatus.getLen();<a name="line.583"></a>
+<span class="sourceLineNo">584</span>    try (FSDataInputStreamWrapper fsdis = new FSDataInputStreamWrapper(fs, path)) {<a name="line.584"></a>
+<span class="sourceLineNo">585</span>      boolean isHBaseChecksum = fsdis.shouldUseHBaseChecksum();<a name="line.585"></a>
+<span class="sourceLineNo">586</span>      assert !isHBaseChecksum; // Initially we must read with FS checksum.<a name="line.586"></a>
+<span class="sourceLineNo">587</span>      FixedFileTrailer.readFromStream(fsdis.getStream(isHBaseChecksum), size);<a name="line.587"></a>
+<span class="sourceLineNo">588</span>      return true;<a name="line.588"></a>
+<span class="sourceLineNo">589</span>    } catch (IllegalArgumentException e) {<a name="line.589"></a>
+<span class="sourceLineNo">590</span>      return false;<a name="line.590"></a>
+<span class="sourceLineNo">591</span>    }<a name="line.591"></a>
+<span class="sourceLineNo">592</span>  }<a name="line.592"></a>
+<span class="sourceLineNo">593</span><a name="line.593"></a>
+<span class="sourceLineNo">594</span>  /**<a name="line.594"></a>
+<span class="sourceLineNo">595</span>   * Get names of supported compression algorithms. The names are acceptable by<a name="line.595"></a>
+<span class="sourceLineNo">596</span>   * HFile.Writer.<a name="line.596"></a>
+<span class="sourceLineNo">597</span>   *<a name="line.597"></a>
+<span class="sourceLineNo">598</span>   * @return Array of strings, each represents a supported compression<a name="line.598"></a>
+<span class="sourceLineNo">599</span>   *         algorithm. Currently, the following compression algorithms are<a name="line.599"></a>
+<span class="sourceLineNo">600</span>   *         supported.<a name="line.600"></a>
+<span class="sourceLineNo">601</span>   *         &lt;ul&gt;<a name="line.601"></a>
+<span class="sourceLineNo">602</span>   *         &lt;li&gt;"none" - No compression.<a name="line.602"></a>
+<span class="sourceLineNo">603</span>   *         &lt;li&gt;"gz" - GZIP compression.<a name="line.603"></a>
+<span class="sourceLineNo">604</span>   *         &lt;/ul&gt;<a name="line.604"></a>
+<span class="sourceLineNo">605</span>   */<a name="line.605"></a>
+<span class="sourceLineNo">606</span>  public static String[] getSupportedCompressionAlgorithms() {<a name="line.606"></a>
+<span class="sourceLineNo">607</span>    return Compression.getSupportedAlgorithms();<a name="line.607"></a>
+<span class="sourceLineNo">608</span>  }<a name="line.608"></a>
+<span class="sourceLineNo">609</span><a name="line.609"></a>
+<span class="sourceLineNo">610</span>  // Utility methods.<a name="line.610"></a>
+<span class="sourceLineNo">611</span>  /*<a name="line.611"></a>
+<span class="sourceLineNo">612</span>   * @param l Long to convert to an int.<a name="line.612"></a>
+<span class="sourceLineNo">613</span>   * @return &lt;code&gt;l&lt;/code&gt; cast as an int.<a name="line.613"></a>
+<span class="sourceLineNo">614</span>   */<a name="line.614"></a>
+<span class="sourceLineNo">615</span>  static int longToInt(final long l) {<a name="line.615"></a>
+<span class="sourceLineNo">616</span>    // Expecting the size() of a block not exceeding 4GB. Assuming the<a name="line.616"></a>
+<span class="sourceLineNo">617</span>    // size() will wrap to negative integer if it exceeds 2GB (From tfile).<a name="line.617"></a>
+<span class="sourceLineNo">618</span>    return (int)(l &amp; 0x00000000ffffffffL);<a name="line.618"></a>
+<span class="sourceLineNo">619</span>  }<a name="line.619"></a>
+<span class="sourceLineNo">620</span><a name="line.620"></a>
+<span class="sourceLineNo">621</span>  /**<a name="line.621"></a>
+<span class="sourceLineNo">622</span>   * Returns all HFiles belonging to the given region directory. Could return an<a name="line.622"></a>
+<span class="sourceLineNo">623</span>   * empty list.<a name="line.623"></a>
+<span class="sourceLineNo">624</span>   *<a name="line.624"></a>
+<span class="sourceLineNo">625</span>   * @param fs  The file system reference.<a name="line.625"></a>
+<span class="sourceLineNo">626</span>   * @param regionDir  The region directory to scan.<a name="line.626"></a>
+<span class="sourceLineNo">627</span>   * @return The list of files found.<a name="line.627"></a>
+<span class="sourceLineNo">628</span>   * @throws IOException When scanning the files fails.<a name="line.628"></a>
+<span class="sourceLineNo">629</span>   */<a name="line.629"></a>
+<span class="sourceLineNo">630</span>  public static List&lt;Path&gt; getStoreFiles(FileSystem fs, Path regionDir)<a name="line.630"></a>
+<span class="sourceLineNo">631</span>      throws IOException {<a name="line.631"></a>
+<span class="sourceLineNo">632</span>    List&lt;Path&gt; regionHFiles = new ArrayList&lt;&gt;();<a name="line.632"></a>
+<span class="sourceLineNo">633</span>    PathFilter dirFilter = new FSUtils.DirFilter(fs);<a name="line.633"></a>
+<span class="sourceLineNo">634</span>    FileStatus[] familyDirs = fs.listStatus(regionDir, dirFilter);<a name="line.634"></a>
+<span class="sourceLineNo">635</span>    for(FileStatus dir : familyDirs) {<a name="line.635"></a>
+<span class="sourceLineNo">636</span>      FileStatus[] files = fs.listStatus(dir.getPath());<a name="line.636"></a>
+<span class="sourceLineNo">637</span>      for (FileStatus file : files) {<a name="line.637"></a>
+<span class="sourceLineNo">638</span>        if (!file.isDirectory() &amp;&amp;<a name="line.638"></a>
+<span class="sourceLineNo">639</span>            (!file.getPath().toString().contains(HConstants.HREGION_OLDLOGDIR_NAME)) &amp;&amp;<a name="line.639"></a>
+<span class="sourceLineNo">640</span>            (!file.getPath().toString().contains(HConstants.RECOVERED_EDITS_DIR))) {<a name="line.640"></a>
+<span class="sourceLineNo">641</span>          regionHFiles.add(file.getPath());<a name="line.641"></a>
+<span class="sourceLineNo">642</span>        }<a name="line.642"></a>
+<span class="sourceLineNo">643</span>      }<a name="line.643"></a>
+<span class="sourceLineNo">644</span>    }<a name="line.644"></a>
+<span class="sourceLineNo">645</span>    return regionHFiles;<a name="line.645"></a>
+<span class="sourceLineNo">646</span>  }<a name="line.646"></a>
+<span class="sourceLineNo">647</span><a name="line.647"></a>
+<span class="sourceLineNo">648</span>  /**<a name="line.648"></a>
+<span class="sourceLineNo">649</span>   * Checks the given {@link HFile} format version, and throws an exception if<a name="line.649"></a>
+<span class="sourceLineNo">650</span>   * invalid. Note that if the version number comes from an input file and has<a name="line.650"></a>
+<span class="sourceLineNo">651</span>   * not been verified, the caller needs to re-throw an {@link IOException} to<a name="line.651"></a>
+<span class="sourceLineNo">652</span>   * indicate that this is not a software error, but corrupted input.<a name="line.652"></a>
+<span class="sourceLineNo">653</span>   *<a name="line.653"></a>
+<span class="sourceLineNo">654</span>   * @param version an HFile version<a name="line.654"></a>
+<span class="sourceLineNo">655</span>   * @throws IllegalArgumentException if the version is invalid<a name="line.655"></a>
+<span class="sourceLineNo">656</span>   */<a name="line.656"></a>
+<span class="sourceLineNo">657</span>  public static void checkFormatVersion(int version)<a name="line.657"></a>
+<span class="sourceLineNo">658</span>      throws IllegalArgumentException {<a name="line.658"></a>
+<span class="sourceLineNo">659</span>    if (version &lt; MIN_FORMAT_VERSION || version &gt; MAX_FORMAT_VERSION) {<a name="line.659"></a>
+<span class="sourceLineNo">660</span>      throw new IllegalArgumentException("Invalid HFile version: " + version<a name="line.660"></a>
+<span class="sourceLineNo">661</span>          + " (expected to be " + "between " + MIN_FORMAT_VERSION + " and "<a name="line.661"></a>
+<span class="sourceLineNo">662</span>          + MAX_FORMAT_VERSION + ")");<a name="line.662"></a>
+<span class="sourceLineNo">663</span>    }<a name="line.663"></a>
+<span class="sourceLineNo">664</span>  }<a name="line.664"></a>
 <span class="sourceLineNo">665</span><a name="line.665"></a>
-<span class="sourceLineNo">666</span>  public static void checkHFileVersion(final Configuration c) {<a name="line.666"></a>
-<span class="sourceLineNo">667</span>    int version = c.getInt(FORMAT_VERSION_KEY, MAX_FORMAT_VERSION);<a name="line.667"></a>
-<span class="sourceLineNo">668</span>    if (version &lt; MAX_FORMAT_VERSION || version &gt; MAX_FORMAT_VERSION) {<a name="line.668"></a>
-<span class="sourceLineNo">669</span>      throw new IllegalArgumentException("The setting for " + FORMAT_VERSION_KEY +<a name="line.669"></a>
-<span class="sourceLineNo">670</span>        " (in your hbase-*.xml files) is " + version + " which does not match " +<a name="line.670"></a>
-<span class="sourceLineNo">671</span>        MAX_FORMAT_VERSION +<a name="line.671"></a>
-<span class="sourceLineNo">672</span>        "; are you running with a configuration from an older or newer hbase install (an " +<a name="line.672"></a>
-<span class="sourceLineNo">673</span>        "incompatible hbase-default.xml or hbase-site.xml on your CLASSPATH)?");<a name="line.673"></a>
-<span class="sourceLineNo">674</span>    }<a name="line.674"></a>
-<span class="sourceLineNo">675</span>  }<a name="line.675"></a>
-<span class="sourceLineNo">676</span><a name="line.676"></a>
-<span class="sourceLineNo">677</span>  public static void main(String[] args) throws Exception {<a name="line.677"></a>
-<span class="sourceLineNo">678</span>    // delegate to preserve old behavior<a name="line.678"></a>
-<span class="sourceLineNo">679</span>    HFilePrettyPrinter.main(args);<a name="line.679"></a>
-<span class="sourceLineNo">680</span>  }<a name="line.680"></a>
-<span class="sourceLineNo">681</span>}<a name="line.681"></a>
+<span class="sourceLineNo">666</span><a name="line.666"></a>
+<span class="sourceLineNo">667</span>  public static void checkHFileVersion(final Configuration c) {<a name="line.667"></a>
+<span class="sourceLineNo">668</span>    int version = c.getInt(FORMAT_VERSION_KEY, MAX_FORMAT_VERSION);<a name="line.668"></a>
+<span class="sourceLineNo">669</span>    if (version &lt; MAX_FORMAT_VERSION || version &gt; MAX_FORMAT_VERSION) {<a name="line.669"></a>
+<span class="sourceLineNo">670</span>      throw new IllegalArgumentException("The setting for " + FORMAT_VERSION_KEY +<a name="line.670"></a>
+<span class="sourceLineNo">671</span>        " (in your hbase-*.xml files) is " + version + " which does not match " +<a name="line.671"></a>
+<span class="sourceLineNo">672</span>        MAX_FORMAT_VERSION +<a name="line.672"></a>
+<span class="sourceLineNo">673</span>        "; are you running with a configuration from an older or newer hbase install (an " +<a name="line.673"></a>
+<span class="sourceLineNo">674</span>        "incompatible hbase-default.xml or hbase-site.xml on your CLASSPATH)?");<a name="line.674"></a>
+<span class="sourceLineNo">675</span>    }<a name="line.675"></a>
+<span class="sourceLineNo">676</span>  }<a name="line.676"></a>
+<span class="sourceLineNo">677</span><a name="line.677"></a>
+<span class="sourceLineNo">678</span>  public static void main(String[] args) throws Exception {<a name="line.678"></a>
+<span class="sourceLineNo">679</span>    // delegate to preserve old behavior<a name="line.679"></a>
+<span class="sourceLineNo">680</span>    HFilePrettyPrinter.main(args);<a name="line.680"></a>
+<span class="sourceLineNo">681</span>  }<a name="line.681"></a>
+<span class="sourceLineNo">682</span>}<a name="line.682"></a>
 
 
 
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.WriterFactory.html b/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.WriterFactory.html
index a82ba7f..2a91d20 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.WriterFactory.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.WriterFactory.html
@@ -513,180 +513,181 @@
 <span class="sourceLineNo">505</span>          throw new IllegalArgumentException("Invalid HFile version " + trailer.getMajorVersion());<a name="line.505"></a>
 <span class="sourceLineNo">506</span>      }<a name="line.506"></a>
 <span class="sourceLineNo">507</span>    } catch (Throwable t) {<a name="line.507"></a>
-<span class="sourceLineNo">508</span>      IOUtils.closeQuietly(context.getInputStreamWrapper());<a name="line.508"></a>
-<span class="sourceLineNo">509</span>      throw new CorruptHFileException("Problem reading HFile Trailer from file "<a name="line.509"></a>
-<span class="sourceLineNo">510</span>          + context.getFilePath(), t);<a name="line.510"></a>
-<span class="sourceLineNo">511</span>    } finally {<a name="line.511"></a>
-<span class="sourceLineNo">512</span>      context.getInputStreamWrapper().unbuffer();<a name="line.512"></a>
-<span class="sourceLineNo">513</span>    }<a name="line.513"></a>
-<span class="sourceLineNo">514</span>  }<a name="line.514"></a>
-<span class="sourceLineNo">515</span><a name="line.515"></a>
-<span class="sourceLineNo">516</span>  /**<a name="line.516"></a>
-<span class="sourceLineNo">517</span>   * Creates reader with cache configuration disabled<a name="line.517"></a>
-<span class="sourceLineNo">518</span>   * @param fs filesystem<a name="line.518"></a>
-<span class="sourceLineNo">519</span>   * @param path Path to file to read<a name="line.519"></a>
-<span class="sourceLineNo">520</span>   * @param conf Configuration<a name="line.520"></a>
-<span class="sourceLineNo">521</span>   * @return an active Reader instance<a name="line.521"></a>
-<span class="sourceLineNo">522</span>   * @throws IOException Will throw a CorruptHFileException<a name="line.522"></a>
-<span class="sourceLineNo">523</span>   *   (DoNotRetryIOException subtype) if hfile is corrupt/invalid.<a name="line.523"></a>
-<span class="sourceLineNo">524</span>   */<a name="line.524"></a>
-<span class="sourceLineNo">525</span>  public static Reader createReader(FileSystem fs, Path path, Configuration conf)<a name="line.525"></a>
-<span class="sourceLineNo">526</span>      throws IOException {<a name="line.526"></a>
-<span class="sourceLineNo">527</span>    // The primaryReplicaReader is mainly used for constructing block cache key, so if we do not use<a name="line.527"></a>
-<span class="sourceLineNo">528</span>    // block cache then it is OK to set it as any value. We use true here.<a name="line.528"></a>
-<span class="sourceLineNo">529</span>    return createReader(fs, path, CacheConfig.DISABLED, true, conf);<a name="line.529"></a>
-<span class="sourceLineNo">530</span>  }<a name="line.530"></a>
-<span class="sourceLineNo">531</span><a name="line.531"></a>
-<span class="sourceLineNo">532</span>  /**<a name="line.532"></a>
-<span class="sourceLineNo">533</span>   * @param fs filesystem<a name="line.533"></a>
-<span class="sourceLineNo">534</span>   * @param path Path to file to read<a name="line.534"></a>
-<span class="sourceLineNo">535</span>   * @param cacheConf This must not be null. @see<a name="line.535"></a>
-<span class="sourceLineNo">536</span>   *          {@link org.apache.hadoop.hbase.io.hfile.CacheConfig#CacheConfig(Configuration)}<a name="line.536"></a>
-<span class="sourceLineNo">537</span>   * @param primaryReplicaReader true if this is a reader for primary replica<a name="line.537"></a>
-<span class="sourceLineNo">538</span>   * @param conf Configuration<a name="line.538"></a>
-<span class="sourceLineNo">539</span>   * @return an active Reader instance<a name="line.539"></a>
-<span class="sourceLineNo">540</span>   * @throws IOException Will throw a CorruptHFileException (DoNotRetryIOException subtype) if hfile<a name="line.540"></a>
-<span class="sourceLineNo">541</span>   *           is corrupt/invalid.<a name="line.541"></a>
-<span class="sourceLineNo">542</span>   */<a name="line.542"></a>
-<span class="sourceLineNo">543</span>  public static Reader createReader(FileSystem fs, Path path, CacheConfig cacheConf,<a name="line.543"></a>
-<span class="sourceLineNo">544</span>      boolean primaryReplicaReader, Configuration conf) throws IOException {<a name="line.544"></a>
-<span class="sourceLineNo">545</span>    Preconditions.checkNotNull(cacheConf, "Cannot create Reader with null CacheConf");<a name="line.545"></a>
-<span class="sourceLineNo">546</span>    FSDataInputStreamWrapper stream = new FSDataInputStreamWrapper(fs, path);<a name="line.546"></a>
-<span class="sourceLineNo">547</span>    ReaderContext context = new ReaderContextBuilder()<a name="line.547"></a>
-<span class="sourceLineNo">548</span>        .withFilePath(path)<a name="line.548"></a>
-<span class="sourceLineNo">549</span>        .withInputStreamWrapper(stream)<a name="line.549"></a>
-<span class="sourceLineNo">550</span>        .withFileSize(fs.getFileStatus(path).getLen())<a name="line.550"></a>
-<span class="sourceLineNo">551</span>        .withFileSystem(stream.getHfs())<a name="line.551"></a>
-<span class="sourceLineNo">552</span>        .withPrimaryReplicaReader(primaryReplicaReader)<a name="line.552"></a>
-<span class="sourceLineNo">553</span>        .withReaderType(ReaderType.PREAD)<a name="line.553"></a>
-<span class="sourceLineNo">554</span>        .build();<a name="line.554"></a>
-<span class="sourceLineNo">555</span>    HFileInfo fileInfo = new HFileInfo(context, conf);<a name="line.555"></a>
-<span class="sourceLineNo">556</span>    Reader reader = createReader(context, fileInfo, cacheConf, conf);<a name="line.556"></a>
-<span class="sourceLineNo">557</span>    fileInfo.initMetaAndIndex(reader);<a name="line.557"></a>
-<span class="sourceLineNo">558</span>    return reader;<a name="line.558"></a>
-<span class="sourceLineNo">559</span>  }<a name="line.559"></a>
-<span class="sourceLineNo">560</span><a name="line.560"></a>
-<span class="sourceLineNo">561</span>  /**<a name="line.561"></a>
-<span class="sourceLineNo">562</span>   * Returns true if the specified file has a valid HFile Trailer.<a name="line.562"></a>
-<span class="sourceLineNo">563</span>   * @param fs filesystem<a name="line.563"></a>
-<span class="sourceLineNo">564</span>   * @param path Path to file to verify<a name="line.564"></a>
-<span class="sourceLineNo">565</span>   * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.565"></a>
-<span class="sourceLineNo">566</span>   * @throws IOException if failed to read from the underlying stream<a name="line.566"></a>
-<span class="sourceLineNo">567</span>   */<a name="line.567"></a>
-<span class="sourceLineNo">568</span>  public static boolean isHFileFormat(final FileSystem fs, final Path path) throws IOException {<a name="line.568"></a>
-<span class="sourceLineNo">569</span>    return isHFileFormat(fs, fs.getFileStatus(path));<a name="line.569"></a>
-<span class="sourceLineNo">570</span>  }<a name="line.570"></a>
-<span class="sourceLineNo">571</span><a name="line.571"></a>
-<span class="sourceLineNo">572</span>  /**<a name="line.572"></a>
-<span class="sourceLineNo">573</span>   * Returns true if the specified file has a valid HFile Trailer.<a name="line.573"></a>
-<span class="sourceLineNo">574</span>   * @param fs filesystem<a name="line.574"></a>
-<span class="sourceLineNo">575</span>   * @param fileStatus the file to verify<a name="line.575"></a>
-<span class="sourceLineNo">576</span>   * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.576"></a>
-<span class="sourceLineNo">577</span>   * @throws IOException if failed to read from the underlying stream<a name="line.577"></a>
-<span class="sourceLineNo">578</span>   */<a name="line.578"></a>
-<span class="sourceLineNo">579</span>  public static boolean isHFileFormat(final FileSystem fs, final FileStatus fileStatus)<a name="line.579"></a>
-<span class="sourceLineNo">580</span>      throws IOException {<a name="line.580"></a>
-<span class="sourceLineNo">581</span>    final Path path = fileStatus.getPath();<a name="line.581"></a>
-<span class="sourceLineNo">582</span>    final long size = fileStatus.getLen();<a name="line.582"></a>
-<span class="sourceLineNo">583</span>    try (FSDataInputStreamWrapper fsdis = new FSDataInputStreamWrapper(fs, path)) {<a name="line.583"></a>
-<span class="sourceLineNo">584</span>      boolean isHBaseChecksum = fsdis.shouldUseHBaseChecksum();<a name="line.584"></a>
-<span class="sourceLineNo">585</span>      assert !isHBaseChecksum; // Initially we must read with FS checksum.<a name="line.585"></a>
-<span class="sourceLineNo">586</span>      FixedFileTrailer.readFromStream(fsdis.getStream(isHBaseChecksum), size);<a name="line.586"></a>
-<span class="sourceLineNo">587</span>      return true;<a name="line.587"></a>
-<span class="sourceLineNo">588</span>    } catch (IllegalArgumentException e) {<a name="line.588"></a>
-<span class="sourceLineNo">589</span>      return false;<a name="line.589"></a>
-<span class="sourceLineNo">590</span>    }<a name="line.590"></a>
-<span class="sourceLineNo">591</span>  }<a name="line.591"></a>
-<span class="sourceLineNo">592</span><a name="line.592"></a>
-<span class="sourceLineNo">593</span>  /**<a name="line.593"></a>
-<span class="sourceLineNo">594</span>   * Get names of supported compression algorithms. The names are acceptable by<a name="line.594"></a>
-<span class="sourceLineNo">595</span>   * HFile.Writer.<a name="line.595"></a>
-<span class="sourceLineNo">596</span>   *<a name="line.596"></a>
-<span class="sourceLineNo">597</span>   * @return Array of strings, each represents a supported compression<a name="line.597"></a>
-<span class="sourceLineNo">598</span>   *         algorithm. Currently, the following compression algorithms are<a name="line.598"></a>
-<span class="sourceLineNo">599</span>   *         supported.<a name="line.599"></a>
-<span class="sourceLineNo">600</span>   *         &lt;ul&gt;<a name="line.600"></a>
-<span class="sourceLineNo">601</span>   *         &lt;li&gt;"none" - No compression.<a name="line.601"></a>
-<span class="sourceLineNo">602</span>   *         &lt;li&gt;"gz" - GZIP compression.<a name="line.602"></a>
-<span class="sourceLineNo">603</span>   *         &lt;/ul&gt;<a name="line.603"></a>
-<span class="sourceLineNo">604</span>   */<a name="line.604"></a>
-<span class="sourceLineNo">605</span>  public static String[] getSupportedCompressionAlgorithms() {<a name="line.605"></a>
-<span class="sourceLineNo">606</span>    return Compression.getSupportedAlgorithms();<a name="line.606"></a>
-<span class="sourceLineNo">607</span>  }<a name="line.607"></a>
-<span class="sourceLineNo">608</span><a name="line.608"></a>
-<span class="sourceLineNo">609</span>  // Utility methods.<a name="line.609"></a>
-<span class="sourceLineNo">610</span>  /*<a name="line.610"></a>
-<span class="sourceLineNo">611</span>   * @param l Long to convert to an int.<a name="line.611"></a>
-<span class="sourceLineNo">612</span>   * @return &lt;code&gt;l&lt;/code&gt; cast as an int.<a name="line.612"></a>
-<span class="sourceLineNo">613</span>   */<a name="line.613"></a>
-<span class="sourceLineNo">614</span>  static int longToInt(final long l) {<a name="line.614"></a>
-<span class="sourceLineNo">615</span>    // Expecting the size() of a block not exceeding 4GB. Assuming the<a name="line.615"></a>
-<span class="sourceLineNo">616</span>    // size() will wrap to negative integer if it exceeds 2GB (From tfile).<a name="line.616"></a>
-<span class="sourceLineNo">617</span>    return (int)(l &amp; 0x00000000ffffffffL);<a name="line.617"></a>
-<span class="sourceLineNo">618</span>  }<a name="line.618"></a>
-<span class="sourceLineNo">619</span><a name="line.619"></a>
-<span class="sourceLineNo">620</span>  /**<a name="line.620"></a>
-<span class="sourceLineNo">621</span>   * Returns all HFiles belonging to the given region directory. Could return an<a name="line.621"></a>
-<span class="sourceLineNo">622</span>   * empty list.<a name="line.622"></a>
-<span class="sourceLineNo">623</span>   *<a name="line.623"></a>
-<span class="sourceLineNo">624</span>   * @param fs  The file system reference.<a name="line.624"></a>
-<span class="sourceLineNo">625</span>   * @param regionDir  The region directory to scan.<a name="line.625"></a>
-<span class="sourceLineNo">626</span>   * @return The list of files found.<a name="line.626"></a>
-<span class="sourceLineNo">627</span>   * @throws IOException When scanning the files fails.<a name="line.627"></a>
-<span class="sourceLineNo">628</span>   */<a name="line.628"></a>
-<span class="sourceLineNo">629</span>  public static List&lt;Path&gt; getStoreFiles(FileSystem fs, Path regionDir)<a name="line.629"></a>
-<span class="sourceLineNo">630</span>      throws IOException {<a name="line.630"></a>
-<span class="sourceLineNo">631</span>    List&lt;Path&gt; regionHFiles = new ArrayList&lt;&gt;();<a name="line.631"></a>
-<span class="sourceLineNo">632</span>    PathFilter dirFilter = new FSUtils.DirFilter(fs);<a name="line.632"></a>
-<span class="sourceLineNo">633</span>    FileStatus[] familyDirs = fs.listStatus(regionDir, dirFilter);<a name="line.633"></a>
-<span class="sourceLineNo">634</span>    for(FileStatus dir : familyDirs) {<a name="line.634"></a>
-<span class="sourceLineNo">635</span>      FileStatus[] files = fs.listStatus(dir.getPath());<a name="line.635"></a>
-<span class="sourceLineNo">636</span>      for (FileStatus file : files) {<a name="line.636"></a>
-<span class="sourceLineNo">637</span>        if (!file.isDirectory() &amp;&amp;<a name="line.637"></a>
-<span class="sourceLineNo">638</span>            (!file.getPath().toString().contains(HConstants.HREGION_OLDLOGDIR_NAME)) &amp;&amp;<a name="line.638"></a>
-<span class="sourceLineNo">639</span>            (!file.getPath().toString().contains(HConstants.RECOVERED_EDITS_DIR))) {<a name="line.639"></a>
-<span class="sourceLineNo">640</span>          regionHFiles.add(file.getPath());<a name="line.640"></a>
-<span class="sourceLineNo">641</span>        }<a name="line.641"></a>
-<span class="sourceLineNo">642</span>      }<a name="line.642"></a>
-<span class="sourceLineNo">643</span>    }<a name="line.643"></a>
-<span class="sourceLineNo">644</span>    return regionHFiles;<a name="line.644"></a>
-<span class="sourceLineNo">645</span>  }<a name="line.645"></a>
-<span class="sourceLineNo">646</span><a name="line.646"></a>
-<span class="sourceLineNo">647</span>  /**<a name="line.647"></a>
-<span class="sourceLineNo">648</span>   * Checks the given {@link HFile} format version, and throws an exception if<a name="line.648"></a>
-<span class="sourceLineNo">649</span>   * invalid. Note that if the version number comes from an input file and has<a name="line.649"></a>
-<span class="sourceLineNo">650</span>   * not been verified, the caller needs to re-throw an {@link IOException} to<a name="line.650"></a>
-<span class="sourceLineNo">651</span>   * indicate that this is not a software error, but corrupted input.<a name="line.651"></a>
-<span class="sourceLineNo">652</span>   *<a name="line.652"></a>
-<span class="sourceLineNo">653</span>   * @param version an HFile version<a name="line.653"></a>
-<span class="sourceLineNo">654</span>   * @throws IllegalArgumentException if the version is invalid<a name="line.654"></a>
-<span class="sourceLineNo">655</span>   */<a name="line.655"></a>
-<span class="sourceLineNo">656</span>  public static void checkFormatVersion(int version)<a name="line.656"></a>
-<span class="sourceLineNo">657</span>      throws IllegalArgumentException {<a name="line.657"></a>
-<span class="sourceLineNo">658</span>    if (version &lt; MIN_FORMAT_VERSION || version &gt; MAX_FORMAT_VERSION) {<a name="line.658"></a>
-<span class="sourceLineNo">659</span>      throw new IllegalArgumentException("Invalid HFile version: " + version<a name="line.659"></a>
-<span class="sourceLineNo">660</span>          + " (expected to be " + "between " + MIN_FORMAT_VERSION + " and "<a name="line.660"></a>
-<span class="sourceLineNo">661</span>          + MAX_FORMAT_VERSION + ")");<a name="line.661"></a>
-<span class="sourceLineNo">662</span>    }<a name="line.662"></a>
-<span class="sourceLineNo">663</span>  }<a name="line.663"></a>
-<span class="sourceLineNo">664</span><a name="line.664"></a>
+<span class="sourceLineNo">508</span>      IOUtils.closeQuietly(context.getInputStreamWrapper(),<a name="line.508"></a>
+<span class="sourceLineNo">509</span>        e -&gt; LOG.warn("failed to close input stream wrapper", e));<a name="line.509"></a>
+<span class="sourceLineNo">510</span>      throw new CorruptHFileException("Problem reading HFile Trailer from file "<a name="line.510"></a>
+<span class="sourceLineNo">511</span>          + context.getFilePath(), t);<a name="line.511"></a>
+<span class="sourceLineNo">512</span>    } finally {<a name="line.512"></a>
+<span class="sourceLineNo">513</span>      context.getInputStreamWrapper().unbuffer();<a name="line.513"></a>
+<span class="sourceLineNo">514</span>    }<a name="line.514"></a>
+<span class="sourceLineNo">515</span>  }<a name="line.515"></a>
+<span class="sourceLineNo">516</span><a name="line.516"></a>
+<span class="sourceLineNo">517</span>  /**<a name="line.517"></a>
+<span class="sourceLineNo">518</span>   * Creates reader with cache configuration disabled<a name="line.518"></a>
+<span class="sourceLineNo">519</span>   * @param fs filesystem<a name="line.519"></a>
+<span class="sourceLineNo">520</span>   * @param path Path to file to read<a name="line.520"></a>
+<span class="sourceLineNo">521</span>   * @param conf Configuration<a name="line.521"></a>
+<span class="sourceLineNo">522</span>   * @return an active Reader instance<a name="line.522"></a>
+<span class="sourceLineNo">523</span>   * @throws IOException Will throw a CorruptHFileException<a name="line.523"></a>
+<span class="sourceLineNo">524</span>   *   (DoNotRetryIOException subtype) if hfile is corrupt/invalid.<a name="line.524"></a>
+<span class="sourceLineNo">525</span>   */<a name="line.525"></a>
+<span class="sourceLineNo">526</span>  public static Reader createReader(FileSystem fs, Path path, Configuration conf)<a name="line.526"></a>
+<span class="sourceLineNo">527</span>      throws IOException {<a name="line.527"></a>
+<span class="sourceLineNo">528</span>    // The primaryReplicaReader is mainly used for constructing block cache key, so if we do not use<a name="line.528"></a>
+<span class="sourceLineNo">529</span>    // block cache then it is OK to set it as any value. We use true here.<a name="line.529"></a>
+<span class="sourceLineNo">530</span>    return createReader(fs, path, CacheConfig.DISABLED, true, conf);<a name="line.530"></a>
+<span class="sourceLineNo">531</span>  }<a name="line.531"></a>
+<span class="sourceLineNo">532</span><a name="line.532"></a>
+<span class="sourceLineNo">533</span>  /**<a name="line.533"></a>
+<span class="sourceLineNo">534</span>   * @param fs filesystem<a name="line.534"></a>
+<span class="sourceLineNo">535</span>   * @param path Path to file to read<a name="line.535"></a>
+<span class="sourceLineNo">536</span>   * @param cacheConf This must not be null. @see<a name="line.536"></a>
+<span class="sourceLineNo">537</span>   *          {@link org.apache.hadoop.hbase.io.hfile.CacheConfig#CacheConfig(Configuration)}<a name="line.537"></a>
+<span class="sourceLineNo">538</span>   * @param primaryReplicaReader true if this is a reader for primary replica<a name="line.538"></a>
+<span class="sourceLineNo">539</span>   * @param conf Configuration<a name="line.539"></a>
+<span class="sourceLineNo">540</span>   * @return an active Reader instance<a name="line.540"></a>
+<span class="sourceLineNo">541</span>   * @throws IOException Will throw a CorruptHFileException (DoNotRetryIOException subtype) if hfile<a name="line.541"></a>
+<span class="sourceLineNo">542</span>   *           is corrupt/invalid.<a name="line.542"></a>
+<span class="sourceLineNo">543</span>   */<a name="line.543"></a>
+<span class="sourceLineNo">544</span>  public static Reader createReader(FileSystem fs, Path path, CacheConfig cacheConf,<a name="line.544"></a>
+<span class="sourceLineNo">545</span>      boolean primaryReplicaReader, Configuration conf) throws IOException {<a name="line.545"></a>
+<span class="sourceLineNo">546</span>    Preconditions.checkNotNull(cacheConf, "Cannot create Reader with null CacheConf");<a name="line.546"></a>
+<span class="sourceLineNo">547</span>    FSDataInputStreamWrapper stream = new FSDataInputStreamWrapper(fs, path);<a name="line.547"></a>
+<span class="sourceLineNo">548</span>    ReaderContext context = new ReaderContextBuilder()<a name="line.548"></a>
+<span class="sourceLineNo">549</span>        .withFilePath(path)<a name="line.549"></a>
+<span class="sourceLineNo">550</span>        .withInputStreamWrapper(stream)<a name="line.550"></a>
+<span class="sourceLineNo">551</span>        .withFileSize(fs.getFileStatus(path).getLen())<a name="line.551"></a>
+<span class="sourceLineNo">552</span>        .withFileSystem(stream.getHfs())<a name="line.552"></a>
+<span class="sourceLineNo">553</span>        .withPrimaryReplicaReader(primaryReplicaReader)<a name="line.553"></a>
+<span class="sourceLineNo">554</span>        .withReaderType(ReaderType.PREAD)<a name="line.554"></a>
+<span class="sourceLineNo">555</span>        .build();<a name="line.555"></a>
+<span class="sourceLineNo">556</span>    HFileInfo fileInfo = new HFileInfo(context, conf);<a name="line.556"></a>
+<span class="sourceLineNo">557</span>    Reader reader = createReader(context, fileInfo, cacheConf, conf);<a name="line.557"></a>
+<span class="sourceLineNo">558</span>    fileInfo.initMetaAndIndex(reader);<a name="line.558"></a>
+<span class="sourceLineNo">559</span>    return reader;<a name="line.559"></a>
+<span class="sourceLineNo">560</span>  }<a name="line.560"></a>
+<span class="sourceLineNo">561</span><a name="line.561"></a>
+<span class="sourceLineNo">562</span>  /**<a name="line.562"></a>
+<span class="sourceLineNo">563</span>   * Returns true if the specified file has a valid HFile Trailer.<a name="line.563"></a>
+<span class="sourceLineNo">564</span>   * @param fs filesystem<a name="line.564"></a>
+<span class="sourceLineNo">565</span>   * @param path Path to file to verify<a name="line.565"></a>
+<span class="sourceLineNo">566</span>   * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.566"></a>
+<span class="sourceLineNo">567</span>   * @throws IOException if failed to read from the underlying stream<a name="line.567"></a>
+<span class="sourceLineNo">568</span>   */<a name="line.568"></a>
+<span class="sourceLineNo">569</span>  public static boolean isHFileFormat(final FileSystem fs, final Path path) throws IOException {<a name="line.569"></a>
+<span class="sourceLineNo">570</span>    return isHFileFormat(fs, fs.getFileStatus(path));<a name="line.570"></a>
+<span class="sourceLineNo">571</span>  }<a name="line.571"></a>
+<span class="sourceLineNo">572</span><a name="line.572"></a>
+<span class="sourceLineNo">573</span>  /**<a name="line.573"></a>
+<span class="sourceLineNo">574</span>   * Returns true if the specified file has a valid HFile Trailer.<a name="line.574"></a>
+<span class="sourceLineNo">575</span>   * @param fs filesystem<a name="line.575"></a>
+<span class="sourceLineNo">576</span>   * @param fileStatus the file to verify<a name="line.576"></a>
+<span class="sourceLineNo">577</span>   * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.577"></a>
+<span class="sourceLineNo">578</span>   * @throws IOException if failed to read from the underlying stream<a name="line.578"></a>
+<span class="sourceLineNo">579</span>   */<a name="line.579"></a>
+<span class="sourceLineNo">580</span>  public static boolean isHFileFormat(final FileSystem fs, final FileStatus fileStatus)<a name="line.580"></a>
+<span class="sourceLineNo">581</span>      throws IOException {<a name="line.581"></a>
+<span class="sourceLineNo">582</span>    final Path path = fileStatus.getPath();<a name="line.582"></a>
+<span class="sourceLineNo">583</span>    final long size = fileStatus.getLen();<a name="line.583"></a>
+<span class="sourceLineNo">584</span>    try (FSDataInputStreamWrapper fsdis = new FSDataInputStreamWrapper(fs, path)) {<a name="line.584"></a>
+<span class="sourceLineNo">585</span>      boolean isHBaseChecksum = fsdis.shouldUseHBaseChecksum();<a name="line.585"></a>
+<span class="sourceLineNo">586</span>      assert !isHBaseChecksum; // Initially we must read with FS checksum.<a name="line.586"></a>
+<span class="sourceLineNo">587</span>      FixedFileTrailer.readFromStream(fsdis.getStream(isHBaseChecksum), size);<a name="line.587"></a>
+<span class="sourceLineNo">588</span>      return true;<a name="line.588"></a>
+<span class="sourceLineNo">589</span>    } catch (IllegalArgumentException e) {<a name="line.589"></a>
+<span class="sourceLineNo">590</span>      return false;<a name="line.590"></a>
+<span class="sourceLineNo">591</span>    }<a name="line.591"></a>
+<span class="sourceLineNo">592</span>  }<a name="line.592"></a>
+<span class="sourceLineNo">593</span><a name="line.593"></a>
+<span class="sourceLineNo">594</span>  /**<a name="line.594"></a>
+<span class="sourceLineNo">595</span>   * Get names of supported compression algorithms. The names are acceptable by<a name="line.595"></a>
+<span class="sourceLineNo">596</span>   * HFile.Writer.<a name="line.596"></a>
+<span class="sourceLineNo">597</span>   *<a name="line.597"></a>
+<span class="sourceLineNo">598</span>   * @return Array of strings, each represents a supported compression<a name="line.598"></a>
+<span class="sourceLineNo">599</span>   *         algorithm. Currently, the following compression algorithms are<a name="line.599"></a>
+<span class="sourceLineNo">600</span>   *         supported.<a name="line.600"></a>
+<span class="sourceLineNo">601</span>   *         &lt;ul&gt;<a name="line.601"></a>
+<span class="sourceLineNo">602</span>   *         &lt;li&gt;"none" - No compression.<a name="line.602"></a>
+<span class="sourceLineNo">603</span>   *         &lt;li&gt;"gz" - GZIP compression.<a name="line.603"></a>
+<span class="sourceLineNo">604</span>   *         &lt;/ul&gt;<a name="line.604"></a>
+<span class="sourceLineNo">605</span>   */<a name="line.605"></a>
+<span class="sourceLineNo">606</span>  public static String[] getSupportedCompressionAlgorithms() {<a name="line.606"></a>
+<span class="sourceLineNo">607</span>    return Compression.getSupportedAlgorithms();<a name="line.607"></a>
+<span class="sourceLineNo">608</span>  }<a name="line.608"></a>
+<span class="sourceLineNo">609</span><a name="line.609"></a>
+<span class="sourceLineNo">610</span>  // Utility methods.<a name="line.610"></a>
+<span class="sourceLineNo">611</span>  /*<a name="line.611"></a>
+<span class="sourceLineNo">612</span>   * @param l Long to convert to an int.<a name="line.612"></a>
+<span class="sourceLineNo">613</span>   * @return &lt;code&gt;l&lt;/code&gt; cast as an int.<a name="line.613"></a>
+<span class="sourceLineNo">614</span>   */<a name="line.614"></a>
+<span class="sourceLineNo">615</span>  static int longToInt(final long l) {<a name="line.615"></a>
+<span class="sourceLineNo">616</span>    // Expecting the size() of a block not exceeding 4GB. Assuming the<a name="line.616"></a>
+<span class="sourceLineNo">617</span>    // size() will wrap to negative integer if it exceeds 2GB (From tfile).<a name="line.617"></a>
+<span class="sourceLineNo">618</span>    return (int)(l &amp; 0x00000000ffffffffL);<a name="line.618"></a>
+<span class="sourceLineNo">619</span>  }<a name="line.619"></a>
+<span class="sourceLineNo">620</span><a name="line.620"></a>
+<span class="sourceLineNo">621</span>  /**<a name="line.621"></a>
+<span class="sourceLineNo">622</span>   * Returns all HFiles belonging to the given region directory. Could return an<a name="line.622"></a>
+<span class="sourceLineNo">623</span>   * empty list.<a name="line.623"></a>
+<span class="sourceLineNo">624</span>   *<a name="line.624"></a>
+<span class="sourceLineNo">625</span>   * @param fs  The file system reference.<a name="line.625"></a>
+<span class="sourceLineNo">626</span>   * @param regionDir  The region directory to scan.<a name="line.626"></a>
+<span class="sourceLineNo">627</span>   * @return The list of files found.<a name="line.627"></a>
+<span class="sourceLineNo">628</span>   * @throws IOException When scanning the files fails.<a name="line.628"></a>
+<span class="sourceLineNo">629</span>   */<a name="line.629"></a>
+<span class="sourceLineNo">630</span>  public static List&lt;Path&gt; getStoreFiles(FileSystem fs, Path regionDir)<a name="line.630"></a>
+<span class="sourceLineNo">631</span>      throws IOException {<a name="line.631"></a>
+<span class="sourceLineNo">632</span>    List&lt;Path&gt; regionHFiles = new ArrayList&lt;&gt;();<a name="line.632"></a>
+<span class="sourceLineNo">633</span>    PathFilter dirFilter = new FSUtils.DirFilter(fs);<a name="line.633"></a>
+<span class="sourceLineNo">634</span>    FileStatus[] familyDirs = fs.listStatus(regionDir, dirFilter);<a name="line.634"></a>
+<span class="sourceLineNo">635</span>    for(FileStatus dir : familyDirs) {<a name="line.635"></a>
+<span class="sourceLineNo">636</span>      FileStatus[] files = fs.listStatus(dir.getPath());<a name="line.636"></a>
+<span class="sourceLineNo">637</span>      for (FileStatus file : files) {<a name="line.637"></a>
+<span class="sourceLineNo">638</span>        if (!file.isDirectory() &amp;&amp;<a name="line.638"></a>
+<span class="sourceLineNo">639</span>            (!file.getPath().toString().contains(HConstants.HREGION_OLDLOGDIR_NAME)) &amp;&amp;<a name="line.639"></a>
+<span class="sourceLineNo">640</span>            (!file.getPath().toString().contains(HConstants.RECOVERED_EDITS_DIR))) {<a name="line.640"></a>
+<span class="sourceLineNo">641</span>          regionHFiles.add(file.getPath());<a name="line.641"></a>
+<span class="sourceLineNo">642</span>        }<a name="line.642"></a>
+<span class="sourceLineNo">643</span>      }<a name="line.643"></a>
+<span class="sourceLineNo">644</span>    }<a name="line.644"></a>
+<span class="sourceLineNo">645</span>    return regionHFiles;<a name="line.645"></a>
+<span class="sourceLineNo">646</span>  }<a name="line.646"></a>
+<span class="sourceLineNo">647</span><a name="line.647"></a>
+<span class="sourceLineNo">648</span>  /**<a name="line.648"></a>
+<span class="sourceLineNo">649</span>   * Checks the given {@link HFile} format version, and throws an exception if<a name="line.649"></a>
+<span class="sourceLineNo">650</span>   * invalid. Note that if the version number comes from an input file and has<a name="line.650"></a>
+<span class="sourceLineNo">651</span>   * not been verified, the caller needs to re-throw an {@link IOException} to<a name="line.651"></a>
+<span class="sourceLineNo">652</span>   * indicate that this is not a software error, but corrupted input.<a name="line.652"></a>
+<span class="sourceLineNo">653</span>   *<a name="line.653"></a>
+<span class="sourceLineNo">654</span>   * @param version an HFile version<a name="line.654"></a>
+<span class="sourceLineNo">655</span>   * @throws IllegalArgumentException if the version is invalid<a name="line.655"></a>
+<span class="sourceLineNo">656</span>   */<a name="line.656"></a>
+<span class="sourceLineNo">657</span>  public static void checkFormatVersion(int version)<a name="line.657"></a>
+<span class="sourceLineNo">658</span>      throws IllegalArgumentException {<a name="line.658"></a>
+<span class="sourceLineNo">659</span>    if (version &lt; MIN_FORMAT_VERSION || version &gt; MAX_FORMAT_VERSION) {<a name="line.659"></a>
+<span class="sourceLineNo">660</span>      throw new IllegalArgumentException("Invalid HFile version: " + version<a name="line.660"></a>
+<span class="sourceLineNo">661</span>          + " (expected to be " + "between " + MIN_FORMAT_VERSION + " and "<a name="line.661"></a>
+<span class="sourceLineNo">662</span>          + MAX_FORMAT_VERSION + ")");<a name="line.662"></a>
+<span class="sourceLineNo">663</span>    }<a name="line.663"></a>
+<span class="sourceLineNo">664</span>  }<a name="line.664"></a>
 <span class="sourceLineNo">665</span><a name="line.665"></a>
-<span class="sourceLineNo">666</span>  public static void checkHFileVersion(final Configuration c) {<a name="line.666"></a>
-<span class="sourceLineNo">667</span>    int version = c.getInt(FORMAT_VERSION_KEY, MAX_FORMAT_VERSION);<a name="line.667"></a>
-<span class="sourceLineNo">668</span>    if (version &lt; MAX_FORMAT_VERSION || version &gt; MAX_FORMAT_VERSION) {<a name="line.668"></a>
-<span class="sourceLineNo">669</span>      throw new IllegalArgumentException("The setting for " + FORMAT_VERSION_KEY +<a name="line.669"></a>
-<span class="sourceLineNo">670</span>        " (in your hbase-*.xml files) is " + version + " which does not match " +<a name="line.670"></a>
-<span class="sourceLineNo">671</span>        MAX_FORMAT_VERSION +<a name="line.671"></a>
-<span class="sourceLineNo">672</span>        "; are you running with a configuration from an older or newer hbase install (an " +<a name="line.672"></a>
-<span class="sourceLineNo">673</span>        "incompatible hbase-default.xml or hbase-site.xml on your CLASSPATH)?");<a name="line.673"></a>
-<span class="sourceLineNo">674</span>    }<a name="line.674"></a>
-<span class="sourceLineNo">675</span>  }<a name="line.675"></a>
-<span class="sourceLineNo">676</span><a name="line.676"></a>
-<span class="sourceLineNo">677</span>  public static void main(String[] args) throws Exception {<a name="line.677"></a>
-<span class="sourceLineNo">678</span>    // delegate to preserve old behavior<a name="line.678"></a>
-<span class="sourceLineNo">679</span>    HFilePrettyPrinter.main(args);<a name="line.679"></a>
-<span class="sourceLineNo">680</span>  }<a name="line.680"></a>
-<span class="sourceLineNo">681</span>}<a name="line.681"></a>
+<span class="sourceLineNo">666</span><a name="line.666"></a>
+<span class="sourceLineNo">667</span>  public static void checkHFileVersion(final Configuration c) {<a name="line.667"></a>
+<span class="sourceLineNo">668</span>    int version = c.getInt(FORMAT_VERSION_KEY, MAX_FORMAT_VERSION);<a name="line.668"></a>
+<span class="sourceLineNo">669</span>    if (version &lt; MAX_FORMAT_VERSION || version &gt; MAX_FORMAT_VERSION) {<a name="line.669"></a>
+<span class="sourceLineNo">670</span>      throw new IllegalArgumentException("The setting for " + FORMAT_VERSION_KEY +<a name="line.670"></a>
+<span class="sourceLineNo">671</span>        " (in your hbase-*.xml files) is " + version + " which does not match " +<a name="line.671"></a>
+<span class="sourceLineNo">672</span>        MAX_FORMAT_VERSION +<a name="line.672"></a>
+<span class="sourceLineNo">673</span>        "; are you running with a configuration from an older or newer hbase install (an " +<a name="line.673"></a>
+<span class="sourceLineNo">674</span>        "incompatible hbase-default.xml or hbase-site.xml on your CLASSPATH)?");<a name="line.674"></a>
+<span class="sourceLineNo">675</span>    }<a name="line.675"></a>
+<span class="sourceLineNo">676</span>  }<a name="line.676"></a>
+<span class="sourceLineNo">677</span><a name="line.677"></a>
+<span class="sourceLineNo">678</span>  public static void main(String[] args) throws Exception {<a name="line.678"></a>
+<span class="sourceLineNo">679</span>    // delegate to preserve old behavior<a name="line.679"></a>
+<span class="sourceLineNo">680</span>    HFilePrettyPrinter.main(args);<a name="line.680"></a>
+<span class="sourceLineNo">681</span>  }<a name="line.681"></a>
+<span class="sourceLineNo">682</span>}<a name="line.682"></a>
 
 
 
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.html b/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.html
index a82ba7f..2a91d20 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.html
@@ -513,180 +513,181 @@
 <span class="sourceLineNo">505</span>          throw new IllegalArgumentException("Invalid HFile version " + trailer.getMajorVersion());<a name="line.505"></a>
 <span class="sourceLineNo">506</span>      }<a name="line.506"></a>
 <span class="sourceLineNo">507</span>    } catch (Throwable t) {<a name="line.507"></a>
-<span class="sourceLineNo">508</span>      IOUtils.closeQuietly(context.getInputStreamWrapper());<a name="line.508"></a>
-<span class="sourceLineNo">509</span>      throw new CorruptHFileException("Problem reading HFile Trailer from file "<a name="line.509"></a>
-<span class="sourceLineNo">510</span>          + context.getFilePath(), t);<a name="line.510"></a>
-<span class="sourceLineNo">511</span>    } finally {<a name="line.511"></a>
-<span class="sourceLineNo">512</span>      context.getInputStreamWrapper().unbuffer();<a name="line.512"></a>
-<span class="sourceLineNo">513</span>    }<a name="line.513"></a>
-<span class="sourceLineNo">514</span>  }<a name="line.514"></a>
-<span class="sourceLineNo">515</span><a name="line.515"></a>
-<span class="sourceLineNo">516</span>  /**<a name="line.516"></a>
-<span class="sourceLineNo">517</span>   * Creates reader with cache configuration disabled<a name="line.517"></a>
-<span class="sourceLineNo">518</span>   * @param fs filesystem<a name="line.518"></a>
-<span class="sourceLineNo">519</span>   * @param path Path to file to read<a name="line.519"></a>
-<span class="sourceLineNo">520</span>   * @param conf Configuration<a name="line.520"></a>
-<span class="sourceLineNo">521</span>   * @return an active Reader instance<a name="line.521"></a>
-<span class="sourceLineNo">522</span>   * @throws IOException Will throw a CorruptHFileException<a name="line.522"></a>
-<span class="sourceLineNo">523</span>   *   (DoNotRetryIOException subtype) if hfile is corrupt/invalid.<a name="line.523"></a>
-<span class="sourceLineNo">524</span>   */<a name="line.524"></a>
-<span class="sourceLineNo">525</span>  public static Reader createReader(FileSystem fs, Path path, Configuration conf)<a name="line.525"></a>
-<span class="sourceLineNo">526</span>      throws IOException {<a name="line.526"></a>
-<span class="sourceLineNo">527</span>    // The primaryReplicaReader is mainly used for constructing block cache key, so if we do not use<a name="line.527"></a>
-<span class="sourceLineNo">528</span>    // block cache then it is OK to set it as any value. We use true here.<a name="line.528"></a>
-<span class="sourceLineNo">529</span>    return createReader(fs, path, CacheConfig.DISABLED, true, conf);<a name="line.529"></a>
-<span class="sourceLineNo">530</span>  }<a name="line.530"></a>
-<span class="sourceLineNo">531</span><a name="line.531"></a>
-<span class="sourceLineNo">532</span>  /**<a name="line.532"></a>
-<span class="sourceLineNo">533</span>   * @param fs filesystem<a name="line.533"></a>
-<span class="sourceLineNo">534</span>   * @param path Path to file to read<a name="line.534"></a>
-<span class="sourceLineNo">535</span>   * @param cacheConf This must not be null. @see<a name="line.535"></a>
-<span class="sourceLineNo">536</span>   *          {@link org.apache.hadoop.hbase.io.hfile.CacheConfig#CacheConfig(Configuration)}<a name="line.536"></a>
-<span class="sourceLineNo">537</span>   * @param primaryReplicaReader true if this is a reader for primary replica<a name="line.537"></a>
-<span class="sourceLineNo">538</span>   * @param conf Configuration<a name="line.538"></a>
-<span class="sourceLineNo">539</span>   * @return an active Reader instance<a name="line.539"></a>
-<span class="sourceLineNo">540</span>   * @throws IOException Will throw a CorruptHFileException (DoNotRetryIOException subtype) if hfile<a name="line.540"></a>
-<span class="sourceLineNo">541</span>   *           is corrupt/invalid.<a name="line.541"></a>
-<span class="sourceLineNo">542</span>   */<a name="line.542"></a>
-<span class="sourceLineNo">543</span>  public static Reader createReader(FileSystem fs, Path path, CacheConfig cacheConf,<a name="line.543"></a>
-<span class="sourceLineNo">544</span>      boolean primaryReplicaReader, Configuration conf) throws IOException {<a name="line.544"></a>
-<span class="sourceLineNo">545</span>    Preconditions.checkNotNull(cacheConf, "Cannot create Reader with null CacheConf");<a name="line.545"></a>
-<span class="sourceLineNo">546</span>    FSDataInputStreamWrapper stream = new FSDataInputStreamWrapper(fs, path);<a name="line.546"></a>
-<span class="sourceLineNo">547</span>    ReaderContext context = new ReaderContextBuilder()<a name="line.547"></a>
-<span class="sourceLineNo">548</span>        .withFilePath(path)<a name="line.548"></a>
-<span class="sourceLineNo">549</span>        .withInputStreamWrapper(stream)<a name="line.549"></a>
-<span class="sourceLineNo">550</span>        .withFileSize(fs.getFileStatus(path).getLen())<a name="line.550"></a>
-<span class="sourceLineNo">551</span>        .withFileSystem(stream.getHfs())<a name="line.551"></a>
-<span class="sourceLineNo">552</span>        .withPrimaryReplicaReader(primaryReplicaReader)<a name="line.552"></a>
-<span class="sourceLineNo">553</span>        .withReaderType(ReaderType.PREAD)<a name="line.553"></a>
-<span class="sourceLineNo">554</span>        .build();<a name="line.554"></a>
-<span class="sourceLineNo">555</span>    HFileInfo fileInfo = new HFileInfo(context, conf);<a name="line.555"></a>
-<span class="sourceLineNo">556</span>    Reader reader = createReader(context, fileInfo, cacheConf, conf);<a name="line.556"></a>
-<span class="sourceLineNo">557</span>    fileInfo.initMetaAndIndex(reader);<a name="line.557"></a>
-<span class="sourceLineNo">558</span>    return reader;<a name="line.558"></a>
-<span class="sourceLineNo">559</span>  }<a name="line.559"></a>
-<span class="sourceLineNo">560</span><a name="line.560"></a>
-<span class="sourceLineNo">561</span>  /**<a name="line.561"></a>
-<span class="sourceLineNo">562</span>   * Returns true if the specified file has a valid HFile Trailer.<a name="line.562"></a>
-<span class="sourceLineNo">563</span>   * @param fs filesystem<a name="line.563"></a>
-<span class="sourceLineNo">564</span>   * @param path Path to file to verify<a name="line.564"></a>
-<span class="sourceLineNo">565</span>   * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.565"></a>
-<span class="sourceLineNo">566</span>   * @throws IOException if failed to read from the underlying stream<a name="line.566"></a>
-<span class="sourceLineNo">567</span>   */<a name="line.567"></a>
-<span class="sourceLineNo">568</span>  public static boolean isHFileFormat(final FileSystem fs, final Path path) throws IOException {<a name="line.568"></a>
-<span class="sourceLineNo">569</span>    return isHFileFormat(fs, fs.getFileStatus(path));<a name="line.569"></a>
-<span class="sourceLineNo">570</span>  }<a name="line.570"></a>
-<span class="sourceLineNo">571</span><a name="line.571"></a>
-<span class="sourceLineNo">572</span>  /**<a name="line.572"></a>
-<span class="sourceLineNo">573</span>   * Returns true if the specified file has a valid HFile Trailer.<a name="line.573"></a>
-<span class="sourceLineNo">574</span>   * @param fs filesystem<a name="line.574"></a>
-<span class="sourceLineNo">575</span>   * @param fileStatus the file to verify<a name="line.575"></a>
-<span class="sourceLineNo">576</span>   * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.576"></a>
-<span class="sourceLineNo">577</span>   * @throws IOException if failed to read from the underlying stream<a name="line.577"></a>
-<span class="sourceLineNo">578</span>   */<a name="line.578"></a>
-<span class="sourceLineNo">579</span>  public static boolean isHFileFormat(final FileSystem fs, final FileStatus fileStatus)<a name="line.579"></a>
-<span class="sourceLineNo">580</span>      throws IOException {<a name="line.580"></a>
-<span class="sourceLineNo">581</span>    final Path path = fileStatus.getPath();<a name="line.581"></a>
-<span class="sourceLineNo">582</span>    final long size = fileStatus.getLen();<a name="line.582"></a>
-<span class="sourceLineNo">583</span>    try (FSDataInputStreamWrapper fsdis = new FSDataInputStreamWrapper(fs, path)) {<a name="line.583"></a>
-<span class="sourceLineNo">584</span>      boolean isHBaseChecksum = fsdis.shouldUseHBaseChecksum();<a name="line.584"></a>
-<span class="sourceLineNo">585</span>      assert !isHBaseChecksum; // Initially we must read with FS checksum.<a name="line.585"></a>
-<span class="sourceLineNo">586</span>      FixedFileTrailer.readFromStream(fsdis.getStream(isHBaseChecksum), size);<a name="line.586"></a>
-<span class="sourceLineNo">587</span>      return true;<a name="line.587"></a>
-<span class="sourceLineNo">588</span>    } catch (IllegalArgumentException e) {<a name="line.588"></a>
-<span class="sourceLineNo">589</span>      return false;<a name="line.589"></a>
-<span class="sourceLineNo">590</span>    }<a name="line.590"></a>
-<span class="sourceLineNo">591</span>  }<a name="line.591"></a>
-<span class="sourceLineNo">592</span><a name="line.592"></a>
-<span class="sourceLineNo">593</span>  /**<a name="line.593"></a>
-<span class="sourceLineNo">594</span>   * Get names of supported compression algorithms. The names are acceptable by<a name="line.594"></a>
-<span class="sourceLineNo">595</span>   * HFile.Writer.<a name="line.595"></a>
-<span class="sourceLineNo">596</span>   *<a name="line.596"></a>
-<span class="sourceLineNo">597</span>   * @return Array of strings, each represents a supported compression<a name="line.597"></a>
-<span class="sourceLineNo">598</span>   *         algorithm. Currently, the following compression algorithms are<a name="line.598"></a>
-<span class="sourceLineNo">599</span>   *         supported.<a name="line.599"></a>
-<span class="sourceLineNo">600</span>   *         &lt;ul&gt;<a name="line.600"></a>
-<span class="sourceLineNo">601</span>   *         &lt;li&gt;"none" - No compression.<a name="line.601"></a>
-<span class="sourceLineNo">602</span>   *         &lt;li&gt;"gz" - GZIP compression.<a name="line.602"></a>
-<span class="sourceLineNo">603</span>   *         &lt;/ul&gt;<a name="line.603"></a>
-<span class="sourceLineNo">604</span>   */<a name="line.604"></a>
-<span class="sourceLineNo">605</span>  public static String[] getSupportedCompressionAlgorithms() {<a name="line.605"></a>
-<span class="sourceLineNo">606</span>    return Compression.getSupportedAlgorithms();<a name="line.606"></a>
-<span class="sourceLineNo">607</span>  }<a name="line.607"></a>
-<span class="sourceLineNo">608</span><a name="line.608"></a>
-<span class="sourceLineNo">609</span>  // Utility methods.<a name="line.609"></a>
-<span class="sourceLineNo">610</span>  /*<a name="line.610"></a>
-<span class="sourceLineNo">611</span>   * @param l Long to convert to an int.<a name="line.611"></a>
-<span class="sourceLineNo">612</span>   * @return &lt;code&gt;l&lt;/code&gt; cast as an int.<a name="line.612"></a>
-<span class="sourceLineNo">613</span>   */<a name="line.613"></a>
-<span class="sourceLineNo">614</span>  static int longToInt(final long l) {<a name="line.614"></a>
-<span class="sourceLineNo">615</span>    // Expecting the size() of a block not exceeding 4GB. Assuming the<a name="line.615"></a>
-<span class="sourceLineNo">616</span>    // size() will wrap to negative integer if it exceeds 2GB (From tfile).<a name="line.616"></a>
-<span class="sourceLineNo">617</span>    return (int)(l &amp; 0x00000000ffffffffL);<a name="line.617"></a>
-<span class="sourceLineNo">618</span>  }<a name="line.618"></a>
-<span class="sourceLineNo">619</span><a name="line.619"></a>
-<span class="sourceLineNo">620</span>  /**<a name="line.620"></a>
-<span class="sourceLineNo">621</span>   * Returns all HFiles belonging to the given region directory. Could return an<a name="line.621"></a>
-<span class="sourceLineNo">622</span>   * empty list.<a name="line.622"></a>
-<span class="sourceLineNo">623</span>   *<a name="line.623"></a>
-<span class="sourceLineNo">624</span>   * @param fs  The file system reference.<a name="line.624"></a>
-<span class="sourceLineNo">625</span>   * @param regionDir  The region directory to scan.<a name="line.625"></a>
-<span class="sourceLineNo">626</span>   * @return The list of files found.<a name="line.626"></a>
-<span class="sourceLineNo">627</span>   * @throws IOException When scanning the files fails.<a name="line.627"></a>
-<span class="sourceLineNo">628</span>   */<a name="line.628"></a>
-<span class="sourceLineNo">629</span>  public static List&lt;Path&gt; getStoreFiles(FileSystem fs, Path regionDir)<a name="line.629"></a>
-<span class="sourceLineNo">630</span>      throws IOException {<a name="line.630"></a>
-<span class="sourceLineNo">631</span>    List&lt;Path&gt; regionHFiles = new ArrayList&lt;&gt;();<a name="line.631"></a>
-<span class="sourceLineNo">632</span>    PathFilter dirFilter = new FSUtils.DirFilter(fs);<a name="line.632"></a>
-<span class="sourceLineNo">633</span>    FileStatus[] familyDirs = fs.listStatus(regionDir, dirFilter);<a name="line.633"></a>
-<span class="sourceLineNo">634</span>    for(FileStatus dir : familyDirs) {<a name="line.634"></a>
-<span class="sourceLineNo">635</span>      FileStatus[] files = fs.listStatus(dir.getPath());<a name="line.635"></a>
-<span class="sourceLineNo">636</span>      for (FileStatus file : files) {<a name="line.636"></a>
-<span class="sourceLineNo">637</span>        if (!file.isDirectory() &amp;&amp;<a name="line.637"></a>
-<span class="sourceLineNo">638</span>            (!file.getPath().toString().contains(HConstants.HREGION_OLDLOGDIR_NAME)) &amp;&amp;<a name="line.638"></a>
-<span class="sourceLineNo">639</span>            (!file.getPath().toString().contains(HConstants.RECOVERED_EDITS_DIR))) {<a name="line.639"></a>
-<span class="sourceLineNo">640</span>          regionHFiles.add(file.getPath());<a name="line.640"></a>
-<span class="sourceLineNo">641</span>        }<a name="line.641"></a>
-<span class="sourceLineNo">642</span>      }<a name="line.642"></a>
-<span class="sourceLineNo">643</span>    }<a name="line.643"></a>
-<span class="sourceLineNo">644</span>    return regionHFiles;<a name="line.644"></a>
-<span class="sourceLineNo">645</span>  }<a name="line.645"></a>
-<span class="sourceLineNo">646</span><a name="line.646"></a>
-<span class="sourceLineNo">647</span>  /**<a name="line.647"></a>
-<span class="sourceLineNo">648</span>   * Checks the given {@link HFile} format version, and throws an exception if<a name="line.648"></a>
-<span class="sourceLineNo">649</span>   * invalid. Note that if the version number comes from an input file and has<a name="line.649"></a>
-<span class="sourceLineNo">650</span>   * not been verified, the caller needs to re-throw an {@link IOException} to<a name="line.650"></a>
-<span class="sourceLineNo">651</span>   * indicate that this is not a software error, but corrupted input.<a name="line.651"></a>
-<span class="sourceLineNo">652</span>   *<a name="line.652"></a>
-<span class="sourceLineNo">653</span>   * @param version an HFile version<a name="line.653"></a>
-<span class="sourceLineNo">654</span>   * @throws IllegalArgumentException if the version is invalid<a name="line.654"></a>
-<span class="sourceLineNo">655</span>   */<a name="line.655"></a>
-<span class="sourceLineNo">656</span>  public static void checkFormatVersion(int version)<a name="line.656"></a>
-<span class="sourceLineNo">657</span>      throws IllegalArgumentException {<a name="line.657"></a>
-<span class="sourceLineNo">658</span>    if (version &lt; MIN_FORMAT_VERSION || version &gt; MAX_FORMAT_VERSION) {<a name="line.658"></a>
-<span class="sourceLineNo">659</span>      throw new IllegalArgumentException("Invalid HFile version: " + version<a name="line.659"></a>
-<span class="sourceLineNo">660</span>          + " (expected to be " + "between " + MIN_FORMAT_VERSION + " and "<a name="line.660"></a>
-<span class="sourceLineNo">661</span>          + MAX_FORMAT_VERSION + ")");<a name="line.661"></a>
-<span class="sourceLineNo">662</span>    }<a name="line.662"></a>
-<span class="sourceLineNo">663</span>  }<a name="line.663"></a>
-<span class="sourceLineNo">664</span><a name="line.664"></a>
+<span class="sourceLineNo">508</span>      IOUtils.closeQuietly(context.getInputStreamWrapper(),<a name="line.508"></a>
+<span class="sourceLineNo">509</span>        e -&gt; LOG.warn("failed to close input stream wrapper", e));<a name="line.509"></a>
+<span class="sourceLineNo">510</span>      throw new CorruptHFileException("Problem reading HFile Trailer from file "<a name="line.510"></a>
+<span class="sourceLineNo">511</span>          + context.getFilePath(), t);<a name="line.511"></a>
+<span class="sourceLineNo">512</span>    } finally {<a name="line.512"></a>
+<span class="sourceLineNo">513</span>      context.getInputStreamWrapper().unbuffer();<a name="line.513"></a>
+<span class="sourceLineNo">514</span>    }<a name="line.514"></a>
+<span class="sourceLineNo">515</span>  }<a name="line.515"></a>
+<span class="sourceLineNo">516</span><a name="line.516"></a>
+<span class="sourceLineNo">517</span>  /**<a name="line.517"></a>
+<span class="sourceLineNo">518</span>   * Creates reader with cache configuration disabled<a name="line.518"></a>
+<span class="sourceLineNo">519</span>   * @param fs filesystem<a name="line.519"></a>
+<span class="sourceLineNo">520</span>   * @param path Path to file to read<a name="line.520"></a>
+<span class="sourceLineNo">521</span>   * @param conf Configuration<a name="line.521"></a>
+<span class="sourceLineNo">522</span>   * @return an active Reader instance<a name="line.522"></a>
+<span class="sourceLineNo">523</span>   * @throws IOException Will throw a CorruptHFileException<a name="line.523"></a>
+<span class="sourceLineNo">524</span>   *   (DoNotRetryIOException subtype) if hfile is corrupt/invalid.<a name="line.524"></a>
+<span class="sourceLineNo">525</span>   */<a name="line.525"></a>
+<span class="sourceLineNo">526</span>  public static Reader createReader(FileSystem fs, Path path, Configuration conf)<a name="line.526"></a>
+<span class="sourceLineNo">527</span>      throws IOException {<a name="line.527"></a>
+<span class="sourceLineNo">528</span>    // The primaryReplicaReader is mainly used for constructing block cache key, so if we do not use<a name="line.528"></a>
+<span class="sourceLineNo">529</span>    // block cache then it is OK to set it as any value. We use true here.<a name="line.529"></a>
+<span class="sourceLineNo">530</span>    return createReader(fs, path, CacheConfig.DISABLED, true, conf);<a name="line.530"></a>
+<span class="sourceLineNo">531</span>  }<a name="line.531"></a>
+<span class="sourceLineNo">532</span><a name="line.532"></a>
+<span class="sourceLineNo">533</span>  /**<a name="line.533"></a>
+<span class="sourceLineNo">534</span>   * @param fs filesystem<a name="line.534"></a>
+<span class="sourceLineNo">535</span>   * @param path Path to file to read<a name="line.535"></a>
+<span class="sourceLineNo">536</span>   * @param cacheConf This must not be null. @see<a name="line.536"></a>
+<span class="sourceLineNo">537</span>   *          {@link org.apache.hadoop.hbase.io.hfile.CacheConfig#CacheConfig(Configuration)}<a name="line.537"></a>
+<span class="sourceLineNo">538</span>   * @param primaryReplicaReader true if this is a reader for primary replica<a name="line.538"></a>
+<span class="sourceLineNo">539</span>   * @param conf Configuration<a name="line.539"></a>
+<span class="sourceLineNo">540</span>   * @return an active Reader instance<a name="line.540"></a>
+<span class="sourceLineNo">541</span>   * @throws IOException Will throw a CorruptHFileException (DoNotRetryIOException subtype) if hfile<a name="line.541"></a>
+<span class="sourceLineNo">542</span>   *           is corrupt/invalid.<a name="line.542"></a>
+<span class="sourceLineNo">543</span>   */<a name="line.543"></a>
+<span class="sourceLineNo">544</span>  public static Reader createReader(FileSystem fs, Path path, CacheConfig cacheConf,<a name="line.544"></a>
+<span class="sourceLineNo">545</span>      boolean primaryReplicaReader, Configuration conf) throws IOException {<a name="line.545"></a>
+<span class="sourceLineNo">546</span>    Preconditions.checkNotNull(cacheConf, "Cannot create Reader with null CacheConf");<a name="line.546"></a>
+<span class="sourceLineNo">547</span>    FSDataInputStreamWrapper stream = new FSDataInputStreamWrapper(fs, path);<a name="line.547"></a>
+<span class="sourceLineNo">548</span>    ReaderContext context = new ReaderContextBuilder()<a name="line.548"></a>
+<span class="sourceLineNo">549</span>        .withFilePath(path)<a name="line.549"></a>
+<span class="sourceLineNo">550</span>        .withInputStreamWrapper(stream)<a name="line.550"></a>
+<span class="sourceLineNo">551</span>        .withFileSize(fs.getFileStatus(path).getLen())<a name="line.551"></a>
+<span class="sourceLineNo">552</span>        .withFileSystem(stream.getHfs())<a name="line.552"></a>
+<span class="sourceLineNo">553</span>        .withPrimaryReplicaReader(primaryReplicaReader)<a name="line.553"></a>
+<span class="sourceLineNo">554</span>        .withReaderType(ReaderType.PREAD)<a name="line.554"></a>
+<span class="sourceLineNo">555</span>        .build();<a name="line.555"></a>
+<span class="sourceLineNo">556</span>    HFileInfo fileInfo = new HFileInfo(context, conf);<a name="line.556"></a>
+<span class="sourceLineNo">557</span>    Reader reader = createReader(context, fileInfo, cacheConf, conf);<a name="line.557"></a>
+<span class="sourceLineNo">558</span>    fileInfo.initMetaAndIndex(reader);<a name="line.558"></a>
+<span class="sourceLineNo">559</span>    return reader;<a name="line.559"></a>
+<span class="sourceLineNo">560</span>  }<a name="line.560"></a>
+<span class="sourceLineNo">561</span><a name="line.561"></a>
+<span class="sourceLineNo">562</span>  /**<a name="line.562"></a>
+<span class="sourceLineNo">563</span>   * Returns true if the specified file has a valid HFile Trailer.<a name="line.563"></a>
+<span class="sourceLineNo">564</span>   * @param fs filesystem<a name="line.564"></a>
+<span class="sourceLineNo">565</span>   * @param path Path to file to verify<a name="line.565"></a>
+<span class="sourceLineNo">566</span>   * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.566"></a>
+<span class="sourceLineNo">567</span>   * @throws IOException if failed to read from the underlying stream<a name="line.567"></a>
+<span class="sourceLineNo">568</span>   */<a name="line.568"></a>
+<span class="sourceLineNo">569</span>  public static boolean isHFileFormat(final FileSystem fs, final Path path) throws IOException {<a name="line.569"></a>
+<span class="sourceLineNo">570</span>    return isHFileFormat(fs, fs.getFileStatus(path));<a name="line.570"></a>
+<span class="sourceLineNo">571</span>  }<a name="line.571"></a>
+<span class="sourceLineNo">572</span><a name="line.572"></a>
+<span class="sourceLineNo">573</span>  /**<a name="line.573"></a>
+<span class="sourceLineNo">574</span>   * Returns true if the specified file has a valid HFile Trailer.<a name="line.574"></a>
+<span class="sourceLineNo">575</span>   * @param fs filesystem<a name="line.575"></a>
+<span class="sourceLineNo">576</span>   * @param fileStatus the file to verify<a name="line.576"></a>
+<span class="sourceLineNo">577</span>   * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.577"></a>
+<span class="sourceLineNo">578</span>   * @throws IOException if failed to read from the underlying stream<a name="line.578"></a>
+<span class="sourceLineNo">579</span>   */<a name="line.579"></a>
+<span class="sourceLineNo">580</span>  public static boolean isHFileFormat(final FileSystem fs, final FileStatus fileStatus)<a name="line.580"></a>
+<span class="sourceLineNo">581</span>      throws IOException {<a name="line.581"></a>
+<span class="sourceLineNo">582</span>    final Path path = fileStatus.getPath();<a name="line.582"></a>
+<span class="sourceLineNo">583</span>    final long size = fileStatus.getLen();<a name="line.583"></a>
+<span class="sourceLineNo">584</span>    try (FSDataInputStreamWrapper fsdis = new FSDataInputStreamWrapper(fs, path)) {<a name="line.584"></a>
+<span class="sourceLineNo">585</span>      boolean isHBaseChecksum = fsdis.shouldUseHBaseChecksum();<a name="line.585"></a>
+<span class="sourceLineNo">586</span>      assert !isHBaseChecksum; // Initially we must read with FS checksum.<a name="line.586"></a>
+<span class="sourceLineNo">587</span>      FixedFileTrailer.readFromStream(fsdis.getStream(isHBaseChecksum), size);<a name="line.587"></a>
+<span class="sourceLineNo">588</span>      return true;<a name="line.588"></a>
+<span class="sourceLineNo">589</span>    } catch (IllegalArgumentException e) {<a name="line.589"></a>
+<span class="sourceLineNo">590</span>      return false;<a name="line.590"></a>
+<span class="sourceLineNo">591</span>    }<a name="line.591"></a>
+<span class="sourceLineNo">592</span>  }<a name="line.592"></a>
+<span class="sourceLineNo">593</span><a name="line.593"></a>
+<span class="sourceLineNo">594</span>  /**<a name="line.594"></a>
+<span class="sourceLineNo">595</span>   * Get names of supported compression algorithms. The names are acceptable by<a name="line.595"></a>
+<span class="sourceLineNo">596</span>   * HFile.Writer.<a name="line.596"></a>
+<span class="sourceLineNo">597</span>   *<a name="line.597"></a>
+<span class="sourceLineNo">598</span>   * @return Array of strings, each represents a supported compression<a name="line.598"></a>
+<span class="sourceLineNo">599</span>   *         algorithm. Currently, the following compression algorithms are<a name="line.599"></a>
+<span class="sourceLineNo">600</span>   *         supported.<a name="line.600"></a>
+<span class="sourceLineNo">601</span>   *         &lt;ul&gt;<a name="line.601"></a>
+<span class="sourceLineNo">602</span>   *         &lt;li&gt;"none" - No compression.<a name="line.602"></a>
+<span class="sourceLineNo">603</span>   *         &lt;li&gt;"gz" - GZIP compression.<a name="line.603"></a>
+<span class="sourceLineNo">604</span>   *         &lt;/ul&gt;<a name="line.604"></a>
+<span class="sourceLineNo">605</span>   */<a name="line.605"></a>
+<span class="sourceLineNo">606</span>  public static String[] getSupportedCompressionAlgorithms() {<a name="line.606"></a>
+<span class="sourceLineNo">607</span>    return Compression.getSupportedAlgorithms();<a name="line.607"></a>
+<span class="sourceLineNo">608</span>  }<a name="line.608"></a>
+<span class="sourceLineNo">609</span><a name="line.609"></a>
+<span class="sourceLineNo">610</span>  // Utility methods.<a name="line.610"></a>
+<span class="sourceLineNo">611</span>  /*<a name="line.611"></a>
+<span class="sourceLineNo">612</span>   * @param l Long to convert to an int.<a name="line.612"></a>
+<span class="sourceLineNo">613</span>   * @return &lt;code&gt;l&lt;/code&gt; cast as an int.<a name="line.613"></a>
+<span class="sourceLineNo">614</span>   */<a name="line.614"></a>
+<span class="sourceLineNo">615</span>  static int longToInt(final long l) {<a name="line.615"></a>
+<span class="sourceLineNo">616</span>    // Expecting the size() of a block not exceeding 4GB. Assuming the<a name="line.616"></a>
+<span class="sourceLineNo">617</span>    // size() will wrap to negative integer if it exceeds 2GB (From tfile).<a name="line.617"></a>
+<span class="sourceLineNo">618</span>    return (int)(l &amp; 0x00000000ffffffffL);<a name="line.618"></a>
+<span class="sourceLineNo">619</span>  }<a name="line.619"></a>
+<span class="sourceLineNo">620</span><a name="line.620"></a>
+<span class="sourceLineNo">621</span>  /**<a name="line.621"></a>
+<span class="sourceLineNo">622</span>   * Returns all HFiles belonging to the given region directory. Could return an<a name="line.622"></a>
+<span class="sourceLineNo">623</span>   * empty list.<a name="line.623"></a>
+<span class="sourceLineNo">624</span>   *<a name="line.624"></a>
+<span class="sourceLineNo">625</span>   * @param fs  The file system reference.<a name="line.625"></a>
+<span class="sourceLineNo">626</span>   * @param regionDir  The region directory to scan.<a name="line.626"></a>
+<span class="sourceLineNo">627</span>   * @return The list of files found.<a name="line.627"></a>
+<span class="sourceLineNo">628</span>   * @throws IOException When scanning the files fails.<a name="line.628"></a>
+<span class="sourceLineNo">629</span>   */<a name="line.629"></a>
+<span class="sourceLineNo">630</span>  public static List&lt;Path&gt; getStoreFiles(FileSystem fs, Path regionDir)<a name="line.630"></a>
+<span class="sourceLineNo">631</span>      throws IOException {<a name="line.631"></a>
+<span class="sourceLineNo">632</span>    List&lt;Path&gt; regionHFiles = new ArrayList&lt;&gt;();<a name="line.632"></a>
+<span class="sourceLineNo">633</span>    PathFilter dirFilter = new FSUtils.DirFilter(fs);<a name="line.633"></a>
+<span class="sourceLineNo">634</span>    FileStatus[] familyDirs = fs.listStatus(regionDir, dirFilter);<a name="line.634"></a>
+<span class="sourceLineNo">635</span>    for(FileStatus dir : familyDirs) {<a name="line.635"></a>
+<span class="sourceLineNo">636</span>      FileStatus[] files = fs.listStatus(dir.getPath());<a name="line.636"></a>
+<span class="sourceLineNo">637</span>      for (FileStatus file : files) {<a name="line.637"></a>
+<span class="sourceLineNo">638</span>        if (!file.isDirectory() &amp;&amp;<a name="line.638"></a>
+<span class="sourceLineNo">639</span>            (!file.getPath().toString().contains(HConstants.HREGION_OLDLOGDIR_NAME)) &amp;&amp;<a name="line.639"></a>
+<span class="sourceLineNo">640</span>            (!file.getPath().toString().contains(HConstants.RECOVERED_EDITS_DIR))) {<a name="line.640"></a>
+<span class="sourceLineNo">641</span>          regionHFiles.add(file.getPath());<a name="line.641"></a>
+<span class="sourceLineNo">642</span>        }<a name="line.642"></a>
+<span class="sourceLineNo">643</span>      }<a name="line.643"></a>
+<span class="sourceLineNo">644</span>    }<a name="line.644"></a>
+<span class="sourceLineNo">645</span>    return regionHFiles;<a name="line.645"></a>
+<span class="sourceLineNo">646</span>  }<a name="line.646"></a>
+<span class="sourceLineNo">647</span><a name="line.647"></a>
+<span class="sourceLineNo">648</span>  /**<a name="line.648"></a>
+<span class="sourceLineNo">649</span>   * Checks the given {@link HFile} format version, and throws an exception if<a name="line.649"></a>
+<span class="sourceLineNo">650</span>   * invalid. Note that if the version number comes from an input file and has<a name="line.650"></a>
+<span class="sourceLineNo">651</span>   * not been verified, the caller needs to re-throw an {@link IOException} to<a name="line.651"></a>
+<span class="sourceLineNo">652</span>   * indicate that this is not a software error, but corrupted input.<a name="line.652"></a>
+<span class="sourceLineNo">653</span>   *<a name="line.653"></a>
+<span class="sourceLineNo">654</span>   * @param version an HFile version<a name="line.654"></a>
+<span class="sourceLineNo">655</span>   * @throws IllegalArgumentException if the version is invalid<a name="line.655"></a>
+<span class="sourceLineNo">656</span>   */<a name="line.656"></a>
+<span class="sourceLineNo">657</span>  public static void checkFormatVersion(int version)<a name="line.657"></a>
+<span class="sourceLineNo">658</span>      throws IllegalArgumentException {<a name="line.658"></a>
+<span class="sourceLineNo">659</span>    if (version &lt; MIN_FORMAT_VERSION || version &gt; MAX_FORMAT_VERSION) {<a name="line.659"></a>
+<span class="sourceLineNo">660</span>      throw new IllegalArgumentException("Invalid HFile version: " + version<a name="line.660"></a>
+<span class="sourceLineNo">661</span>          + " (expected to be " + "between " + MIN_FORMAT_VERSION + " and "<a name="line.661"></a>
+<span class="sourceLineNo">662</span>          + MAX_FORMAT_VERSION + ")");<a name="line.662"></a>
+<span class="sourceLineNo">663</span>    }<a name="line.663"></a>
+<span class="sourceLineNo">664</span>  }<a name="line.664"></a>
 <span class="sourceLineNo">665</span><a name="line.665"></a>
-<span class="sourceLineNo">666</span>  public static void checkHFileVersion(final Configuration c) {<a name="line.666"></a>
-<span class="sourceLineNo">667</span>    int version = c.getInt(FORMAT_VERSION_KEY, MAX_FORMAT_VERSION);<a name="line.667"></a>
-<span class="sourceLineNo">668</span>    if (version &lt; MAX_FORMAT_VERSION || version &gt; MAX_FORMAT_VERSION) {<a name="line.668"></a>
-<span class="sourceLineNo">669</span>      throw new IllegalArgumentException("The setting for " + FORMAT_VERSION_KEY +<a name="line.669"></a>
-<span class="sourceLineNo">670</span>        " (in your hbase-*.xml files) is " + version + " which does not match " +<a name="line.670"></a>
-<span class="sourceLineNo">671</span>        MAX_FORMAT_VERSION +<a name="line.671"></a>
-<span class="sourceLineNo">672</span>        "; are you running with a configuration from an older or newer hbase install (an " +<a name="line.672"></a>
-<span class="sourceLineNo">673</span>        "incompatible hbase-default.xml or hbase-site.xml on your CLASSPATH)?");<a name="line.673"></a>
-<span class="sourceLineNo">674</span>    }<a name="line.674"></a>
-<span class="sourceLineNo">675</span>  }<a name="line.675"></a>
-<span class="sourceLineNo">676</span><a name="line.676"></a>
-<span class="sourceLineNo">677</span>  public static void main(String[] args) throws Exception {<a name="line.677"></a>
-<span class="sourceLineNo">678</span>    // delegate to preserve old behavior<a name="line.678"></a>
-<span class="sourceLineNo">679</span>    HFilePrettyPrinter.main(args);<a name="line.679"></a>
-<span class="sourceLineNo">680</span>  }<a name="line.680"></a>
-<span class="sourceLineNo">681</span>}<a name="line.681"></a>
+<span class="sourceLineNo">666</span><a name="line.666"></a>
+<span class="sourceLineNo">667</span>  public static void checkHFileVersion(final Configuration c) {<a name="line.667"></a>
+<span class="sourceLineNo">668</span>    int version = c.getInt(FORMAT_VERSION_KEY, MAX_FORMAT_VERSION);<a name="line.668"></a>
+<span class="sourceLineNo">669</span>    if (version &lt; MAX_FORMAT_VERSION || version &gt; MAX_FORMAT_VERSION) {<a name="line.669"></a>
+<span class="sourceLineNo">670</span>      throw new IllegalArgumentException("The setting for " + FORMAT_VERSION_KEY +<a name="line.670"></a>
+<span class="sourceLineNo">671</span>        " (in your hbase-*.xml files) is " + version + " which does not match " +<a name="line.671"></a>
+<span class="sourceLineNo">672</span>        MAX_FORMAT_VERSION +<a name="line.672"></a>
+<span class="sourceLineNo">673</span>        "; are you running with a configuration from an older or newer hbase install (an " +<a name="line.673"></a>
+<span class="sourceLineNo">674</span>        "incompatible hbase-default.xml or hbase-site.xml on your CLASSPATH)?");<a name="line.674"></a>
+<span class="sourceLineNo">675</span>    }<a name="line.675"></a>
+<span class="sourceLineNo">676</span>  }<a name="line.676"></a>
+<span class="sourceLineNo">677</span><a name="line.677"></a>
+<span class="sourceLineNo">678</span>  public static void main(String[] args) throws Exception {<a name="line.678"></a>
+<span class="sourceLineNo">679</span>    // delegate to preserve old behavior<a name="line.679"></a>
+<span class="sourceLineNo">680</span>    HFilePrettyPrinter.main(args);<a name="line.680"></a>
+<span class="sourceLineNo">681</span>  }<a name="line.681"></a>
+<span class="sourceLineNo">682</span>}<a name="line.682"></a>
 
 
 
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html b/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html
index 2bc1603..28cda78 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html
@@ -52,479 +52,488 @@
 <span class="sourceLineNo">044</span>import org.apache.hadoop.hbase.security.EncryptionUtil;<a name="line.44"></a>
 <span class="sourceLineNo">045</span>import org.apache.hadoop.hbase.util.Bytes;<a name="line.45"></a>
 <span class="sourceLineNo">046</span>import org.apache.yetus.audience.InterfaceAudience;<a name="line.46"></a>
-<span class="sourceLineNo">047</span>import org.apache.hbase.thirdparty.com.google.protobuf.UnsafeByteOperations;<a name="line.47"></a>
-<span class="sourceLineNo">048</span>import org.apache.hadoop.hbase.shaded.protobuf.ProtobufUtil;<a name="line.48"></a>
-<span class="sourceLineNo">049</span>import org.apache.hadoop.hbase.shaded.protobuf.generated.HBaseProtos;<a name="line.49"></a>
-<span class="sourceLineNo">050</span>import org.apache.hadoop.hbase.shaded.protobuf.generated.HBaseProtos.BytesBytesPair;<a name="line.50"></a>
-<span class="sourceLineNo">051</span>import org.apache.hadoop.hbase.shaded.protobuf.generated.HFileProtos;<a name="line.51"></a>
-<span class="sourceLineNo">052</span><a name="line.52"></a>
-<span class="sourceLineNo">053</span>/**<a name="line.53"></a>
-<span class="sourceLineNo">054</span> * Metadata Map of attributes for HFile written out as HFile Trailer. Created by the Writer and<a name="line.54"></a>
-<span class="sourceLineNo">055</span> * added to the tail of the file just before close. Metadata includes core attributes such as last<a name="line.55"></a>
-<span class="sourceLineNo">056</span> * key seen, comparator used writing the file, etc. Clients can add their own attributes via<a name="line.56"></a>
-<span class="sourceLineNo">057</span> * {@link #append(byte[], byte[], boolean)} and they'll be persisted and available at read time.<a name="line.57"></a>
-<span class="sourceLineNo">058</span> * Reader creates the HFileInfo on open by reading the tail of the HFile. The parse of the HFile<a name="line.58"></a>
-<span class="sourceLineNo">059</span> * trailer also creates a {@link HFileContext}, a read-only data structure that includes bulk of<a name="line.59"></a>
-<span class="sourceLineNo">060</span> * the HFileInfo and extras that is safe to pass around when working on HFiles.<a name="line.60"></a>
-<span class="sourceLineNo">061</span> * @see HFileContext<a name="line.61"></a>
-<span class="sourceLineNo">062</span> */<a name="line.62"></a>
-<span class="sourceLineNo">063</span>@InterfaceAudience.Private<a name="line.63"></a>
-<span class="sourceLineNo">064</span>public class HFileInfo implements SortedMap&lt;byte[], byte[]&gt; {<a name="line.64"></a>
-<span class="sourceLineNo">065</span>  static final String RESERVED_PREFIX = "hfile.";<a name="line.65"></a>
-<span class="sourceLineNo">066</span>  static final byte[] RESERVED_PREFIX_BYTES = Bytes.toBytes(RESERVED_PREFIX);<a name="line.66"></a>
-<span class="sourceLineNo">067</span>  static final byte [] LASTKEY = Bytes.toBytes(RESERVED_PREFIX + "LASTKEY");<a name="line.67"></a>
-<span class="sourceLineNo">068</span>  static final byte [] AVG_KEY_LEN = Bytes.toBytes(RESERVED_PREFIX + "AVG_KEY_LEN");<a name="line.68"></a>
-<span class="sourceLineNo">069</span>  static final byte [] AVG_VALUE_LEN = Bytes.toBytes(RESERVED_PREFIX + "AVG_VALUE_LEN");<a name="line.69"></a>
-<span class="sourceLineNo">070</span>  static final byte [] CREATE_TIME_TS = Bytes.toBytes(RESERVED_PREFIX + "CREATE_TIME_TS");<a name="line.70"></a>
-<span class="sourceLineNo">071</span>  static final byte [] TAGS_COMPRESSED = Bytes.toBytes(RESERVED_PREFIX + "TAGS_COMPRESSED");<a name="line.71"></a>
-<span class="sourceLineNo">072</span>  public static final byte [] MAX_TAGS_LEN = Bytes.toBytes(RESERVED_PREFIX + "MAX_TAGS_LEN");<a name="line.72"></a>
-<span class="sourceLineNo">073</span>  private final SortedMap&lt;byte [], byte []&gt; map = new TreeMap&lt;&gt;(Bytes.BYTES_COMPARATOR);<a name="line.73"></a>
-<span class="sourceLineNo">074</span><a name="line.74"></a>
-<span class="sourceLineNo">075</span>  /**<a name="line.75"></a>
-<span class="sourceLineNo">076</span>   * We can read files whose major version is v2 IFF their minor version is at least 3.<a name="line.76"></a>
-<span class="sourceLineNo">077</span>   */<a name="line.77"></a>
-<span class="sourceLineNo">078</span>  private static final int MIN_V2_MINOR_VERSION_WITH_PB = 3;<a name="line.78"></a>
-<span class="sourceLineNo">079</span><a name="line.79"></a>
-<span class="sourceLineNo">080</span>  /** Maximum minor version supported by this HFile format */<a name="line.80"></a>
-<span class="sourceLineNo">081</span>  // We went to version 2 when we moved to pb'ing fileinfo and the trailer on<a name="line.81"></a>
-<span class="sourceLineNo">082</span>  // the file. This version can read Writables version 1.<a name="line.82"></a>
-<span class="sourceLineNo">083</span>  static final int MAX_MINOR_VERSION = 3;<a name="line.83"></a>
-<span class="sourceLineNo">084</span><a name="line.84"></a>
-<span class="sourceLineNo">085</span>  /** Last key in the file. Filled in when we read in the file info */<a name="line.85"></a>
-<span class="sourceLineNo">086</span>  private Cell lastKeyCell = null;<a name="line.86"></a>
-<span class="sourceLineNo">087</span>  /** Average key length read from file info */<a name="line.87"></a>
-<span class="sourceLineNo">088</span>  private int avgKeyLen = -1;<a name="line.88"></a>
-<span class="sourceLineNo">089</span>  /** Average value length read from file info */<a name="line.89"></a>
-<span class="sourceLineNo">090</span>  private int avgValueLen = -1;<a name="line.90"></a>
-<span class="sourceLineNo">091</span>  private boolean includesMemstoreTS = false;<a name="line.91"></a>
-<span class="sourceLineNo">092</span>  private boolean decodeMemstoreTS = false;<a name="line.92"></a>
-<span class="sourceLineNo">093</span><a name="line.93"></a>
-<span class="sourceLineNo">094</span>  /**<a name="line.94"></a>
-<span class="sourceLineNo">095</span>   * Blocks read from the load-on-open section, excluding data root index, meta<a name="line.95"></a>
-<span class="sourceLineNo">096</span>   * index, and file info.<a name="line.96"></a>
-<span class="sourceLineNo">097</span>   */<a name="line.97"></a>
-<span class="sourceLineNo">098</span>  private List&lt;HFileBlock&gt; loadOnOpenBlocks = new ArrayList&lt;&gt;();<a name="line.98"></a>
-<span class="sourceLineNo">099</span><a name="line.99"></a>
-<span class="sourceLineNo">100</span>  /**<a name="line.100"></a>
-<span class="sourceLineNo">101</span>   * The iterator will track all blocks in load-on-open section, since we use the<a name="line.101"></a>
-<span class="sourceLineNo">102</span>   * {@link org.apache.hadoop.hbase.io.ByteBuffAllocator} to manage the ByteBuffers in block now,<a name="line.102"></a>
-<span class="sourceLineNo">103</span>   * so we must ensure that deallocate all ByteBuffers in the end.<a name="line.103"></a>
+<span class="sourceLineNo">047</span>import org.slf4j.Logger;<a name="line.47"></a>
+<span class="sourceLineNo">048</span>import org.slf4j.LoggerFactory;<a name="line.48"></a>
+<span class="sourceLineNo">049</span><a name="line.49"></a>
+<span class="sourceLineNo">050</span>import org.apache.hbase.thirdparty.com.google.protobuf.UnsafeByteOperations;<a name="line.50"></a>
+<span class="sourceLineNo">051</span><a name="line.51"></a>
+<span class="sourceLineNo">052</span>import org.apache.hadoop.hbase.shaded.protobuf.ProtobufUtil;<a name="line.52"></a>
+<span class="sourceLineNo">053</span>import org.apache.hadoop.hbase.shaded.protobuf.generated.HBaseProtos;<a name="line.53"></a>
+<span class="sourceLineNo">054</span>import org.apache.hadoop.hbase.shaded.protobuf.generated.HBaseProtos.BytesBytesPair;<a name="line.54"></a>
+<span class="sourceLineNo">055</span>import org.apache.hadoop.hbase.shaded.protobuf.generated.HFileProtos;<a name="line.55"></a>
+<span class="sourceLineNo">056</span><a name="line.56"></a>
+<span class="sourceLineNo">057</span>/**<a name="line.57"></a>
+<span class="sourceLineNo">058</span> * Metadata Map of attributes for HFile written out as HFile Trailer. Created by the Writer and<a name="line.58"></a>
+<span class="sourceLineNo">059</span> * added to the tail of the file just before close. Metadata includes core attributes such as last<a name="line.59"></a>
+<span class="sourceLineNo">060</span> * key seen, comparator used writing the file, etc. Clients can add their own attributes via<a name="line.60"></a>
+<span class="sourceLineNo">061</span> * {@link #append(byte[], byte[], boolean)} and they'll be persisted and available at read time.<a name="line.61"></a>
+<span class="sourceLineNo">062</span> * Reader creates the HFileInfo on open by reading the tail of the HFile. The parse of the HFile<a name="line.62"></a>
+<span class="sourceLineNo">063</span> * trailer also creates a {@link HFileContext}, a read-only data structure that includes bulk of<a name="line.63"></a>
+<span class="sourceLineNo">064</span> * the HFileInfo and extras that is safe to pass around when working on HFiles.<a name="line.64"></a>
+<span class="sourceLineNo">065</span> * @see HFileContext<a name="line.65"></a>
+<span class="sourceLineNo">066</span> */<a name="line.66"></a>
+<span class="sourceLineNo">067</span>@InterfaceAudience.Private<a name="line.67"></a>
+<span class="sourceLineNo">068</span>public class HFileInfo implements SortedMap&lt;byte[], byte[]&gt; {<a name="line.68"></a>
+<span class="sourceLineNo">069</span><a name="line.69"></a>
+<span class="sourceLineNo">070</span>  private static final Logger LOG = LoggerFactory.getLogger(HFileInfo.class);<a name="line.70"></a>
+<span class="sourceLineNo">071</span><a name="line.71"></a>
+<span class="sourceLineNo">072</span>  static final String RESERVED_PREFIX = "hfile.";<a name="line.72"></a>
+<span class="sourceLineNo">073</span>  static final byte[] RESERVED_PREFIX_BYTES = Bytes.toBytes(RESERVED_PREFIX);<a name="line.73"></a>
+<span class="sourceLineNo">074</span>  static final byte [] LASTKEY = Bytes.toBytes(RESERVED_PREFIX + "LASTKEY");<a name="line.74"></a>
+<span class="sourceLineNo">075</span>  static final byte [] AVG_KEY_LEN = Bytes.toBytes(RESERVED_PREFIX + "AVG_KEY_LEN");<a name="line.75"></a>
+<span class="sourceLineNo">076</span>  static final byte [] AVG_VALUE_LEN = Bytes.toBytes(RESERVED_PREFIX + "AVG_VALUE_LEN");<a name="line.76"></a>
+<span class="sourceLineNo">077</span>  static final byte [] CREATE_TIME_TS = Bytes.toBytes(RESERVED_PREFIX + "CREATE_TIME_TS");<a name="line.77"></a>
+<span class="sourceLineNo">078</span>  static final byte [] TAGS_COMPRESSED = Bytes.toBytes(RESERVED_PREFIX + "TAGS_COMPRESSED");<a name="line.78"></a>
+<span class="sourceLineNo">079</span>  public static final byte [] MAX_TAGS_LEN = Bytes.toBytes(RESERVED_PREFIX + "MAX_TAGS_LEN");<a name="line.79"></a>
+<span class="sourceLineNo">080</span>  private final SortedMap&lt;byte [], byte []&gt; map = new TreeMap&lt;&gt;(Bytes.BYTES_COMPARATOR);<a name="line.80"></a>
+<span class="sourceLineNo">081</span><a name="line.81"></a>
+<span class="sourceLineNo">082</span>  /**<a name="line.82"></a>
+<span class="sourceLineNo">083</span>   * We can read files whose major version is v2 IFF their minor version is at least 3.<a name="line.83"></a>
+<span class="sourceLineNo">084</span>   */<a name="line.84"></a>
+<span class="sourceLineNo">085</span>  private static final int MIN_V2_MINOR_VERSION_WITH_PB = 3;<a name="line.85"></a>
+<span class="sourceLineNo">086</span><a name="line.86"></a>
+<span class="sourceLineNo">087</span>  /** Maximum minor version supported by this HFile format */<a name="line.87"></a>
+<span class="sourceLineNo">088</span>  // We went to version 2 when we moved to pb'ing fileinfo and the trailer on<a name="line.88"></a>
+<span class="sourceLineNo">089</span>  // the file. This version can read Writables version 1.<a name="line.89"></a>
+<span class="sourceLineNo">090</span>  static final int MAX_MINOR_VERSION = 3;<a name="line.90"></a>
+<span class="sourceLineNo">091</span><a name="line.91"></a>
+<span class="sourceLineNo">092</span>  /** Last key in the file. Filled in when we read in the file info */<a name="line.92"></a>
+<span class="sourceLineNo">093</span>  private Cell lastKeyCell = null;<a name="line.93"></a>
+<span class="sourceLineNo">094</span>  /** Average key length read from file info */<a name="line.94"></a>
+<span class="sourceLineNo">095</span>  private int avgKeyLen = -1;<a name="line.95"></a>
+<span class="sourceLineNo">096</span>  /** Average value length read from file info */<a name="line.96"></a>
+<span class="sourceLineNo">097</span>  private int avgValueLen = -1;<a name="line.97"></a>
+<span class="sourceLineNo">098</span>  private boolean includesMemstoreTS = false;<a name="line.98"></a>
+<span class="sourceLineNo">099</span>  private boolean decodeMemstoreTS = false;<a name="line.99"></a>
+<span class="sourceLineNo">100</span><a name="line.100"></a>
+<span class="sourceLineNo">101</span>  /**<a name="line.101"></a>
+<span class="sourceLineNo">102</span>   * Blocks read from the load-on-open section, excluding data root index, meta<a name="line.102"></a>
+<span class="sourceLineNo">103</span>   * index, and file info.<a name="line.103"></a>
 <span class="sourceLineNo">104</span>   */<a name="line.104"></a>
-<span class="sourceLineNo">105</span>  private HFileBlock.BlockIterator blockIter;<a name="line.105"></a>
+<span class="sourceLineNo">105</span>  private List&lt;HFileBlock&gt; loadOnOpenBlocks = new ArrayList&lt;&gt;();<a name="line.105"></a>
 <span class="sourceLineNo">106</span><a name="line.106"></a>
-<span class="sourceLineNo">107</span>  private HFileBlockIndex.CellBasedKeyBlockIndexReader dataIndexReader;<a name="line.107"></a>
-<span class="sourceLineNo">108</span>  private HFileBlockIndex.ByteArrayKeyBlockIndexReader metaIndexReader;<a name="line.108"></a>
-<span class="sourceLineNo">109</span><a name="line.109"></a>
-<span class="sourceLineNo">110</span>  private FixedFileTrailer trailer;<a name="line.110"></a>
-<span class="sourceLineNo">111</span>  private HFileContext hfileContext;<a name="line.111"></a>
-<span class="sourceLineNo">112</span><a name="line.112"></a>
-<span class="sourceLineNo">113</span>  public HFileInfo() {<a name="line.113"></a>
-<span class="sourceLineNo">114</span>    super();<a name="line.114"></a>
-<span class="sourceLineNo">115</span>  }<a name="line.115"></a>
+<span class="sourceLineNo">107</span>  /**<a name="line.107"></a>
+<span class="sourceLineNo">108</span>   * The iterator will track all blocks in load-on-open section, since we use the<a name="line.108"></a>
+<span class="sourceLineNo">109</span>   * {@link org.apache.hadoop.hbase.io.ByteBuffAllocator} to manage the ByteBuffers in block now,<a name="line.109"></a>
+<span class="sourceLineNo">110</span>   * so we must ensure that deallocate all ByteBuffers in the end.<a name="line.110"></a>
+<span class="sourceLineNo">111</span>   */<a name="line.111"></a>
+<span class="sourceLineNo">112</span>  private HFileBlock.BlockIterator blockIter;<a name="line.112"></a>
+<span class="sourceLineNo">113</span><a name="line.113"></a>
+<span class="sourceLineNo">114</span>  private HFileBlockIndex.CellBasedKeyBlockIndexReader dataIndexReader;<a name="line.114"></a>
+<span class="sourceLineNo">115</span>  private HFileBlockIndex.ByteArrayKeyBlockIndexReader metaIndexReader;<a name="line.115"></a>
 <span class="sourceLineNo">116</span><a name="line.116"></a>
-<span class="sourceLineNo">117</span>  public HFileInfo(ReaderContext context, Configuration conf) throws IOException {<a name="line.117"></a>
-<span class="sourceLineNo">118</span>    this.initTrailerAndContext(context, conf);<a name="line.118"></a>
-<span class="sourceLineNo">119</span>  }<a name="line.119"></a>
-<span class="sourceLineNo">120</span><a name="line.120"></a>
-<span class="sourceLineNo">121</span>  /**<a name="line.121"></a>
-<span class="sourceLineNo">122</span>   * Append the given key/value pair to the file info, optionally checking the<a name="line.122"></a>
-<span class="sourceLineNo">123</span>   * key prefix.<a name="line.123"></a>
-<span class="sourceLineNo">124</span>   *<a name="line.124"></a>
-<span class="sourceLineNo">125</span>   * @param k key to add<a name="line.125"></a>
-<span class="sourceLineNo">126</span>   * @param v value to add<a name="line.126"></a>
-<span class="sourceLineNo">127</span>   * @param checkPrefix whether to check that the provided key does not start<a name="line.127"></a>
-<span class="sourceLineNo">128</span>   *          with the reserved prefix<a name="line.128"></a>
-<span class="sourceLineNo">129</span>   * @return this file info object<a name="line.129"></a>
-<span class="sourceLineNo">130</span>   * @throws IOException if the key or value is invalid<a name="line.130"></a>
-<span class="sourceLineNo">131</span>   * @throws NullPointerException if {@code key} or {@code value} is {@code null}<a name="line.131"></a>
-<span class="sourceLineNo">132</span>   */<a name="line.132"></a>
-<span class="sourceLineNo">133</span>  public HFileInfo append(final byte[] k, final byte[] v,<a name="line.133"></a>
-<span class="sourceLineNo">134</span>      final boolean checkPrefix) throws IOException {<a name="line.134"></a>
-<span class="sourceLineNo">135</span>    Objects.requireNonNull(k, "key cannot be null");<a name="line.135"></a>
-<span class="sourceLineNo">136</span>    Objects.requireNonNull(v, "value cannot be null");<a name="line.136"></a>
-<span class="sourceLineNo">137</span><a name="line.137"></a>
-<span class="sourceLineNo">138</span>    if (checkPrefix &amp;&amp; isReservedFileInfoKey(k)) {<a name="line.138"></a>
-<span class="sourceLineNo">139</span>      throw new IOException("Keys with a " + HFileInfo.RESERVED_PREFIX<a name="line.139"></a>
-<span class="sourceLineNo">140</span>          + " are reserved");<a name="line.140"></a>
-<span class="sourceLineNo">141</span>    }<a name="line.141"></a>
-<span class="sourceLineNo">142</span>    put(k, v);<a name="line.142"></a>
-<span class="sourceLineNo">143</span>    return this;<a name="line.143"></a>
-<span class="sourceLineNo">144</span>  }<a name="line.144"></a>
-<span class="sourceLineNo">145</span><a name="line.145"></a>
-<span class="sourceLineNo">146</span>  /** Return true if the given file info key is reserved for internal use. */<a name="line.146"></a>
-<span class="sourceLineNo">147</span>  public static boolean isReservedFileInfoKey(byte[] key) {<a name="line.147"></a>
-<span class="sourceLineNo">148</span>    return Bytes.startsWith(key, HFileInfo.RESERVED_PREFIX_BYTES);<a name="line.148"></a>
-<span class="sourceLineNo">149</span>  }<a name="line.149"></a>
-<span class="sourceLineNo">150</span><a name="line.150"></a>
-<span class="sourceLineNo">151</span>  @Override<a name="line.151"></a>
-<span class="sourceLineNo">152</span>  public void clear() {<a name="line.152"></a>
-<span class="sourceLineNo">153</span>    this.map.clear();<a name="line.153"></a>
-<span class="sourceLineNo">154</span>  }<a name="line.154"></a>
-<span class="sourceLineNo">155</span><a name="line.155"></a>
-<span class="sourceLineNo">156</span>  @Override<a name="line.156"></a>
-<span class="sourceLineNo">157</span>  public Comparator&lt;? super byte[]&gt; comparator() {<a name="line.157"></a>
-<span class="sourceLineNo">158</span>    return map.comparator();<a name="line.158"></a>
-<span class="sourceLineNo">159</span>  }<a name="line.159"></a>
-<span class="sourceLineNo">160</span><a name="line.160"></a>
-<span class="sourceLineNo">161</span>  @Override<a name="line.161"></a>
-<span class="sourceLineNo">162</span>  public boolean containsKey(Object key) {<a name="line.162"></a>
-<span class="sourceLineNo">163</span>    return map.containsKey(key);<a name="line.163"></a>
-<span class="sourceLineNo">164</span>  }<a name="line.164"></a>
-<span class="sourceLineNo">165</span><a name="line.165"></a>
-<span class="sourceLineNo">166</span>  @Override<a name="line.166"></a>
-<span class="sourceLineNo">167</span>  public boolean containsValue(Object value) {<a name="line.167"></a>
-<span class="sourceLineNo">168</span>    return map.containsValue(value);<a name="line.168"></a>
-<span class="sourceLineNo">169</span>  }<a name="line.169"></a>
-<span class="sourceLineNo">170</span><a name="line.170"></a>
-<span class="sourceLineNo">171</span>  @Override<a name="line.171"></a>
-<span class="sourceLineNo">172</span>  public Set&lt;java.util.Map.Entry&lt;byte[], byte[]&gt;&gt; entrySet() {<a name="line.172"></a>
-<span class="sourceLineNo">173</span>    return map.entrySet();<a name="line.173"></a>
-<span class="sourceLineNo">174</span>  }<a name="line.174"></a>
-<span class="sourceLineNo">175</span><a name="line.175"></a>
-<span class="sourceLineNo">176</span>  @Override<a name="line.176"></a>
-<span class="sourceLineNo">177</span>  public boolean equals(Object o) {<a name="line.177"></a>
-<span class="sourceLineNo">178</span>    return map.equals(o);<a name="line.178"></a>
-<span class="sourceLineNo">179</span>  }<a name="line.179"></a>
-<span class="sourceLineNo">180</span><a name="line.180"></a>
-<span class="sourceLineNo">181</span>  @Override<a name="line.181"></a>
-<span class="sourceLineNo">182</span>  public byte[] firstKey() {<a name="line.182"></a>
-<span class="sourceLineNo">183</span>    return map.firstKey();<a name="line.183"></a>
-<span class="sourceLineNo">184</span>  }<a name="line.184"></a>
-<span class="sourceLineNo">185</span><a name="line.185"></a>
-<span class="sourceLineNo">186</span>  @Override<a name="line.186"></a>
-<span class="sourceLineNo">187</span>  public byte[] get(Object key) {<a name="line.187"></a>
-<span class="sourceLineNo">188</span>    return map.get(key);<a name="line.188"></a>
-<span class="sourceLineNo">189</span>  }<a name="line.189"></a>
-<span class="sourceLineNo">190</span><a name="line.190"></a>
-<span class="sourceLineNo">191</span>  @Override<a name="line.191"></a>
-<span class="sourceLineNo">192</span>  public int hashCode() {<a name="line.192"></a>
-<span class="sourceLineNo">193</span>    return map.hashCode();<a name="line.193"></a>
-<span class="sourceLineNo">194</span>  }<a name="line.194"></a>
-<span class="sourceLineNo">195</span><a name="line.195"></a>
-<span class="sourceLineNo">196</span>  @Override<a name="line.196"></a>
-<span class="sourceLineNo">197</span>  public SortedMap&lt;byte[], byte[]&gt; headMap(byte[] toKey) {<a name="line.197"></a>
-<span class="sourceLineNo">198</span>    return this.map.headMap(toKey);<a name="line.198"></a>
-<span class="sourceLineNo">199</span>  }<a name="line.199"></a>
-<span class="sourceLineNo">200</span><a name="line.200"></a>
-<span class="sourceLineNo">201</span>  @Override<a name="line.201"></a>
-<span class="sourceLineNo">202</span>  public boolean isEmpty() {<a name="line.202"></a>
-<span class="sourceLineNo">203</span>    return map.isEmpty();<a name="line.203"></a>
-<span class="sourceLineNo">204</span>  }<a name="line.204"></a>
-<span class="sourceLineNo">205</span><a name="line.205"></a>
-<span class="sourceLineNo">206</span>  @Override<a name="line.206"></a>
-<span class="sourceLineNo">207</span>  public Set&lt;byte[]&gt; keySet() {<a name="line.207"></a>
-<span class="sourceLineNo">208</span>    return map.keySet();<a name="line.208"></a>
-<span class="sourceLineNo">209</span>  }<a name="line.209"></a>
-<span class="sourceLineNo">210</span><a name="line.210"></a>
-<span class="sourceLineNo">211</span>  @Override<a name="line.211"></a>
-<span class="sourceLineNo">212</span>  public byte[] lastKey() {<a name="line.212"></a>
-<span class="sourceLineNo">213</span>    return map.lastKey();<a name="line.213"></a>
-<span class="sourceLineNo">214</span>  }<a name="line.214"></a>
-<span class="sourceLineNo">215</span><a name="line.215"></a>
-<span class="sourceLineNo">216</span>  @Override<a name="line.216"></a>
-<span class="sourceLineNo">217</span>  public byte[] put(byte[] key, byte[] value) {<a name="line.217"></a>
-<span class="sourceLineNo">218</span>    return this.map.put(key, value);<a name="line.218"></a>
-<span class="sourceLineNo">219</span>  }<a name="line.219"></a>
-<span class="sourceLineNo">220</span><a name="line.220"></a>
-<span class="sourceLineNo">221</span>  @Override<a name="line.221"></a>
-<span class="sourceLineNo">222</span>  public void putAll(Map&lt;? extends byte[], ? extends byte[]&gt; m) {<a name="line.222"></a>
-<span class="sourceLineNo">223</span>    this.map.putAll(m);<a name="line.223"></a>
-<span class="sourceLineNo">224</span>  }<a name="line.224"></a>
-<span class="sourceLineNo">225</span><a name="line.225"></a>
-<span class="sourceLineNo">226</span>  @Override<a name="line.226"></a>
-<span class="sourceLineNo">227</span>  public byte[] remove(Object key) {<a name="line.227"></a>
-<span class="sourceLineNo">228</span>    return this.map.remove(key);<a name="line.228"></a>
-<span class="sourceLineNo">229</span>  }<a name="line.229"></a>
-<span class="sourceLineNo">230</span><a name="line.230"></a>
-<span class="sourceLineNo">231</span>  @Override<a name="line.231"></a>
-<span class="sourceLineNo">232</span>  public int size() {<a name="line.232"></a>
-<span class="sourceLineNo">233</span>    return map.size();<a name="line.233"></a>
-<span class="sourceLineNo">234</span>  }<a name="line.234"></a>
-<span class="sourceLineNo">235</span><a name="line.235"></a>
-<span class="sourceLineNo">236</span>  @Override<a name="line.236"></a>
-<span class="sourceLineNo">237</span>  public SortedMap&lt;byte[], byte[]&gt; subMap(byte[] fromKey, byte[] toKey) {<a name="line.237"></a>
-<span class="sourceLineNo">238</span>    return this.map.subMap(fromKey, toKey);<a name="line.238"></a>
-<span class="sourceLineNo">239</span>  }<a name="line.239"></a>
-<span class="sourceLineNo">240</span><a name="line.240"></a>
-<span class="sourceLineNo">241</span>  @Override<a name="line.241"></a>
-<span class="sourceLineNo">242</span>  public SortedMap&lt;byte[], byte[]&gt; tailMap(byte[] fromKey) {<a name="line.242"></a>
-<span class="sourceLineNo">243</span>    return this.map.tailMap(fromKey);<a name="line.243"></a>
-<span class="sourceLineNo">244</span>  }<a name="line.244"></a>
-<span class="sourceLineNo">245</span><a name="line.245"></a>
-<span class="sourceLineNo">246</span>  @Override<a name="line.246"></a>
-<span class="sourceLineNo">247</span>  public Collection&lt;byte[]&gt; values() {<a name="line.247"></a>
-<span class="sourceLineNo">248</span>    return map.values();<a name="line.248"></a>
-<span class="sourceLineNo">249</span>  }<a name="line.249"></a>
-<span class="sourceLineNo">250</span><a name="line.250"></a>
-<span class="sourceLineNo">251</span>  /**<a name="line.251"></a>
-<span class="sourceLineNo">252</span>   * Write out this instance on the passed in &lt;code&gt;out&lt;/code&gt; stream.<a name="line.252"></a>
-<span class="sourceLineNo">253</span>   * We write it as a protobuf.<a name="line.253"></a>
-<span class="sourceLineNo">254</span>   * @see #read(DataInputStream)<a name="line.254"></a>
-<span class="sourceLineNo">255</span>   */<a name="line.255"></a>
-<span class="sourceLineNo">256</span>  void write(final DataOutputStream out) throws IOException {<a name="line.256"></a>
-<span class="sourceLineNo">257</span>    HFileProtos.FileInfoProto.Builder builder = HFileProtos.FileInfoProto.newBuilder();<a name="line.257"></a>
-<span class="sourceLineNo">258</span>    for (Map.Entry&lt;byte [], byte[]&gt; e: this.map.entrySet()) {<a name="line.258"></a>
-<span class="sourceLineNo">259</span>      HBaseProtos.BytesBytesPair.Builder bbpBuilder = HBaseProtos.BytesBytesPair.newBuilder();<a name="line.259"></a>
-<span class="sourceLineNo">260</span>      bbpBuilder.setFirst(UnsafeByteOperations.unsafeWrap(e.getKey()));<a name="line.260"></a>
-<span class="sourceLineNo">261</span>      bbpBuilder.setSecond(UnsafeByteOperations.unsafeWrap(e.getValue()));<a name="line.261"></a>
-<span class="sourceLineNo">262</span>      builder.addMapEntry(bbpBuilder.build());<a name="line.262"></a>
-<span class="sourceLineNo">263</span>    }<a name="line.263"></a>
-<span class="sourceLineNo">264</span>    out.write(ProtobufMagic.PB_MAGIC);<a name="line.264"></a>
-<span class="sourceLineNo">265</span>    builder.build().writeDelimitedTo(out);<a name="line.265"></a>
-<span class="sourceLineNo">266</span>  }<a name="line.266"></a>
-<span class="sourceLineNo">267</span><a name="line.267"></a>
-<span class="sourceLineNo">268</span>  /**<a name="line.268"></a>
-<span class="sourceLineNo">269</span>   * Populate this instance with what we find on the passed in &lt;code&gt;in&lt;/code&gt; stream.<a name="line.269"></a>
-<span class="sourceLineNo">270</span>   * Can deserialize protobuf of old Writables format.<a name="line.270"></a>
-<span class="sourceLineNo">271</span>   * @see #write(DataOutputStream)<a name="line.271"></a>
-<span class="sourceLineNo">272</span>   */<a name="line.272"></a>
-<span class="sourceLineNo">273</span>  void read(final DataInputStream in) throws IOException {<a name="line.273"></a>
-<span class="sourceLineNo">274</span>    // This code is tested over in TestHFileReaderV1 where we read an old hfile w/ this new code.<a name="line.274"></a>
-<span class="sourceLineNo">275</span>    int pblen = ProtobufUtil.lengthOfPBMagic();<a name="line.275"></a>
-<span class="sourceLineNo">276</span>    byte [] pbuf = new byte[pblen];<a name="line.276"></a>
-<span class="sourceLineNo">277</span>    if (in.markSupported()) {<a name="line.277"></a>
-<span class="sourceLineNo">278</span>      in.mark(pblen);<a name="line.278"></a>
-<span class="sourceLineNo">279</span>    }<a name="line.279"></a>
-<span class="sourceLineNo">280</span>    int read = in.read(pbuf);<a name="line.280"></a>
-<span class="sourceLineNo">281</span>    if (read != pblen) {<a name="line.281"></a>
-<span class="sourceLineNo">282</span>      throw new IOException("read=" + read + ", wanted=" + pblen);<a name="line.282"></a>
-<span class="sourceLineNo">283</span>    }<a name="line.283"></a>
-<span class="sourceLineNo">284</span>    if (ProtobufUtil.isPBMagicPrefix(pbuf)) {<a name="line.284"></a>
-<span class="sourceLineNo">285</span>      parsePB(HFileProtos.FileInfoProto.parseDelimitedFrom(in));<a name="line.285"></a>
-<span class="sourceLineNo">286</span>    } else {<a name="line.286"></a>
-<span class="sourceLineNo">287</span>      if (in.markSupported()) {<a name="line.287"></a>
-<span class="sourceLineNo">288</span>        in.reset();<a name="line.288"></a>
-<span class="sourceLineNo">289</span>        parseWritable(in);<a name="line.289"></a>
-<span class="sourceLineNo">290</span>      } else {<a name="line.290"></a>
-<span class="sourceLineNo">291</span>        // We cannot use BufferedInputStream, it consumes more than we read from the underlying IS<a name="line.291"></a>
-<span class="sourceLineNo">292</span>        ByteArrayInputStream bais = new ByteArrayInputStream(pbuf);<a name="line.292"></a>
-<span class="sourceLineNo">293</span>        SequenceInputStream sis = new SequenceInputStream(bais, in); // Concatenate input streams<a name="line.293"></a>
-<span class="sourceLineNo">294</span>        // TODO: Am I leaking anything here wrapping the passed in stream?  We are not calling<a name="line.294"></a>
-<span class="sourceLineNo">295</span>        // close on the wrapped streams but they should be let go after we leave this context?<a name="line.295"></a>
-<span class="sourceLineNo">296</span>        // I see that we keep a reference to the passed in inputstream but since we no longer<a name="line.296"></a>
-<span class="sourceLineNo">297</span>        // have a reference to this after we leave, we should be ok.<a name="line.297"></a>
-<span class="sourceLineNo">298</span>        parseWritable(new DataInputStream(sis));<a name="line.298"></a>
-<span class="sourceLineNo">299</span>      }<a name="line.299"></a>
-<span class="sourceLineNo">300</span>    }<a name="line.300"></a>
-<span class="sourceLineNo">301</span>  }<a name="line.301"></a>
-<span class="sourceLineNo">302</span><a name="line.302"></a>
-<span class="sourceLineNo">303</span>  /**<a name="line.303"></a>
-<span class="sourceLineNo">304</span>   * Now parse the old Writable format.  It was a list of Map entries.  Each map entry was a<a name="line.304"></a>
-<span class="sourceLineNo">305</span>   * key and a value of a byte [].  The old map format had a byte before each entry that held<a name="line.305"></a>
-<span class="sourceLineNo">306</span>   * a code which was short for the key or value type.  We know it was a byte [] so in below<a name="line.306"></a>
-<span class="sourceLineNo">307</span>   * we just read and dump it.<a name="line.307"></a>
-<span class="sourceLineNo">308</span>   */<a name="line.308"></a>
-<span class="sourceLineNo">309</span>  void parseWritable(final DataInputStream in) throws IOException {<a name="line.309"></a>
-<span class="sourceLineNo">310</span>    // First clear the map.<a name="line.310"></a>
-<span class="sourceLineNo">311</span>    // Otherwise we will just accumulate entries every time this method is called.<a name="line.311"></a>
-<span class="sourceLineNo">312</span>    this.map.clear();<a name="line.312"></a>
-<span class="sourceLineNo">313</span>    // Read the number of entries in the map<a name="line.313"></a>
-<span class="sourceLineNo">314</span>    int entries = in.readInt();<a name="line.314"></a>
-<span class="sourceLineNo">315</span>    // Then read each key/value pair<a name="line.315"></a>
-<span class="sourceLineNo">316</span>    for (int i = 0; i &lt; entries; i++) {<a name="line.316"></a>
-<span class="sourceLineNo">317</span>      byte [] key = Bytes.readByteArray(in);<a name="line.317"></a>
-<span class="sourceLineNo">318</span>      // We used to read a byte that encoded the class type.<a name="line.318"></a>
-<span class="sourceLineNo">319</span>      // Read and ignore it because it is always byte [] in hfile<a name="line.319"></a>
-<span class="sourceLineNo">320</span>      in.readByte();<a name="line.320"></a>
-<span class="sourceLineNo">321</span>      byte [] value = Bytes.readByteArray(in);<a name="line.321"></a>
-<span class="sourceLineNo">322</span>      this.map.put(key, value);<a name="line.322"></a>
-<span class="sourceLineNo">323</span>    }<a name="line.323"></a>
-<span class="sourceLineNo">324</span>  }<a name="line.324"></a>
-<span class="sourceLineNo">325</span><a name="line.325"></a>
-<span class="sourceLineNo">326</span>  /**<a name="line.326"></a>
-<span class="sourceLineNo">327</span>   * Fill our map with content of the pb we read off disk<a name="line.327"></a>
-<span class="sourceLineNo">328</span>   * @param fip protobuf message to read<a name="line.328"></a>
-<span class="sourceLineNo">329</span>   */<a name="line.329"></a>
-<span class="sourceLineNo">330</span>  void parsePB(final HFileProtos.FileInfoProto fip) {<a name="line.330"></a>
-<span class="sourceLineNo">331</span>    this.map.clear();<a name="line.331"></a>
-<span class="sourceLineNo">332</span>    for (BytesBytesPair pair: fip.getMapEntryList()) {<a name="line.332"></a>
-<span class="sourceLineNo">333</span>      this.map.put(pair.getFirst().toByteArray(), pair.getSecond().toByteArray());<a name="line.333"></a>
-<span class="sourceLineNo">334</span>    }<a name="line.334"></a>
-<span class="sourceLineNo">335</span>  }<a name="line.335"></a>
-<span class="sourceLineNo">336</span><a name="line.336"></a>
-<span class="sourceLineNo">337</span>  public void initTrailerAndContext(ReaderContext context, Configuration conf) throws IOException {<a name="line.337"></a>
-<span class="sourceLineNo">338</span>    try {<a name="line.338"></a>
-<span class="sourceLineNo">339</span>      boolean isHBaseChecksum = context.getInputStreamWrapper().shouldUseHBaseChecksum();<a name="line.339"></a>
-<span class="sourceLineNo">340</span>      trailer = FixedFileTrailer.readFromStream(context.getInputStreamWrapper()<a name="line.340"></a>
-<span class="sourceLineNo">341</span>          .getStream(isHBaseChecksum), context.getFileSize());<a name="line.341"></a>
-<span class="sourceLineNo">342</span>      Path path = context.getFilePath();<a name="line.342"></a>
-<span class="sourceLineNo">343</span>      checkFileVersion(path);<a name="line.343"></a>
-<span class="sourceLineNo">344</span>      this.hfileContext = createHFileContext(path, trailer, conf);<a name="line.344"></a>
-<span class="sourceLineNo">345</span>      context.getInputStreamWrapper().unbuffer();<a name="line.345"></a>
-<span class="sourceLineNo">346</span>    } catch (Throwable t) {<a name="line.346"></a>
-<span class="sourceLineNo">347</span>      IOUtils.closeQuietly(context.getInputStreamWrapper());<a name="line.347"></a>
-<span class="sourceLineNo">348</span>      throw new CorruptHFileException("Problem reading HFile Trailer from file "<a name="line.348"></a>
-<span class="sourceLineNo">349</span>          + context.getFilePath(), t);<a name="line.349"></a>
-<span class="sourceLineNo">350</span>    }<a name="line.350"></a>
-<span class="sourceLineNo">351</span>  }<a name="line.351"></a>
-<span class="sourceLineNo">352</span><a name="line.352"></a>
-<span class="sourceLineNo">353</span>  /**<a name="line.353"></a>
-<span class="sourceLineNo">354</span>   * should be called after initTrailerAndContext<a name="line.354"></a>
-<span class="sourceLineNo">355</span>   */<a name="line.355"></a>
-<span class="sourceLineNo">356</span>  public void initMetaAndIndex(HFile.Reader reader) throws IOException {<a name="line.356"></a>
-<span class="sourceLineNo">357</span>    ReaderContext context = reader.getContext();<a name="line.357"></a>
-<span class="sourceLineNo">358</span>    try {<a name="line.358"></a>
-<span class="sourceLineNo">359</span>      HFileBlock.FSReader blockReader = reader.getUncachedBlockReader();<a name="line.359"></a>
-<span class="sourceLineNo">360</span>      // Initialize an block iterator, and parse load-on-open blocks in the following.<a name="line.360"></a>
-<span class="sourceLineNo">361</span>      blockIter = blockReader.blockRange(trailer.getLoadOnOpenDataOffset(),<a name="line.361"></a>
-<span class="sourceLineNo">362</span>          context.getFileSize() - trailer.getTrailerSize());<a name="line.362"></a>
-<span class="sourceLineNo">363</span>      // Data index. We also read statistics about the block index written after<a name="line.363"></a>
-<span class="sourceLineNo">364</span>      // the root level.<a name="line.364"></a>
-<span class="sourceLineNo">365</span>      this.dataIndexReader =<a name="line.365"></a>
-<span class="sourceLineNo">366</span>        new HFileBlockIndex.CellBasedKeyBlockIndexReader(trailer.createComparator(), trailer.getNumDataIndexLevels());<a name="line.366"></a>
-<span class="sourceLineNo">367</span>      dataIndexReader<a name="line.367"></a>
-<span class="sourceLineNo">368</span>        .readMultiLevelIndexRoot(blockIter.nextBlockWithBlockType(BlockType.ROOT_INDEX), trailer.getDataIndexCount());<a name="line.368"></a>
-<span class="sourceLineNo">369</span>      reader.setDataBlockIndexReader(dataIndexReader);<a name="line.369"></a>
-<span class="sourceLineNo">370</span>      // Meta index.<a name="line.370"></a>
-<span class="sourceLineNo">371</span>      this.metaIndexReader = new HFileBlockIndex.ByteArrayKeyBlockIndexReader(1);<a name="line.371"></a>
-<span class="sourceLineNo">372</span>      metaIndexReader.readRootIndex(blockIter.nextBlockWithBlockType(BlockType.ROOT_INDEX),<a name="line.372"></a>
-<span class="sourceLineNo">373</span>        trailer.getMetaIndexCount());<a name="line.373"></a>
-<span class="sourceLineNo">374</span>      reader.setMetaBlockIndexReader(metaIndexReader);<a name="line.374"></a>
-<span class="sourceLineNo">375</span>      loadMetaInfo(blockIter, hfileContext);<a name="line.375"></a>
-<span class="sourceLineNo">376</span>      reader.setDataBlockEncoder(HFileDataBlockEncoderImpl.createFromFileInfo(this));<a name="line.376"></a>
-<span class="sourceLineNo">377</span>      // Load-On-Open info<a name="line.377"></a>
-<span class="sourceLineNo">378</span>      HFileBlock b;<a name="line.378"></a>
-<span class="sourceLineNo">379</span>      while ((b = blockIter.nextBlock()) != null) {<a name="line.379"></a>
-<span class="sourceLineNo">380</span>        loadOnOpenBlocks.add(b);<a name="line.380"></a>
-<span class="sourceLineNo">381</span>      }<a name="line.381"></a>
-<span class="sourceLineNo">382</span>      // close the block reader<a name="line.382"></a>
-<span class="sourceLineNo">383</span>      context.getInputStreamWrapper().unbuffer();<a name="line.383"></a>
-<span class="sourceLineNo">384</span>    } catch (Throwable t) {<a name="line.384"></a>
-<span class="sourceLineNo">385</span>      IOUtils.closeQuietly(context.getInputStreamWrapper());<a name="line.385"></a>
-<span class="sourceLineNo">386</span>      throw new CorruptHFileException("Problem reading data index and meta index from file "<a name="line.386"></a>
-<span class="sourceLineNo">387</span>        + context.getFilePath(), t);<a name="line.387"></a>
-<span class="sourceLineNo">388</span>    }<a name="line.388"></a>
-<span class="sourceLineNo">389</span>  }<a name="line.389"></a>
-<span class="sourceLineNo">390</span><a name="line.390"></a>
-<span class="sourceLineNo">391</span>  private HFileContext createHFileContext(Path path,<a name="line.391"></a>
-<span class="sourceLineNo">392</span>      FixedFileTrailer trailer, Configuration conf) throws IOException {<a name="line.392"></a>
-<span class="sourceLineNo">393</span>    HFileContextBuilder builder = new HFileContextBuilder()<a name="line.393"></a>
-<span class="sourceLineNo">394</span>      .withHBaseCheckSum(true)<a name="line.394"></a>
-<span class="sourceLineNo">395</span>      .withHFileName(path.getName())<a name="line.395"></a>
-<span class="sourceLineNo">396</span>      .withCompression(trailer.getCompressionCodec())<a name="line.396"></a>
-<span class="sourceLineNo">397</span>      .withCellComparator(FixedFileTrailer.createComparator(trailer.getComparatorClassName()));<a name="line.397"></a>
-<span class="sourceLineNo">398</span>    // Check for any key material available<a name="line.398"></a>
-<span class="sourceLineNo">399</span>    byte[] keyBytes = trailer.getEncryptionKey();<a name="line.399"></a>
-<span class="sourceLineNo">400</span>    if (keyBytes != null) {<a name="line.400"></a>
-<span class="sourceLineNo">401</span>      Encryption.Context cryptoContext = Encryption.newContext(conf);<a name="line.401"></a>
-<span class="sourceLineNo">402</span>      Key key = EncryptionUtil.unwrapKey(conf, keyBytes);<a name="line.402"></a>
-<span class="sourceLineNo">403</span>      // Use the algorithm the key wants<a name="line.403"></a>
-<span class="sourceLineNo">404</span>      Cipher cipher = Encryption.getCipher(conf, key.getAlgorithm());<a name="line.404"></a>
-<span class="sourceLineNo">405</span>      if (cipher == null) {<a name="line.405"></a>
-<span class="sourceLineNo">406</span>        throw new IOException("Cipher '" + key.getAlgorithm() + "' is not available"<a name="line.406"></a>
-<span class="sourceLineNo">407</span>            + ", path=" + path);<a name="line.407"></a>
-<span class="sourceLineNo">408</span>      }<a name="line.408"></a>
-<span class="sourceLineNo">409</span>      cryptoContext.setCipher(cipher);<a name="line.409"></a>
-<span class="sourceLineNo">410</span>      cryptoContext.setKey(key);<a name="line.410"></a>
-<span class="sourceLineNo">411</span>      builder.withEncryptionContext(cryptoContext);<a name="line.411"></a>
-<span class="sourceLineNo">412</span>    }<a name="line.412"></a>
-<span class="sourceLineNo">413</span>    HFileContext context = builder.build();<a name="line.413"></a>
-<span class="sourceLineNo">414</span>    return context;<a name="line.414"></a>
-<span class="sourceLineNo">415</span>  }<a name="line.415"></a>
-<span class="sourceLineNo">416</span><a name="line.416"></a>
-<span class="sourceLineNo">417</span>  private void loadMetaInfo(HFileBlock.BlockIterator blockIter, HFileContext hfileContext)<a name="line.417"></a>
-<span class="sourceLineNo">418</span>      throws IOException {<a name="line.418"></a>
-<span class="sourceLineNo">419</span>    read(blockIter.nextBlockWithBlockType(BlockType.FILE_INFO).getByteStream());<a name="line.419"></a>
-<span class="sourceLineNo">420</span>    byte[] creationTimeBytes = get(HFileInfo.CREATE_TIME_TS);<a name="line.420"></a>
-<span class="sourceLineNo">421</span>    hfileContext.setFileCreateTime(creationTimeBytes == null ?<a name="line.421"></a>
-<span class="sourceLineNo">422</span>        0 : Bytes.toLong(creationTimeBytes));<a name="line.422"></a>
-<span class="sourceLineNo">423</span>    byte[] tmp = get(HFileInfo.MAX_TAGS_LEN);<a name="line.423"></a>
-<span class="sourceLineNo">424</span>    // max tag length is not present in the HFile means tags were not at all written to file.<a name="line.424"></a>
-<span class="sourceLineNo">425</span>    if (tmp != null) {<a name="line.425"></a>
-<span class="sourceLineNo">426</span>      hfileContext.setIncludesTags(true);<a name="line.426"></a>
-<span class="sourceLineNo">427</span>      tmp = get(HFileInfo.TAGS_COMPRESSED);<a name="line.427"></a>
-<span class="sourceLineNo">428</span>      if (tmp != null &amp;&amp; Bytes.toBoolean(tmp)) {<a name="line.428"></a>
-<span class="sourceLineNo">429</span>        hfileContext.setCompressTags(true);<a name="line.429"></a>
-<span class="sourceLineNo">430</span>      }<a name="line.430"></a>
-<span class="sourceLineNo">431</span>    }<a name="line.431"></a>
-<span class="sourceLineNo">432</span>    // parse meta info<a name="line.432"></a>
-<span class="sourceLineNo">433</span>    if (get(HFileInfo.LASTKEY) != null) {<a name="line.433"></a>
-<span class="sourceLineNo">434</span>      lastKeyCell = new KeyValue.KeyOnlyKeyValue(get(HFileInfo.LASTKEY));<a name="line.434"></a>
-<span class="sourceLineNo">435</span>    }<a name="line.435"></a>
-<span class="sourceLineNo">436</span>    avgKeyLen = Bytes.toInt(get(HFileInfo.AVG_KEY_LEN));<a name="line.436"></a>
-<span class="sourceLineNo">437</span>    avgValueLen = Bytes.toInt(get(HFileInfo.AVG_VALUE_LEN));<a name="line.437"></a>
-<span class="sourceLineNo">438</span>    byte [] keyValueFormatVersion = get(HFileWriterImpl.KEY_VALUE_VERSION);<a name="line.438"></a>
-<span class="sourceLineNo">439</span>    includesMemstoreTS = keyValueFormatVersion != null &amp;&amp;<a name="line.439"></a>
-<span class="sourceLineNo">440</span>        Bytes.toInt(keyValueFormatVersion) == HFileWriterImpl.KEY_VALUE_VER_WITH_MEMSTORE;<a name="line.440"></a>
-<span class="sourceLineNo">441</span>    hfileContext.setIncludesMvcc(includesMemstoreTS);<a name="line.441"></a>
-<span class="sourceLineNo">442</span>    if (includesMemstoreTS) {<a name="line.442"></a>
-<span class="sourceLineNo">443</span>      decodeMemstoreTS = Bytes.toLong(get(HFileWriterImpl.MAX_MEMSTORE_TS_KEY)) &gt; 0;<a name="line.443"></a>
+<span class="sourceLineNo">117</span>  private FixedFileTrailer trailer;<a name="line.117"></a>
+<span class="sourceLineNo">118</span>  private HFileContext hfileContext;<a name="line.118"></a>
+<span class="sourceLineNo">119</span><a name="line.119"></a>
+<span class="sourceLineNo">120</span>  public HFileInfo() {<a name="line.120"></a>
+<span class="sourceLineNo">121</span>    super();<a name="line.121"></a>
+<span class="sourceLineNo">122</span>  }<a name="line.122"></a>
+<span class="sourceLineNo">123</span><a name="line.123"></a>
+<span class="sourceLineNo">124</span>  public HFileInfo(ReaderContext context, Configuration conf) throws IOException {<a name="line.124"></a>
+<span class="sourceLineNo">125</span>    this.initTrailerAndContext(context, conf);<a name="line.125"></a>
+<span class="sourceLineNo">126</span>  }<a name="line.126"></a>
+<span class="sourceLineNo">127</span><a name="line.127"></a>
+<span class="sourceLineNo">128</span>  /**<a name="line.128"></a>
+<span class="sourceLineNo">129</span>   * Append the given key/value pair to the file info, optionally checking the<a name="line.129"></a>
+<span class="sourceLineNo">130</span>   * key prefix.<a name="line.130"></a>
+<span class="sourceLineNo">131</span>   *<a name="line.131"></a>
+<span class="sourceLineNo">132</span>   * @param k key to add<a name="line.132"></a>
+<span class="sourceLineNo">133</span>   * @param v value to add<a name="line.133"></a>
+<span class="sourceLineNo">134</span>   * @param checkPrefix whether to check that the provided key does not start<a name="line.134"></a>
+<span class="sourceLineNo">135</span>   *          with the reserved prefix<a name="line.135"></a>
+<span class="sourceLineNo">136</span>   * @return this file info object<a name="line.136"></a>
+<span class="sourceLineNo">137</span>   * @throws IOException if the key or value is invalid<a name="line.137"></a>
+<span class="sourceLineNo">138</span>   * @throws NullPointerException if {@code key} or {@code value} is {@code null}<a name="line.138"></a>
+<span class="sourceLineNo">139</span>   */<a name="line.139"></a>
+<span class="sourceLineNo">140</span>  public HFileInfo append(final byte[] k, final byte[] v,<a name="line.140"></a>
+<span class="sourceLineNo">141</span>      final boolean checkPrefix) throws IOException {<a name="line.141"></a>
+<span class="sourceLineNo">142</span>    Objects.requireNonNull(k, "key cannot be null");<a name="line.142"></a>
+<span class="sourceLineNo">143</span>    Objects.requireNonNull(v, "value cannot be null");<a name="line.143"></a>
+<span class="sourceLineNo">144</span><a name="line.144"></a>
+<span class="sourceLineNo">145</span>    if (checkPrefix &amp;&amp; isReservedFileInfoKey(k)) {<a name="line.145"></a>
+<span class="sourceLineNo">146</span>      throw new IOException("Keys with a " + HFileInfo.RESERVED_PREFIX<a name="line.146"></a>
+<span class="sourceLineNo">147</span>          + " are reserved");<a name="line.147"></a>
+<span class="sourceLineNo">148</span>    }<a name="line.148"></a>
+<span class="sourceLineNo">149</span>    put(k, v);<a name="line.149"></a>
+<span class="sourceLineNo">150</span>    return this;<a name="line.150"></a>
+<span class="sourceLineNo">151</span>  }<a name="line.151"></a>
+<span class="sourceLineNo">152</span><a name="line.152"></a>
+<span class="sourceLineNo">153</span>  /** Return true if the given file info key is reserved for internal use. */<a name="line.153"></a>
+<span class="sourceLineNo">154</span>  public static boolean isReservedFileInfoKey(byte[] key) {<a name="line.154"></a>
+<span class="sourceLineNo">155</span>    return Bytes.startsWith(key, HFileInfo.RESERVED_PREFIX_BYTES);<a name="line.155"></a>
+<span class="sourceLineNo">156</span>  }<a name="line.156"></a>
+<span class="sourceLineNo">157</span><a name="line.157"></a>
+<span class="sourceLineNo">158</span>  @Override<a name="line.158"></a>
+<span class="sourceLineNo">159</span>  public void clear() {<a name="line.159"></a>
+<span class="sourceLineNo">160</span>    this.map.clear();<a name="line.160"></a>
+<span class="sourceLineNo">161</span>  }<a name="line.161"></a>
+<span class="sourceLineNo">162</span><a name="line.162"></a>
+<span class="sourceLineNo">163</span>  @Override<a name="line.163"></a>
+<span class="sourceLineNo">164</span>  public Comparator&lt;? super byte[]&gt; comparator() {<a name="line.164"></a>
+<span class="sourceLineNo">165</span>    return map.comparator();<a name="line.165"></a>
+<span class="sourceLineNo">166</span>  }<a name="line.166"></a>
+<span class="sourceLineNo">167</span><a name="line.167"></a>
+<span class="sourceLineNo">168</span>  @Override<a name="line.168"></a>
+<span class="sourceLineNo">169</span>  public boolean containsKey(Object key) {<a name="line.169"></a>
+<span class="sourceLineNo">170</span>    return map.containsKey(key);<a name="line.170"></a>
+<span class="sourceLineNo">171</span>  }<a name="line.171"></a>
+<span class="sourceLineNo">172</span><a name="line.172"></a>
+<span class="sourceLineNo">173</span>  @Override<a name="line.173"></a>
+<span class="sourceLineNo">174</span>  public boolean containsValue(Object value) {<a name="line.174"></a>
+<span class="sourceLineNo">175</span>    return map.containsValue(value);<a name="line.175"></a>
+<span class="sourceLineNo">176</span>  }<a name="line.176"></a>
+<span class="sourceLineNo">177</span><a name="line.177"></a>
+<span class="sourceLineNo">178</span>  @Override<a name="line.178"></a>
+<span class="sourceLineNo">179</span>  public Set&lt;java.util.Map.Entry&lt;byte[], byte[]&gt;&gt; entrySet() {<a name="line.179"></a>
+<span class="sourceLineNo">180</span>    return map.entrySet();<a name="line.180"></a>
+<span class="sourceLineNo">181</span>  }<a name="line.181"></a>
+<span class="sourceLineNo">182</span><a name="line.182"></a>
+<span class="sourceLineNo">183</span>  @Override<a name="line.183"></a>
+<span class="sourceLineNo">184</span>  public boolean equals(Object o) {<a name="line.184"></a>
+<span class="sourceLineNo">185</span>    return map.equals(o);<a name="line.185"></a>
+<span class="sourceLineNo">186</span>  }<a name="line.186"></a>
+<span class="sourceLineNo">187</span><a name="line.187"></a>
+<span class="sourceLineNo">188</span>  @Override<a name="line.188"></a>
+<span class="sourceLineNo">189</span>  public byte[] firstKey() {<a name="line.189"></a>
+<span class="sourceLineNo">190</span>    return map.firstKey();<a name="line.190"></a>
+<span class="sourceLineNo">191</span>  }<a name="line.191"></a>
+<span class="sourceLineNo">192</span><a name="line.192"></a>
+<span class="sourceLineNo">193</span>  @Override<a name="line.193"></a>
+<span class="sourceLineNo">194</span>  public byte[] get(Object key) {<a name="line.194"></a>
+<span class="sourceLineNo">195</span>    return map.get(key);<a name="line.195"></a>
+<span class="sourceLineNo">196</span>  }<a name="line.196"></a>
+<span class="sourceLineNo">197</span><a name="line.197"></a>
+<span class="sourceLineNo">198</span>  @Override<a name="line.198"></a>
+<span class="sourceLineNo">199</span>  public int hashCode() {<a name="line.199"></a>
+<span class="sourceLineNo">200</span>    return map.hashCode();<a name="line.200"></a>
+<span class="sourceLineNo">201</span>  }<a name="line.201"></a>
+<span class="sourceLineNo">202</span><a name="line.202"></a>
+<span class="sourceLineNo">203</span>  @Override<a name="line.203"></a>
+<span class="sourceLineNo">204</span>  public SortedMap&lt;byte[], byte[]&gt; headMap(byte[] toKey) {<a name="line.204"></a>
+<span class="sourceLineNo">205</span>    return this.map.headMap(toKey);<a name="line.205"></a>
+<span class="sourceLineNo">206</span>  }<a name="line.206"></a>
+<span class="sourceLineNo">207</span><a name="line.207"></a>
+<span class="sourceLineNo">208</span>  @Override<a name="line.208"></a>
+<span class="sourceLineNo">209</span>  public boolean isEmpty() {<a name="line.209"></a>
+<span class="sourceLineNo">210</span>    return map.isEmpty();<a name="line.210"></a>
+<span class="sourceLineNo">211</span>  }<a name="line.211"></a>
+<span class="sourceLineNo">212</span><a name="line.212"></a>
+<span class="sourceLineNo">213</span>  @Override<a name="line.213"></a>
+<span class="sourceLineNo">214</span>  public Set&lt;byte[]&gt; keySet() {<a name="line.214"></a>
+<span class="sourceLineNo">215</span>    return map.keySet();<a name="line.215"></a>
+<span class="sourceLineNo">216</span>  }<a name="line.216"></a>
+<span class="sourceLineNo">217</span><a name="line.217"></a>
+<span class="sourceLineNo">218</span>  @Override<a name="line.218"></a>
+<span class="sourceLineNo">219</span>  public byte[] lastKey() {<a name="line.219"></a>
+<span class="sourceLineNo">220</span>    return map.lastKey();<a name="line.220"></a>
+<span class="sourceLineNo">221</span>  }<a name="line.221"></a>
+<span class="sourceLineNo">222</span><a name="line.222"></a>
+<span class="sourceLineNo">223</span>  @Override<a name="line.223"></a>
+<span class="sourceLineNo">224</span>  public byte[] put(byte[] key, byte[] value) {<a name="line.224"></a>
+<span class="sourceLineNo">225</span>    return this.map.put(key, value);<a name="line.225"></a>
+<span class="sourceLineNo">226</span>  }<a name="line.226"></a>
+<span class="sourceLineNo">227</span><a name="line.227"></a>
+<span class="sourceLineNo">228</span>  @Override<a name="line.228"></a>
+<span class="sourceLineNo">229</span>  public void putAll(Map&lt;? extends byte[], ? extends byte[]&gt; m) {<a name="line.229"></a>
+<span class="sourceLineNo">230</span>    this.map.putAll(m);<a name="line.230"></a>
+<span class="sourceLineNo">231</span>  }<a name="line.231"></a>
+<span class="sourceLineNo">232</span><a name="line.232"></a>
+<span class="sourceLineNo">233</span>  @Override<a name="line.233"></a>
+<span class="sourceLineNo">234</span>  public byte[] remove(Object key) {<a name="line.234"></a>
+<span class="sourceLineNo">235</span>    return this.map.remove(key);<a name="line.235"></a>
+<span class="sourceLineNo">236</span>  }<a name="line.236"></a>
+<span class="sourceLineNo">237</span><a name="line.237"></a>
+<span class="sourceLineNo">238</span>  @Override<a name="line.238"></a>
+<span class="sourceLineNo">239</span>  public int size() {<a name="line.239"></a>
+<span class="sourceLineNo">240</span>    return map.size();<a name="line.240"></a>
+<span class="sourceLineNo">241</span>  }<a name="line.241"></a>
+<span class="sourceLineNo">242</span><a name="line.242"></a>
+<span class="sourceLineNo">243</span>  @Override<a name="line.243"></a>
+<span class="sourceLineNo">244</span>  public SortedMap&lt;byte[], byte[]&gt; subMap(byte[] fromKey, byte[] toKey) {<a name="line.244"></a>
+<span class="sourceLineNo">245</span>    return this.map.subMap(fromKey, toKey);<a name="line.245"></a>
+<span class="sourceLineNo">246</span>  }<a name="line.246"></a>
+<span class="sourceLineNo">247</span><a name="line.247"></a>
+<span class="sourceLineNo">248</span>  @Override<a name="line.248"></a>
+<span class="sourceLineNo">249</span>  public SortedMap&lt;byte[], byte[]&gt; tailMap(byte[] fromKey) {<a name="line.249"></a>
+<span class="sourceLineNo">250</span>    return this.map.tailMap(fromKey);<a name="line.250"></a>
+<span class="sourceLineNo">251</span>  }<a name="line.251"></a>
+<span class="sourceLineNo">252</span><a name="line.252"></a>
+<span class="sourceLineNo">253</span>  @Override<a name="line.253"></a>
+<span class="sourceLineNo">254</span>  public Collection&lt;byte[]&gt; values() {<a name="line.254"></a>
+<span class="sourceLineNo">255</span>    return map.values();<a name="line.255"></a>
+<span class="sourceLineNo">256</span>  }<a name="line.256"></a>
+<span class="sourceLineNo">257</span><a name="line.257"></a>
+<span class="sourceLineNo">258</span>  /**<a name="line.258"></a>
+<span class="sourceLineNo">259</span>   * Write out this instance on the passed in &lt;code&gt;out&lt;/code&gt; stream.<a name="line.259"></a>
+<span class="sourceLineNo">260</span>   * We write it as a protobuf.<a name="line.260"></a>
+<span class="sourceLineNo">261</span>   * @see #read(DataInputStream)<a name="line.261"></a>
+<span class="sourceLineNo">262</span>   */<a name="line.262"></a>
+<span class="sourceLineNo">263</span>  void write(final DataOutputStream out) throws IOException {<a name="line.263"></a>
+<span class="sourceLineNo">264</span>    HFileProtos.FileInfoProto.Builder builder = HFileProtos.FileInfoProto.newBuilder();<a name="line.264"></a>
+<span class="sourceLineNo">265</span>    for (Map.Entry&lt;byte [], byte[]&gt; e: this.map.entrySet()) {<a name="line.265"></a>
+<span class="sourceLineNo">266</span>      HBaseProtos.BytesBytesPair.Builder bbpBuilder = HBaseProtos.BytesBytesPair.newBuilder();<a name="line.266"></a>
+<span class="sourceLineNo">267</span>      bbpBuilder.setFirst(UnsafeByteOperations.unsafeWrap(e.getKey()));<a name="line.267"></a>
+<span class="sourceLineNo">268</span>      bbpBuilder.setSecond(UnsafeByteOperations.unsafeWrap(e.getValue()));<a name="line.268"></a>
+<span class="sourceLineNo">269</span>      builder.addMapEntry(bbpBuilder.build());<a name="line.269"></a>
+<span class="sourceLineNo">270</span>    }<a name="line.270"></a>
+<span class="sourceLineNo">271</span>    out.write(ProtobufMagic.PB_MAGIC);<a name="line.271"></a>
+<span class="sourceLineNo">272</span>    builder.build().writeDelimitedTo(out);<a name="line.272"></a>
+<span class="sourceLineNo">273</span>  }<a name="line.273"></a>
+<span class="sourceLineNo">274</span><a name="line.274"></a>
+<span class="sourceLineNo">275</span>  /**<a name="line.275"></a>
+<span class="sourceLineNo">276</span>   * Populate this instance with what we find on the passed in &lt;code&gt;in&lt;/code&gt; stream.<a name="line.276"></a>
+<span class="sourceLineNo">277</span>   * Can deserialize protobuf of old Writables format.<a name="line.277"></a>
+<span class="sourceLineNo">278</span>   * @see #write(DataOutputStream)<a name="line.278"></a>
+<span class="sourceLineNo">279</span>   */<a name="line.279"></a>
+<span class="sourceLineNo">280</span>  void read(final DataInputStream in) throws IOException {<a name="line.280"></a>
+<span class="sourceLineNo">281</span>    // This code is tested over in TestHFileReaderV1 where we read an old hfile w/ this new code.<a name="line.281"></a>
+<span class="sourceLineNo">282</span>    int pblen = ProtobufUtil.lengthOfPBMagic();<a name="line.282"></a>
+<span class="sourceLineNo">283</span>    byte [] pbuf = new byte[pblen];<a name="line.283"></a>
+<span class="sourceLineNo">284</span>    if (in.markSupported()) {<a name="line.284"></a>
+<span class="sourceLineNo">285</span>      in.mark(pblen);<a name="line.285"></a>
+<span class="sourceLineNo">286</span>    }<a name="line.286"></a>
+<span class="sourceLineNo">287</span>    int read = in.read(pbuf);<a name="line.287"></a>
+<span class="sourceLineNo">288</span>    if (read != pblen) {<a name="line.288"></a>
+<span class="sourceLineNo">289</span>      throw new IOException("read=" + read + ", wanted=" + pblen);<a name="line.289"></a>
+<span class="sourceLineNo">290</span>    }<a name="line.290"></a>
+<span class="sourceLineNo">291</span>    if (ProtobufUtil.isPBMagicPrefix(pbuf)) {<a name="line.291"></a>
+<span class="sourceLineNo">292</span>      parsePB(HFileProtos.FileInfoProto.parseDelimitedFrom(in));<a name="line.292"></a>
+<span class="sourceLineNo">293</span>    } else {<a name="line.293"></a>
+<span class="sourceLineNo">294</span>      if (in.markSupported()) {<a name="line.294"></a>
+<span class="sourceLineNo">295</span>        in.reset();<a name="line.295"></a>
+<span class="sourceLineNo">296</span>        parseWritable(in);<a name="line.296"></a>
+<span class="sourceLineNo">297</span>      } else {<a name="line.297"></a>
+<span class="sourceLineNo">298</span>        // We cannot use BufferedInputStream, it consumes more than we read from the underlying IS<a name="line.298"></a>
+<span class="sourceLineNo">299</span>        ByteArrayInputStream bais = new ByteArrayInputStream(pbuf);<a name="line.299"></a>
+<span class="sourceLineNo">300</span>        SequenceInputStream sis = new SequenceInputStream(bais, in); // Concatenate input streams<a name="line.300"></a>
+<span class="sourceLineNo">301</span>        // TODO: Am I leaking anything here wrapping the passed in stream?  We are not calling<a name="line.301"></a>
+<span class="sourceLineNo">302</span>        // close on the wrapped streams but they should be let go after we leave this context?<a name="line.302"></a>
+<span class="sourceLineNo">303</span>        // I see that we keep a reference to the passed in inputstream but since we no longer<a name="line.303"></a>
+<span class="sourceLineNo">304</span>        // have a reference to this after we leave, we should be ok.<a name="line.304"></a>
+<span class="sourceLineNo">305</span>        parseWritable(new DataInputStream(sis));<a name="line.305"></a>
+<span class="sourceLineNo">306</span>      }<a name="line.306"></a>
+<span class="sourceLineNo">307</span>    }<a name="line.307"></a>
+<span class="sourceLineNo">308</span>  }<a name="line.308"></a>
+<span class="sourceLineNo">309</span><a name="line.309"></a>
+<span class="sourceLineNo">310</span>  /**<a name="line.310"></a>
+<span class="sourceLineNo">311</span>   * Now parse the old Writable format.  It was a list of Map entries.  Each map entry was a<a name="line.311"></a>
+<span class="sourceLineNo">312</span>   * key and a value of a byte [].  The old map format had a byte before each entry that held<a name="line.312"></a>
+<span class="sourceLineNo">313</span>   * a code which was short for the key or value type.  We know it was a byte [] so in below<a name="line.313"></a>
+<span class="sourceLineNo">314</span>   * we just read and dump it.<a name="line.314"></a>
+<span class="sourceLineNo">315</span>   */<a name="line.315"></a>
+<span class="sourceLineNo">316</span>  void parseWritable(final DataInputStream in) throws IOException {<a name="line.316"></a>
+<span class="sourceLineNo">317</span>    // First clear the map.<a name="line.317"></a>
+<span class="sourceLineNo">318</span>    // Otherwise we will just accumulate entries every time this method is called.<a name="line.318"></a>
+<span class="sourceLineNo">319</span>    this.map.clear();<a name="line.319"></a>
+<span class="sourceLineNo">320</span>    // Read the number of entries in the map<a name="line.320"></a>
+<span class="sourceLineNo">321</span>    int entries = in.readInt();<a name="line.321"></a>
+<span class="sourceLineNo">322</span>    // Then read each key/value pair<a name="line.322"></a>
+<span class="sourceLineNo">323</span>    for (int i = 0; i &lt; entries; i++) {<a name="line.323"></a>
+<span class="sourceLineNo">324</span>      byte [] key = Bytes.readByteArray(in);<a name="line.324"></a>
+<span class="sourceLineNo">325</span>      // We used to read a byte that encoded the class type.<a name="line.325"></a>
+<span class="sourceLineNo">326</span>      // Read and ignore it because it is always byte [] in hfile<a name="line.326"></a>
+<span class="sourceLineNo">327</span>      in.readByte();<a name="line.327"></a>
+<span class="sourceLineNo">328</span>      byte [] value = Bytes.readByteArray(in);<a name="line.328"></a>
+<span class="sourceLineNo">329</span>      this.map.put(key, value);<a name="line.329"></a>
+<span class="sourceLineNo">330</span>    }<a name="line.330"></a>
+<span class="sourceLineNo">331</span>  }<a name="line.331"></a>
+<span class="sourceLineNo">332</span><a name="line.332"></a>
+<span class="sourceLineNo">333</span>  /**<a name="line.333"></a>
+<span class="sourceLineNo">334</span>   * Fill our map with content of the pb we read off disk<a name="line.334"></a>
+<span class="sourceLineNo">335</span>   * @param fip protobuf message to read<a name="line.335"></a>
+<span class="sourceLineNo">336</span>   */<a name="line.336"></a>
+<span class="sourceLineNo">337</span>  void parsePB(final HFileProtos.FileInfoProto fip) {<a name="line.337"></a>
+<span class="sourceLineNo">338</span>    this.map.clear();<a name="line.338"></a>
+<span class="sourceLineNo">339</span>    for (BytesBytesPair pair: fip.getMapEntryList()) {<a name="line.339"></a>
+<span class="sourceLineNo">340</span>      this.map.put(pair.getFirst().toByteArray(), pair.getSecond().toByteArray());<a name="line.340"></a>
+<span class="sourceLineNo">341</span>    }<a name="line.341"></a>
+<span class="sourceLineNo">342</span>  }<a name="line.342"></a>
+<span class="sourceLineNo">343</span><a name="line.343"></a>
+<span class="sourceLineNo">344</span>  public void initTrailerAndContext(ReaderContext context, Configuration conf) throws IOException {<a name="line.344"></a>
+<span class="sourceLineNo">345</span>    try {<a name="line.345"></a>
+<span class="sourceLineNo">346</span>      boolean isHBaseChecksum = context.getInputStreamWrapper().shouldUseHBaseChecksum();<a name="line.346"></a>
+<span class="sourceLineNo">347</span>      trailer = FixedFileTrailer.readFromStream(context.getInputStreamWrapper()<a name="line.347"></a>
+<span class="sourceLineNo">348</span>          .getStream(isHBaseChecksum), context.getFileSize());<a name="line.348"></a>
+<span class="sourceLineNo">349</span>      Path path = context.getFilePath();<a name="line.349"></a>
+<span class="sourceLineNo">350</span>      checkFileVersion(path);<a name="line.350"></a>
+<span class="sourceLineNo">351</span>      this.hfileContext = createHFileContext(path, trailer, conf);<a name="line.351"></a>
+<span class="sourceLineNo">352</span>      context.getInputStreamWrapper().unbuffer();<a name="line.352"></a>
+<span class="sourceLineNo">353</span>    } catch (Throwable t) {<a name="line.353"></a>
+<span class="sourceLineNo">354</span>      IOUtils.closeQuietly(context.getInputStreamWrapper(),<a name="line.354"></a>
+<span class="sourceLineNo">355</span>        e -&gt; LOG.warn("failed to close input stream wrapper", e));<a name="line.355"></a>
+<span class="sourceLineNo">356</span>      throw new CorruptHFileException("Problem reading HFile Trailer from file "<a name="line.356"></a>
+<span class="sourceLineNo">357</span>          + context.getFilePath(), t);<a name="line.357"></a>
+<span class="sourceLineNo">358</span>    }<a name="line.358"></a>
+<span class="sourceLineNo">359</span>  }<a name="line.359"></a>
+<span class="sourceLineNo">360</span><a name="line.360"></a>
+<span class="sourceLineNo">361</span>  /**<a name="line.361"></a>
+<span class="sourceLineNo">362</span>   * should be called after initTrailerAndContext<a name="line.362"></a>
+<span class="sourceLineNo">363</span>   */<a name="line.363"></a>
+<span class="sourceLineNo">364</span>  public void initMetaAndIndex(HFile.Reader reader) throws IOException {<a name="line.364"></a>
+<span class="sourceLineNo">365</span>    ReaderContext context = reader.getContext();<a name="line.365"></a>
+<span class="sourceLineNo">366</span>    try {<a name="line.366"></a>
+<span class="sourceLineNo">367</span>      HFileBlock.FSReader blockReader = reader.getUncachedBlockReader();<a name="line.367"></a>
+<span class="sourceLineNo">368</span>      // Initialize an block iterator, and parse load-on-open blocks in the following.<a name="line.368"></a>
+<span class="sourceLineNo">369</span>      blockIter = blockReader.blockRange(trailer.getLoadOnOpenDataOffset(),<a name="line.369"></a>
+<span class="sourceLineNo">370</span>          context.getFileSize() - trailer.getTrailerSize());<a name="line.370"></a>
+<span class="sourceLineNo">371</span>      // Data index. We also read statistics about the block index written after<a name="line.371"></a>
+<span class="sourceLineNo">372</span>      // the root level.<a name="line.372"></a>
+<span class="sourceLineNo">373</span>      this.dataIndexReader =<a name="line.373"></a>
+<span class="sourceLineNo">374</span>        new HFileBlockIndex.CellBasedKeyBlockIndexReader(trailer.createComparator(), trailer.getNumDataIndexLevels());<a name="line.374"></a>
+<span class="sourceLineNo">375</span>      dataIndexReader<a name="line.375"></a>
+<span class="sourceLineNo">376</span>        .readMultiLevelIndexRoot(blockIter.nextBlockWithBlockType(BlockType.ROOT_INDEX), trailer.getDataIndexCount());<a name="line.376"></a>
+<span class="sourceLineNo">377</span>      reader.setDataBlockIndexReader(dataIndexReader);<a name="line.377"></a>
+<span class="sourceLineNo">378</span>      // Meta index.<a name="line.378"></a>
+<span class="sourceLineNo">379</span>      this.metaIndexReader = new HFileBlockIndex.ByteArrayKeyBlockIndexReader(1);<a name="line.379"></a>
+<span class="sourceLineNo">380</span>      metaIndexReader.readRootIndex(blockIter.nextBlockWithBlockType(BlockType.ROOT_INDEX),<a name="line.380"></a>
+<span class="sourceLineNo">381</span>        trailer.getMetaIndexCount());<a name="line.381"></a>
+<span class="sourceLineNo">382</span>      reader.setMetaBlockIndexReader(metaIndexReader);<a name="line.382"></a>
+<span class="sourceLineNo">383</span>      loadMetaInfo(blockIter, hfileContext);<a name="line.383"></a>
+<span class="sourceLineNo">384</span>      reader.setDataBlockEncoder(HFileDataBlockEncoderImpl.createFromFileInfo(this));<a name="line.384"></a>
+<span class="sourceLineNo">385</span>      // Load-On-Open info<a name="line.385"></a>
+<span class="sourceLineNo">386</span>      HFileBlock b;<a name="line.386"></a>
+<span class="sourceLineNo">387</span>      while ((b = blockIter.nextBlock()) != null) {<a name="line.387"></a>
+<span class="sourceLineNo">388</span>        loadOnOpenBlocks.add(b);<a name="line.388"></a>
+<span class="sourceLineNo">389</span>      }<a name="line.389"></a>
+<span class="sourceLineNo">390</span>      // close the block reader<a name="line.390"></a>
+<span class="sourceLineNo">391</span>      context.getInputStreamWrapper().unbuffer();<a name="line.391"></a>
+<span class="sourceLineNo">392</span>    } catch (Throwable t) {<a name="line.392"></a>
+<span class="sourceLineNo">393</span>      IOUtils.closeQuietly(context.getInputStreamWrapper(),<a name="line.393"></a>
+<span class="sourceLineNo">394</span>        e -&gt; LOG.warn("failed to close input stream wrapper", e));<a name="line.394"></a>
+<span class="sourceLineNo">395</span>      throw new CorruptHFileException(<a name="line.395"></a>
+<span class="sourceLineNo">396</span>        "Problem reading data index and meta index from file " + context.getFilePath(), t);<a name="line.396"></a>
+<span class="sourceLineNo">397</span>    }<a name="line.397"></a>
+<span class="sourceLineNo">398</span>  }<a name="line.398"></a>
+<span class="sourceLineNo">399</span><a name="line.399"></a>
+<span class="sourceLineNo">400</span>  private HFileContext createHFileContext(Path path,<a name="line.400"></a>
+<span class="sourceLineNo">401</span>      FixedFileTrailer trailer, Configuration conf) throws IOException {<a name="line.401"></a>
+<span class="sourceLineNo">402</span>    HFileContextBuilder builder = new HFileContextBuilder()<a name="line.402"></a>
+<span class="sourceLineNo">403</span>      .withHBaseCheckSum(true)<a name="line.403"></a>
+<span class="sourceLineNo">404</span>      .withHFileName(path.getName())<a name="line.404"></a>
+<span class="sourceLineNo">405</span>      .withCompression(trailer.getCompressionCodec())<a name="line.405"></a>
+<span class="sourceLineNo">406</span>      .withCellComparator(FixedFileTrailer.createComparator(trailer.getComparatorClassName()));<a name="line.406"></a>
+<span class="sourceLineNo">407</span>    // Check for any key material available<a name="line.407"></a>
+<span class="sourceLineNo">408</span>    byte[] keyBytes = trailer.getEncryptionKey();<a name="line.408"></a>
+<span class="sourceLineNo">409</span>    if (keyBytes != null) {<a name="line.409"></a>
+<span class="sourceLineNo">410</span>      Encryption.Context cryptoContext = Encryption.newContext(conf);<a name="line.410"></a>
+<span class="sourceLineNo">411</span>      Key key = EncryptionUtil.unwrapKey(conf, keyBytes);<a name="line.411"></a>
+<span class="sourceLineNo">412</span>      // Use the algorithm the key wants<a name="line.412"></a>
+<span class="sourceLineNo">413</span>      Cipher cipher = Encryption.getCipher(conf, key.getAlgorithm());<a name="line.413"></a>
+<span class="sourceLineNo">414</span>      if (cipher == null) {<a name="line.414"></a>
+<span class="sourceLineNo">415</span>        throw new IOException("Cipher '" + key.getAlgorithm() + "' is not available"<a name="line.415"></a>
+<span class="sourceLineNo">416</span>            + ", path=" + path);<a name="line.416"></a>
+<span class="sourceLineNo">417</span>      }<a name="line.417"></a>
+<span class="sourceLineNo">418</span>      cryptoContext.setCipher(cipher);<a name="line.418"></a>
+<span class="sourceLineNo">419</span>      cryptoContext.setKey(key);<a name="line.419"></a>
+<span class="sourceLineNo">420</span>      builder.withEncryptionContext(cryptoContext);<a name="line.420"></a>
+<span class="sourceLineNo">421</span>    }<a name="line.421"></a>
+<span class="sourceLineNo">422</span>    HFileContext context = builder.build();<a name="line.422"></a>
+<span class="sourceLineNo">423</span>    return context;<a name="line.423"></a>
+<span class="sourceLineNo">424</span>  }<a name="line.424"></a>
+<span class="sourceLineNo">425</span><a name="line.425"></a>
+<span class="sourceLineNo">426</span>  private void loadMetaInfo(HFileBlock.BlockIterator blockIter, HFileContext hfileContext)<a name="line.426"></a>
+<span class="sourceLineNo">427</span>      throws IOException {<a name="line.427"></a>
+<span class="sourceLineNo">428</span>    read(blockIter.nextBlockWithBlockType(BlockType.FILE_INFO).getByteStream());<a name="line.428"></a>
+<span class="sourceLineNo">429</span>    byte[] creationTimeBytes = get(HFileInfo.CREATE_TIME_TS);<a name="line.429"></a>
+<span class="sourceLineNo">430</span>    hfileContext.setFileCreateTime(creationTimeBytes == null ?<a name="line.430"></a>
+<span class="sourceLineNo">431</span>        0 : Bytes.toLong(creationTimeBytes));<a name="line.431"></a>
+<span class="sourceLineNo">432</span>    byte[] tmp = get(HFileInfo.MAX_TAGS_LEN);<a name="line.432"></a>
+<span class="sourceLineNo">433</span>    // max tag length is not present in the HFile means tags were not at all written to file.<a name="line.433"></a>
+<span class="sourceLineNo">434</span>    if (tmp != null) {<a name="line.434"></a>
+<span class="sourceLineNo">435</span>      hfileContext.setIncludesTags(true);<a name="line.435"></a>
+<span class="sourceLineNo">436</span>      tmp = get(HFileInfo.TAGS_COMPRESSED);<a name="line.436"></a>
+<span class="sourceLineNo">437</span>      if (tmp != null &amp;&amp; Bytes.toBoolean(tmp)) {<a name="line.437"></a>
+<span class="sourceLineNo">438</span>        hfileContext.setCompressTags(true);<a name="line.438"></a>
+<span class="sourceLineNo">439</span>      }<a name="line.439"></a>
+<span class="sourceLineNo">440</span>    }<a name="line.440"></a>
+<span class="sourceLineNo">441</span>    // parse meta info<a name="line.441"></a>
+<span class="sourceLineNo">442</span>    if (get(HFileInfo.LASTKEY) != null) {<a name="line.442"></a>
+<span class="sourceLineNo">443</span>      lastKeyCell = new KeyValue.KeyOnlyKeyValue(get(HFileInfo.LASTKEY));<a name="line.443"></a>
 <span class="sourceLineNo">444</span>    }<a name="line.444"></a>
-<span class="sourceLineNo">445</span>  }<a name="line.445"></a>
-<span class="sourceLineNo">446</span><a name="line.446"></a>
-<span class="sourceLineNo">447</span>  /**<a name="line.447"></a>
-<span class="sourceLineNo">448</span>   * File version check is a little sloppy. We read v3 files but can also read v2 files if their<a name="line.448"></a>
-<span class="sourceLineNo">449</span>   * content has been pb'd; files written with 0.98.<a name="line.449"></a>
-<span class="sourceLineNo">450</span>   */<a name="line.450"></a>
-<span class="sourceLineNo">451</span>  private void checkFileVersion(Path path) {<a name="line.451"></a>
-<span class="sourceLineNo">452</span>    int majorVersion = trailer.getMajorVersion();<a name="line.452"></a>
-<span class="sourceLineNo">453</span>    if (majorVersion == getMajorVersion()) {<a name="line.453"></a>
-<span class="sourceLineNo">454</span>      return;<a name="line.454"></a>
-<span class="sourceLineNo">455</span>    }<a name="line.455"></a>
-<span class="sourceLineNo">456</span>    int minorVersion = trailer.getMinorVersion();<a name="line.456"></a>
-<span class="sourceLineNo">457</span>    if (majorVersion == 2 &amp;&amp; minorVersion &gt;= MIN_V2_MINOR_VERSION_WITH_PB) {<a name="line.457"></a>
-<span class="sourceLineNo">458</span>      return;<a name="line.458"></a>
-<span class="sourceLineNo">459</span>    }<a name="line.459"></a>
-<span class="sourceLineNo">460</span>    // We can read v3 or v2 versions of hfile.<a name="line.460"></a>
-<span class="sourceLineNo">461</span>    throw new IllegalArgumentException("Invalid HFile version: major=" +<a name="line.461"></a>
-<span class="sourceLineNo">462</span>      trailer.getMajorVersion() + ", minor=" + trailer.getMinorVersion() + ": expected at least " +<a name="line.462"></a>
-<span class="sourceLineNo">463</span>      "major=2 and minor=" + MAX_MINOR_VERSION + ", path=" + path);<a name="line.463"></a>
-<span class="sourceLineNo">464</span>  }<a name="line.464"></a>
-<span class="sourceLineNo">465</span><a name="line.465"></a>
-<span class="sourceLineNo">466</span>  public void close() {<a name="line.466"></a>
-<span class="sourceLineNo">467</span>    if (blockIter != null) {<a name="line.467"></a>
-<span class="sourceLineNo">468</span>      blockIter.freeBlocks();<a name="line.468"></a>
-<span class="sourceLineNo">469</span>    }<a name="line.469"></a>
-<span class="sourceLineNo">470</span>  }<a name="line.470"></a>
-<span class="sourceLineNo">471</span><a name="line.471"></a>
-<span class="sourceLineNo">472</span>  public int getMajorVersion() {<a name="line.472"></a>
-<span class="sourceLineNo">473</span>    return 3;<a name="line.473"></a>
-<span class="sourceLineNo">474</span>  }<a name="line.474"></a>
-<span class="sourceLineNo">475</span><a name="line.475"></a>
-<span class="sourceLineNo">476</span>  public void setTrailer(FixedFileTrailer trailer) {<a name="line.476"></a>
-<span class="sourceLineNo">477</span>    this.trailer = trailer;<a name="line.477"></a>
-<span class="sourceLineNo">478</span>  }<a name="line.478"></a>
-<span class="sourceLineNo">479</span><a name="line.479"></a>
-<span class="sourceLineNo">480</span>  public FixedFileTrailer getTrailer() {<a name="line.480"></a>
-<span class="sourceLineNo">481</span>    return this.trailer;<a name="line.481"></a>
-<span class="sourceLineNo">482</span>  }<a name="line.482"></a>
-<span class="sourceLineNo">483</span><a name="line.483"></a>
-<span class="sourceLineNo">484</span>  public HFileBlockIndex.CellBasedKeyBlockIndexReader getDataBlockIndexReader() {<a name="line.484"></a>
-<span class="sourceLineNo">485</span>    return this.dataIndexReader;<a name="line.485"></a>
-<span class="sourceLineNo">486</span>  }<a name="line.486"></a>
-<span class="sourceLineNo">487</span><a name="line.487"></a>
-<span class="sourceLineNo">488</span>  public HFileBlockIndex.ByteArrayKeyBlockIndexReader getMetaBlockIndexReader() {<a name="line.488"></a>
-<span class="sourceLineNo">489</span>    return this.metaIndexReader;<a name="line.489"></a>
-<span class="sourceLineNo">490</span>  }<a name="line.490"></a>
-<span class="sourceLineNo">491</span><a name="line.491"></a>
-<span class="sourceLineNo">492</span>  public HFileContext getHFileContext() {<a name="line.492"></a>
-<span class="sourceLineNo">493</span>    return this.hfileContext;<a name="line.493"></a>
-<span class="sourceLineNo">494</span>  }<a name="line.494"></a>
-<span class="sourceLineNo">495</span><a name="line.495"></a>
-<span class="sourceLineNo">496</span>  public List&lt;HFileBlock&gt; getLoadOnOpenBlocks() {<a name="line.496"></a>
-<span class="sourceLineNo">497</span>    return loadOnOpenBlocks;<a name="line.497"></a>
-<span class="sourceLineNo">498</span>  }<a name="line.498"></a>
-<span class="sourceLineNo">499</span><a name="line.499"></a>
-<span class="sourceLineNo">500</span>  public Cell getLastKeyCell() {<a name="line.500"></a>
-<span class="sourceLineNo">501</span>    return lastKeyCell;<a name="line.501"></a>
-<span class="sourceLineNo">502</span>  }<a name="line.502"></a>
-<span class="sourceLineNo">503</span><a name="line.503"></a>
-<span class="sourceLineNo">504</span>  public int getAvgKeyLen() {<a name="line.504"></a>
-<span class="sourceLineNo">505</span>    return avgKeyLen;<a name="line.505"></a>
-<span class="sourceLineNo">506</span>  }<a name="line.506"></a>
-<span class="sourceLineNo">507</span><a name="line.507"></a>
-<span class="sourceLineNo">508</span>  public int getAvgValueLen() {<a name="line.508"></a>
-<span class="sourceLineNo">509</span>    return avgValueLen;<a name="line.509"></a>
-<span class="sourceLineNo">510</span>  }<a name="line.510"></a>
-<span class="sourceLineNo">511</span><a name="line.511"></a>
-<span class="sourceLineNo">512</span>  public boolean shouldIncludeMemStoreTS() {<a name="line.512"></a>
-<span class="sourceLineNo">513</span>    return includesMemstoreTS;<a name="line.513"></a>
-<span class="sourceLineNo">514</span>  }<a name="line.514"></a>
-<span class="sourceLineNo">515</span><a name="line.515"></a>
-<span class="sourceLineNo">516</span>  public boolean isDecodeMemstoreTS() {<a name="line.516"></a>
-<span class="sourceLineNo">517</span>    return decodeMemstoreTS;<a name="line.517"></a>
-<span class="sourceLineNo">518</span>  }<a name="line.518"></a>
-<span class="sourceLineNo">519</span>}<a name="line.519"></a>
+<span class="sourceLineNo">445</span>    avgKeyLen = Bytes.toInt(get(HFileInfo.AVG_KEY_LEN));<a name="line.445"></a>
+<span class="sourceLineNo">446</span>    avgValueLen = Bytes.toInt(get(HFileInfo.AVG_VALUE_LEN));<a name="line.446"></a>
+<span class="sourceLineNo">447</span>    byte [] keyValueFormatVersion = get(HFileWriterImpl.KEY_VALUE_VERSION);<a name="line.447"></a>
+<span class="sourceLineNo">448</span>    includesMemstoreTS = keyValueFormatVersion != null &amp;&amp;<a name="line.448"></a>
+<span class="sourceLineNo">449</span>        Bytes.toInt(keyValueFormatVersion) == HFileWriterImpl.KEY_VALUE_VER_WITH_MEMSTORE;<a name="line.449"></a>
+<span class="sourceLineNo">450</span>    hfileContext.setIncludesMvcc(includesMemstoreTS);<a name="line.450"></a>
+<span class="sourceLineNo">451</span>    if (includesMemstoreTS) {<a name="line.451"></a>
+<span class="sourceLineNo">452</span>      decodeMemstoreTS = Bytes.toLong(get(HFileWriterImpl.MAX_MEMSTORE_TS_KEY)) &gt; 0;<a name="line.452"></a>
+<span class="sourceLineNo">453</span>    }<a name="line.453"></a>
+<span class="sourceLineNo">454</span>  }<a name="line.454"></a>
+<span class="sourceLineNo">455</span><a name="line.455"></a>
+<span class="sourceLineNo">456</span>  /**<a name="line.456"></a>
+<span class="sourceLineNo">457</span>   * File version check is a little sloppy. We read v3 files but can also read v2 files if their<a name="line.457"></a>
+<span class="sourceLineNo">458</span>   * content has been pb'd; files written with 0.98.<a name="line.458"></a>
+<span class="sourceLineNo">459</span>   */<a name="line.459"></a>
+<span class="sourceLineNo">460</span>  private void checkFileVersion(Path path) {<a name="line.460"></a>
+<span class="sourceLineNo">461</span>    int majorVersion = trailer.getMajorVersion();<a name="line.461"></a>
+<span class="sourceLineNo">462</span>    if (majorVersion == getMajorVersion()) {<a name="line.462"></a>
+<span class="sourceLineNo">463</span>      return;<a name="line.463"></a>
+<span class="sourceLineNo">464</span>    }<a name="line.464"></a>
+<span class="sourceLineNo">465</span>    int minorVersion = trailer.getMinorVersion();<a name="line.465"></a>
+<span class="sourceLineNo">466</span>    if (majorVersion == 2 &amp;&amp; minorVersion &gt;= MIN_V2_MINOR_VERSION_WITH_PB) {<a name="line.466"></a>
+<span class="sourceLineNo">467</span>      return;<a name="line.467"></a>
+<span class="sourceLineNo">468</span>    }<a name="line.468"></a>
+<span class="sourceLineNo">469</span>    // We can read v3 or v2 versions of hfile.<a name="line.469"></a>
+<span class="sourceLineNo">470</span>    throw new IllegalArgumentException("Invalid HFile version: major=" +<a name="line.470"></a>
+<span class="sourceLineNo">471</span>      trailer.getMajorVersion() + ", minor=" + trailer.getMinorVersion() + ": expected at least " +<a name="line.471"></a>
+<span class="sourceLineNo">472</span>      "major=2 and minor=" + MAX_MINOR_VERSION + ", path=" + path);<a name="line.472"></a>
+<span class="sourceLineNo">473</span>  }<a name="line.473"></a>
+<span class="sourceLineNo">474</span><a name="line.474"></a>
+<span class="sourceLineNo">475</span>  public void close() {<a name="line.475"></a>
+<span class="sourceLineNo">476</span>    if (blockIter != null) {<a name="line.476"></a>
+<span class="sourceLineNo">477</span>      blockIter.freeBlocks();<a name="line.477"></a>
+<span class="sourceLineNo">478</span>    }<a name="line.478"></a>
+<span class="sourceLineNo">479</span>  }<a name="line.479"></a>
+<span class="sourceLineNo">480</span><a name="line.480"></a>
+<span class="sourceLineNo">481</span>  public int getMajorVersion() {<a name="line.481"></a>
+<span class="sourceLineNo">482</span>    return 3;<a name="line.482"></a>
+<span class="sourceLineNo">483</span>  }<a name="line.483"></a>
+<span class="sourceLineNo">484</span><a name="line.484"></a>
+<span class="sourceLineNo">485</span>  public void setTrailer(FixedFileTrailer trailer) {<a name="line.485"></a>
+<span class="sourceLineNo">486</span>    this.trailer = trailer;<a name="line.486"></a>
+<span class="sourceLineNo">487</span>  }<a name="line.487"></a>
+<span class="sourceLineNo">488</span><a name="line.488"></a>
+<span class="sourceLineNo">489</span>  public FixedFileTrailer getTrailer() {<a name="line.489"></a>
+<span class="sourceLineNo">490</span>    return this.trailer;<a name="line.490"></a>
+<span class="sourceLineNo">491</span>  }<a name="line.491"></a>
+<span class="sourceLineNo">492</span><a name="line.492"></a>
+<span class="sourceLineNo">493</span>  public HFileBlockIndex.CellBasedKeyBlockIndexReader getDataBlockIndexReader() {<a name="line.493"></a>
+<span class="sourceLineNo">494</span>    return this.dataIndexReader;<a name="line.494"></a>
+<span class="sourceLineNo">495</span>  }<a name="line.495"></a>
+<span class="sourceLineNo">496</span><a name="line.496"></a>
+<span class="sourceLineNo">497</span>  public HFileBlockIndex.ByteArrayKeyBlockIndexReader getMetaBlockIndexReader() {<a name="line.497"></a>
+<span class="sourceLineNo">498</span>    return this.metaIndexReader;<a name="line.498"></a>
+<span class="sourceLineNo">499</span>  }<a name="line.499"></a>
+<span class="sourceLineNo">500</span><a name="line.500"></a>
+<span class="sourceLineNo">501</span>  public HFileContext getHFileContext() {<a name="line.501"></a>
+<span class="sourceLineNo">502</span>    return this.hfileContext;<a name="line.502"></a>
+<span class="sourceLineNo">503</span>  }<a name="line.503"></a>
+<span class="sourceLineNo">504</span><a name="line.504"></a>
+<span class="sourceLineNo">505</span>  public List&lt;HFileBlock&gt; getLoadOnOpenBlocks() {<a name="line.505"></a>
+<span class="sourceLineNo">506</span>    return loadOnOpenBlocks;<a name="line.506"></a>
+<span class="sourceLineNo">507</span>  }<a name="line.507"></a>
+<span class="sourceLineNo">508</span><a name="line.508"></a>
+<span class="sourceLineNo">509</span>  public Cell getLastKeyCell() {<a name="line.509"></a>
+<span class="sourceLineNo">510</span>    return lastKeyCell;<a name="line.510"></a>
+<span class="sourceLineNo">511</span>  }<a name="line.511"></a>
+<span class="sourceLineNo">512</span><a name="line.512"></a>
+<span class="sourceLineNo">513</span>  public int getAvgKeyLen() {<a name="line.513"></a>
+<span class="sourceLineNo">514</span>    return avgKeyLen;<a name="line.514"></a>
+<span class="sourceLineNo">515</span>  }<a name="line.515"></a>
+<span class="sourceLineNo">516</span><a name="line.516"></a>
+<span class="sourceLineNo">517</span>  public int getAvgValueLen() {<a name="line.517"></a>
+<span class="sourceLineNo">518</span>    return avgValueLen;<a name="line.518"></a>
+<span class="sourceLineNo">519</span>  }<a name="line.519"></a>
+<span class="sourceLineNo">520</span><a name="line.520"></a>
+<span class="sourceLineNo">521</span>  public boolean shouldIncludeMemStoreTS() {<a name="line.521"></a>
+<span class="sourceLineNo">522</span>    return includesMemstoreTS;<a name="line.522"></a>
+<span class="sourceLineNo">523</span>  }<a name="line.523"></a>
+<span class="sourceLineNo">524</span><a name="line.524"></a>
+<span class="sourceLineNo">525</span>  public boolean isDecodeMemstoreTS() {<a name="line.525"></a>
+<span class="sourceLineNo">526</span>    return decodeMemstoreTS;<a name="line.526"></a>
+<span class="sourceLineNo">527</span>  }<a name="line.527"></a>
+<span class="sourceLineNo">528</span>}<a name="line.528"></a>
 
 
 
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/master/HMaster.TableDescriptorGetter.html b/devapidocs/src-html/org/apache/hadoop/hbase/master/HMaster.TableDescriptorGetter.html
index 9554da3..749ea2c 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/master/HMaster.TableDescriptorGetter.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/master/HMaster.TableDescriptorGetter.html
@@ -59,176 +59,176 @@
 <span class="sourceLineNo">051</span>import java.util.regex.Pattern;<a name="line.51"></a>
 <span class="sourceLineNo">052</span>import java.util.stream.Collectors;<a name="line.52"></a>
 <span class="sourceLineNo">053</span>import javax.servlet.http.HttpServlet;<a name="line.53"></a>
-<span class="sourceLineNo">054</span>import org.apache.commons.io.IOUtils;<a name="line.54"></a>
-<span class="sourceLineNo">055</span>import org.apache.commons.lang3.StringUtils;<a name="line.55"></a>
-<span class="sourceLineNo">056</span>import org.apache.hadoop.conf.Configuration;<a name="line.56"></a>
-<span class="sourceLineNo">057</span>import org.apache.hadoop.fs.FSDataOutputStream;<a name="line.57"></a>
-<span class="sourceLineNo">058</span>import org.apache.hadoop.fs.Path;<a name="line.58"></a>
-<span class="sourceLineNo">059</span>import org.apache.hadoop.hbase.ChoreService;<a name="line.59"></a>
-<span class="sourceLineNo">060</span>import org.apache.hadoop.hbase.ClusterId;<a name="line.60"></a>
-<span class="sourceLineNo">061</span>import org.apache.hadoop.hbase.ClusterMetrics;<a name="line.61"></a>
-<span class="sourceLineNo">062</span>import org.apache.hadoop.hbase.ClusterMetrics.Option;<a name="line.62"></a>
-<span class="sourceLineNo">063</span>import org.apache.hadoop.hbase.ClusterMetricsBuilder;<a name="line.63"></a>
-<span class="sourceLineNo">064</span>import org.apache.hadoop.hbase.DoNotRetryIOException;<a name="line.64"></a>
-<span class="sourceLineNo">065</span>import org.apache.hadoop.hbase.HBaseIOException;<a name="line.65"></a>
-<span class="sourceLineNo">066</span>import org.apache.hadoop.hbase.HBaseInterfaceAudience;<a name="line.66"></a>
-<span class="sourceLineNo">067</span>import org.apache.hadoop.hbase.HConstants;<a name="line.67"></a>
-<span class="sourceLineNo">068</span>import org.apache.hadoop.hbase.InvalidFamilyOperationException;<a name="line.68"></a>
-<span class="sourceLineNo">069</span>import org.apache.hadoop.hbase.MasterNotRunningException;<a name="line.69"></a>
-<span class="sourceLineNo">070</span>import org.apache.hadoop.hbase.MetaTableAccessor;<a name="line.70"></a>
-<span class="sourceLineNo">071</span>import org.apache.hadoop.hbase.NamespaceDescriptor;<a name="line.71"></a>
-<span class="sourceLineNo">072</span>import org.apache.hadoop.hbase.PleaseHoldException;<a name="line.72"></a>
-<span class="sourceLineNo">073</span>import org.apache.hadoop.hbase.RegionMetrics;<a name="line.73"></a>
-<span class="sourceLineNo">074</span>import org.apache.hadoop.hbase.ReplicationPeerNotFoundException;<a name="line.74"></a>
-<span class="sourceLineNo">075</span>import org.apache.hadoop.hbase.ServerMetrics;<a name="line.75"></a>
-<span class="sourceLineNo">076</span>import org.apache.hadoop.hbase.ServerName;<a name="line.76"></a>
-<span class="sourceLineNo">077</span>import org.apache.hadoop.hbase.TableName;<a name="line.77"></a>
-<span class="sourceLineNo">078</span>import org.apache.hadoop.hbase.TableNotDisabledException;<a name="line.78"></a>
-<span class="sourceLineNo">079</span>import org.apache.hadoop.hbase.TableNotFoundException;<a name="line.79"></a>
-<span class="sourceLineNo">080</span>import org.apache.hadoop.hbase.UnknownRegionException;<a name="line.80"></a>
-<span class="sourceLineNo">081</span>import org.apache.hadoop.hbase.client.ColumnFamilyDescriptor;<a name="line.81"></a>
-<span class="sourceLineNo">082</span>import org.apache.hadoop.hbase.client.CompactionState;<a name="line.82"></a>
-<span class="sourceLineNo">083</span>import org.apache.hadoop.hbase.client.MasterSwitchType;<a name="line.83"></a>
-<span class="sourceLineNo">084</span>import org.apache.hadoop.hbase.client.NormalizeTableFilterParams;<a name="line.84"></a>
-<span class="sourceLineNo">085</span>import org.apache.hadoop.hbase.client.RegionInfo;<a name="line.85"></a>
-<span class="sourceLineNo">086</span>import org.apache.hadoop.hbase.client.RegionInfoBuilder;<a name="line.86"></a>
-<span class="sourceLineNo">087</span>import org.apache.hadoop.hbase.client.RegionStatesCount;<a name="line.87"></a>
-<span class="sourceLineNo">088</span>import org.apache.hadoop.hbase.client.TableDescriptor;<a name="line.88"></a>
-<span class="sourceLineNo">089</span>import org.apache.hadoop.hbase.client.TableDescriptorBuilder;<a name="line.89"></a>
-<span class="sourceLineNo">090</span>import org.apache.hadoop.hbase.client.TableState;<a name="line.90"></a>
-<span class="sourceLineNo">091</span>import org.apache.hadoop.hbase.coprocessor.CoprocessorHost;<a name="line.91"></a>
-<span class="sourceLineNo">092</span>import org.apache.hadoop.hbase.exceptions.MasterStoppedException;<a name="line.92"></a>
-<span class="sourceLineNo">093</span>import org.apache.hadoop.hbase.executor.ExecutorType;<a name="line.93"></a>
-<span class="sourceLineNo">094</span>import org.apache.hadoop.hbase.favored.FavoredNodesManager;<a name="line.94"></a>
-<span class="sourceLineNo">095</span>import org.apache.hadoop.hbase.ipc.CoprocessorRpcUtils;<a name="line.95"></a>
-<span class="sourceLineNo">096</span>import org.apache.hadoop.hbase.ipc.RpcServer;<a name="line.96"></a>
-<span class="sourceLineNo">097</span>import org.apache.hadoop.hbase.ipc.ServerNotRunningYetException;<a name="line.97"></a>
-<span class="sourceLineNo">098</span>import org.apache.hadoop.hbase.log.HBaseMarkers;<a name="line.98"></a>
-<span class="sourceLineNo">099</span>import org.apache.hadoop.hbase.master.MasterRpcServices.BalanceSwitchMode;<a name="line.99"></a>
-<span class="sourceLineNo">100</span>import org.apache.hadoop.hbase.master.assignment.AssignmentManager;<a name="line.100"></a>
-<span class="sourceLineNo">101</span>import org.apache.hadoop.hbase.master.assignment.MergeTableRegionsProcedure;<a name="line.101"></a>
-<span class="sourceLineNo">102</span>import org.apache.hadoop.hbase.master.assignment.RegionStateNode;<a name="line.102"></a>
-<span class="sourceLineNo">103</span>import org.apache.hadoop.hbase.master.assignment.RegionStates;<a name="line.103"></a>
-<span class="sourceLineNo">104</span>import org.apache.hadoop.hbase.master.assignment.TransitRegionStateProcedure;<a name="line.104"></a>
-<span class="sourceLineNo">105</span>import org.apache.hadoop.hbase.master.balancer.BalancerChore;<a name="line.105"></a>
-<span class="sourceLineNo">106</span>import org.apache.hadoop.hbase.master.balancer.ClusterStatusChore;<a name="line.106"></a>
-<span class="sourceLineNo">107</span>import org.apache.hadoop.hbase.master.balancer.LoadBalancerFactory;<a name="line.107"></a>
-<span class="sourceLineNo">108</span>import org.apache.hadoop.hbase.master.cleaner.DirScanPool;<a name="line.108"></a>
-<span class="sourceLineNo">109</span>import org.apache.hadoop.hbase.master.cleaner.HFileCleaner;<a name="line.109"></a>
-<span class="sourceLineNo">110</span>import org.apache.hadoop.hbase.master.cleaner.LogCleaner;<a name="line.110"></a>
-<span class="sourceLineNo">111</span>import org.apache.hadoop.hbase.master.cleaner.ReplicationBarrierCleaner;<a name="line.111"></a>
-<span class="sourceLineNo">112</span>import org.apache.hadoop.hbase.master.cleaner.SnapshotCleanerChore;<a name="line.112"></a>
-<span class="sourceLineNo">113</span>import org.apache.hadoop.hbase.master.janitor.CatalogJanitor;<a name="line.113"></a>
-<span class="sourceLineNo">114</span>import org.apache.hadoop.hbase.master.locking.LockManager;<a name="line.114"></a>
-<span class="sourceLineNo">115</span>import org.apache.hadoop.hbase.master.normalizer.RegionNormalizerFactory;<a name="line.115"></a>
-<span class="sourceLineNo">116</span>import org.apache.hadoop.hbase.master.normalizer.RegionNormalizerManager;<a name="line.116"></a>
-<span class="sourceLineNo">117</span>import org.apache.hadoop.hbase.master.procedure.CreateTableProcedure;<a name="line.117"></a>
-<span class="sourceLineNo">118</span>import org.apache.hadoop.hbase.master.procedure.DeleteNamespaceProcedure;<a name="line.118"></a>
-<span class="sourceLineNo">119</span>import org.apache.hadoop.hbase.master.procedure.DeleteTableProcedure;<a name="line.119"></a>
-<span class="sourceLineNo">120</span>import org.apache.hadoop.hbase.master.procedure.DisableTableProcedure;<a name="line.120"></a>
-<span class="sourceLineNo">121</span>import org.apache.hadoop.hbase.master.procedure.EnableTableProcedure;<a name="line.121"></a>
-<span class="sourceLineNo">122</span>import org.apache.hadoop.hbase.master.procedure.InitMetaProcedure;<a name="line.122"></a>
-<span class="sourceLineNo">123</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureConstants;<a name="line.123"></a>
-<span class="sourceLineNo">124</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureEnv;<a name="line.124"></a>
-<span class="sourceLineNo">125</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureScheduler;<a name="line.125"></a>
-<span class="sourceLineNo">126</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureUtil;<a name="line.126"></a>
-<span class="sourceLineNo">127</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureUtil.NonceProcedureRunnable;<a name="line.127"></a>
-<span class="sourceLineNo">128</span>import org.apache.hadoop.hbase.master.procedure.ModifyTableProcedure;<a name="line.128"></a>
-<span class="sourceLineNo">129</span>import org.apache.hadoop.hbase.master.procedure.ProcedurePrepareLatch;<a name="line.129"></a>
-<span class="sourceLineNo">130</span>import org.apache.hadoop.hbase.master.procedure.ProcedureSyncWait;<a name="line.130"></a>
-<span class="sourceLineNo">131</span>import org.apache.hadoop.hbase.master.procedure.ReopenTableRegionsProcedure;<a name="line.131"></a>
-<span class="sourceLineNo">132</span>import org.apache.hadoop.hbase.master.procedure.ServerCrashProcedure;<a name="line.132"></a>
-<span class="sourceLineNo">133</span>import org.apache.hadoop.hbase.master.procedure.TruncateTableProcedure;<a name="line.133"></a>
-<span class="sourceLineNo">134</span>import org.apache.hadoop.hbase.master.region.MasterRegion;<a name="line.134"></a>
-<span class="sourceLineNo">135</span>import org.apache.hadoop.hbase.master.region.MasterRegionFactory;<a name="line.135"></a>
-<span class="sourceLineNo">136</span>import org.apache.hadoop.hbase.master.replication.AbstractPeerProcedure;<a name="line.136"></a>
-<span class="sourceLineNo">137</span>import org.apache.hadoop.hbase.master.replication.AddPeerProcedure;<a name="line.137"></a>
-<span class="sourceLineNo">138</span>import org.apache.hadoop.hbase.master.replication.DisablePeerProcedure;<a name="line.138"></a>
-<span class="sourceLineNo">139</span>import org.apache.hadoop.hbase.master.replication.EnablePeerProcedure;<a name="line.139"></a>
-<span class="sourceLineNo">140</span>import org.apache.hadoop.hbase.master.replication.RemovePeerProcedure;<a name="line.140"></a>
-<span class="sourceLineNo">141</span>import org.apache.hadoop.hbase.master.replication.ReplicationPeerManager;<a name="line.141"></a>
-<span class="sourceLineNo">142</span>import org.apache.hadoop.hbase.master.replication.SyncReplicationReplayWALManager;<a name="line.142"></a>
-<span class="sourceLineNo">143</span>import org.apache.hadoop.hbase.master.replication.TransitPeerSyncReplicationStateProcedure;<a name="line.143"></a>
-<span class="sourceLineNo">144</span>import org.apache.hadoop.hbase.master.replication.UpdatePeerConfigProcedure;<a name="line.144"></a>
-<span class="sourceLineNo">145</span>import org.apache.hadoop.hbase.master.slowlog.SlowLogMasterService;<a name="line.145"></a>
-<span class="sourceLineNo">146</span>import org.apache.hadoop.hbase.master.snapshot.SnapshotManager;<a name="line.146"></a>
-<span class="sourceLineNo">147</span>import org.apache.hadoop.hbase.master.zksyncer.MasterAddressSyncer;<a name="line.147"></a>
-<span class="sourceLineNo">148</span>import org.apache.hadoop.hbase.master.zksyncer.MetaLocationSyncer;<a name="line.148"></a>
-<span class="sourceLineNo">149</span>import org.apache.hadoop.hbase.mob.MobFileCleanerChore;<a name="line.149"></a>
-<span class="sourceLineNo">150</span>import org.apache.hadoop.hbase.mob.MobFileCompactionChore;<a name="line.150"></a>
-<span class="sourceLineNo">151</span>import org.apache.hadoop.hbase.monitoring.MemoryBoundedLogMessageBuffer;<a name="line.151"></a>
-<span class="sourceLineNo">152</span>import org.apache.hadoop.hbase.monitoring.MonitoredTask;<a name="line.152"></a>
-<span class="sourceLineNo">153</span>import org.apache.hadoop.hbase.monitoring.TaskMonitor;<a name="line.153"></a>
-<span class="sourceLineNo">154</span>import org.apache.hadoop.hbase.procedure.MasterProcedureManagerHost;<a name="line.154"></a>
-<span class="sourceLineNo">155</span>import org.apache.hadoop.hbase.procedure.flush.MasterFlushTableProcedureManager;<a name="line.155"></a>
-<span class="sourceLineNo">156</span>import org.apache.hadoop.hbase.procedure2.LockedResource;<a name="line.156"></a>
-<span class="sourceLineNo">157</span>import org.apache.hadoop.hbase.procedure2.Procedure;<a name="line.157"></a>
-<span class="sourceLineNo">158</span>import org.apache.hadoop.hbase.procedure2.ProcedureEvent;<a name="line.158"></a>
-<span class="sourceLineNo">159</span>import org.apache.hadoop.hbase.procedure2.ProcedureExecutor;<a name="line.159"></a>
-<span class="sourceLineNo">160</span>import org.apache.hadoop.hbase.procedure2.RemoteProcedureDispatcher.RemoteProcedure;<a name="line.160"></a>
-<span class="sourceLineNo">161</span>import org.apache.hadoop.hbase.procedure2.RemoteProcedureException;<a name="line.161"></a>
-<span class="sourceLineNo">162</span>import org.apache.hadoop.hbase.procedure2.store.ProcedureStore;<a name="line.162"></a>
-<span class="sourceLineNo">163</span>import org.apache.hadoop.hbase.procedure2.store.ProcedureStore.ProcedureStoreListener;<a name="line.163"></a>
-<span class="sourceLineNo">164</span>import org.apache.hadoop.hbase.procedure2.store.region.RegionProcedureStore;<a name="line.164"></a>
-<span class="sourceLineNo">165</span>import org.apache.hadoop.hbase.quotas.MasterQuotaManager;<a name="line.165"></a>
-<span class="sourceLineNo">166</span>import org.apache.hadoop.hbase.quotas.MasterQuotasObserver;<a name="line.166"></a>
-<span class="sourceLineNo">167</span>import org.apache.hadoop.hbase.quotas.QuotaObserverChore;<a name="line.167"></a>
-<span class="sourceLineNo">168</span>import org.apache.hadoop.hbase.quotas.QuotaTableUtil;<a name="line.168"></a>
-<span class="sourceLineNo">169</span>import org.apache.hadoop.hbase.quotas.QuotaUtil;<a name="line.169"></a>
-<span class="sourceLineNo">170</span>import org.apache.hadoop.hbase.quotas.SnapshotQuotaObserverChore;<a name="line.170"></a>
-<span class="sourceLineNo">171</span>import org.apache.hadoop.hbase.quotas.SpaceQuotaSnapshot;<a name="line.171"></a>
-<span class="sourceLineNo">172</span>import org.apache.hadoop.hbase.quotas.SpaceQuotaSnapshot.SpaceQuotaStatus;<a name="line.172"></a>
-<span class="sourceLineNo">173</span>import org.apache.hadoop.hbase.quotas.SpaceQuotaSnapshotNotifier;<a name="line.173"></a>
-<span class="sourceLineNo">174</span>import org.apache.hadoop.hbase.quotas.SpaceQuotaSnapshotNotifierFactory;<a name="line.174"></a>
-<span class="sourceLineNo">175</span>import org.apache.hadoop.hbase.quotas.SpaceViolationPolicy;<a name="line.175"></a>
-<span class="sourceLineNo">176</span>import org.apache.hadoop.hbase.regionserver.HRegionServer;<a name="line.176"></a>
-<span class="sourceLineNo">177</span>import org.apache.hadoop.hbase.regionserver.RSRpcServices;<a name="line.177"></a>
-<span class="sourceLineNo">178</span>import org.apache.hadoop.hbase.replication.ReplicationException;<a name="line.178"></a>
-<span class="sourceLineNo">179</span>import org.apache.hadoop.hbase.replication.ReplicationLoadSource;<a name="line.179"></a>
-<span class="sourceLineNo">180</span>import org.apache.hadoop.hbase.replication.ReplicationPeerConfig;<a name="line.180"></a>
-<span class="sourceLineNo">181</span>import org.apache.hadoop.hbase.replication.ReplicationPeerDescription;<a name="line.181"></a>
-<span class="sourceLineNo">182</span>import org.apache.hadoop.hbase.replication.ReplicationUtils;<a name="line.182"></a>
-<span class="sourceLineNo">183</span>import org.apache.hadoop.hbase.replication.SyncReplicationState;<a name="line.183"></a>
-<span class="sourceLineNo">184</span>import org.apache.hadoop.hbase.replication.master.ReplicationHFileCleaner;<a name="line.184"></a>
-<span class="sourceLineNo">185</span>import org.apache.hadoop.hbase.replication.master.ReplicationLogCleaner;<a name="line.185"></a>
-<span class="sourceLineNo">186</span>import org.apache.hadoop.hbase.replication.regionserver.ReplicationStatus;<a name="line.186"></a>
-<span class="sourceLineNo">187</span>import org.apache.hadoop.hbase.rsgroup.RSGroupAdminEndpoint;<a name="line.187"></a>
-<span class="sourceLineNo">188</span>import org.apache.hadoop.hbase.rsgroup.RSGroupBasedLoadBalancer;<a name="line.188"></a>
-<span class="sourceLineNo">189</span>import org.apache.hadoop.hbase.rsgroup.RSGroupInfoManager;<a name="line.189"></a>
-<span class="sourceLineNo">190</span>import org.apache.hadoop.hbase.rsgroup.RSGroupUtil;<a name="line.190"></a>
-<span class="sourceLineNo">191</span>import org.apache.hadoop.hbase.security.AccessDeniedException;<a name="line.191"></a>
-<span class="sourceLineNo">192</span>import org.apache.hadoop.hbase.security.SecurityConstants;<a name="line.192"></a>
-<span class="sourceLineNo">193</span>import org.apache.hadoop.hbase.security.UserProvider;<a name="line.193"></a>
-<span class="sourceLineNo">194</span>import org.apache.hadoop.hbase.trace.TraceUtil;<a name="line.194"></a>
-<span class="sourceLineNo">195</span>import org.apache.hadoop.hbase.util.Addressing;<a name="line.195"></a>
-<span class="sourceLineNo">196</span>import org.apache.hadoop.hbase.util.Bytes;<a name="line.196"></a>
-<span class="sourceLineNo">197</span>import org.apache.hadoop.hbase.util.FutureUtils;<a name="line.197"></a>
-<span class="sourceLineNo">198</span>import org.apache.hadoop.hbase.util.HBaseFsck;<a name="line.198"></a>
-<span class="sourceLineNo">199</span>import org.apache.hadoop.hbase.util.HFileArchiveUtil;<a name="line.199"></a>
-<span class="sourceLineNo">200</span>import org.apache.hadoop.hbase.util.IdLock;<a name="line.200"></a>
-<span class="sourceLineNo">201</span>import org.apache.hadoop.hbase.util.ModifyRegionUtils;<a name="line.201"></a>
-<span class="sourceLineNo">202</span>import org.apache.hadoop.hbase.util.Pair;<a name="line.202"></a>
-<span class="sourceLineNo">203</span>import org.apache.hadoop.hbase.util.RetryCounter;<a name="line.203"></a>
-<span class="sourceLineNo">204</span>import org.apache.hadoop.hbase.util.RetryCounterFactory;<a name="line.204"></a>
-<span class="sourceLineNo">205</span>import org.apache.hadoop.hbase.util.TableDescriptorChecker;<a name="line.205"></a>
-<span class="sourceLineNo">206</span>import org.apache.hadoop.hbase.util.Threads;<a name="line.206"></a>
-<span class="sourceLineNo">207</span>import org.apache.hadoop.hbase.util.VersionInfo;<a name="line.207"></a>
-<span class="sourceLineNo">208</span>import org.apache.hadoop.hbase.zookeeper.LoadBalancerTracker;<a name="line.208"></a>
-<span class="sourceLineNo">209</span>import org.apache.hadoop.hbase.zookeeper.MasterAddressTracker;<a name="line.209"></a>
-<span class="sourceLineNo">210</span>import org.apache.hadoop.hbase.zookeeper.RegionNormalizerTracker;<a name="line.210"></a>
-<span class="sourceLineNo">211</span>import org.apache.hadoop.hbase.zookeeper.SnapshotCleanupTracker;<a name="line.211"></a>
-<span class="sourceLineNo">212</span>import org.apache.hadoop.hbase.zookeeper.ZKClusterId;<a name="line.212"></a>
-<span class="sourceLineNo">213</span>import org.apache.hadoop.hbase.zookeeper.ZKUtil;<a name="line.213"></a>
-<span class="sourceLineNo">214</span>import org.apache.hadoop.hbase.zookeeper.ZKWatcher;<a name="line.214"></a>
-<span class="sourceLineNo">215</span>import org.apache.hadoop.hbase.zookeeper.ZNodePaths;<a name="line.215"></a>
-<span class="sourceLineNo">216</span>import org.apache.yetus.audience.InterfaceAudience;<a name="line.216"></a>
-<span class="sourceLineNo">217</span>import org.apache.zookeeper.KeeperException;<a name="line.217"></a>
-<span class="sourceLineNo">218</span>import org.slf4j.Logger;<a name="line.218"></a>
-<span class="sourceLineNo">219</span>import org.slf4j.LoggerFactory;<a name="line.219"></a>
-<span class="sourceLineNo">220</span><a name="line.220"></a>
-<span class="sourceLineNo">221</span>import org.apache.hbase.thirdparty.com.google.common.collect.Lists;<a name="line.221"></a>
-<span class="sourceLineNo">222</span>import org.apache.hbase.thirdparty.com.google.common.collect.Maps;<a name="line.222"></a>
-<span class="sourceLineNo">223</span>import org.apache.hbase.thirdparty.com.google.common.collect.Sets;<a name="line.223"></a>
+<span class="sourceLineNo">054</span>import org.apache.commons.lang3.StringUtils;<a name="line.54"></a>
+<span class="sourceLineNo">055</span>import org.apache.hadoop.conf.Configuration;<a name="line.55"></a>
+<span class="sourceLineNo">056</span>import org.apache.hadoop.fs.FSDataOutputStream;<a name="line.56"></a>
+<span class="sourceLineNo">057</span>import org.apache.hadoop.fs.Path;<a name="line.57"></a>
+<span class="sourceLineNo">058</span>import org.apache.hadoop.hbase.ChoreService;<a name="line.58"></a>
+<span class="sourceLineNo">059</span>import org.apache.hadoop.hbase.ClusterId;<a name="line.59"></a>
+<span class="sourceLineNo">060</span>import org.apache.hadoop.hbase.ClusterMetrics;<a name="line.60"></a>
+<span class="sourceLineNo">061</span>import org.apache.hadoop.hbase.ClusterMetrics.Option;<a name="line.61"></a>
+<span class="sourceLineNo">062</span>import org.apache.hadoop.hbase.ClusterMetricsBuilder;<a name="line.62"></a>
+<span class="sourceLineNo">063</span>import org.apache.hadoop.hbase.DoNotRetryIOException;<a name="line.63"></a>
+<span class="sourceLineNo">064</span>import org.apache.hadoop.hbase.HBaseIOException;<a name="line.64"></a>
+<span class="sourceLineNo">065</span>import org.apache.hadoop.hbase.HBaseInterfaceAudience;<a name="line.65"></a>
+<span class="sourceLineNo">066</span>import org.apache.hadoop.hbase.HConstants;<a name="line.66"></a>
+<span class="sourceLineNo">067</span>import org.apache.hadoop.hbase.InvalidFamilyOperationException;<a name="line.67"></a>
+<span class="sourceLineNo">068</span>import org.apache.hadoop.hbase.MasterNotRunningException;<a name="line.68"></a>
+<span class="sourceLineNo">069</span>import org.apache.hadoop.hbase.MetaTableAccessor;<a name="line.69"></a>
+<span class="sourceLineNo">070</span>import org.apache.hadoop.hbase.NamespaceDescriptor;<a name="line.70"></a>
+<span class="sourceLineNo">071</span>import org.apache.hadoop.hbase.PleaseHoldException;<a name="line.71"></a>
+<span class="sourceLineNo">072</span>import org.apache.hadoop.hbase.RegionMetrics;<a name="line.72"></a>
+<span class="sourceLineNo">073</span>import org.apache.hadoop.hbase.ReplicationPeerNotFoundException;<a name="line.73"></a>
+<span class="sourceLineNo">074</span>import org.apache.hadoop.hbase.ServerMetrics;<a name="line.74"></a>
+<span class="sourceLineNo">075</span>import org.apache.hadoop.hbase.ServerName;<a name="line.75"></a>
+<span class="sourceLineNo">076</span>import org.apache.hadoop.hbase.TableName;<a name="line.76"></a>
+<span class="sourceLineNo">077</span>import org.apache.hadoop.hbase.TableNotDisabledException;<a name="line.77"></a>
+<span class="sourceLineNo">078</span>import org.apache.hadoop.hbase.TableNotFoundException;<a name="line.78"></a>
+<span class="sourceLineNo">079</span>import org.apache.hadoop.hbase.UnknownRegionException;<a name="line.79"></a>
+<span class="sourceLineNo">080</span>import org.apache.hadoop.hbase.client.ColumnFamilyDescriptor;<a name="line.80"></a>
+<span class="sourceLineNo">081</span>import org.apache.hadoop.hbase.client.CompactionState;<a name="line.81"></a>
+<span class="sourceLineNo">082</span>import org.apache.hadoop.hbase.client.MasterSwitchType;<a name="line.82"></a>
+<span class="sourceLineNo">083</span>import org.apache.hadoop.hbase.client.NormalizeTableFilterParams;<a name="line.83"></a>
+<span class="sourceLineNo">084</span>import org.apache.hadoop.hbase.client.RegionInfo;<a name="line.84"></a>
+<span class="sourceLineNo">085</span>import org.apache.hadoop.hbase.client.RegionInfoBuilder;<a name="line.85"></a>
+<span class="sourceLineNo">086</span>import org.apache.hadoop.hbase.client.RegionStatesCount;<a name="line.86"></a>
+<span class="sourceLineNo">087</span>import org.apache.hadoop.hbase.client.TableDescriptor;<a name="line.87"></a>
+<span class="sourceLineNo">088</span>import org.apache.hadoop.hbase.client.TableDescriptorBuilder;<a name="line.88"></a>
+<span class="sourceLineNo">089</span>import org.apache.hadoop.hbase.client.TableState;<a name="line.89"></a>
+<span class="sourceLineNo">090</span>import org.apache.hadoop.hbase.coprocessor.CoprocessorHost;<a name="line.90"></a>
+<span class="sourceLineNo">091</span>import org.apache.hadoop.hbase.exceptions.MasterStoppedException;<a name="line.91"></a>
+<span class="sourceLineNo">092</span>import org.apache.hadoop.hbase.executor.ExecutorType;<a name="line.92"></a>
+<span class="sourceLineNo">093</span>import org.apache.hadoop.hbase.favored.FavoredNodesManager;<a name="line.93"></a>
+<span class="sourceLineNo">094</span>import org.apache.hadoop.hbase.ipc.CoprocessorRpcUtils;<a name="line.94"></a>
+<span class="sourceLineNo">095</span>import org.apache.hadoop.hbase.ipc.RpcServer;<a name="line.95"></a>
+<span class="sourceLineNo">096</span>import org.apache.hadoop.hbase.ipc.ServerNotRunningYetException;<a name="line.96"></a>
+<span class="sourceLineNo">097</span>import org.apache.hadoop.hbase.log.HBaseMarkers;<a name="line.97"></a>
+<span class="sourceLineNo">098</span>import org.apache.hadoop.hbase.master.MasterRpcServices.BalanceSwitchMode;<a name="line.98"></a>
+<span class="sourceLineNo">099</span>import org.apache.hadoop.hbase.master.assignment.AssignmentManager;<a name="line.99"></a>
+<span class="sourceLineNo">100</span>import org.apache.hadoop.hbase.master.assignment.MergeTableRegionsProcedure;<a name="line.100"></a>
+<span class="sourceLineNo">101</span>import org.apache.hadoop.hbase.master.assignment.RegionStateNode;<a name="line.101"></a>
+<span class="sourceLineNo">102</span>import org.apache.hadoop.hbase.master.assignment.RegionStates;<a name="line.102"></a>
+<span class="sourceLineNo">103</span>import org.apache.hadoop.hbase.master.assignment.TransitRegionStateProcedure;<a name="line.103"></a>
+<span class="sourceLineNo">104</span>import org.apache.hadoop.hbase.master.balancer.BalancerChore;<a name="line.104"></a>
+<span class="sourceLineNo">105</span>import org.apache.hadoop.hbase.master.balancer.ClusterStatusChore;<a name="line.105"></a>
+<span class="sourceLineNo">106</span>import org.apache.hadoop.hbase.master.balancer.LoadBalancerFactory;<a name="line.106"></a>
+<span class="sourceLineNo">107</span>import org.apache.hadoop.hbase.master.cleaner.DirScanPool;<a name="line.107"></a>
+<span class="sourceLineNo">108</span>import org.apache.hadoop.hbase.master.cleaner.HFileCleaner;<a name="line.108"></a>
+<span class="sourceLineNo">109</span>import org.apache.hadoop.hbase.master.cleaner.LogCleaner;<a name="line.109"></a>
+<span class="sourceLineNo">110</span>import org.apache.hadoop.hbase.master.cleaner.ReplicationBarrierCleaner;<a name="line.110"></a>
+<span class="sourceLineNo">111</span>import org.apache.hadoop.hbase.master.cleaner.SnapshotCleanerChore;<a name="line.111"></a>
+<span class="sourceLineNo">112</span>import org.apache.hadoop.hbase.master.janitor.CatalogJanitor;<a name="line.112"></a>
+<span class="sourceLineNo">113</span>import org.apache.hadoop.hbase.master.locking.LockManager;<a name="line.113"></a>
+<span class="sourceLineNo">114</span>import org.apache.hadoop.hbase.master.normalizer.RegionNormalizerFactory;<a name="line.114"></a>
+<span class="sourceLineNo">115</span>import org.apache.hadoop.hbase.master.normalizer.RegionNormalizerManager;<a name="line.115"></a>
+<span class="sourceLineNo">116</span>import org.apache.hadoop.hbase.master.procedure.CreateTableProcedure;<a name="line.116"></a>
+<span class="sourceLineNo">117</span>import org.apache.hadoop.hbase.master.procedure.DeleteNamespaceProcedure;<a name="line.117"></a>
+<span class="sourceLineNo">118</span>import org.apache.hadoop.hbase.master.procedure.DeleteTableProcedure;<a name="line.118"></a>
+<span class="sourceLineNo">119</span>import org.apache.hadoop.hbase.master.procedure.DisableTableProcedure;<a name="line.119"></a>
+<span class="sourceLineNo">120</span>import org.apache.hadoop.hbase.master.procedure.EnableTableProcedure;<a name="line.120"></a>
+<span class="sourceLineNo">121</span>import org.apache.hadoop.hbase.master.procedure.InitMetaProcedure;<a name="line.121"></a>
+<span class="sourceLineNo">122</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureConstants;<a name="line.122"></a>
+<span class="sourceLineNo">123</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureEnv;<a name="line.123"></a>
+<span class="sourceLineNo">124</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureScheduler;<a name="line.124"></a>
+<span class="sourceLineNo">125</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureUtil;<a name="line.125"></a>
+<span class="sourceLineNo">126</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureUtil.NonceProcedureRunnable;<a name="line.126"></a>
+<span class="sourceLineNo">127</span>import org.apache.hadoop.hbase.master.procedure.ModifyTableProcedure;<a name="line.127"></a>
+<span class="sourceLineNo">128</span>import org.apache.hadoop.hbase.master.procedure.ProcedurePrepareLatch;<a name="line.128"></a>
+<span class="sourceLineNo">129</span>import org.apache.hadoop.hbase.master.procedure.ProcedureSyncWait;<a name="line.129"></a>
+<span class="sourceLineNo">130</span>import org.apache.hadoop.hbase.master.procedure.ReopenTableRegionsProcedure;<a name="line.130"></a>
+<span class="sourceLineNo">131</span>import org.apache.hadoop.hbase.master.procedure.ServerCrashProcedure;<a name="line.131"></a>
+<span class="sourceLineNo">132</span>import org.apache.hadoop.hbase.master.procedure.TruncateTableProcedure;<a name="line.132"></a>
+<span class="sourceLineNo">133</span>import org.apache.hadoop.hbase.master.region.MasterRegion;<a name="line.133"></a>
+<span class="sourceLineNo">134</span>import org.apache.hadoop.hbase.master.region.MasterRegionFactory;<a name="line.134"></a>
+<span class="sourceLineNo">135</span>import org.apache.hadoop.hbase.master.replication.AbstractPeerProcedure;<a name="line.135"></a>
+<span class="sourceLineNo">136</span>import org.apache.hadoop.hbase.master.replication.AddPeerProcedure;<a name="line.136"></a>
+<span class="sourceLineNo">137</span>import org.apache.hadoop.hbase.master.replication.DisablePeerProcedure;<a name="line.137"></a>
+<span class="sourceLineNo">138</span>import org.apache.hadoop.hbase.master.replication.EnablePeerProcedure;<a name="line.138"></a>
+<span class="sourceLineNo">139</span>import org.apache.hadoop.hbase.master.replication.RemovePeerProcedure;<a name="line.139"></a>
+<span class="sourceLineNo">140</span>import org.apache.hadoop.hbase.master.replication.ReplicationPeerManager;<a name="line.140"></a>
+<span class="sourceLineNo">141</span>import org.apache.hadoop.hbase.master.replication.SyncReplicationReplayWALManager;<a name="line.141"></a>
+<span class="sourceLineNo">142</span>import org.apache.hadoop.hbase.master.replication.TransitPeerSyncReplicationStateProcedure;<a name="line.142"></a>
+<span class="sourceLineNo">143</span>import org.apache.hadoop.hbase.master.replication.UpdatePeerConfigProcedure;<a name="line.143"></a>
+<span class="sourceLineNo">144</span>import org.apache.hadoop.hbase.master.slowlog.SlowLogMasterService;<a name="line.144"></a>
+<span class="sourceLineNo">145</span>import org.apache.hadoop.hbase.master.snapshot.SnapshotManager;<a name="line.145"></a>
+<span class="sourceLineNo">146</span>import org.apache.hadoop.hbase.master.zksyncer.MasterAddressSyncer;<a name="line.146"></a>
+<span class="sourceLineNo">147</span>import org.apache.hadoop.hbase.master.zksyncer.MetaLocationSyncer;<a name="line.147"></a>
+<span class="sourceLineNo">148</span>import org.apache.hadoop.hbase.mob.MobFileCleanerChore;<a name="line.148"></a>
+<span class="sourceLineNo">149</span>import org.apache.hadoop.hbase.mob.MobFileCompactionChore;<a name="line.149"></a>
+<span class="sourceLineNo">150</span>import org.apache.hadoop.hbase.monitoring.MemoryBoundedLogMessageBuffer;<a name="line.150"></a>
+<span class="sourceLineNo">151</span>import org.apache.hadoop.hbase.monitoring.MonitoredTask;<a name="line.151"></a>
+<span class="sourceLineNo">152</span>import org.apache.hadoop.hbase.monitoring.TaskMonitor;<a name="line.152"></a>
+<span class="sourceLineNo">153</span>import org.apache.hadoop.hbase.procedure.MasterProcedureManagerHost;<a name="line.153"></a>
+<span class="sourceLineNo">154</span>import org.apache.hadoop.hbase.procedure.flush.MasterFlushTableProcedureManager;<a name="line.154"></a>
+<span class="sourceLineNo">155</span>import org.apache.hadoop.hbase.procedure2.LockedResource;<a name="line.155"></a>
+<span class="sourceLineNo">156</span>import org.apache.hadoop.hbase.procedure2.Procedure;<a name="line.156"></a>
+<span class="sourceLineNo">157</span>import org.apache.hadoop.hbase.procedure2.ProcedureEvent;<a name="line.157"></a>
+<span class="sourceLineNo">158</span>import org.apache.hadoop.hbase.procedure2.ProcedureExecutor;<a name="line.158"></a>
+<span class="sourceLineNo">159</span>import org.apache.hadoop.hbase.procedure2.RemoteProcedureDispatcher.RemoteProcedure;<a name="line.159"></a>
+<span class="sourceLineNo">160</span>import org.apache.hadoop.hbase.procedure2.RemoteProcedureException;<a name="line.160"></a>
+<span class="sourceLineNo">161</span>import org.apache.hadoop.hbase.procedure2.store.ProcedureStore;<a name="line.161"></a>
+<span class="sourceLineNo">162</span>import org.apache.hadoop.hbase.procedure2.store.ProcedureStore.ProcedureStoreListener;<a name="line.162"></a>
+<span class="sourceLineNo">163</span>import org.apache.hadoop.hbase.procedure2.store.region.RegionProcedureStore;<a name="line.163"></a>
+<span class="sourceLineNo">164</span>import org.apache.hadoop.hbase.quotas.MasterQuotaManager;<a name="line.164"></a>
+<span class="sourceLineNo">165</span>import org.apache.hadoop.hbase.quotas.MasterQuotasObserver;<a name="line.165"></a>
+<span class="sourceLineNo">166</span>import org.apache.hadoop.hbase.quotas.QuotaObserverChore;<a name="line.166"></a>
+<span class="sourceLineNo">167</span>import org.apache.hadoop.hbase.quotas.QuotaTableUtil;<a name="line.167"></a>
+<span class="sourceLineNo">168</span>import org.apache.hadoop.hbase.quotas.QuotaUtil;<a name="line.168"></a>
+<span class="sourceLineNo">169</span>import org.apache.hadoop.hbase.quotas.SnapshotQuotaObserverChore;<a name="line.169"></a>
+<span class="sourceLineNo">170</span>import org.apache.hadoop.hbase.quotas.SpaceQuotaSnapshot;<a name="line.170"></a>
+<span class="sourceLineNo">171</span>import org.apache.hadoop.hbase.quotas.SpaceQuotaSnapshot.SpaceQuotaStatus;<a name="line.171"></a>
+<span class="sourceLineNo">172</span>import org.apache.hadoop.hbase.quotas.SpaceQuotaSnapshotNotifier;<a name="line.172"></a>
+<span class="sourceLineNo">173</span>import org.apache.hadoop.hbase.quotas.SpaceQuotaSnapshotNotifierFactory;<a name="line.173"></a>
+<span class="sourceLineNo">174</span>import org.apache.hadoop.hbase.quotas.SpaceViolationPolicy;<a name="line.174"></a>
+<span class="sourceLineNo">175</span>import org.apache.hadoop.hbase.regionserver.HRegionServer;<a name="line.175"></a>
+<span class="sourceLineNo">176</span>import org.apache.hadoop.hbase.regionserver.RSRpcServices;<a name="line.176"></a>
+<span class="sourceLineNo">177</span>import org.apache.hadoop.hbase.replication.ReplicationException;<a name="line.177"></a>
+<span class="sourceLineNo">178</span>import org.apache.hadoop.hbase.replication.ReplicationLoadSource;<a name="line.178"></a>
+<span class="sourceLineNo">179</span>import org.apache.hadoop.hbase.replication.ReplicationPeerConfig;<a name="line.179"></a>
+<span class="sourceLineNo">180</span>import org.apache.hadoop.hbase.replication.ReplicationPeerDescription;<a name="line.180"></a>
+<span class="sourceLineNo">181</span>import org.apache.hadoop.hbase.replication.ReplicationUtils;<a name="line.181"></a>
+<span class="sourceLineNo">182</span>import org.apache.hadoop.hbase.replication.SyncReplicationState;<a name="line.182"></a>
+<span class="sourceLineNo">183</span>import org.apache.hadoop.hbase.replication.master.ReplicationHFileCleaner;<a name="line.183"></a>
+<span class="sourceLineNo">184</span>import org.apache.hadoop.hbase.replication.master.ReplicationLogCleaner;<a name="line.184"></a>
+<span class="sourceLineNo">185</span>import org.apache.hadoop.hbase.replication.regionserver.ReplicationStatus;<a name="line.185"></a>
+<span class="sourceLineNo">186</span>import org.apache.hadoop.hbase.rsgroup.RSGroupAdminEndpoint;<a name="line.186"></a>
+<span class="sourceLineNo">187</span>import org.apache.hadoop.hbase.rsgroup.RSGroupBasedLoadBalancer;<a name="line.187"></a>
+<span class="sourceLineNo">188</span>import org.apache.hadoop.hbase.rsgroup.RSGroupInfoManager;<a name="line.188"></a>
+<span class="sourceLineNo">189</span>import org.apache.hadoop.hbase.rsgroup.RSGroupUtil;<a name="line.189"></a>
+<span class="sourceLineNo">190</span>import org.apache.hadoop.hbase.security.AccessDeniedException;<a name="line.190"></a>
+<span class="sourceLineNo">191</span>import org.apache.hadoop.hbase.security.SecurityConstants;<a name="line.191"></a>
+<span class="sourceLineNo">192</span>import org.apache.hadoop.hbase.security.UserProvider;<a name="line.192"></a>
+<span class="sourceLineNo">193</span>import org.apache.hadoop.hbase.trace.TraceUtil;<a name="line.193"></a>
+<span class="sourceLineNo">194</span>import org.apache.hadoop.hbase.util.Addressing;<a name="line.194"></a>
+<span class="sourceLineNo">195</span>import org.apache.hadoop.hbase.util.Bytes;<a name="line.195"></a>
+<span class="sourceLineNo">196</span>import org.apache.hadoop.hbase.util.FutureUtils;<a name="line.196"></a>
+<span class="sourceLineNo">197</span>import org.apache.hadoop.hbase.util.HBaseFsck;<a name="line.197"></a>
+<span class="sourceLineNo">198</span>import org.apache.hadoop.hbase.util.HFileArchiveUtil;<a name="line.198"></a>
+<span class="sourceLineNo">199</span>import org.apache.hadoop.hbase.util.IdLock;<a name="line.199"></a>
+<span class="sourceLineNo">200</span>import org.apache.hadoop.hbase.util.ModifyRegionUtils;<a name="line.200"></a>
+<span class="sourceLineNo">201</span>import org.apache.hadoop.hbase.util.Pair;<a name="line.201"></a>
+<span class="sourceLineNo">202</span>import org.apache.hadoop.hbase.util.RetryCounter;<a name="line.202"></a>
+<span class="sourceLineNo">203</span>import org.apache.hadoop.hbase.util.RetryCounterFactory;<a name="line.203"></a>
+<span class="sourceLineNo">204</span>import org.apache.hadoop.hbase.util.TableDescriptorChecker;<a name="line.204"></a>
+<span class="sourceLineNo">205</span>import org.apache.hadoop.hbase.util.Threads;<a name="line.205"></a>
+<span class="sourceLineNo">206</span>import org.apache.hadoop.hbase.util.VersionInfo;<a name="line.206"></a>
+<span class="sourceLineNo">207</span>import org.apache.hadoop.hbase.zookeeper.LoadBalancerTracker;<a name="line.207"></a>
+<span class="sourceLineNo">208</span>import org.apache.hadoop.hbase.zookeeper.MasterAddressTracker;<a name="line.208"></a>
+<span class="sourceLineNo">209</span>import org.apache.hadoop.hbase.zookeeper.RegionNormalizerTracker;<a name="line.209"></a>
+<span class="sourceLineNo">210</span>import org.apache.hadoop.hbase.zookeeper.SnapshotCleanupTracker;<a name="line.210"></a>
+<span class="sourceLineNo">211</span>import org.apache.hadoop.hbase.zookeeper.ZKClusterId;<a name="line.211"></a>
+<span class="sourceLineNo">212</span>import org.apache.hadoop.hbase.zookeeper.ZKUtil;<a name="line.212"></a>
+<span class="sourceLineNo">213</span>import org.apache.hadoop.hbase.zookeeper.ZKWatcher;<a name="line.213"></a>
+<span class="sourceLineNo">214</span>import org.apache.hadoop.hbase.zookeeper.ZNodePaths;<a name="line.214"></a>
+<span class="sourceLineNo">215</span>import org.apache.yetus.audience.InterfaceAudience;<a name="line.215"></a>
+<span class="sourceLineNo">216</span>import org.apache.zookeeper.KeeperException;<a name="line.216"></a>
+<span class="sourceLineNo">217</span>import org.slf4j.Logger;<a name="line.217"></a>
+<span class="sourceLineNo">218</span>import org.slf4j.LoggerFactory;<a name="line.218"></a>
+<span class="sourceLineNo">219</span><a name="line.219"></a>
+<span class="sourceLineNo">220</span>import org.apache.hbase.thirdparty.com.google.common.collect.Lists;<a name="line.220"></a>
+<span class="sourceLineNo">221</span>import org.apache.hbase.thirdparty.com.google.common.collect.Maps;<a name="line.221"></a>
+<span class="sourceLineNo">222</span>import org.apache.hbase.thirdparty.com.google.common.collect.Sets;<a name="line.222"></a>
+<span class="sourceLineNo">223</span>import org.apache.hbase.thirdparty.com.google.common.io.Closeables;<a name="line.223"></a>
 <span class="sourceLineNo">224</span>import org.apache.hbase.thirdparty.com.google.protobuf.Descriptors;<a name="line.224"></a>
 <span class="sourceLineNo">225</span>import org.apache.hbase.thirdparty.com.google.protobuf.Service;<a name="line.225"></a>
 <span class="sourceLineNo">226</span>import org.apache.hbase.thirdparty.org.eclipse.jetty.server.Server;<a name="line.226"></a>
@@ -840,7 +840,7 @@
 <span class="sourceLineNo">832</span>            HBaseFsck.createLockRetryCounterFactory(this.conf).create());<a name="line.832"></a>
 <span class="sourceLineNo">833</span>      } finally {<a name="line.833"></a>
 <span class="sourceLineNo">834</span>        if (result != null) {<a name="line.834"></a>
-<span class="sourceLineNo">835</span>          IOUtils.closeQuietly(result.getSecond());<a name="line.835"></a>
+<span class="sourceLineNo">835</span>          Closeables.close(result.getSecond(), true);<a name="line.835"></a>
 <span class="sourceLineNo">836</span>        }<a name="line.836"></a>
 <span class="sourceLineNo">837</span>      }<a name="line.837"></a>
 <span class="sourceLineNo">838</span>    }<a name="line.838"></a>
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/master/HMaster.html b/devapidocs/src-html/org/apache/hadoop/hbase/master/HMaster.html
index 9554da3..749ea2c 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/master/HMaster.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/master/HMaster.html
@@ -59,176 +59,176 @@
 <span class="sourceLineNo">051</span>import java.util.regex.Pattern;<a name="line.51"></a>
 <span class="sourceLineNo">052</span>import java.util.stream.Collectors;<a name="line.52"></a>
 <span class="sourceLineNo">053</span>import javax.servlet.http.HttpServlet;<a name="line.53"></a>
-<span class="sourceLineNo">054</span>import org.apache.commons.io.IOUtils;<a name="line.54"></a>
-<span class="sourceLineNo">055</span>import org.apache.commons.lang3.StringUtils;<a name="line.55"></a>
-<span class="sourceLineNo">056</span>import org.apache.hadoop.conf.Configuration;<a name="line.56"></a>
-<span class="sourceLineNo">057</span>import org.apache.hadoop.fs.FSDataOutputStream;<a name="line.57"></a>
-<span class="sourceLineNo">058</span>import org.apache.hadoop.fs.Path;<a name="line.58"></a>
-<span class="sourceLineNo">059</span>import org.apache.hadoop.hbase.ChoreService;<a name="line.59"></a>
-<span class="sourceLineNo">060</span>import org.apache.hadoop.hbase.ClusterId;<a name="line.60"></a>
-<span class="sourceLineNo">061</span>import org.apache.hadoop.hbase.ClusterMetrics;<a name="line.61"></a>
-<span class="sourceLineNo">062</span>import org.apache.hadoop.hbase.ClusterMetrics.Option;<a name="line.62"></a>
-<span class="sourceLineNo">063</span>import org.apache.hadoop.hbase.ClusterMetricsBuilder;<a name="line.63"></a>
-<span class="sourceLineNo">064</span>import org.apache.hadoop.hbase.DoNotRetryIOException;<a name="line.64"></a>
-<span class="sourceLineNo">065</span>import org.apache.hadoop.hbase.HBaseIOException;<a name="line.65"></a>
-<span class="sourceLineNo">066</span>import org.apache.hadoop.hbase.HBaseInterfaceAudience;<a name="line.66"></a>
-<span class="sourceLineNo">067</span>import org.apache.hadoop.hbase.HConstants;<a name="line.67"></a>
-<span class="sourceLineNo">068</span>import org.apache.hadoop.hbase.InvalidFamilyOperationException;<a name="line.68"></a>
-<span class="sourceLineNo">069</span>import org.apache.hadoop.hbase.MasterNotRunningException;<a name="line.69"></a>
-<span class="sourceLineNo">070</span>import org.apache.hadoop.hbase.MetaTableAccessor;<a name="line.70"></a>
-<span class="sourceLineNo">071</span>import org.apache.hadoop.hbase.NamespaceDescriptor;<a name="line.71"></a>
-<span class="sourceLineNo">072</span>import org.apache.hadoop.hbase.PleaseHoldException;<a name="line.72"></a>
-<span class="sourceLineNo">073</span>import org.apache.hadoop.hbase.RegionMetrics;<a name="line.73"></a>
-<span class="sourceLineNo">074</span>import org.apache.hadoop.hbase.ReplicationPeerNotFoundException;<a name="line.74"></a>
-<span class="sourceLineNo">075</span>import org.apache.hadoop.hbase.ServerMetrics;<a name="line.75"></a>
-<span class="sourceLineNo">076</span>import org.apache.hadoop.hbase.ServerName;<a name="line.76"></a>
-<span class="sourceLineNo">077</span>import org.apache.hadoop.hbase.TableName;<a name="line.77"></a>
-<span class="sourceLineNo">078</span>import org.apache.hadoop.hbase.TableNotDisabledException;<a name="line.78"></a>
-<span class="sourceLineNo">079</span>import org.apache.hadoop.hbase.TableNotFoundException;<a name="line.79"></a>
-<span class="sourceLineNo">080</span>import org.apache.hadoop.hbase.UnknownRegionException;<a name="line.80"></a>
-<span class="sourceLineNo">081</span>import org.apache.hadoop.hbase.client.ColumnFamilyDescriptor;<a name="line.81"></a>
-<span class="sourceLineNo">082</span>import org.apache.hadoop.hbase.client.CompactionState;<a name="line.82"></a>
-<span class="sourceLineNo">083</span>import org.apache.hadoop.hbase.client.MasterSwitchType;<a name="line.83"></a>
-<span class="sourceLineNo">084</span>import org.apache.hadoop.hbase.client.NormalizeTableFilterParams;<a name="line.84"></a>
-<span class="sourceLineNo">085</span>import org.apache.hadoop.hbase.client.RegionInfo;<a name="line.85"></a>
-<span class="sourceLineNo">086</span>import org.apache.hadoop.hbase.client.RegionInfoBuilder;<a name="line.86"></a>
-<span class="sourceLineNo">087</span>import org.apache.hadoop.hbase.client.RegionStatesCount;<a name="line.87"></a>
-<span class="sourceLineNo">088</span>import org.apache.hadoop.hbase.client.TableDescriptor;<a name="line.88"></a>
-<span class="sourceLineNo">089</span>import org.apache.hadoop.hbase.client.TableDescriptorBuilder;<a name="line.89"></a>
-<span class="sourceLineNo">090</span>import org.apache.hadoop.hbase.client.TableState;<a name="line.90"></a>
-<span class="sourceLineNo">091</span>import org.apache.hadoop.hbase.coprocessor.CoprocessorHost;<a name="line.91"></a>
-<span class="sourceLineNo">092</span>import org.apache.hadoop.hbase.exceptions.MasterStoppedException;<a name="line.92"></a>
-<span class="sourceLineNo">093</span>import org.apache.hadoop.hbase.executor.ExecutorType;<a name="line.93"></a>
-<span class="sourceLineNo">094</span>import org.apache.hadoop.hbase.favored.FavoredNodesManager;<a name="line.94"></a>
-<span class="sourceLineNo">095</span>import org.apache.hadoop.hbase.ipc.CoprocessorRpcUtils;<a name="line.95"></a>
-<span class="sourceLineNo">096</span>import org.apache.hadoop.hbase.ipc.RpcServer;<a name="line.96"></a>
-<span class="sourceLineNo">097</span>import org.apache.hadoop.hbase.ipc.ServerNotRunningYetException;<a name="line.97"></a>
-<span class="sourceLineNo">098</span>import org.apache.hadoop.hbase.log.HBaseMarkers;<a name="line.98"></a>
-<span class="sourceLineNo">099</span>import org.apache.hadoop.hbase.master.MasterRpcServices.BalanceSwitchMode;<a name="line.99"></a>
-<span class="sourceLineNo">100</span>import org.apache.hadoop.hbase.master.assignment.AssignmentManager;<a name="line.100"></a>
-<span class="sourceLineNo">101</span>import org.apache.hadoop.hbase.master.assignment.MergeTableRegionsProcedure;<a name="line.101"></a>
-<span class="sourceLineNo">102</span>import org.apache.hadoop.hbase.master.assignment.RegionStateNode;<a name="line.102"></a>
-<span class="sourceLineNo">103</span>import org.apache.hadoop.hbase.master.assignment.RegionStates;<a name="line.103"></a>
-<span class="sourceLineNo">104</span>import org.apache.hadoop.hbase.master.assignment.TransitRegionStateProcedure;<a name="line.104"></a>
-<span class="sourceLineNo">105</span>import org.apache.hadoop.hbase.master.balancer.BalancerChore;<a name="line.105"></a>
-<span class="sourceLineNo">106</span>import org.apache.hadoop.hbase.master.balancer.ClusterStatusChore;<a name="line.106"></a>
-<span class="sourceLineNo">107</span>import org.apache.hadoop.hbase.master.balancer.LoadBalancerFactory;<a name="line.107"></a>
-<span class="sourceLineNo">108</span>import org.apache.hadoop.hbase.master.cleaner.DirScanPool;<a name="line.108"></a>
-<span class="sourceLineNo">109</span>import org.apache.hadoop.hbase.master.cleaner.HFileCleaner;<a name="line.109"></a>
-<span class="sourceLineNo">110</span>import org.apache.hadoop.hbase.master.cleaner.LogCleaner;<a name="line.110"></a>
-<span class="sourceLineNo">111</span>import org.apache.hadoop.hbase.master.cleaner.ReplicationBarrierCleaner;<a name="line.111"></a>
-<span class="sourceLineNo">112</span>import org.apache.hadoop.hbase.master.cleaner.SnapshotCleanerChore;<a name="line.112"></a>
-<span class="sourceLineNo">113</span>import org.apache.hadoop.hbase.master.janitor.CatalogJanitor;<a name="line.113"></a>
-<span class="sourceLineNo">114</span>import org.apache.hadoop.hbase.master.locking.LockManager;<a name="line.114"></a>
-<span class="sourceLineNo">115</span>import org.apache.hadoop.hbase.master.normalizer.RegionNormalizerFactory;<a name="line.115"></a>
-<span class="sourceLineNo">116</span>import org.apache.hadoop.hbase.master.normalizer.RegionNormalizerManager;<a name="line.116"></a>
-<span class="sourceLineNo">117</span>import org.apache.hadoop.hbase.master.procedure.CreateTableProcedure;<a name="line.117"></a>
-<span class="sourceLineNo">118</span>import org.apache.hadoop.hbase.master.procedure.DeleteNamespaceProcedure;<a name="line.118"></a>
-<span class="sourceLineNo">119</span>import org.apache.hadoop.hbase.master.procedure.DeleteTableProcedure;<a name="line.119"></a>
-<span class="sourceLineNo">120</span>import org.apache.hadoop.hbase.master.procedure.DisableTableProcedure;<a name="line.120"></a>
-<span class="sourceLineNo">121</span>import org.apache.hadoop.hbase.master.procedure.EnableTableProcedure;<a name="line.121"></a>
-<span class="sourceLineNo">122</span>import org.apache.hadoop.hbase.master.procedure.InitMetaProcedure;<a name="line.122"></a>
-<span class="sourceLineNo">123</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureConstants;<a name="line.123"></a>
-<span class="sourceLineNo">124</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureEnv;<a name="line.124"></a>
-<span class="sourceLineNo">125</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureScheduler;<a name="line.125"></a>
-<span class="sourceLineNo">126</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureUtil;<a name="line.126"></a>
-<span class="sourceLineNo">127</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureUtil.NonceProcedureRunnable;<a name="line.127"></a>
-<span class="sourceLineNo">128</span>import org.apache.hadoop.hbase.master.procedure.ModifyTableProcedure;<a name="line.128"></a>
-<span class="sourceLineNo">129</span>import org.apache.hadoop.hbase.master.procedure.ProcedurePrepareLatch;<a name="line.129"></a>
-<span class="sourceLineNo">130</span>import org.apache.hadoop.hbase.master.procedure.ProcedureSyncWait;<a name="line.130"></a>
-<span class="sourceLineNo">131</span>import org.apache.hadoop.hbase.master.procedure.ReopenTableRegionsProcedure;<a name="line.131"></a>
-<span class="sourceLineNo">132</span>import org.apache.hadoop.hbase.master.procedure.ServerCrashProcedure;<a name="line.132"></a>
-<span class="sourceLineNo">133</span>import org.apache.hadoop.hbase.master.procedure.TruncateTableProcedure;<a name="line.133"></a>
-<span class="sourceLineNo">134</span>import org.apache.hadoop.hbase.master.region.MasterRegion;<a name="line.134"></a>
-<span class="sourceLineNo">135</span>import org.apache.hadoop.hbase.master.region.MasterRegionFactory;<a name="line.135"></a>
-<span class="sourceLineNo">136</span>import org.apache.hadoop.hbase.master.replication.AbstractPeerProcedure;<a name="line.136"></a>
-<span class="sourceLineNo">137</span>import org.apache.hadoop.hbase.master.replication.AddPeerProcedure;<a name="line.137"></a>
-<span class="sourceLineNo">138</span>import org.apache.hadoop.hbase.master.replication.DisablePeerProcedure;<a name="line.138"></a>
-<span class="sourceLineNo">139</span>import org.apache.hadoop.hbase.master.replication.EnablePeerProcedure;<a name="line.139"></a>
-<span class="sourceLineNo">140</span>import org.apache.hadoop.hbase.master.replication.RemovePeerProcedure;<a name="line.140"></a>
-<span class="sourceLineNo">141</span>import org.apache.hadoop.hbase.master.replication.ReplicationPeerManager;<a name="line.141"></a>
-<span class="sourceLineNo">142</span>import org.apache.hadoop.hbase.master.replication.SyncReplicationReplayWALManager;<a name="line.142"></a>
-<span class="sourceLineNo">143</span>import org.apache.hadoop.hbase.master.replication.TransitPeerSyncReplicationStateProcedure;<a name="line.143"></a>
-<span class="sourceLineNo">144</span>import org.apache.hadoop.hbase.master.replication.UpdatePeerConfigProcedure;<a name="line.144"></a>
-<span class="sourceLineNo">145</span>import org.apache.hadoop.hbase.master.slowlog.SlowLogMasterService;<a name="line.145"></a>
-<span class="sourceLineNo">146</span>import org.apache.hadoop.hbase.master.snapshot.SnapshotManager;<a name="line.146"></a>
-<span class="sourceLineNo">147</span>import org.apache.hadoop.hbase.master.zksyncer.MasterAddressSyncer;<a name="line.147"></a>
-<span class="sourceLineNo">148</span>import org.apache.hadoop.hbase.master.zksyncer.MetaLocationSyncer;<a name="line.148"></a>
-<span class="sourceLineNo">149</span>import org.apache.hadoop.hbase.mob.MobFileCleanerChore;<a name="line.149"></a>
-<span class="sourceLineNo">150</span>import org.apache.hadoop.hbase.mob.MobFileCompactionChore;<a name="line.150"></a>
-<span class="sourceLineNo">151</span>import org.apache.hadoop.hbase.monitoring.MemoryBoundedLogMessageBuffer;<a name="line.151"></a>
-<span class="sourceLineNo">152</span>import org.apache.hadoop.hbase.monitoring.MonitoredTask;<a name="line.152"></a>
-<span class="sourceLineNo">153</span>import org.apache.hadoop.hbase.monitoring.TaskMonitor;<a name="line.153"></a>
-<span class="sourceLineNo">154</span>import org.apache.hadoop.hbase.procedure.MasterProcedureManagerHost;<a name="line.154"></a>
-<span class="sourceLineNo">155</span>import org.apache.hadoop.hbase.procedure.flush.MasterFlushTableProcedureManager;<a name="line.155"></a>
-<span class="sourceLineNo">156</span>import org.apache.hadoop.hbase.procedure2.LockedResource;<a name="line.156"></a>
-<span class="sourceLineNo">157</span>import org.apache.hadoop.hbase.procedure2.Procedure;<a name="line.157"></a>
-<span class="sourceLineNo">158</span>import org.apache.hadoop.hbase.procedure2.ProcedureEvent;<a name="line.158"></a>
-<span class="sourceLineNo">159</span>import org.apache.hadoop.hbase.procedure2.ProcedureExecutor;<a name="line.159"></a>
-<span class="sourceLineNo">160</span>import org.apache.hadoop.hbase.procedure2.RemoteProcedureDispatcher.RemoteProcedure;<a name="line.160"></a>
-<span class="sourceLineNo">161</span>import org.apache.hadoop.hbase.procedure2.RemoteProcedureException;<a name="line.161"></a>
-<span class="sourceLineNo">162</span>import org.apache.hadoop.hbase.procedure2.store.ProcedureStore;<a name="line.162"></a>
-<span class="sourceLineNo">163</span>import org.apache.hadoop.hbase.procedure2.store.ProcedureStore.ProcedureStoreListener;<a name="line.163"></a>
-<span class="sourceLineNo">164</span>import org.apache.hadoop.hbase.procedure2.store.region.RegionProcedureStore;<a name="line.164"></a>
-<span class="sourceLineNo">165</span>import org.apache.hadoop.hbase.quotas.MasterQuotaManager;<a name="line.165"></a>
-<span class="sourceLineNo">166</span>import org.apache.hadoop.hbase.quotas.MasterQuotasObserver;<a name="line.166"></a>
-<span class="sourceLineNo">167</span>import org.apache.hadoop.hbase.quotas.QuotaObserverChore;<a name="line.167"></a>
-<span class="sourceLineNo">168</span>import org.apache.hadoop.hbase.quotas.QuotaTableUtil;<a name="line.168"></a>
-<span class="sourceLineNo">169</span>import org.apache.hadoop.hbase.quotas.QuotaUtil;<a name="line.169"></a>
-<span class="sourceLineNo">170</span>import org.apache.hadoop.hbase.quotas.SnapshotQuotaObserverChore;<a name="line.170"></a>
-<span class="sourceLineNo">171</span>import org.apache.hadoop.hbase.quotas.SpaceQuotaSnapshot;<a name="line.171"></a>
-<span class="sourceLineNo">172</span>import org.apache.hadoop.hbase.quotas.SpaceQuotaSnapshot.SpaceQuotaStatus;<a name="line.172"></a>
-<span class="sourceLineNo">173</span>import org.apache.hadoop.hbase.quotas.SpaceQuotaSnapshotNotifier;<a name="line.173"></a>
-<span class="sourceLineNo">174</span>import org.apache.hadoop.hbase.quotas.SpaceQuotaSnapshotNotifierFactory;<a name="line.174"></a>
-<span class="sourceLineNo">175</span>import org.apache.hadoop.hbase.quotas.SpaceViolationPolicy;<a name="line.175"></a>
-<span class="sourceLineNo">176</span>import org.apache.hadoop.hbase.regionserver.HRegionServer;<a name="line.176"></a>
-<span class="sourceLineNo">177</span>import org.apache.hadoop.hbase.regionserver.RSRpcServices;<a name="line.177"></a>
-<span class="sourceLineNo">178</span>import org.apache.hadoop.hbase.replication.ReplicationException;<a name="line.178"></a>
-<span class="sourceLineNo">179</span>import org.apache.hadoop.hbase.replication.ReplicationLoadSource;<a name="line.179"></a>
-<span class="sourceLineNo">180</span>import org.apache.hadoop.hbase.replication.ReplicationPeerConfig;<a name="line.180"></a>
-<span class="sourceLineNo">181</span>import org.apache.hadoop.hbase.replication.ReplicationPeerDescription;<a name="line.181"></a>
-<span class="sourceLineNo">182</span>import org.apache.hadoop.hbase.replication.ReplicationUtils;<a name="line.182"></a>
-<span class="sourceLineNo">183</span>import org.apache.hadoop.hbase.replication.SyncReplicationState;<a name="line.183"></a>
-<span class="sourceLineNo">184</span>import org.apache.hadoop.hbase.replication.master.ReplicationHFileCleaner;<a name="line.184"></a>
-<span class="sourceLineNo">185</span>import org.apache.hadoop.hbase.replication.master.ReplicationLogCleaner;<a name="line.185"></a>
-<span class="sourceLineNo">186</span>import org.apache.hadoop.hbase.replication.regionserver.ReplicationStatus;<a name="line.186"></a>
-<span class="sourceLineNo">187</span>import org.apache.hadoop.hbase.rsgroup.RSGroupAdminEndpoint;<a name="line.187"></a>
-<span class="sourceLineNo">188</span>import org.apache.hadoop.hbase.rsgroup.RSGroupBasedLoadBalancer;<a name="line.188"></a>
-<span class="sourceLineNo">189</span>import org.apache.hadoop.hbase.rsgroup.RSGroupInfoManager;<a name="line.189"></a>
-<span class="sourceLineNo">190</span>import org.apache.hadoop.hbase.rsgroup.RSGroupUtil;<a name="line.190"></a>
-<span class="sourceLineNo">191</span>import org.apache.hadoop.hbase.security.AccessDeniedException;<a name="line.191"></a>
-<span class="sourceLineNo">192</span>import org.apache.hadoop.hbase.security.SecurityConstants;<a name="line.192"></a>
-<span class="sourceLineNo">193</span>import org.apache.hadoop.hbase.security.UserProvider;<a name="line.193"></a>
-<span class="sourceLineNo">194</span>import org.apache.hadoop.hbase.trace.TraceUtil;<a name="line.194"></a>
-<span class="sourceLineNo">195</span>import org.apache.hadoop.hbase.util.Addressing;<a name="line.195"></a>
-<span class="sourceLineNo">196</span>import org.apache.hadoop.hbase.util.Bytes;<a name="line.196"></a>
-<span class="sourceLineNo">197</span>import org.apache.hadoop.hbase.util.FutureUtils;<a name="line.197"></a>
-<span class="sourceLineNo">198</span>import org.apache.hadoop.hbase.util.HBaseFsck;<a name="line.198"></a>
-<span class="sourceLineNo">199</span>import org.apache.hadoop.hbase.util.HFileArchiveUtil;<a name="line.199"></a>
-<span class="sourceLineNo">200</span>import org.apache.hadoop.hbase.util.IdLock;<a name="line.200"></a>
-<span class="sourceLineNo">201</span>import org.apache.hadoop.hbase.util.ModifyRegionUtils;<a name="line.201"></a>
-<span class="sourceLineNo">202</span>import org.apache.hadoop.hbase.util.Pair;<a name="line.202"></a>
-<span class="sourceLineNo">203</span>import org.apache.hadoop.hbase.util.RetryCounter;<a name="line.203"></a>
-<span class="sourceLineNo">204</span>import org.apache.hadoop.hbase.util.RetryCounterFactory;<a name="line.204"></a>
-<span class="sourceLineNo">205</span>import org.apache.hadoop.hbase.util.TableDescriptorChecker;<a name="line.205"></a>
-<span class="sourceLineNo">206</span>import org.apache.hadoop.hbase.util.Threads;<a name="line.206"></a>
-<span class="sourceLineNo">207</span>import org.apache.hadoop.hbase.util.VersionInfo;<a name="line.207"></a>
-<span class="sourceLineNo">208</span>import org.apache.hadoop.hbase.zookeeper.LoadBalancerTracker;<a name="line.208"></a>
-<span class="sourceLineNo">209</span>import org.apache.hadoop.hbase.zookeeper.MasterAddressTracker;<a name="line.209"></a>
-<span class="sourceLineNo">210</span>import org.apache.hadoop.hbase.zookeeper.RegionNormalizerTracker;<a name="line.210"></a>
-<span class="sourceLineNo">211</span>import org.apache.hadoop.hbase.zookeeper.SnapshotCleanupTracker;<a name="line.211"></a>
-<span class="sourceLineNo">212</span>import org.apache.hadoop.hbase.zookeeper.ZKClusterId;<a name="line.212"></a>
-<span class="sourceLineNo">213</span>import org.apache.hadoop.hbase.zookeeper.ZKUtil;<a name="line.213"></a>
-<span class="sourceLineNo">214</span>import org.apache.hadoop.hbase.zookeeper.ZKWatcher;<a name="line.214"></a>
-<span class="sourceLineNo">215</span>import org.apache.hadoop.hbase.zookeeper.ZNodePaths;<a name="line.215"></a>
-<span class="sourceLineNo">216</span>import org.apache.yetus.audience.InterfaceAudience;<a name="line.216"></a>
-<span class="sourceLineNo">217</span>import org.apache.zookeeper.KeeperException;<a name="line.217"></a>
-<span class="sourceLineNo">218</span>import org.slf4j.Logger;<a name="line.218"></a>
-<span class="sourceLineNo">219</span>import org.slf4j.LoggerFactory;<a name="line.219"></a>
-<span class="sourceLineNo">220</span><a name="line.220"></a>
-<span class="sourceLineNo">221</span>import org.apache.hbase.thirdparty.com.google.common.collect.Lists;<a name="line.221"></a>
-<span class="sourceLineNo">222</span>import org.apache.hbase.thirdparty.com.google.common.collect.Maps;<a name="line.222"></a>
-<span class="sourceLineNo">223</span>import org.apache.hbase.thirdparty.com.google.common.collect.Sets;<a name="line.223"></a>
+<span class="sourceLineNo">054</span>import org.apache.commons.lang3.StringUtils;<a name="line.54"></a>
+<span class="sourceLineNo">055</span>import org.apache.hadoop.conf.Configuration;<a name="line.55"></a>
+<span class="sourceLineNo">056</span>import org.apache.hadoop.fs.FSDataOutputStream;<a name="line.56"></a>
+<span class="sourceLineNo">057</span>import org.apache.hadoop.fs.Path;<a name="line.57"></a>
+<span class="sourceLineNo">058</span>import org.apache.hadoop.hbase.ChoreService;<a name="line.58"></a>
+<span class="sourceLineNo">059</span>import org.apache.hadoop.hbase.ClusterId;<a name="line.59"></a>
+<span class="sourceLineNo">060</span>import org.apache.hadoop.hbase.ClusterMetrics;<a name="line.60"></a>
+<span class="sourceLineNo">061</span>import org.apache.hadoop.hbase.ClusterMetrics.Option;<a name="line.61"></a>
+<span class="sourceLineNo">062</span>import org.apache.hadoop.hbase.ClusterMetricsBuilder;<a name="line.62"></a>
+<span class="sourceLineNo">063</span>import org.apache.hadoop.hbase.DoNotRetryIOException;<a name="line.63"></a>
+<span class="sourceLineNo">064</span>import org.apache.hadoop.hbase.HBaseIOException;<a name="line.64"></a>
+<span class="sourceLineNo">065</span>import org.apache.hadoop.hbase.HBaseInterfaceAudience;<a name="line.65"></a>
+<span class="sourceLineNo">066</span>import org.apache.hadoop.hbase.HConstants;<a name="line.66"></a>
+<span class="sourceLineNo">067</span>import org.apache.hadoop.hbase.InvalidFamilyOperationException;<a name="line.67"></a>
+<span class="sourceLineNo">068</span>import org.apache.hadoop.hbase.MasterNotRunningException;<a name="line.68"></a>
+<span class="sourceLineNo">069</span>import org.apache.hadoop.hbase.MetaTableAccessor;<a name="line.69"></a>
+<span class="sourceLineNo">070</span>import org.apache.hadoop.hbase.NamespaceDescriptor;<a name="line.70"></a>
+<span class="sourceLineNo">071</span>import org.apache.hadoop.hbase.PleaseHoldException;<a name="line.71"></a>
+<span class="sourceLineNo">072</span>import org.apache.hadoop.hbase.RegionMetrics;<a name="line.72"></a>
+<span class="sourceLineNo">073</span>import org.apache.hadoop.hbase.ReplicationPeerNotFoundException;<a name="line.73"></a>
+<span class="sourceLineNo">074</span>import org.apache.hadoop.hbase.ServerMetrics;<a name="line.74"></a>
+<span class="sourceLineNo">075</span>import org.apache.hadoop.hbase.ServerName;<a name="line.75"></a>
+<span class="sourceLineNo">076</span>import org.apache.hadoop.hbase.TableName;<a name="line.76"></a>
+<span class="sourceLineNo">077</span>import org.apache.hadoop.hbase.TableNotDisabledException;<a name="line.77"></a>
+<span class="sourceLineNo">078</span>import org.apache.hadoop.hbase.TableNotFoundException;<a name="line.78"></a>
+<span class="sourceLineNo">079</span>import org.apache.hadoop.hbase.UnknownRegionException;<a name="line.79"></a>
+<span class="sourceLineNo">080</span>import org.apache.hadoop.hbase.client.ColumnFamilyDescriptor;<a name="line.80"></a>
+<span class="sourceLineNo">081</span>import org.apache.hadoop.hbase.client.CompactionState;<a name="line.81"></a>
+<span class="sourceLineNo">082</span>import org.apache.hadoop.hbase.client.MasterSwitchType;<a name="line.82"></a>
+<span class="sourceLineNo">083</span>import org.apache.hadoop.hbase.client.NormalizeTableFilterParams;<a name="line.83"></a>
+<span class="sourceLineNo">084</span>import org.apache.hadoop.hbase.client.RegionInfo;<a name="line.84"></a>
+<span class="sourceLineNo">085</span>import org.apache.hadoop.hbase.client.RegionInfoBuilder;<a name="line.85"></a>
+<span class="sourceLineNo">086</span>import org.apache.hadoop.hbase.client.RegionStatesCount;<a name="line.86"></a>
+<span class="sourceLineNo">087</span>import org.apache.hadoop.hbase.client.TableDescriptor;<a name="line.87"></a>
+<span class="sourceLineNo">088</span>import org.apache.hadoop.hbase.client.TableDescriptorBuilder;<a name="line.88"></a>
+<span class="sourceLineNo">089</span>import org.apache.hadoop.hbase.client.TableState;<a name="line.89"></a>
+<span class="sourceLineNo">090</span>import org.apache.hadoop.hbase.coprocessor.CoprocessorHost;<a name="line.90"></a>
+<span class="sourceLineNo">091</span>import org.apache.hadoop.hbase.exceptions.MasterStoppedException;<a name="line.91"></a>
+<span class="sourceLineNo">092</span>import org.apache.hadoop.hbase.executor.ExecutorType;<a name="line.92"></a>
+<span class="sourceLineNo">093</span>import org.apache.hadoop.hbase.favored.FavoredNodesManager;<a name="line.93"></a>
+<span class="sourceLineNo">094</span>import org.apache.hadoop.hbase.ipc.CoprocessorRpcUtils;<a name="line.94"></a>
+<span class="sourceLineNo">095</span>import org.apache.hadoop.hbase.ipc.RpcServer;<a name="line.95"></a>
+<span class="sourceLineNo">096</span>import org.apache.hadoop.hbase.ipc.ServerNotRunningYetException;<a name="line.96"></a>
+<span class="sourceLineNo">097</span>import org.apache.hadoop.hbase.log.HBaseMarkers;<a name="line.97"></a>
+<span class="sourceLineNo">098</span>import org.apache.hadoop.hbase.master.MasterRpcServices.BalanceSwitchMode;<a name="line.98"></a>
+<span class="sourceLineNo">099</span>import org.apache.hadoop.hbase.master.assignment.AssignmentManager;<a name="line.99"></a>
+<span class="sourceLineNo">100</span>import org.apache.hadoop.hbase.master.assignment.MergeTableRegionsProcedure;<a name="line.100"></a>
+<span class="sourceLineNo">101</span>import org.apache.hadoop.hbase.master.assignment.RegionStateNode;<a name="line.101"></a>
+<span class="sourceLineNo">102</span>import org.apache.hadoop.hbase.master.assignment.RegionStates;<a name="line.102"></a>
+<span class="sourceLineNo">103</span>import org.apache.hadoop.hbase.master.assignment.TransitRegionStateProcedure;<a name="line.103"></a>
+<span class="sourceLineNo">104</span>import org.apache.hadoop.hbase.master.balancer.BalancerChore;<a name="line.104"></a>
+<span class="sourceLineNo">105</span>import org.apache.hadoop.hbase.master.balancer.ClusterStatusChore;<a name="line.105"></a>
+<span class="sourceLineNo">106</span>import org.apache.hadoop.hbase.master.balancer.LoadBalancerFactory;<a name="line.106"></a>
+<span class="sourceLineNo">107</span>import org.apache.hadoop.hbase.master.cleaner.DirScanPool;<a name="line.107"></a>
+<span class="sourceLineNo">108</span>import org.apache.hadoop.hbase.master.cleaner.HFileCleaner;<a name="line.108"></a>
+<span class="sourceLineNo">109</span>import org.apache.hadoop.hbase.master.cleaner.LogCleaner;<a name="line.109"></a>
+<span class="sourceLineNo">110</span>import org.apache.hadoop.hbase.master.cleaner.ReplicationBarrierCleaner;<a name="line.110"></a>
+<span class="sourceLineNo">111</span>import org.apache.hadoop.hbase.master.cleaner.SnapshotCleanerChore;<a name="line.111"></a>
+<span class="sourceLineNo">112</span>import org.apache.hadoop.hbase.master.janitor.CatalogJanitor;<a name="line.112"></a>
+<span class="sourceLineNo">113</span>import org.apache.hadoop.hbase.master.locking.LockManager;<a name="line.113"></a>
+<span class="sourceLineNo">114</span>import org.apache.hadoop.hbase.master.normalizer.RegionNormalizerFactory;<a name="line.114"></a>
+<span class="sourceLineNo">115</span>import org.apache.hadoop.hbase.master.normalizer.RegionNormalizerManager;<a name="line.115"></a>
+<span class="sourceLineNo">116</span>import org.apache.hadoop.hbase.master.procedure.CreateTableProcedure;<a name="line.116"></a>
+<span class="sourceLineNo">117</span>import org.apache.hadoop.hbase.master.procedure.DeleteNamespaceProcedure;<a name="line.117"></a>
+<span class="sourceLineNo">118</span>import org.apache.hadoop.hbase.master.procedure.DeleteTableProcedure;<a name="line.118"></a>
+<span class="sourceLineNo">119</span>import org.apache.hadoop.hbase.master.procedure.DisableTableProcedure;<a name="line.119"></a>
+<span class="sourceLineNo">120</span>import org.apache.hadoop.hbase.master.procedure.EnableTableProcedure;<a name="line.120"></a>
+<span class="sourceLineNo">121</span>import org.apache.hadoop.hbase.master.procedure.InitMetaProcedure;<a name="line.121"></a>
+<span class="sourceLineNo">122</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureConstants;<a name="line.122"></a>
+<span class="sourceLineNo">123</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureEnv;<a name="line.123"></a>
+<span class="sourceLineNo">124</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureScheduler;<a name="line.124"></a>
+<span class="sourceLineNo">125</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureUtil;<a name="line.125"></a>
+<span class="sourceLineNo">126</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureUtil.NonceProcedureRunnable;<a name="line.126"></a>
+<span class="sourceLineNo">127</span>import org.apache.hadoop.hbase.master.procedure.ModifyTableProcedure;<a name="line.127"></a>
+<span class="sourceLineNo">128</span>import org.apache.hadoop.hbase.master.procedure.ProcedurePrepareLatch;<a name="line.128"></a>
+<span class="sourceLineNo">129</span>import org.apache.hadoop.hbase.master.procedure.ProcedureSyncWait;<a name="line.129"></a>
+<span class="sourceLineNo">130</span>import org.apache.hadoop.hbase.master.procedure.ReopenTableRegionsProcedure;<a name="line.130"></a>
+<span class="sourceLineNo">131</span>import org.apache.hadoop.hbase.master.procedure.ServerCrashProcedure;<a name="line.131"></a>
+<span class="sourceLineNo">132</span>import org.apache.hadoop.hbase.master.procedure.TruncateTableProcedure;<a name="line.132"></a>
+<span class="sourceLineNo">133</span>import org.apache.hadoop.hbase.master.region.MasterRegion;<a name="line.133"></a>
+<span class="sourceLineNo">134</span>import org.apache.hadoop.hbase.master.region.MasterRegionFactory;<a name="line.134"></a>
+<span class="sourceLineNo">135</span>import org.apache.hadoop.hbase.master.replication.AbstractPeerProcedure;<a name="line.135"></a>
+<span class="sourceLineNo">136</span>import org.apache.hadoop.hbase.master.replication.AddPeerProcedure;<a name="line.136"></a>
+<span class="sourceLineNo">137</span>import org.apache.hadoop.hbase.master.replication.DisablePeerProcedure;<a name="line.137"></a>
+<span class="sourceLineNo">138</span>import org.apache.hadoop.hbase.master.replication.EnablePeerProcedure;<a name="line.138"></a>
+<span class="sourceLineNo">139</span>import org.apache.hadoop.hbase.master.replication.RemovePeerProcedure;<a name="line.139"></a>
+<span class="sourceLineNo">140</span>import org.apache.hadoop.hbase.master.replication.ReplicationPeerManager;<a name="line.140"></a>
+<span class="sourceLineNo">141</span>import org.apache.hadoop.hbase.master.replication.SyncReplicationReplayWALManager;<a name="line.141"></a>
+<span class="sourceLineNo">142</span>import org.apache.hadoop.hbase.master.replication.TransitPeerSyncReplicationStateProcedure;<a name="line.142"></a>
+<span class="sourceLineNo">143</span>import org.apache.hadoop.hbase.master.replication.UpdatePeerConfigProcedure;<a name="line.143"></a>
+<span class="sourceLineNo">144</span>import org.apache.hadoop.hbase.master.slowlog.SlowLogMasterService;<a name="line.144"></a>
+<span class="sourceLineNo">145</span>import org.apache.hadoop.hbase.master.snapshot.SnapshotManager;<a name="line.145"></a>
+<span class="sourceLineNo">146</span>import org.apache.hadoop.hbase.master.zksyncer.MasterAddressSyncer;<a name="line.146"></a>
+<span class="sourceLineNo">147</span>import org.apache.hadoop.hbase.master.zksyncer.MetaLocationSyncer;<a name="line.147"></a>
+<span class="sourceLineNo">148</span>import org.apache.hadoop.hbase.mob.MobFileCleanerChore;<a name="line.148"></a>
+<span class="sourceLineNo">149</span>import org.apache.hadoop.hbase.mob.MobFileCompactionChore;<a name="line.149"></a>
+<span class="sourceLineNo">150</span>import org.apache.hadoop.hbase.monitoring.MemoryBoundedLogMessageBuffer;<a name="line.150"></a>
+<span class="sourceLineNo">151</span>import org.apache.hadoop.hbase.monitoring.MonitoredTask;<a name="line.151"></a>
+<span class="sourceLineNo">152</span>import org.apache.hadoop.hbase.monitoring.TaskMonitor;<a name="line.152"></a>
+<span class="sourceLineNo">153</span>import org.apache.hadoop.hbase.procedure.MasterProcedureManagerHost;<a name="line.153"></a>
+<span class="sourceLineNo">154</span>import org.apache.hadoop.hbase.procedure.flush.MasterFlushTableProcedureManager;<a name="line.154"></a>
+<span class="sourceLineNo">155</span>import org.apache.hadoop.hbase.procedure2.LockedResource;<a name="line.155"></a>
+<span class="sourceLineNo">156</span>import org.apache.hadoop.hbase.procedure2.Procedure;<a name="line.156"></a>
+<span class="sourceLineNo">157</span>import org.apache.hadoop.hbase.procedure2.ProcedureEvent;<a name="line.157"></a>
+<span class="sourceLineNo">158</span>import org.apache.hadoop.hbase.procedure2.ProcedureExecutor;<a name="line.158"></a>
+<span class="sourceLineNo">159</span>import org.apache.hadoop.hbase.procedure2.RemoteProcedureDispatcher.RemoteProcedure;<a name="line.159"></a>
+<span class="sourceLineNo">160</span>import org.apache.hadoop.hbase.procedure2.RemoteProcedureException;<a name="line.160"></a>
+<span class="sourceLineNo">161</span>import org.apache.hadoop.hbase.procedure2.store.ProcedureStore;<a name="line.161"></a>
+<span class="sourceLineNo">162</span>import org.apache.hadoop.hbase.procedure2.store.ProcedureStore.ProcedureStoreListener;<a name="line.162"></a>
+<span class="sourceLineNo">163</span>import org.apache.hadoop.hbase.procedure2.store.region.RegionProcedureStore;<a name="line.163"></a>
+<span class="sourceLineNo">164</span>import org.apache.hadoop.hbase.quotas.MasterQuotaManager;<a name="line.164"></a>
+<span class="sourceLineNo">165</span>import org.apache.hadoop.hbase.quotas.MasterQuotasObserver;<a name="line.165"></a>
+<span class="sourceLineNo">166</span>import org.apache.hadoop.hbase.quotas.QuotaObserverChore;<a name="line.166"></a>
+<span class="sourceLineNo">167</span>import org.apache.hadoop.hbase.quotas.QuotaTableUtil;<a name="line.167"></a>
+<span class="sourceLineNo">168</span>import org.apache.hadoop.hbase.quotas.QuotaUtil;<a name="line.168"></a>
+<span class="sourceLineNo">169</span>import org.apache.hadoop.hbase.quotas.SnapshotQuotaObserverChore;<a name="line.169"></a>
+<span class="sourceLineNo">170</span>import org.apache.hadoop.hbase.quotas.SpaceQuotaSnapshot;<a name="line.170"></a>
+<span class="sourceLineNo">171</span>import org.apache.hadoop.hbase.quotas.SpaceQuotaSnapshot.SpaceQuotaStatus;<a name="line.171"></a>
+<span class="sourceLineNo">172</span>import org.apache.hadoop.hbase.quotas.SpaceQuotaSnapshotNotifier;<a name="line.172"></a>
+<span class="sourceLineNo">173</span>import org.apache.hadoop.hbase.quotas.SpaceQuotaSnapshotNotifierFactory;<a name="line.173"></a>
+<span class="sourceLineNo">174</span>import org.apache.hadoop.hbase.quotas.SpaceViolationPolicy;<a name="line.174"></a>
+<span class="sourceLineNo">175</span>import org.apache.hadoop.hbase.regionserver.HRegionServer;<a name="line.175"></a>
+<span class="sourceLineNo">176</span>import org.apache.hadoop.hbase.regionserver.RSRpcServices;<a name="line.176"></a>
+<span class="sourceLineNo">177</span>import org.apache.hadoop.hbase.replication.ReplicationException;<a name="line.177"></a>
+<span class="sourceLineNo">178</span>import org.apache.hadoop.hbase.replication.ReplicationLoadSource;<a name="line.178"></a>
+<span class="sourceLineNo">179</span>import org.apache.hadoop.hbase.replication.ReplicationPeerConfig;<a name="line.179"></a>
+<span class="sourceLineNo">180</span>import org.apache.hadoop.hbase.replication.ReplicationPeerDescription;<a name="line.180"></a>
+<span class="sourceLineNo">181</span>import org.apache.hadoop.hbase.replication.ReplicationUtils;<a name="line.181"></a>
+<span class="sourceLineNo">182</span>import org.apache.hadoop.hbase.replication.SyncReplicationState;<a name="line.182"></a>
+<span class="sourceLineNo">183</span>import org.apache.hadoop.hbase.replication.master.ReplicationHFileCleaner;<a name="line.183"></a>
+<span class="sourceLineNo">184</span>import org.apache.hadoop.hbase.replication.master.ReplicationLogCleaner;<a name="line.184"></a>
+<span class="sourceLineNo">185</span>import org.apache.hadoop.hbase.replication.regionserver.ReplicationStatus;<a name="line.185"></a>
+<span class="sourceLineNo">186</span>import org.apache.hadoop.hbase.rsgroup.RSGroupAdminEndpoint;<a name="line.186"></a>
+<span class="sourceLineNo">187</span>import org.apache.hadoop.hbase.rsgroup.RSGroupBasedLoadBalancer;<a name="line.187"></a>
+<span class="sourceLineNo">188</span>import org.apache.hadoop.hbase.rsgroup.RSGroupInfoManager;<a name="line.188"></a>
+<span class="sourceLineNo">189</span>import org.apache.hadoop.hbase.rsgroup.RSGroupUtil;<a name="line.189"></a>
+<span class="sourceLineNo">190</span>import org.apache.hadoop.hbase.security.AccessDeniedException;<a name="line.190"></a>
+<span class="sourceLineNo">191</span>import org.apache.hadoop.hbase.security.SecurityConstants;<a name="line.191"></a>
+<span class="sourceLineNo">192</span>import org.apache.hadoop.hbase.security.UserProvider;<a name="line.192"></a>
+<span class="sourceLineNo">193</span>import org.apache.hadoop.hbase.trace.TraceUtil;<a name="line.193"></a>
+<span class="sourceLineNo">194</span>import org.apache.hadoop.hbase.util.Addressing;<a name="line.194"></a>
+<span class="sourceLineNo">195</span>import org.apache.hadoop.hbase.util.Bytes;<a name="line.195"></a>
+<span class="sourceLineNo">196</span>import org.apache.hadoop.hbase.util.FutureUtils;<a name="line.196"></a>
+<span class="sourceLineNo">197</span>import org.apache.hadoop.hbase.util.HBaseFsck;<a name="line.197"></a>
+<span class="sourceLineNo">198</span>import org.apache.hadoop.hbase.util.HFileArchiveUtil;<a name="line.198"></a>
+<span class="sourceLineNo">199</span>import org.apache.hadoop.hbase.util.IdLock;<a name="line.199"></a>
+<span class="sourceLineNo">200</span>import org.apache.hadoop.hbase.util.ModifyRegionUtils;<a name="line.200"></a>
+<span class="sourceLineNo">201</span>import org.apache.hadoop.hbase.util.Pair;<a name="line.201"></a>
+<span class="sourceLineNo">202</span>import org.apache.hadoop.hbase.util.RetryCounter;<a name="line.202"></a>
+<span class="sourceLineNo">203</span>import org.apache.hadoop.hbase.util.RetryCounterFactory;<a name="line.203"></a>
+<span class="sourceLineNo">204</span>import org.apache.hadoop.hbase.util.TableDescriptorChecker;<a name="line.204"></a>
+<span class="sourceLineNo">205</span>import org.apache.hadoop.hbase.util.Threads;<a name="line.205"></a>
+<span class="sourceLineNo">206</span>import org.apache.hadoop.hbase.util.VersionInfo;<a name="line.206"></a>
+<span class="sourceLineNo">207</span>import org.apache.hadoop.hbase.zookeeper.LoadBalancerTracker;<a name="line.207"></a>
+<span class="sourceLineNo">208</span>import org.apache.hadoop.hbase.zookeeper.MasterAddressTracker;<a name="line.208"></a>
+<span class="sourceLineNo">209</span>import org.apache.hadoop.hbase.zookeeper.RegionNormalizerTracker;<a name="line.209"></a>
+<span class="sourceLineNo">210</span>import org.apache.hadoop.hbase.zookeeper.SnapshotCleanupTracker;<a name="line.210"></a>
+<span class="sourceLineNo">211</span>import org.apache.hadoop.hbase.zookeeper.ZKClusterId;<a name="line.211"></a>
+<span class="sourceLineNo">212</span>import org.apache.hadoop.hbase.zookeeper.ZKUtil;<a name="line.212"></a>
+<span class="sourceLineNo">213</span>import org.apache.hadoop.hbase.zookeeper.ZKWatcher;<a name="line.213"></a>
+<span class="sourceLineNo">214</span>import org.apache.hadoop.hbase.zookeeper.ZNodePaths;<a name="line.214"></a>
+<span class="sourceLineNo">215</span>import org.apache.yetus.audience.InterfaceAudience;<a name="line.215"></a>
+<span class="sourceLineNo">216</span>import org.apache.zookeeper.KeeperException;<a name="line.216"></a>
+<span class="sourceLineNo">217</span>import org.slf4j.Logger;<a name="line.217"></a>
+<span class="sourceLineNo">218</span>import org.slf4j.LoggerFactory;<a name="line.218"></a>
+<span class="sourceLineNo">219</span><a name="line.219"></a>
+<span class="sourceLineNo">220</span>import org.apache.hbase.thirdparty.com.google.common.collect.Lists;<a name="line.220"></a>
+<span class="sourceLineNo">221</span>import org.apache.hbase.thirdparty.com.google.common.collect.Maps;<a name="line.221"></a>
+<span class="sourceLineNo">222</span>import org.apache.hbase.thirdparty.com.google.common.collect.Sets;<a name="line.222"></a>
+<span class="sourceLineNo">223</span>import org.apache.hbase.thirdparty.com.google.common.io.Closeables;<a name="line.223"></a>
 <span class="sourceLineNo">224</span>import org.apache.hbase.thirdparty.com.google.protobuf.Descriptors;<a name="line.224"></a>
 <span class="sourceLineNo">225</span>import org.apache.hbase.thirdparty.com.google.protobuf.Service;<a name="line.225"></a>
 <span class="sourceLineNo">226</span>import org.apache.hbase.thirdparty.org.eclipse.jetty.server.Server;<a name="line.226"></a>
@@ -840,7 +840,7 @@
 <span class="sourceLineNo">832</span>            HBaseFsck.createLockRetryCounterFactory(this.conf).create());<a name="line.832"></a>
 <span class="sourceLineNo">833</span>      } finally {<a name="line.833"></a>
 <span class="sourceLineNo">834</span>        if (result != null) {<a name="line.834"></a>
-<span class="sourceLineNo">835</span>          IOUtils.closeQuietly(result.getSecond());<a name="line.835"></a>
+<span class="sourceLineNo">835</span>          Closeables.close(result.getSecond(), true);<a name="line.835"></a>
 <span class="sourceLineNo">836</span>        }<a name="line.836"></a>
 <span class="sourceLineNo">837</span>      }<a name="line.837"></a>
 <span class="sourceLineNo">838</span>    }<a name="line.838"></a>
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html b/devapidocs/src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html
index b056718..d880d89 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html
@@ -50,267 +50,271 @@
 <span class="sourceLineNo">042</span>      "hbase.regionserver.enable.table.latencies";<a name="line.42"></a>
 <span class="sourceLineNo">043</span>  public static final boolean RS_ENABLE_TABLE_METRICS_DEFAULT = true;<a name="line.43"></a>
 <span class="sourceLineNo">044</span><a name="line.44"></a>
-<span class="sourceLineNo">045</span>  private final MetricsRegionServerSource serverSource;<a name="line.45"></a>
-<span class="sourceLineNo">046</span>  private final MetricsRegionServerWrapper regionServerWrapper;<a name="line.46"></a>
-<span class="sourceLineNo">047</span>  private RegionServerTableMetrics tableMetrics;<a name="line.47"></a>
-<span class="sourceLineNo">048</span>  private final MetricsTable metricsTable;<a name="line.48"></a>
-<span class="sourceLineNo">049</span>  private MetricsRegionServerQuotaSource quotaSource;<a name="line.49"></a>
-<span class="sourceLineNo">050</span>  private final MetricsUserAggregate userAggregate;<a name="line.50"></a>
-<span class="sourceLineNo">051</span><a name="line.51"></a>
-<span class="sourceLineNo">052</span>  private MetricRegistry metricRegistry;<a name="line.52"></a>
-<span class="sourceLineNo">053</span>  private Timer bulkLoadTimer;<a name="line.53"></a>
-<span class="sourceLineNo">054</span>  private Meter serverReadQueryMeter;<a name="line.54"></a>
-<span class="sourceLineNo">055</span>  private Meter serverWriteQueryMeter;<a name="line.55"></a>
-<span class="sourceLineNo">056</span><a name="line.56"></a>
-<span class="sourceLineNo">057</span>  public MetricsRegionServer(MetricsRegionServerWrapper regionServerWrapper, Configuration conf,<a name="line.57"></a>
-<span class="sourceLineNo">058</span>      MetricsTable metricsTable) {<a name="line.58"></a>
-<span class="sourceLineNo">059</span>    this(regionServerWrapper,<a name="line.59"></a>
-<span class="sourceLineNo">060</span>        CompatibilitySingletonFactory.getInstance(MetricsRegionServerSourceFactory.class)<a name="line.60"></a>
-<span class="sourceLineNo">061</span>            .createServer(regionServerWrapper), createTableMetrics(conf), metricsTable,<a name="line.61"></a>
-<span class="sourceLineNo">062</span>        MetricsUserAggregateFactory.getMetricsUserAggregate(conf));<a name="line.62"></a>
-<span class="sourceLineNo">063</span><a name="line.63"></a>
-<span class="sourceLineNo">064</span>    // Create hbase-metrics module based metrics. The registry should already be registered by the<a name="line.64"></a>
-<span class="sourceLineNo">065</span>    // MetricsRegionServerSource<a name="line.65"></a>
-<span class="sourceLineNo">066</span>    metricRegistry = MetricRegistries.global().get(serverSource.getMetricRegistryInfo()).get();<a name="line.66"></a>
-<span class="sourceLineNo">067</span><a name="line.67"></a>
-<span class="sourceLineNo">068</span>    // create and use metrics from the new hbase-metrics based registry.<a name="line.68"></a>
-<span class="sourceLineNo">069</span>    bulkLoadTimer = metricRegistry.timer("Bulkload");<a name="line.69"></a>
+<span class="sourceLineNo">045</span>  public static final String SLOW_METRIC_TIME = "hbase.ipc.slow.metric.time";<a name="line.45"></a>
+<span class="sourceLineNo">046</span>  private final MetricsRegionServerSource serverSource;<a name="line.46"></a>
+<span class="sourceLineNo">047</span>  private final MetricsRegionServerWrapper regionServerWrapper;<a name="line.47"></a>
+<span class="sourceLineNo">048</span>  private RegionServerTableMetrics tableMetrics;<a name="line.48"></a>
+<span class="sourceLineNo">049</span>  private final MetricsTable metricsTable;<a name="line.49"></a>
+<span class="sourceLineNo">050</span>  private MetricsRegionServerQuotaSource quotaSource;<a name="line.50"></a>
+<span class="sourceLineNo">051</span>  private final MetricsUserAggregate userAggregate;<a name="line.51"></a>
+<span class="sourceLineNo">052</span><a name="line.52"></a>
+<span class="sourceLineNo">053</span>  private MetricRegistry metricRegistry;<a name="line.53"></a>
+<span class="sourceLineNo">054</span>  private Timer bulkLoadTimer;<a name="line.54"></a>
+<span class="sourceLineNo">055</span>  private Meter serverReadQueryMeter;<a name="line.55"></a>
+<span class="sourceLineNo">056</span>  private Meter serverWriteQueryMeter;<a name="line.56"></a>
+<span class="sourceLineNo">057</span>  protected long slowMetricTime;<a name="line.57"></a>
+<span class="sourceLineNo">058</span>  protected static final int DEFAULT_SLOW_METRIC_TIME = 1000; // milliseconds<a name="line.58"></a>
+<span class="sourceLineNo">059</span><a name="line.59"></a>
+<span class="sourceLineNo">060</span>  public MetricsRegionServer(MetricsRegionServerWrapper regionServerWrapper, Configuration conf,<a name="line.60"></a>
+<span class="sourceLineNo">061</span>      MetricsTable metricsTable) {<a name="line.61"></a>
+<span class="sourceLineNo">062</span>    this(regionServerWrapper,<a name="line.62"></a>
+<span class="sourceLineNo">063</span>        CompatibilitySingletonFactory.getInstance(MetricsRegionServerSourceFactory.class)<a name="line.63"></a>
+<span class="sourceLineNo">064</span>            .createServer(regionServerWrapper), createTableMetrics(conf), metricsTable,<a name="line.64"></a>
+<span class="sourceLineNo">065</span>        MetricsUserAggregateFactory.getMetricsUserAggregate(conf));<a name="line.65"></a>
+<span class="sourceLineNo">066</span><a name="line.66"></a>
+<span class="sourceLineNo">067</span>    // Create hbase-metrics module based metrics. The registry should already be registered by the<a name="line.67"></a>
+<span class="sourceLineNo">068</span>    // MetricsRegionServerSource<a name="line.68"></a>
+<span class="sourceLineNo">069</span>    metricRegistry = MetricRegistries.global().get(serverSource.getMetricRegistryInfo()).get();<a name="line.69"></a>
 <span class="sourceLineNo">070</span><a name="line.70"></a>
-<span class="sourceLineNo">071</span>    quotaSource = CompatibilitySingletonFactory.getInstance(MetricsRegionServerQuotaSource.class);<a name="line.71"></a>
-<span class="sourceLineNo">072</span>    serverReadQueryMeter = metricRegistry.meter("ServerReadQueryPerSecond");<a name="line.72"></a>
-<span class="sourceLineNo">073</span>    serverWriteQueryMeter = metricRegistry.meter("ServerWriteQueryPerSecond");<a name="line.73"></a>
-<span class="sourceLineNo">074</span>  }<a name="line.74"></a>
-<span class="sourceLineNo">075</span><a name="line.75"></a>
-<span class="sourceLineNo">076</span>  MetricsRegionServer(MetricsRegionServerWrapper regionServerWrapper,<a name="line.76"></a>
-<span class="sourceLineNo">077</span>      MetricsRegionServerSource serverSource, RegionServerTableMetrics tableMetrics,<a name="line.77"></a>
-<span class="sourceLineNo">078</span>      MetricsTable metricsTable, MetricsUserAggregate userAggregate) {<a name="line.78"></a>
-<span class="sourceLineNo">079</span>    this.regionServerWrapper = regionServerWrapper;<a name="line.79"></a>
-<span class="sourceLineNo">080</span>    this.serverSource = serverSource;<a name="line.80"></a>
-<span class="sourceLineNo">081</span>    this.tableMetrics = tableMetrics;<a name="line.81"></a>
-<span class="sourceLineNo">082</span>    this.metricsTable = metricsTable;<a name="line.82"></a>
-<span class="sourceLineNo">083</span>    this.userAggregate = userAggregate;<a name="line.83"></a>
-<span class="sourceLineNo">084</span>  }<a name="line.84"></a>
-<span class="sourceLineNo">085</span><a name="line.85"></a>
-<span class="sourceLineNo">086</span>  /**<a name="line.86"></a>
-<span class="sourceLineNo">087</span>   * Creates an instance of {@link RegionServerTableMetrics} only if the feature is enabled.<a name="line.87"></a>
-<span class="sourceLineNo">088</span>   */<a name="line.88"></a>
-<span class="sourceLineNo">089</span>  static RegionServerTableMetrics createTableMetrics(Configuration conf) {<a name="line.89"></a>
-<span class="sourceLineNo">090</span>    if (conf.getBoolean(RS_ENABLE_TABLE_METRICS_KEY, RS_ENABLE_TABLE_METRICS_DEFAULT)) {<a name="line.90"></a>
-<span class="sourceLineNo">091</span>      return new RegionServerTableMetrics();<a name="line.91"></a>
-<span class="sourceLineNo">092</span>    }<a name="line.92"></a>
-<span class="sourceLineNo">093</span>    return null;<a name="line.93"></a>
-<span class="sourceLineNo">094</span>  }<a name="line.94"></a>
-<span class="sourceLineNo">095</span><a name="line.95"></a>
-<span class="sourceLineNo">096</span>  public MetricsRegionServerSource getMetricsSource() {<a name="line.96"></a>
-<span class="sourceLineNo">097</span>    return serverSource;<a name="line.97"></a>
+<span class="sourceLineNo">071</span>    // create and use metrics from the new hbase-metrics based registry.<a name="line.71"></a>
+<span class="sourceLineNo">072</span>    bulkLoadTimer = metricRegistry.timer("Bulkload");<a name="line.72"></a>
+<span class="sourceLineNo">073</span><a name="line.73"></a>
+<span class="sourceLineNo">074</span>    slowMetricTime = conf.getLong(SLOW_METRIC_TIME, DEFAULT_SLOW_METRIC_TIME);<a name="line.74"></a>
+<span class="sourceLineNo">075</span>    quotaSource = CompatibilitySingletonFactory.getInstance(MetricsRegionServerQuotaSource.class);<a name="line.75"></a>
+<span class="sourceLineNo">076</span>    serverReadQueryMeter = metricRegistry.meter("ServerReadQueryPerSecond");<a name="line.76"></a>
+<span class="sourceLineNo">077</span>    serverWriteQueryMeter = metricRegistry.meter("ServerWriteQueryPerSecond");<a name="line.77"></a>
+<span class="sourceLineNo">078</span>  }<a name="line.78"></a>
+<span class="sourceLineNo">079</span><a name="line.79"></a>
+<span class="sourceLineNo">080</span>  MetricsRegionServer(MetricsRegionServerWrapper regionServerWrapper,<a name="line.80"></a>
+<span class="sourceLineNo">081</span>      MetricsRegionServerSource serverSource, RegionServerTableMetrics tableMetrics,<a name="line.81"></a>
+<span class="sourceLineNo">082</span>      MetricsTable metricsTable, MetricsUserAggregate userAggregate) {<a name="line.82"></a>
+<span class="sourceLineNo">083</span>    this.regionServerWrapper = regionServerWrapper;<a name="line.83"></a>
+<span class="sourceLineNo">084</span>    this.serverSource = serverSource;<a name="line.84"></a>
+<span class="sourceLineNo">085</span>    this.tableMetrics = tableMetrics;<a name="line.85"></a>
+<span class="sourceLineNo">086</span>    this.metricsTable = metricsTable;<a name="line.86"></a>
+<span class="sourceLineNo">087</span>    this.userAggregate = userAggregate;<a name="line.87"></a>
+<span class="sourceLineNo">088</span>  }<a name="line.88"></a>
+<span class="sourceLineNo">089</span><a name="line.89"></a>
+<span class="sourceLineNo">090</span>  /**<a name="line.90"></a>
+<span class="sourceLineNo">091</span>   * Creates an instance of {@link RegionServerTableMetrics} only if the feature is enabled.<a name="line.91"></a>
+<span class="sourceLineNo">092</span>   */<a name="line.92"></a>
+<span class="sourceLineNo">093</span>  static RegionServerTableMetrics createTableMetrics(Configuration conf) {<a name="line.93"></a>
+<span class="sourceLineNo">094</span>    if (conf.getBoolean(RS_ENABLE_TABLE_METRICS_KEY, RS_ENABLE_TABLE_METRICS_DEFAULT)) {<a name="line.94"></a>
+<span class="sourceLineNo">095</span>      return new RegionServerTableMetrics();<a name="line.95"></a>
+<span class="sourceLineNo">096</span>    }<a name="line.96"></a>
+<span class="sourceLineNo">097</span>    return null;<a name="line.97"></a>
 <span class="sourceLineNo">098</span>  }<a name="line.98"></a>
 <span class="sourceLineNo">099</span><a name="line.99"></a>
-<span class="sourceLineNo">100</span>  public MetricsUserAggregate getMetricsUserAggregate() {<a name="line.100"></a>
-<span class="sourceLineNo">101</span>    return userAggregate;<a name="line.101"></a>
+<span class="sourceLineNo">100</span>  public MetricsRegionServerSource getMetricsSource() {<a name="line.100"></a>
+<span class="sourceLineNo">101</span>    return serverSource;<a name="line.101"></a>
 <span class="sourceLineNo">102</span>  }<a name="line.102"></a>
 <span class="sourceLineNo">103</span><a name="line.103"></a>
-<span class="sourceLineNo">104</span>  public MetricsRegionServerWrapper getRegionServerWrapper() {<a name="line.104"></a>
-<span class="sourceLineNo">105</span>    return regionServerWrapper;<a name="line.105"></a>
+<span class="sourceLineNo">104</span>  public MetricsUserAggregate getMetricsUserAggregate() {<a name="line.104"></a>
+<span class="sourceLineNo">105</span>    return userAggregate;<a name="line.105"></a>
 <span class="sourceLineNo">106</span>  }<a name="line.106"></a>
 <span class="sourceLineNo">107</span><a name="line.107"></a>
-<span class="sourceLineNo">108</span>  public void updatePutBatch(TableName tn, long t) {<a name="line.108"></a>
-<span class="sourceLineNo">109</span>    if (tableMetrics != null &amp;&amp; tn != null) {<a name="line.109"></a>
-<span class="sourceLineNo">110</span>      tableMetrics.updatePutBatch(tn, t);<a name="line.110"></a>
-<span class="sourceLineNo">111</span>    }<a name="line.111"></a>
-<span class="sourceLineNo">112</span>    if (t &gt; 1000) {<a name="line.112"></a>
-<span class="sourceLineNo">113</span>      serverSource.incrSlowPut();<a name="line.113"></a>
-<span class="sourceLineNo">114</span>    }<a name="line.114"></a>
-<span class="sourceLineNo">115</span>    serverSource.updatePutBatch(t);<a name="line.115"></a>
-<span class="sourceLineNo">116</span>  }<a name="line.116"></a>
-<span class="sourceLineNo">117</span><a name="line.117"></a>
-<span class="sourceLineNo">118</span>  public void updatePut(TableName tn, long t) {<a name="line.118"></a>
-<span class="sourceLineNo">119</span>    if (tableMetrics != null &amp;&amp; tn != null) {<a name="line.119"></a>
-<span class="sourceLineNo">120</span>      tableMetrics.updatePut(tn, t);<a name="line.120"></a>
-<span class="sourceLineNo">121</span>    }<a name="line.121"></a>
-<span class="sourceLineNo">122</span>    serverSource.updatePut(t);<a name="line.122"></a>
-<span class="sourceLineNo">123</span>    userAggregate.updatePut(t);<a name="line.123"></a>
-<span class="sourceLineNo">124</span>  }<a name="line.124"></a>
-<span class="sourceLineNo">125</span><a name="line.125"></a>
-<span class="sourceLineNo">126</span>  public void updateDelete(TableName tn, long t) {<a name="line.126"></a>
-<span class="sourceLineNo">127</span>    if (tableMetrics != null &amp;&amp; tn != null) {<a name="line.127"></a>
-<span class="sourceLineNo">128</span>      tableMetrics.updateDelete(tn, t);<a name="line.128"></a>
-<span class="sourceLineNo">129</span>    }<a name="line.129"></a>
-<span class="sourceLineNo">130</span>    serverSource.updateDelete(t);<a name="line.130"></a>
-<span class="sourceLineNo">131</span>    userAggregate.updateDelete(t);<a name="line.131"></a>
-<span class="sourceLineNo">132</span>  }<a name="line.132"></a>
-<span class="sourceLineNo">133</span><a name="line.133"></a>
-<span class="sourceLineNo">134</span>  public void updateDeleteBatch(TableName tn, long t) {<a name="line.134"></a>
-<span class="sourceLineNo">135</span>    if (tableMetrics != null &amp;&amp; tn != null) {<a name="line.135"></a>
-<span class="sourceLineNo">136</span>      tableMetrics.updateDeleteBatch(tn, t);<a name="line.136"></a>
-<span class="sourceLineNo">137</span>    }<a name="line.137"></a>
-<span class="sourceLineNo">138</span>    if (t &gt; 1000) {<a name="line.138"></a>
-<span class="sourceLineNo">139</span>      serverSource.incrSlowDelete();<a name="line.139"></a>
-<span class="sourceLineNo">140</span>    }<a name="line.140"></a>
-<span class="sourceLineNo">141</span>    serverSource.updateDeleteBatch(t);<a name="line.141"></a>
-<span class="sourceLineNo">142</span>  }<a name="line.142"></a>
-<span class="sourceLineNo">143</span><a name="line.143"></a>
-<span class="sourceLineNo">144</span>  public void updateCheckAndDelete(TableName tn, long t) {<a name="line.144"></a>
-<span class="sourceLineNo">145</span>    if (tableMetrics != null &amp;&amp; tn != null) {<a name="line.145"></a>
-<span class="sourceLineNo">146</span>      tableMetrics.updateCheckAndDelete(tn, t);<a name="line.146"></a>
-<span class="sourceLineNo">147</span>    }<a name="line.147"></a>
-<span class="sourceLineNo">148</span>    serverSource.updateCheckAndDelete(t);<a name="line.148"></a>
-<span class="sourceLineNo">149</span>  }<a name="line.149"></a>
-<span class="sourceLineNo">150</span><a name="line.150"></a>
-<span class="sourceLineNo">151</span>  public void updateCheckAndPut(TableName tn, long t) {<a name="line.151"></a>
-<span class="sourceLineNo">152</span>    if (tableMetrics != null &amp;&amp; tn != null) {<a name="line.152"></a>
-<span class="sourceLineNo">153</span>      tableMetrics.updateCheckAndPut(tn, t);<a name="line.153"></a>
-<span class="sourceLineNo">154</span>    }<a name="line.154"></a>
-<span class="sourceLineNo">155</span>    serverSource.updateCheckAndPut(t);<a name="line.155"></a>
-<span class="sourceLineNo">156</span>  }<a name="line.156"></a>
-<span class="sourceLineNo">157</span><a name="line.157"></a>
-<span class="sourceLineNo">158</span>  public void updateCheckAndMutate(TableName tn, long t) {<a name="line.158"></a>
-<span class="sourceLineNo">159</span>    if (tableMetrics != null &amp;&amp; tn != null) {<a name="line.159"></a>
-<span class="sourceLineNo">160</span>      tableMetrics.updateCheckAndMutate(tn, t);<a name="line.160"></a>
-<span class="sourceLineNo">161</span>    }<a name="line.161"></a>
-<span class="sourceLineNo">162</span>    serverSource.updateCheckAndMutate(t);<a name="line.162"></a>
-<span class="sourceLineNo">163</span>  }<a name="line.163"></a>
-<span class="sourceLineNo">164</span><a name="line.164"></a>
-<span class="sourceLineNo">165</span>  public void updateGet(TableName tn, long t) {<a name="line.165"></a>
-<span class="sourceLineNo">166</span>    if (tableMetrics != null &amp;&amp; tn != null) {<a name="line.166"></a>
-<span class="sourceLineNo">167</span>      tableMetrics.updateGet(tn, t);<a name="line.167"></a>
-<span class="sourceLineNo">168</span>    }<a name="line.168"></a>
-<span class="sourceLineNo">169</span>    if (t &gt; 1000) {<a name="line.169"></a>
-<span class="sourceLineNo">170</span>      serverSource.incrSlowGet();<a name="line.170"></a>
-<span class="sourceLineNo">171</span>    }<a name="line.171"></a>
-<span class="sourceLineNo">172</span>    serverSource.updateGet(t);<a name="line.172"></a>
-<span class="sourceLineNo">173</span>    userAggregate.updateGet(t);<a name="line.173"></a>
-<span class="sourceLineNo">174</span>  }<a name="line.174"></a>
-<span class="sourceLineNo">175</span><a name="line.175"></a>
-<span class="sourceLineNo">176</span>  public void updateIncrement(TableName tn, long t) {<a name="line.176"></a>
-<span class="sourceLineNo">177</span>    if (tableMetrics != null &amp;&amp; tn != null) {<a name="line.177"></a>
-<span class="sourceLineNo">178</span>      tableMetrics.updateIncrement(tn, t);<a name="line.178"></a>
-<span class="sourceLineNo">179</span>    }<a name="line.179"></a>
-<span class="sourceLineNo">180</span>    if (t &gt; 1000) {<a name="line.180"></a>
-<span class="sourceLineNo">181</span>      serverSource.incrSlowIncrement();<a name="line.181"></a>
-<span class="sourceLineNo">182</span>    }<a name="line.182"></a>
-<span class="sourceLineNo">183</span>    serverSource.updateIncrement(t);<a name="line.183"></a>
-<span class="sourceLineNo">184</span>    userAggregate.updateIncrement(t);<a name="line.184"></a>
-<span class="sourceLineNo">185</span>  }<a name="line.185"></a>
-<span class="sourceLineNo">186</span><a name="line.186"></a>
-<span class="sourceLineNo">187</span>  public void updateAppend(TableName tn, long t) {<a name="line.187"></a>
-<span class="sourceLineNo">188</span>    if (tableMetrics != null &amp;&amp; tn != null) {<a name="line.188"></a>
-<span class="sourceLineNo">189</span>      tableMetrics.updateAppend(tn, t);<a name="line.189"></a>
-<span class="sourceLineNo">190</span>    }<a name="line.190"></a>
-<span class="sourceLineNo">191</span>    if (t &gt; 1000) {<a name="line.191"></a>
-<span class="sourceLineNo">192</span>      serverSource.incrSlowAppend();<a name="line.192"></a>
-<span class="sourceLineNo">193</span>    }<a name="line.193"></a>
-<span class="sourceLineNo">194</span>    serverSource.updateAppend(t);<a name="line.194"></a>
-<span class="sourceLineNo">195</span>    userAggregate.updateAppend(t);<a name="line.195"></a>
-<span class="sourceLineNo">196</span>  }<a name="line.196"></a>
-<span class="sourceLineNo">197</span><a name="line.197"></a>
-<span class="sourceLineNo">198</span>  public void updateReplay(long t){<a name="line.198"></a>
-<span class="sourceLineNo">199</span>    serverSource.updateReplay(t);<a name="line.199"></a>
-<span class="sourceLineNo">200</span>    userAggregate.updateReplay(t);<a name="line.200"></a>
-<span class="sourceLineNo">201</span>  }<a name="line.201"></a>
-<span class="sourceLineNo">202</span><a name="line.202"></a>
-<span class="sourceLineNo">203</span>  public void updateScanSize(TableName tn, long scanSize){<a name="line.203"></a>
-<span class="sourceLineNo">204</span>    if (tableMetrics != null &amp;&amp; tn != null) {<a name="line.204"></a>
-<span class="sourceLineNo">205</span>      tableMetrics.updateScanSize(tn, scanSize);<a name="line.205"></a>
-<span class="sourceLineNo">206</span>    }<a name="line.206"></a>
-<span class="sourceLineNo">207</span>    serverSource.updateScanSize(scanSize);<a name="line.207"></a>
-<span class="sourceLineNo">208</span>  }<a name="line.208"></a>
-<span class="sourceLineNo">209</span><a name="line.209"></a>
-<span class="sourceLineNo">210</span>  public void updateScanTime(TableName tn, long t) {<a name="line.210"></a>
-<span class="sourceLineNo">211</span>    if (tableMetrics != null &amp;&amp; tn != null) {<a name="line.211"></a>
-<span class="sourceLineNo">212</span>      tableMetrics.updateScanTime(tn, t);<a name="line.212"></a>
-<span class="sourceLineNo">213</span>    }<a name="line.213"></a>
-<span class="sourceLineNo">214</span>    serverSource.updateScanTime(t);<a name="line.214"></a>
-<span class="sourceLineNo">215</span>    userAggregate.updateScanTime(t);<a name="line.215"></a>
-<span class="sourceLineNo">216</span>  }<a name="line.216"></a>
-<span class="sourceLineNo">217</span><a name="line.217"></a>
-<span class="sourceLineNo">218</span>  public void updateSplitTime(long t) {<a name="line.218"></a>
-<span class="sourceLineNo">219</span>    serverSource.updateSplitTime(t);<a name="line.219"></a>
+<span class="sourceLineNo">108</span>  public MetricsRegionServerWrapper getRegionServerWrapper() {<a name="line.108"></a>
+<span class="sourceLineNo">109</span>    return regionServerWrapper;<a name="line.109"></a>
+<span class="sourceLineNo">110</span>  }<a name="line.110"></a>
+<span class="sourceLineNo">111</span><a name="line.111"></a>
+<span class="sourceLineNo">112</span>  public void updatePutBatch(TableName tn, long t) {<a name="line.112"></a>
+<span class="sourceLineNo">113</span>    if (tableMetrics != null &amp;&amp; tn != null) {<a name="line.113"></a>
+<span class="sourceLineNo">114</span>      tableMetrics.updatePutBatch(tn, t);<a name="line.114"></a>
+<span class="sourceLineNo">115</span>    }<a name="line.115"></a>
+<span class="sourceLineNo">116</span>    if (t &gt; slowMetricTime) {<a name="line.116"></a>
+<span class="sourceLineNo">117</span>      serverSource.incrSlowPut();<a name="line.117"></a>
+<span class="sourceLineNo">118</span>    }<a name="line.118"></a>
+<span class="sourceLineNo">119</span>    serverSource.updatePutBatch(t);<a name="line.119"></a>
+<span class="sourceLineNo">120</span>  }<a name="line.120"></a>
+<span class="sourceLineNo">121</span><a name="line.121"></a>
+<span class="sourceLineNo">122</span>  public void updatePut(TableName tn, long t) {<a name="line.122"></a>
+<span class="sourceLineNo">123</span>    if (tableMetrics != null &amp;&amp; tn != null) {<a name="line.123"></a>
+<span class="sourceLineNo">124</span>      tableMetrics.updatePut(tn, t);<a name="line.124"></a>
+<span class="sourceLineNo">125</span>    }<a name="line.125"></a>
+<span class="sourceLineNo">126</span>    serverSource.updatePut(t);<a name="line.126"></a>
+<span class="sourceLineNo">127</span>    userAggregate.updatePut(t);<a name="line.127"></a>
+<span class="sourceLineNo">128</span>  }<a name="line.128"></a>
+<span class="sourceLineNo">129</span><a name="line.129"></a>
+<span class="sourceLineNo">130</span>  public void updateDelete(TableName tn, long t) {<a name="line.130"></a>
+<span class="sourceLineNo">131</span>    if (tableMetrics != null &amp;&amp; tn != null) {<a name="line.131"></a>
+<span class="sourceLineNo">132</span>      tableMetrics.updateDelete(tn, t);<a name="line.132"></a>
+<span class="sourceLineNo">133</span>    }<a name="line.133"></a>
+<span class="sourceLineNo">134</span>    serverSource.updateDelete(t);<a name="line.134"></a>
+<span class="sourceLineNo">135</span>    userAggregate.updateDelete(t);<a name="line.135"></a>
+<span class="sourceLineNo">136</span>  }<a name="line.136"></a>
+<span class="sourceLineNo">137</span><a name="line.137"></a>
+<span class="sourceLineNo">138</span>  public void updateDeleteBatch(TableName tn, long t) {<a name="line.138"></a>
+<span class="sourceLineNo">139</span>    if (tableMetrics != null &amp;&amp; tn != null) {<a name="line.139"></a>
+<span class="sourceLineNo">140</span>      tableMetrics.updateDeleteBatch(tn, t);<a name="line.140"></a>
+<span class="sourceLineNo">141</span>    }<a name="line.141"></a>
+<span class="sourceLineNo">142</span>    if (t &gt; slowMetricTime) {<a name="line.142"></a>
+<span class="sourceLineNo">143</span>      serverSource.incrSlowDelete();<a name="line.143"></a>
+<span class="sourceLineNo">144</span>    }<a name="line.144"></a>
+<span class="sourceLineNo">145</span>    serverSource.updateDeleteBatch(t);<a name="line.145"></a>
+<span class="sourceLineNo">146</span>  }<a name="line.146"></a>
+<span class="sourceLineNo">147</span><a name="line.147"></a>
+<span class="sourceLineNo">148</span>  public void updateCheckAndDelete(TableName tn, long t) {<a name="line.148"></a>
+<span class="sourceLineNo">149</span>    if (tableMetrics != null &amp;&amp; tn != null) {<a name="line.149"></a>
+<span class="sourceLineNo">150</span>      tableMetrics.updateCheckAndDelete(tn, t);<a name="line.150"></a>
+<span class="sourceLineNo">151</span>    }<a name="line.151"></a>
+<span class="sourceLineNo">152</span>    serverSource.updateCheckAndDelete(t);<a name="line.152"></a>
+<span class="sourceLineNo">153</span>  }<a name="line.153"></a>
+<span class="sourceLineNo">154</span><a name="line.154"></a>
+<span class="sourceLineNo">155</span>  public void updateCheckAndPut(TableName tn, long t) {<a name="line.155"></a>
+<span class="sourceLineNo">156</span>    if (tableMetrics != null &amp;&amp; tn != null) {<a name="line.156"></a>
+<span class="sourceLineNo">157</span>      tableMetrics.updateCheckAndPut(tn, t);<a name="line.157"></a>
+<span class="sourceLineNo">158</span>    }<a name="line.158"></a>
+<span class="sourceLineNo">159</span>    serverSource.updateCheckAndPut(t);<a name="line.159"></a>
+<span class="sourceLineNo">160</span>  }<a name="line.160"></a>
+<span class="sourceLineNo">161</span><a name="line.161"></a>
+<span class="sourceLineNo">162</span>  public void updateCheckAndMutate(TableName tn, long t) {<a name="line.162"></a>
+<span class="sourceLineNo">163</span>    if (tableMetrics != null &amp;&amp; tn != null) {<a name="line.163"></a>
+<span class="sourceLineNo">164</span>      tableMetrics.updateCheckAndMutate(tn, t);<a name="line.164"></a>
+<span class="sourceLineNo">165</span>    }<a name="line.165"></a>
+<span class="sourceLineNo">166</span>    serverSource.updateCheckAndMutate(t);<a name="line.166"></a>
+<span class="sourceLineNo">167</span>  }<a name="line.167"></a>
+<span class="sourceLineNo">168</span><a name="line.168"></a>
+<span class="sourceLineNo">169</span>  public void updateGet(TableName tn, long t) {<a name="line.169"></a>
+<span class="sourceLineNo">170</span>    if (tableMetrics != null &amp;&amp; tn != null) {<a name="line.170"></a>
+<span class="sourceLineNo">171</span>      tableMetrics.updateGet(tn, t);<a name="line.171"></a>
+<span class="sourceLineNo">172</span>    }<a name="line.172"></a>
+<span class="sourceLineNo">173</span>    if (t &gt; slowMetricTime) {<a name="line.173"></a>
+<span class="sourceLineNo">174</span>      serverSource.incrSlowGet();<a name="line.174"></a>
+<span class="sourceLineNo">175</span>    }<a name="line.175"></a>
+<span class="sourceLineNo">176</span>    serverSource.updateGet(t);<a name="line.176"></a>
+<span class="sourceLineNo">177</span>    userAggregate.updateGet(t);<a name="line.177"></a>
+<span class="sourceLineNo">178</span>  }<a name="line.178"></a>
+<span class="sourceLineNo">179</span><a name="line.179"></a>
+<span class="sourceLineNo">180</span>  public void updateIncrement(TableName tn, long t) {<a name="line.180"></a>
+<span class="sourceLineNo">181</span>    if (tableMetrics != null &amp;&amp; tn != null) {<a name="line.181"></a>
+<span class="sourceLineNo">182</span>      tableMetrics.updateIncrement(tn, t);<a name="line.182"></a>
+<span class="sourceLineNo">183</span>    }<a name="line.183"></a>
+<span class="sourceLineNo">184</span>    if (t &gt; slowMetricTime) {<a name="line.184"></a>
+<span class="sourceLineNo">185</span>      serverSource.incrSlowIncrement();<a name="line.185"></a>
+<span class="sourceLineNo">186</span>    }<a name="line.186"></a>
+<span class="sourceLineNo">187</span>    serverSource.updateIncrement(t);<a name="line.187"></a>
+<span class="sourceLineNo">188</span>    userAggregate.updateIncrement(t);<a name="line.188"></a>
+<span class="sourceLineNo">189</span>  }<a name="line.189"></a>
+<span class="sourceLineNo">190</span><a name="line.190"></a>
+<span class="sourceLineNo">191</span>  public void updateAppend(TableName tn, long t) {<a name="line.191"></a>
+<span class="sourceLineNo">192</span>    if (tableMetrics != null &amp;&amp; tn != null) {<a name="line.192"></a>
+<span class="sourceLineNo">193</span>      tableMetrics.updateAppend(tn, t);<a name="line.193"></a>
+<span class="sourceLineNo">194</span>    }<a name="line.194"></a>
+<span class="sourceLineNo">195</span>    if (t &gt; slowMetricTime) {<a name="line.195"></a>
+<span class="sourceLineNo">196</span>      serverSource.incrSlowAppend();<a name="line.196"></a>
+<span class="sourceLineNo">197</span>    }<a name="line.197"></a>
+<span class="sourceLineNo">198</span>    serverSource.updateAppend(t);<a name="line.198"></a>
... 98626 lines suppressed ...