org.jpac.plc.IoLogical Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of elbfisch.core Show documentation
Show all versions of elbfisch.core Show documentation
Open-source runtime system for component-based implementation of automation solutions with Java
The newest version!
/**
* PROJECT : Elbfisch - java process automation controller (jPac)
* MODULE : IoLogical.java
* VERSION : -
* DATE : -
* PURPOSE :
* AUTHOR : Bernd Schuster, MSK Gesellschaft fuer Automatisierung mbH, Schenefeld
* REMARKS : -
* CHANGES : CH#n
*
* This file is part of the jPac process automation controller.
* jPac is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* jPac is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with the jPac If not, see .
*/
package org.jpac.plc;
import org.slf4j.LoggerFactory;
import org.slf4j.Logger;
import org.jpac.AbstractModule;
import org.jpac.IoDirection;
import org.jpac.Logical;
import org.jpac.SignalAccessException;
import org.jpac.SignalAlreadyExistsException;
import org.jpac.SignalInvalidException;
/**
*
* @author berndschuster
*/
public class IoLogical extends Logical implements IoSignal{
static Logger Log = LoggerFactory.getLogger("jpac.Signal");
private Address address;
private Data data;
private Data bitData;
private WriteRequest writeRequest;
private IoDirection ioDirection;
private Connection connection;
protected boolean changedByCheck;
protected boolean inCheck;
protected boolean outCheck;
protected boolean toBePutOut;
public IoLogical(AbstractModule containingModule, String name, Data data, Address address, IoDirection ioDirection) throws SignalAlreadyExistsException{
super(containingModule, name);
this.data = data;
this.address = address;
this.ioDirection = ioDirection;
}
/**
* used to checkIn, if this signal has been changed inside the process image. If so, the signal change is automatically
* propagated to all connected signals
* @throws SignalAccessException
* @throws AddressException
*/
@Override
public void checkIn() throws SignalAccessException, AddressException{
try{
inCheck = true;
set(data.getBIT(address.getByteIndex(), address.getBitIndex()));
}
finally{
inCheck = false;
}
}
/**
* used to check, if this signal has been changed by this jPac instance. If so, the signal change is
* propagated to the process image
* @throws SignalAccessException
* @throws AddressException
*/
@Override
public void checkOut() throws SignalAccessException, AddressException{
try{
outCheck = true;
try{data.setBIT(address.getByteIndex(), address.getBitIndex(), isValid() ? is(true) : false);}catch(SignalInvalidException exc){/*cannot happen*/}
}
finally{
outCheck = false;
}
}
@Override
public void set(boolean value) throws SignalAccessException{
super.set(value);
changedByCheck = isChanged() && inCheck;
}
@Override
public void propagate() throws SignalInvalidException{
if (hasChanged() && value.isValid() && !changedByCheck){
//this signal has been altered inside the Elbfisch application (not by the external device).
//Mark it as to be put out to the external device
toBePutOut = true;
}
changedByCheck = false;
super.propagate();
}
@Override
public boolean isToBePutOut(){
return toBePutOut;
}
@Override
public void resetToBePutOut(){
toBePutOut = false;
}
/**
* returns a write request suitable for transmitting this signal to the plc
* @param connection
* @return
*/
@Override
public WriteRequest getWriteRequest(Connection connection){
boolean errorOccured = false;
try{
if (bitData == null || this.connection == null || this.connection != connection){
bitData = connection.generateDataObject(1);
this.connection = connection;
this.writeRequest = null;
}
bitData.setBYTE(0, isValid() && is(true) ? 0x01 : 0x00);
if (writeRequest == null){
writeRequest = connection.generateWriteRequest(Request.DATATYPE.BIT, address, 0, bitData);
}
else{
writeRequest.setData(bitData);
}
}
catch(Exception exc){
Log.error("Error: " + exc);
errorOccured = true;
}
return errorOccured ? null : writeRequest;
}
/**
*
* @param ioDirection to be set
*/
@Override
public void setIoDirection(IoDirection ioDirection){
this.ioDirection = ioDirection;
}
/**
*
* @return ioDirection
*/
@Override
public IoDirection getIoDirection(){
return this.ioDirection;
}
/**
* @param address address of the signal
*/
@Override
public void setAddress(Address address){
this.address = address;
}
/**
* @return the address of the signal
*/
@Override
public Address getAddress(){
return this.address;
}
@Override
public String toString(){
String ts = null;
if (address != null){
ts = super.toString() + (ioDirection == IoDirection.INPUT ? " <- " : " -> ") + address.toString();
}
else{
ts = super.toString();
}
return ts;
}
}