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

org.apache.hive.hplsql.Package Maven / Gradle / Ivy

The newest version!
/*
 * 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.hive.hplsql;

import static org.apache.hive.hplsql.functions.InMemoryFunctionRegistry.setCallParameters;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import org.antlr.v4.runtime.ParserRuleContext;
import org.apache.hive.hplsql.HplsqlParser.Create_function_stmtContext;
import org.apache.hive.hplsql.HplsqlParser.Create_procedure_stmtContext;
import org.apache.hive.hplsql.HplsqlParser.Package_body_itemContext;
import org.apache.hive.hplsql.HplsqlParser.Package_spec_itemContext;
import org.apache.hive.hplsql.functions.BuiltinFunctions;
import org.apache.hive.hplsql.functions.InMemoryFunctionRegistry;

/**
 * Program package
 */
public class Package {
  
  private String name;
  private List vars = new ArrayList<>();
  private List publicFuncs = new ArrayList<>();
  private List publicProcs = new ArrayList<>();
  
  HashMap func = new HashMap<>();
  HashMap proc = new HashMap<>();
    
  boolean allMembersPublic = false;
    
  Exec exec;
  InMemoryFunctionRegistry function;
  boolean trace = false;
  
  Package(String name, Exec exec, BuiltinFunctions builtinFunctions) {
    this.name = name;
    this.exec = exec;
    this.function = new InMemoryFunctionRegistry(exec, builtinFunctions);
    this.trace = exec.getTrace();
  }
  
  /**
   * Add a local variable
   */
  public void addVariable(Var var) {
    vars.add(var);
  }
  
  /**
   * Find the variable by name
   */
  public Var findVariable(String name) {
    for (Var var : vars) {
      if (name.equalsIgnoreCase(var.getName())) {
        return var;
      }
    }
    return null;
  }
  
  /**
   * Create the package specification
   */
  public void createSpecification(HplsqlParser.Create_package_stmtContext ctx) {
    int cnt = ctx.package_spec().package_spec_item().size();
    for (int i = 0; i < cnt; i++) {
      Package_spec_itemContext c = ctx.package_spec().package_spec_item(i);
      if (c.declare_stmt_item() != null) {
        visit(c);
      }
      else if (c.T_FUNCTION() != null) {
        publicFuncs.add(c.ident().getText().toUpperCase());
      }
      else if (c.T_PROC() != null || c.T_PROCEDURE() != null) {
        publicProcs.add(c.ident().getText().toUpperCase());
      }
    }
  } 
  
  /**
   * Create the package body
   */
  public void createBody(HplsqlParser.Create_package_body_stmtContext ctx) {
    int cnt = ctx.package_body().package_body_item().size();
    for (int i = 0; i < cnt; i++) {
      Package_body_itemContext c = ctx.package_body().package_body_item(i);
      if (c.declare_stmt_item() != null) {
        visit(c);
      }
      else if (c.create_function_stmt() != null) {
        func.put(c.create_function_stmt().ident().getText().toUpperCase(), c.create_function_stmt());
      }
      else if (c.create_procedure_stmt() != null) {
        proc.put(c.create_procedure_stmt().ident(0).getText().toUpperCase(), c.create_procedure_stmt());
      }
    }    
  } 
  
  /**
   * Execute function
   */
  public boolean execFunc(String name, HplsqlParser.Expr_func_paramsContext ctx) {
    Create_function_stmtContext f = func.get(name.toUpperCase());
    if (f == null) {
      return execProc(name, ctx, false /*trace error if not exists*/);
    }
    if (trace) {
      trace(ctx, "EXEC PACKAGE FUNCTION " + this.name + "." + name);
    }
    ArrayList actualParams = function.getActualCallParameters(ctx);
    exec.enterScope(Scope.Type.ROUTINE, this);
    setCallParameters(name, ctx, actualParams, f.create_routine_params(), null, exec);
    visit(f.single_block_stmt());
    exec.leaveScope(); 
    return true;
  }
  
  /**
   * Execute procedure
   */
  public boolean execProc(String name, HplsqlParser.Expr_func_paramsContext ctx, boolean traceNotExists) {
    Create_procedure_stmtContext p = proc.get(name.toUpperCase());
    if (p == null) {
      if (trace && traceNotExists) {
        trace(ctx, "Package procedure not found: " + this.name + "." + name);
      }
      return false;        
    }
    if (trace) {
      trace(ctx, "EXEC PACKAGE PROCEDURE " + this.name + "." + name);
    }
    ArrayList actualParams = function.getActualCallParameters(ctx);
    HashMap out = new HashMap();
    exec.enterScope(Scope.Type.ROUTINE, this);
    exec.callStackPush(name);
    if (p.declare_block_inplace() != null) {
      visit(p.declare_block_inplace());
    }
    if (p.create_routine_params() != null) {
      setCallParameters(name, ctx, actualParams, p.create_routine_params(), out, exec);
    }
    visit(p.proc_block());
    exec.callStackPop();
    exec.leaveScope();       
    for (Map.Entry i : out.entrySet()) {      // Set OUT parameters
      exec.setVariable(i.getKey(), i.getValue());
    }
    return true;
  }
  
  /**
   * Set whether all members are public (when package specification is missed) or not 
   */
  void setAllMembersPublic(boolean value) {
    allMembersPublic = value;
  }
  
  /**
   * Execute rules
   */
  Integer visit(ParserRuleContext ctx) {
    return exec.visit(ctx);  
  } 

  /**
   * Trace information
   */
  public void trace(ParserRuleContext ctx, String message) {
    if (trace) {
      exec.trace(ctx, message);
    }
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy