/**
* (C) Copyright IBM Corp. 2010, 2015
*
* Licensed 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 com.ibm.bi.dml.parser;
import java.util.ArrayList;
import com.ibm.bi.dml.lops.Lop;
public class FunctionStatement extends Statement
{
private ArrayList<StatementBlock> _body;
protected String _name;
protected ArrayList <DataIdentifier> _inputParams;
protected ArrayList <DataIdentifier> _outputParams;
public Statement rewriteStatement(String prefix) throws LanguageException{
LOG.error(this.printErrorLocation() + "should not call rewriteStatement for FunctionStatement");
throw new LanguageException(this.printErrorLocation() + "should not call rewriteStatement for FunctionStatement");
}
public FunctionStatement(){
_body = new ArrayList<StatementBlock>();
_name = null;
_inputParams = new ArrayList<DataIdentifier>();
_outputParams = new ArrayList<DataIdentifier>();
}
public ArrayList<DataIdentifier> getInputParams(){
return _inputParams;
}
public ArrayList<DataIdentifier> getOutputParams(){
return _outputParams;
}
public void setInputParams(ArrayList<DataIdentifier> inputParams){
_inputParams = inputParams;
}
public void setOutputParams(ArrayList<DataIdentifier> outputParams){
_outputParams = outputParams;
}
public void setName(String fname){
_name = fname;
}
public String getName(){
return _name;
}
public void addStatementBlock(StatementBlock sb){
_body.add(sb);
}
public ArrayList<StatementBlock> getBody(){
return _body;
}
public void setBody(ArrayList<StatementBlock> body){
_body = body;
}
@Override
public boolean controlStatement() {
return true;
}
public void mergeStatementBlocks(){
_body = StatementBlock.mergeStatementBlocks(_body);
}
public String toString(){
StringBuilder sb = new StringBuilder();
sb.append(_name + " = ");
sb.append("function ( ");
for (int i=0; i<_inputParams.size(); i++){
DataIdentifier curr = _inputParams.get(i);
sb.append(curr.getName());
if (curr.getDefaultValue() != null) sb.append(" = " + curr.getDefaultValue());
if (i < _inputParams.size()-1) sb.append(", ");
}
sb.append(") return (");
for (int i=0; i<_outputParams.size(); i++){
sb.append(_outputParams.get(i).getName());
if (i < _outputParams.size()-1) sb.append(", ");
}
sb.append(") { \n");
for (StatementBlock block : _body){
sb.append(block.toString());
}
sb.append("} \n");
return sb.toString();
}
public void initializeforwardLV(VariableSet activeIn) throws LanguageException{
LOG.error(this.printErrorLocation() + "should never call initializeforwardLV for FunctionStatement");
throw new LanguageException(this.printErrorLocation() + "should never call initializeforwardLV for FunctionStatement");
}
public VariableSet initializebackwardLV(VariableSet lo) throws LanguageException{
LOG.error(this.printErrorLocation() + "should never call initializeforwardLV for FunctionStatement");
throw new LanguageException(this.printErrorLocation() + "should never call initializeforwardLV for FunctionStatement");
}
@Override
public VariableSet variablesRead() {
LOG.warn(this.printWarningLocation() + " -- should not call variablesRead from FunctionStatement ");
return new VariableSet();
}
@Override
public VariableSet variablesUpdated() {
LOG.warn(this.printWarningLocation() + " -- should not call variablesRead from FunctionStatement ");
return new VariableSet();
}
public static String[] createFunctionCallVariables( ArrayList<Lop> lops )
{
String[] ret = new String[lops.size()]; //vars in order
for( int i=0; i<lops.size(); i++ )
{
Lop llops = lops.get(i);
if( llops.getType()==Lop.Type.Data )
ret[i] = llops.getOutputParameters().getLabel();
}
return ret;
}
}