package org.apache.lucene.util.packed;
/**
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You 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,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import org.apache.lucene.store.DataInput;
import org.apache.lucene.util.RamUsageEstimator;
import java.io.IOException;
import java.util.Arrays;
/**
* Direct wrapping of 32 bit values to a backing array of ints.
* @lucene.internal
*/
class Direct64 extends PackedInts.ReaderImpl
implements PackedInts.Mutable {
private long[] values;
private static final int BITS_PER_VALUE = 64;
public Direct64(int valueCount) {
super(valueCount, BITS_PER_VALUE);
values = new long[valueCount];
}
public Direct64(DataInput in, int valueCount) throws IOException {
super(valueCount, BITS_PER_VALUE);
long[] values = new long[valueCount];
for(int i=0;i<valueCount;i++) {
values[i] = in.readLong();
}
this.values = values;
}
/**
* Creates an array backed by the given values.
* </p><p>
* Note: The values are used directly, so changes to the given values will
* affect the structure.
* @param values used as the internal backing array.
*/
public Direct64(long[] values) {
super(values.length, BITS_PER_VALUE);
this.values = values;
}
public long get(final int index) {
return values[index];
}
public void set(final int index, final long value) {
values[index] = value;
}
public long ramBytesUsed() {
return RamUsageEstimator.NUM_BYTES_ARRAY_HEADER +
values.length * RamUsageEstimator.NUM_BYTES_LONG;
}
public void clear() {
Arrays.fill(values, 0L);
}
@Override
public long[] getArray() {
return values;
}
@Override
public boolean hasArray() {
return true;
}
}