HBASE-14904 Mark Base[En|De]coder LimitedPrivate and fix binary compat issue
Conflicts: hbase-common/src/main/java/org/apache/hadoop/hbase/codec/BaseDecoder.java hbase-common/src/main/java/org/apache/hadoop/hbase/codec/BaseEncoder.java
This commit is contained in:
parent
b001019d9b
commit
edb8edfeb3
|
@ -26,17 +26,18 @@ import javax.annotation.Nonnull;
|
||||||
|
|
||||||
import org.apache.commons.logging.Log;
|
import org.apache.commons.logging.Log;
|
||||||
import org.apache.commons.logging.LogFactory;
|
import org.apache.commons.logging.LogFactory;
|
||||||
import org.apache.hadoop.hbase.classification.InterfaceAudience;
|
|
||||||
import org.apache.hadoop.hbase.Cell;
|
import org.apache.hadoop.hbase.Cell;
|
||||||
|
import org.apache.hadoop.hbase.HBaseInterfaceAudience;
|
||||||
|
import org.apache.hadoop.hbase.classification.InterfaceAudience;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* TODO javadoc
|
* TODO javadoc
|
||||||
*/
|
*/
|
||||||
@InterfaceAudience.Private
|
@InterfaceAudience.LimitedPrivate({HBaseInterfaceAudience.COPROC, HBaseInterfaceAudience.PHOENIX})
|
||||||
public abstract class BaseDecoder implements Codec.Decoder {
|
public abstract class BaseDecoder implements Codec.Decoder {
|
||||||
protected static final Log LOG = LogFactory.getLog(BaseDecoder.class);
|
protected static final Log LOG = LogFactory.getLog(BaseDecoder.class);
|
||||||
|
|
||||||
protected final PBIS in;
|
protected final InputStream in;
|
||||||
private Cell current = null;
|
private Cell current = null;
|
||||||
|
|
||||||
protected static class PBIS extends PushbackInputStream {
|
protected static class PBIS extends PushbackInputStream {
|
||||||
|
@ -60,13 +61,13 @@ public abstract class BaseDecoder implements Codec.Decoder {
|
||||||
if (firstByte == -1) {
|
if (firstByte == -1) {
|
||||||
return false;
|
return false;
|
||||||
} else {
|
} else {
|
||||||
in.unread(firstByte);
|
((PBIS)in).unread(firstByte);
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
this.current = parseCell();
|
this.current = parseCell();
|
||||||
} catch (IOException ioEx) {
|
} catch (IOException ioEx) {
|
||||||
in.resetBuf(1); // reset the buffer in case the underlying stream is read from upper layers
|
((PBIS)in).resetBuf(1); // reset the buffer in case the underlying stream is read from upper layers
|
||||||
rethrowEofException(ioEx);
|
rethrowEofException(ioEx);
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
|
@ -88,6 +89,10 @@ public abstract class BaseDecoder implements Codec.Decoder {
|
||||||
throw eofEx;
|
throw eofEx;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected InputStream getInputStream() {
|
||||||
|
return in;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Extract a Cell.
|
* Extract a Cell.
|
||||||
* @return a parsed Cell or throws an Exception. EOFException or a generic IOException maybe
|
* @return a parsed Cell or throws an Exception. EOFException or a generic IOException maybe
|
||||||
|
|
|
@ -20,14 +20,16 @@ package org.apache.hadoop.hbase.codec;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.OutputStream;
|
import java.io.OutputStream;
|
||||||
|
|
||||||
import org.apache.hadoop.hbase.classification.InterfaceAudience;
|
|
||||||
import org.apache.hadoop.hbase.Cell;
|
import org.apache.hadoop.hbase.Cell;
|
||||||
|
import org.apache.hadoop.hbase.HBaseInterfaceAudience;
|
||||||
|
import org.apache.hadoop.hbase.classification.InterfaceAudience;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* TODO javadoc
|
* TODO javadoc
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@InterfaceAudience.Private
|
@InterfaceAudience.LimitedPrivate({HBaseInterfaceAudience.COPROC, HBaseInterfaceAudience.PHOENIX})
|
||||||
public abstract class BaseEncoder implements Codec.Encoder {
|
public abstract class BaseEncoder implements Codec.Encoder {
|
||||||
protected final OutputStream out;
|
protected final OutputStream out;
|
||||||
// This encoder is 'done' once flush has been called.
|
// This encoder is 'done' once flush has been called.
|
||||||
|
@ -37,6 +39,10 @@ public abstract class BaseEncoder implements Codec.Encoder {
|
||||||
this.out = out;
|
this.out = out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected OutputStream getOuputStream() {
|
||||||
|
return out;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public abstract void write(Cell cell) throws IOException;
|
public abstract void write(Cell cell) throws IOException;
|
||||||
|
|
||||||
|
|
|
@ -21,6 +21,7 @@ package org.apache.hadoop.hbase.regionserver.wal;
|
||||||
import java.lang.reflect.Constructor;
|
import java.lang.reflect.Constructor;
|
||||||
import java.lang.reflect.InvocationTargetException;
|
import java.lang.reflect.InvocationTargetException;
|
||||||
|
|
||||||
|
import org.apache.hadoop.hbase.HBaseInterfaceAudience;
|
||||||
import org.apache.hadoop.hbase.classification.InterfaceAudience;
|
import org.apache.hadoop.hbase.classification.InterfaceAudience;
|
||||||
import org.apache.hadoop.hbase.io.TagCompressionContext;
|
import org.apache.hadoop.hbase.io.TagCompressionContext;
|
||||||
import org.apache.hadoop.hbase.io.util.Dictionary;
|
import org.apache.hadoop.hbase.io.util.Dictionary;
|
||||||
|
@ -28,7 +29,7 @@ import org.apache.hadoop.hbase.io.util.Dictionary;
|
||||||
/**
|
/**
|
||||||
* Context that holds the various dictionaries for compression in WAL.
|
* Context that holds the various dictionaries for compression in WAL.
|
||||||
*/
|
*/
|
||||||
@InterfaceAudience.Private
|
@InterfaceAudience.LimitedPrivate({HBaseInterfaceAudience.COPROC, HBaseInterfaceAudience.PHOENIX})
|
||||||
public class CompressionContext {
|
public class CompressionContext {
|
||||||
|
|
||||||
static final String ENABLE_WAL_TAGS_COMPRESSION =
|
static final String ENABLE_WAL_TAGS_COMPRESSION =
|
||||||
|
|
|
@ -22,12 +22,12 @@ import java.io.IOException;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.io.OutputStream;
|
import java.io.OutputStream;
|
||||||
|
|
||||||
import org.apache.hadoop.hbase.classification.InterfaceAudience;
|
|
||||||
import org.apache.hadoop.conf.Configuration;
|
import org.apache.hadoop.conf.Configuration;
|
||||||
import org.apache.hadoop.hbase.Cell;
|
import org.apache.hadoop.hbase.Cell;
|
||||||
import org.apache.hadoop.hbase.HBaseInterfaceAudience;
|
import org.apache.hadoop.hbase.HBaseInterfaceAudience;
|
||||||
import org.apache.hadoop.hbase.KeyValue;
|
import org.apache.hadoop.hbase.KeyValue;
|
||||||
import org.apache.hadoop.hbase.KeyValueUtil;
|
import org.apache.hadoop.hbase.KeyValueUtil;
|
||||||
|
import org.apache.hadoop.hbase.classification.InterfaceAudience;
|
||||||
import org.apache.hadoop.hbase.codec.BaseDecoder;
|
import org.apache.hadoop.hbase.codec.BaseDecoder;
|
||||||
import org.apache.hadoop.hbase.codec.BaseEncoder;
|
import org.apache.hadoop.hbase.codec.BaseEncoder;
|
||||||
import org.apache.hadoop.hbase.codec.Codec;
|
import org.apache.hadoop.hbase.codec.Codec;
|
||||||
|
|
|
@ -236,7 +236,7 @@ public class WALPrettyPrinter {
|
||||||
*/
|
*/
|
||||||
public void processFile(final Configuration conf, final Path p)
|
public void processFile(final Configuration conf, final Path p)
|
||||||
throws IOException {
|
throws IOException {
|
||||||
FileSystem fs = FileSystem.get(conf);
|
FileSystem fs = p.getFileSystem(conf);
|
||||||
if (!fs.exists(p)) {
|
if (!fs.exists(p)) {
|
||||||
throw new FileNotFoundException(p.toString());
|
throw new FileNotFoundException(p.toString());
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue