com.hazelcast.jet.sql.impl.opt.FieldCollation Maven / Gradle / Ivy
/*
* Copyright 2021 Hazelcast Inc.
*
* Licensed under the Hazelcast Community License (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://hazelcast.com/hazelcast-community-license
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.hazelcast.jet.sql.impl.opt;
import com.hazelcast.jet.impl.util.Util;
import com.hazelcast.jet.sql.impl.JetSqlSerializerHook;
import com.hazelcast.nio.ObjectDataInput;
import com.hazelcast.nio.ObjectDataOutput;
import com.hazelcast.nio.serialization.IdentifiedDataSerializable;
import com.hazelcast.org.apache.calcite.rel.RelFieldCollation;
import com.hazelcast.org.apache.calcite.rel.RelFieldCollation.Direction;
import com.hazelcast.org.apache.calcite.rel.RelFieldCollation.NullDirection;
import java.io.IOException;
import java.io.Serializable;
import java.util.List;
/**
* Serializable equivalent of {@link RelFieldCollation}.
*/
public class FieldCollation implements Serializable, IdentifiedDataSerializable {
private int index;
private Direction direction;
private NullDirection nullDirection;
public FieldCollation() {
}
public FieldCollation(RelFieldCollation coll) {
index = coll.getFieldIndex();
direction = coll.getDirection();
nullDirection = coll.nullDirection;
}
public static List convertCollation(List colls) {
return Util.toList(colls, FieldCollation::new);
}
public int getIndex() {
return index;
}
public Direction getDirection() {
return direction;
}
public NullDirection getNullDirection() {
return nullDirection;
}
@Override
public void writeData(ObjectDataOutput out) throws IOException {
out.writeInt(index);
out.writeObject(direction);
out.writeObject(nullDirection);
}
@Override
public void readData(ObjectDataInput in) throws IOException {
index = in.readInt();
direction = in.readObject();
nullDirection = in.readObject();
}
@Override
public int getFactoryId() {
return JetSqlSerializerHook.F_ID;
}
@Override
public int getClassId() {
return JetSqlSerializerHook.FIELD_COLLATION;
}
}