org.elasticsearch.compute.operator.ProjectOperator Maven / Gradle / Ivy
/*
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
* or more contributor license agreements. Licensed under the Elastic License
* 2.0; you may not use this file except in compliance with the Elastic License
* 2.0.
*/
package org.elasticsearch.compute.operator;
import org.elasticsearch.compute.data.Page;
import java.util.Arrays;
import java.util.List;
public class ProjectOperator extends AbstractPageMappingOperator {
public record ProjectOperatorFactory(List projection) implements OperatorFactory {
@Override
public Operator get(DriverContext driverContext) {
return new ProjectOperator(projection);
}
@Override
public String describe() {
if (projection.size() < 10) {
return "ProjectOperator[projection = " + projection + "]";
}
return "ProjectOperator[projection = [" + projection.size() + " fields]]";
}
}
private final int[] projection;
/**
* Creates an operator that applies the given projection, encoded as an integer list where
* the ordinal indicates the output order and the value, the backing channel that to be used.
* Given the input {a,b,c,d}, project {a,d,a} is encoded as {0,3,0}.
*
* @param projection list of blocks to keep and their order.
*/
public ProjectOperator(List projection) {
this.projection = projection.stream().mapToInt(Integer::intValue).toArray();
}
@Override
protected Page process(Page page) {
var blockCount = page.getBlockCount();
if (blockCount == 0) {
return page;
}
try {
return page.projectBlocks(projection);
} finally {
page.releaseBlocks();
}
}
@Override
public String toString() {
if (projection.length < 10) {
return "ProjectOperator[projection = " + Arrays.toString(projection) + "]";
}
return "ProjectOperator[projection = [" + projection.length + " fields]]";
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy