/*
* JaamSim Discrete Event Simulation
* Copyright (C) 2014 Ausenco Engineering Canada Inc.
*
* 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.jaamsim.Thresholds;
import com.jaamsim.input.BooleanInput;
import com.jaamsim.input.Keyword;
/**
* SignalThreshold is a type of Threshold that is controlled directly by
* another object. At present, it is required only for EntitySignal.
* @author Harry
*
*/
public class SignalThreshold extends Threshold {
@Keyword(description = "The state for the SignalThreshold at the start of "
+ "the simulation run: TRUE = Open, FALSE = Closed.",
exampleList = {"FALSE"})
private final BooleanInput initState;
{
initState = new BooleanInput("InitialState", "Key Inputs", false);
this.addInput(initState);
}
public SignalThreshold() {}
@Override
public void startUp() {
super.startUp();
this.setOpen(initState.getValue());
}
@Override
public String getInitialState() {
if (initState.getValue())
return "Open";
else
return "Closed";
}
}