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

ro.ciprianpascu.sbus.msg.ExceptionResponse Maven / Gradle / Ivy

Go to download

jamod is an object oriented implementation of the S-Bus protocol, realized 100% in Java. It allows to quickly realize master and slave applications in various transport flavors (IP and serial).

The newest version!
/**
 * Copyright 2002-2010 jamod development 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 ro.ciprianpascu.sbus.msg;

import java.io.DataInput;
import java.io.DataOutput;
import java.io.IOException;

import ro.ciprianpascu.sbus.Modbus;

/**
 * Provides the a{@link ModbusResponse}
 * implementation that represents a Modbus exception.
 *
 * @author Dieter Wimberger
 * @author Ciprian Pascu

 * @version %I% (%G%)
 */
public class ExceptionResponse extends ModbusResponse {

    // instance attributes
    private int m_ExceptionCode = -1;

    /**
     * Constructs a new {@link ExceptionResponse} instance.
     */
    public ExceptionResponse() {
        // exception code, unitid and function code not counted.
        setDataLength(1);
    }// constructor

    /**
     * Constructs a new {@link ExceptionResponse} instance with
     * a given function code. Adds the exception offset automatically.
     *
     * @param fc the function code as {@link int}.
     */
    public ExceptionResponse(int fc) {
        // unitid and function code not counted.
        setDataLength(1);
        setFunctionCode(fc + Modbus.EXCEPTION_OFFSET);
    }// constructor

    /**
     * Constructs a new {@link ExceptionResponse} instance with
     * a given function code and an exception code. The function
     * code will be automatically increased with the exception offset.
     *
     *
     * @param fc the function code as {@link int}.
     * @param exc the exception code as {@link int}.
     */
    public ExceptionResponse(int fc, int exc) {
        // exception code, unitid and function code not counted.
        setDataLength(1);
        setFunctionCode(fc + Modbus.EXCEPTION_OFFSET);
        m_ExceptionCode = exc;
    }// constructor

    /**
     * Returns the Modbus exception code of this
     * {@link ExceptionResponse}.
* 
     *
     * @return the exception code as {@link int}.
     */
    public int getExceptionCode() {
        return m_ExceptionCode;
    }// getExceptionCode

    @Override
    public void writeData(DataOutput dout) throws IOException {
        dout.writeByte(getExceptionCode());
    }// writeData

    @Override
    public void readData(DataInput din) throws IOException {
        m_ExceptionCode = din.readUnsignedByte();
    }// readData


}// ExceptionResponse




© 2015 - 2024 Weber Informatics LLC | Privacy Policy