org.openstreetmap.atlas.utilities.arrays.IntegerArrayOfArrays Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of atlas Show documentation
Show all versions of atlas Show documentation
"Library to load OSM data into an Atlas format"
package org.openstreetmap.atlas.utilities.arrays;
import java.util.Objects;
import org.openstreetmap.atlas.geography.atlas.packed.PackedAtlasSerializer;
import org.openstreetmap.atlas.proto.ProtoSerializable;
import org.openstreetmap.atlas.proto.adapters.ProtoAdapter;
import org.openstreetmap.atlas.proto.adapters.ProtoIntegerArrayOfArraysAdapter;
/**
* {@link LargeArray} of arrays of int (int[])
*
* @author matthieun
* @author lcram
*/
public class IntegerArrayOfArrays extends LargeArray implements ProtoSerializable
{
/**
* {@link PrimitiveArray} for type {@link Long}
*
* @author matthieun
*/
public static class PrimitiveIntegerArrayArray extends PrimitiveArray
{
private static final long serialVersionUID = -4397674333836117261L;
private final int[][] array = new int[size()][];
public PrimitiveIntegerArrayArray(final int size)
{
super(size);
}
@Override
public int[] get(final int index)
{
return this.array[index];
}
@Override
public PrimitiveArray getNewArray(final int size)
{
return new PrimitiveIntegerArrayArray(size);
}
@Override
public void set(final int index, final int[] item)
{
this.array[index] = item;
}
}
private static final long serialVersionUID = 6793499910834785994L;
public IntegerArrayOfArrays(final long maximumSize)
{
super(maximumSize);
}
public IntegerArrayOfArrays(final long maximumSize, final int memoryBlockSize,
final int subArraySize)
{
super(maximumSize, memoryBlockSize, subArraySize);
}
/**
* This nullary constructor is solely for use by the {@link PackedAtlasSerializer}, which calls
* it using reflection. It allows the serializer code to obtain a handle on a
* {@link IntegerArrayOfArrays} that it can use to grab the correct {@link ProtoAdapter}. The
* object initialized with this constructor will be corrupted for general use and should be
* discarded.
*/
@SuppressWarnings("unused")
private IntegerArrayOfArrays()
{
super();
}
@Override
public boolean equals(final Object other)
{
if (other instanceof IntegerArrayOfArrays)
{
if (this == other)
{
return true;
}
final IntegerArrayOfArrays that = (IntegerArrayOfArrays) other;
if (!Objects.equals(this.getName(), that.getName()))
{
return false;
}
if (this.size() != that.size())
{
return false;
}
for (long index = 0; index < this.size(); index++)
{
final int[] thisSubArray = this.get(index);
final int[] thatSubArray = that.get(index);
if (thisSubArray.length != thatSubArray.length)
{
return false;
}
for (int subIndex = 0; subIndex < thisSubArray.length; subIndex++)
{
if (thisSubArray[subIndex] != thatSubArray[subIndex])
{
return false;
}
}
}
return true;
}
return false;
}
@Override
public ProtoAdapter getProtoAdapter()
{
return new ProtoIntegerArrayOfArraysAdapter();
}
/*
* NOTE: This hashCode implementation uses the array object references and not the actual array
* values. Keep this in mind before using.
*/
@Override
public int hashCode()
{
final int initialPrime = 31;
final int hashSeed = 37;
final int nameHash = this.getName() == null ? 0 : this.getName().hashCode();
int hash = hashSeed * initialPrime + nameHash;
hash = hashSeed * hash + Long.valueOf(this.size()).hashCode();
for (long index = 0; index < this.size(); index++)
{
hash = hashSeed * hash + this.get(index).hashCode();
}
return hash;
}
@Override
protected PrimitiveArray getNewArray(final int size)
{
return new PrimitiveIntegerArrayArray(size);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy