com.pingcap.tikv.key.IntHandle Maven / Gradle / Ivy
/*
* Copyright 2020 PingCAP, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.pingcap.tikv.key;
import com.pingcap.tikv.codec.Codec.IntegerCodec;
import com.pingcap.tikv.codec.CodecDataOutput;
import com.pingcap.tikv.exception.CodecException;
import com.pingcap.tikv.types.DataType;
import com.pingcap.tikv.types.IntegerType;
import java.util.Arrays;
public class IntHandle implements Handle {
private final long handle;
private final int infFlag;
public IntHandle(long handle) {
this.handle = handle;
this.infFlag = 0;
}
private IntHandle(long handle, int infFlag) {
this.handle = handle;
this.infFlag = infFlag;
}
@Override
public boolean isInt() {
return true;
}
@Override
public long intValue() {
return handle;
}
@Override
public Handle next() {
if (handle != Long.MAX_VALUE) {
return new IntHandle(handle + 1);
}
return new IntHandle(handle, 1);
}
@Override
public boolean equals(Object other) {
if (other instanceof IntHandle) {
return ((IntHandle) other).intValue() == handle;
}
return false;
}
@Override
public int compare(Handle h) {
if (!h.isInt()) {
throw new RuntimeException("IntHandle compares to CommonHandle");
}
if (infFlag != ((IntHandle) h).infFlag) {
return infFlag - ((IntHandle) h).infFlag;
}
long val = intValue();
long hVal = h.intValue();
if (val > hVal) {
return 1;
} else if (val < hVal) {
return -1;
}
return 0;
}
@Override
public byte[] encoded() {
CodecDataOutput cdo = new CodecDataOutput();
IntegerCodec.writeLong(cdo, handle);
byte[] encoded = cdo.toBytes();
if (infFlag == 1) {
return Arrays.copyOf(encoded, encoded.length + 1);
}
return encoded;
}
@Override
public byte[] encodedAsKey() {
CodecDataOutput cdo = new CodecDataOutput();
IntegerType.BIGINT.encode(cdo, DataType.EncodeType.KEY, handle);
byte[] encoded = cdo.toBytes();
if (infFlag == 1) {
return Arrays.copyOf(encoded, encoded.length + 1);
}
return encoded;
}
@Override
public int len() {
if (infFlag == 1) {
return 9;
}
return 8;
}
@Override
public int numCols() {
throw new CodecException("not supported in IntHandle");
}
@Override
public byte[] encodedCol(int idx) {
throw new CodecException("not supported in IntHandle");
}
@Override
public Object[] data() {
return new Object[] {handle};
}
@Override
public String toString() {
if (infFlag == -1) {
return "-inf";
} else if (infFlag == 1) {
return "+inf";
}
return String.valueOf(handle);
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy