ArrowFlightJdbcTimeStampVectorGetter.java
/*
* 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.
*/
package org.apache.arrow.driver.jdbc.accessor.impl.calendar;
import org.apache.arrow.vector.TimeStampMicroTZVector;
import org.apache.arrow.vector.TimeStampMicroVector;
import org.apache.arrow.vector.TimeStampMilliTZVector;
import org.apache.arrow.vector.TimeStampMilliVector;
import org.apache.arrow.vector.TimeStampNanoTZVector;
import org.apache.arrow.vector.TimeStampNanoVector;
import org.apache.arrow.vector.TimeStampSecTZVector;
import org.apache.arrow.vector.TimeStampSecVector;
import org.apache.arrow.vector.TimeStampVector;
import org.apache.arrow.vector.holders.NullableTimeStampMicroHolder;
import org.apache.arrow.vector.holders.NullableTimeStampMicroTZHolder;
import org.apache.arrow.vector.holders.NullableTimeStampMilliHolder;
import org.apache.arrow.vector.holders.NullableTimeStampMilliTZHolder;
import org.apache.arrow.vector.holders.NullableTimeStampNanoHolder;
import org.apache.arrow.vector.holders.NullableTimeStampNanoTZHolder;
import org.apache.arrow.vector.holders.NullableTimeStampSecHolder;
import org.apache.arrow.vector.holders.NullableTimeStampSecTZHolder;
/** Auxiliary class used to unify data access on TimeStampVectors. */
final class ArrowFlightJdbcTimeStampVectorGetter {
private ArrowFlightJdbcTimeStampVectorGetter() {
// Prevent instantiation.
}
/**
* Auxiliary class meant to unify TimeStamp*Vector#get implementations with different classes of
* ValueHolders.
*/
static class Holder {
int isSet; // Tells if value is set; 0 = not set, 1 = set
long value; // Holds actual value in its respective timeunit
}
/** Functional interface used to unify TimeStamp*Vector#get implementations. */
@FunctionalInterface
interface Getter {
void get(int index, Holder holder);
}
static Getter createGetter(TimeStampVector vector) {
if (vector instanceof TimeStampNanoVector) {
return createGetter((TimeStampNanoVector) vector);
} else if (vector instanceof TimeStampNanoTZVector) {
return createGetter((TimeStampNanoTZVector) vector);
} else if (vector instanceof TimeStampMicroVector) {
return createGetter((TimeStampMicroVector) vector);
} else if (vector instanceof TimeStampMicroTZVector) {
return createGetter((TimeStampMicroTZVector) vector);
} else if (vector instanceof TimeStampMilliVector) {
return createGetter((TimeStampMilliVector) vector);
} else if (vector instanceof TimeStampMilliTZVector) {
return createGetter((TimeStampMilliTZVector) vector);
} else if (vector instanceof TimeStampSecVector) {
return createGetter((TimeStampSecVector) vector);
} else if (vector instanceof TimeStampSecTZVector) {
return createGetter((TimeStampSecTZVector) vector);
}
throw new UnsupportedOperationException("Unsupported Timestamp vector type");
}
private static Getter createGetter(TimeStampNanoVector vector) {
NullableTimeStampNanoHolder auxHolder = new NullableTimeStampNanoHolder();
return (index, holder) -> {
vector.get(index, auxHolder);
holder.isSet = auxHolder.isSet;
holder.value = auxHolder.value;
};
}
private static Getter createGetter(TimeStampNanoTZVector vector) {
NullableTimeStampNanoTZHolder auxHolder = new NullableTimeStampNanoTZHolder();
return (index, holder) -> {
vector.get(index, auxHolder);
holder.isSet = auxHolder.isSet;
holder.value = auxHolder.value;
};
}
private static Getter createGetter(TimeStampMicroVector vector) {
NullableTimeStampMicroHolder auxHolder = new NullableTimeStampMicroHolder();
return (index, holder) -> {
vector.get(index, auxHolder);
holder.isSet = auxHolder.isSet;
holder.value = auxHolder.value;
};
}
private static Getter createGetter(TimeStampMicroTZVector vector) {
NullableTimeStampMicroTZHolder auxHolder = new NullableTimeStampMicroTZHolder();
return (index, holder) -> {
vector.get(index, auxHolder);
holder.isSet = auxHolder.isSet;
holder.value = auxHolder.value;
};
}
private static Getter createGetter(TimeStampMilliVector vector) {
NullableTimeStampMilliHolder auxHolder = new NullableTimeStampMilliHolder();
return (index, holder) -> {
vector.get(index, auxHolder);
holder.isSet = auxHolder.isSet;
holder.value = auxHolder.value;
};
}
private static Getter createGetter(TimeStampMilliTZVector vector) {
NullableTimeStampMilliTZHolder auxHolder = new NullableTimeStampMilliTZHolder();
return (index, holder) -> {
vector.get(index, auxHolder);
holder.isSet = auxHolder.isSet;
holder.value = auxHolder.value;
};
}
private static Getter createGetter(TimeStampSecVector vector) {
NullableTimeStampSecHolder auxHolder = new NullableTimeStampSecHolder();
return (index, holder) -> {
vector.get(index, auxHolder);
holder.isSet = auxHolder.isSet;
holder.value = auxHolder.value;
};
}
private static Getter createGetter(TimeStampSecTZVector vector) {
NullableTimeStampSecTZHolder auxHolder = new NullableTimeStampSecTZHolder();
return (index, holder) -> {
vector.get(index, auxHolder);
holder.isSet = auxHolder.isSet;
holder.value = auxHolder.value;
};
}
}