All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.drill.exec.ops.FragmentContextInterface Maven / Gradle / Ivy

/*
 * 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.drill.exec.ops;

import java.io.IOException;
import java.util.List;

import org.apache.drill.common.config.DrillConfig;
import org.apache.drill.exec.exception.ClassTransformationException;
import org.apache.drill.exec.exception.OutOfMemoryException;
import org.apache.drill.exec.expr.ClassGenerator;
import org.apache.drill.exec.expr.CodeGenerator;
import org.apache.drill.exec.expr.fn.FunctionImplementationRegistry;
import org.apache.drill.exec.physical.base.PhysicalOperator;
import org.apache.drill.exec.server.DrillbitContext;
import org.apache.drill.exec.server.options.OptionManager;
import org.apache.drill.exec.testing.ExecutionControls;

import io.netty.buffer.DrillBuf;

/**
 * Fragment context interface: separates implementation from definition.
 * Allows unit testing by mocking or reimplementing services with
 * test-time versions. The name is awkward, chosen to avoid renaming
 * the implementation class which is used in many places in legacy code.
 * New code should use this interface, and the names should eventually
 * be swapped with FragmentContext becoming
 * FragmentContextImpl and this interface becoming
 * FragmentContext.
 */

public interface FragmentContextInterface {

  /**
   * Drillbit context. Valid only in production; returns null in
   * operator test environments.
   */

  DrillbitContext getDrillbitContext();

  /**
   * Returns the UDF registry.
   * @return the UDF registry
   */
  FunctionImplementationRegistry getFunctionRegistry();
  /**
   * Returns the session options.
   * @return the session options
   */
  OptionManager getOptions();

  /**
   * Generates code for a class given a {@link ClassGenerator},
   * and returns a single instance of the generated class. (Note
   * that the name is a misnomer, it would be better called
   * getImplementationInstance.)
   *
   * @param cg the class generator
   * @return an instance of the generated class
   */

   T getImplementationClass(final ClassGenerator cg)
      throws ClassTransformationException, IOException;

  /**
   * Generates code for a class given a {@link CodeGenerator},
   * and returns a single instance of the generated class. (Note
   * that the name is a misnomer, it would be better called
   * getImplementationInstance.)
   *
   * @param cg the code generator
   * @return an instance of the generated class
   */

   T getImplementationClass(final CodeGenerator cg)
      throws ClassTransformationException, IOException;

  /**
   * Generates code for a class given a {@link ClassGenerator}, and returns the
   * specified number of instances of the generated class. (Note that the name
   * is a misnomer, it would be better called
   * getImplementationInstances.)
   *
   * @param cg
   *          the class generator
   * @return list of instances of the generated class
   */

   List getImplementationClass(final ClassGenerator cg, final int instanceCount)
      throws ClassTransformationException, IOException;

  /**
   * Generates code for a class given a {@link CodeGenerator}, and returns the
   * specified number of instances of the generated class. (Note that the name
   * is a misnomer, it would be better called
   * getImplementationInstances.)
   *
   * @param cg
   *          the code generator
   * @return list of instances of the generated class
   */

   List getImplementationClass(final CodeGenerator cg, final int instanceCount)
      throws ClassTransformationException, IOException;

  /**
   * Determine if fragment execution has been interrupted.
   * @return true if execution should continue, false if an interruption has
   * occurred and fragment execution should halt
   */

  boolean shouldContinue();

  /**
   * Return the set of execution controls used to inject faults into running
   * code for testing.
   *
   * @return the execution controls
   */
  ExecutionControls getExecutionControls();

  /**
   * Returns the Drill configuration for this run. Note that the config is
   * global and immutable.
   *
   * @return the Drill configuration
   */

  DrillConfig getConfig();

  DrillBuf replace(DrillBuf old, int newSize);

  DrillBuf getManagedBuffer();

  DrillBuf getManagedBuffer(int size);

  OperatorContext newOperatorContext(PhysicalOperator popConfig, OperatorStats stats)
      throws OutOfMemoryException;
  OperatorContext newOperatorContext(PhysicalOperator popConfig)
      throws OutOfMemoryException;

  String getQueryUserName();

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy