/**
* Copyright 2011-2017 Asakusa Framework Team.
*
* 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.asakusafw.compiler.flow.stage;
import com.asakusafw.compiler.common.Precondition;
/**
* A compiled model of shuffle fragment.
*/
public class CompiledShuffleFragment {
private final CompiledType mapOutputType;
private final CompiledType combineOutputType;
/**
* Creates a new instance.
* @param mapOutput the output type of map action
* @param combineOutput the output type of combine action
* @throws IllegalArgumentException if the parameters are {@code null}
*/
public CompiledShuffleFragment(CompiledType mapOutput, CompiledType combineOutput) {
Precondition.checkMustNotBeNull(mapOutput, "mapOutput"); //$NON-NLS-1$
Precondition.checkMustNotBeNull(combineOutput, "combineOutput"); //$NON-NLS-1$
this.mapOutputType = mapOutput;
this.combineOutputType = combineOutput;
}
/**
* Returns the output type of map action.
* @return the output type of map action
*/
public CompiledType getMapOutputType() {
return mapOutputType;
}
/**
* Returns the output type of combine action.
* @return the output type of combine action
*/
public CompiledType getCombineOutputType() {
return combineOutputType;
}
}