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

net.wimpi.modbus.util.SerialParameters Maven / Gradle / Ivy

Go to download

jamod is an object oriented implementation of the Modbus 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 net.wimpi.modbus.util;

import net.wimpi.modbus.Modbus;

import gnu.io.SerialPort;
import java.util.Properties;

/**
 * Helper class wrapping all serial port communication parameters.
 * Very similar to the javax.comm demos, however, not the same.
 *
 * @author Dieter Wimberger
 * @author John Charlton
 * @version @version@ (@date@)
 */
public class SerialParameters {

  //instance attributes
  private String m_PortName;
  private int m_BaudRate;
  private int m_FlowControlIn;
  private int m_FlowControlOut;
  private int m_Databits;
  private int m_Stopbits;
  private int m_Parity;
  private String m_Encoding;
  private boolean m_Echo;
  private int m_ReceiveTimeout;

  /**
   * Constructs a new SerialParameters instance with
   * default values.
   */
  public SerialParameters() {
    m_PortName = "";
    m_BaudRate = 9600;
    m_FlowControlIn = SerialPort.FLOWCONTROL_NONE;
    m_FlowControlOut = SerialPort.FLOWCONTROL_NONE;
    m_Databits = SerialPort.DATABITS_8;
    m_Stopbits = SerialPort.STOPBITS_1;
    m_Parity = SerialPort.PARITY_NONE;
    m_Encoding = Modbus.DEFAULT_SERIAL_ENCODING;
    m_ReceiveTimeout = 500; //5 secs
    m_Echo = false;
  }//constructor

  /**
   * Constructs a new SerialParameters instance with
   * given parameters.
   *
   * @param portName       The name of the port.
   * @param baudRate       The baud rate.
   * @param flowControlIn  Type of flow control for receiving.
   * @param flowControlOut Type of flow control for sending.
   * @param databits       The number of data bits.
   * @param stopbits       The number of stop bits.
   * @param parity         The type of parity.
   * @param echo           Flag for setting the RS485 echo mode.
   */
  public SerialParameters(String portName,
                          int baudRate,
                          int flowControlIn,
                          int flowControlOut,
                          int databits,
                          int stopbits,
                          int parity,
                          boolean echo,
                          int timeout) {
    m_PortName = portName;
    m_BaudRate = baudRate;
    m_FlowControlIn = flowControlIn;
    m_FlowControlOut = flowControlOut;
    m_Databits = databits;
    m_Stopbits = stopbits;
    m_Parity = parity;
    m_Echo = echo;
    m_ReceiveTimeout = timeout;
  }//constructor

  /**
   * Constructs a new SerialParameters instance with
   * parameters obtained from a Properties instance.
   *
   * @param props  a Properties instance.
   * @param prefix a prefix for the properties keys if embedded into
   *               other properties.
   */
  public SerialParameters(Properties props, String prefix) {
    if (prefix == null) {
      prefix = "";
    }
    setPortName(props.getProperty(prefix + "portName", ""));
    setBaudRate(props.getProperty(prefix + "baudRate", "" + 9600));
    setFlowControlIn(props.getProperty(prefix + "flowControlIn", "" + SerialPort.FLOWCONTROL_NONE));
    setFlowControlOut(props.getProperty(prefix + "flowControlOut", "" + SerialPort.FLOWCONTROL_NONE));
    setParity(props.getProperty(prefix + "parity", "" + SerialPort.PARITY_NONE));
    setDatabits(props.getProperty(prefix + "databits", "" + SerialPort.DATABITS_8));
    setStopbits(props.getProperty(prefix + "stopbits", "" + SerialPort.STOPBITS_1));
    setEncoding(props.getProperty(prefix + "encoding", Modbus.DEFAULT_SERIAL_ENCODING));
    setEcho("true".equals(props.getProperty(prefix + "echo")));
    setReceiveTimeout(props.getProperty(prefix + "timeout", "" + 500));
  }//constructor


  /**
   * Sets the port name.
   *
   * @param name the new port name.
   */
  public void setPortName(String name) {
    m_PortName = name;
  }//setPortName

  /**
   * Returns the port name.
   *
   * @return the port name.
   */
  public String getPortName() {
    return m_PortName;
  }//getPortName

  /**
   * Sets the baud rate.
   *
   * @param rate the new baud rate.
   */
  public void setBaudRate(int rate) {
    m_BaudRate = rate;
  }//setBaudRate

  /**
   * Sets the baud rate.
   *
   * @param rate the new baud rate.
   */
  public void setBaudRate(String rate) {
    m_BaudRate = Integer.parseInt(rate);
  }//setBaudRate

  /**
   * Return the baud rate as int.
   *
   * @return the baud rate as int.
   */
  public int getBaudRate() {
    return m_BaudRate;
  }//getBaudRate

  /**
   * Returns the baud rate as a String.
   *
   * @return the baud rate as String.
   */
  public String getBaudRateString() {
    return Integer.toString(m_BaudRate);
  }//getBaudRateString

  /**
   * Sets the type of flow control for the input
   * as given by the passed in int.
   *
   * @param flowcontrol the new flow control type.
   */
  public void setFlowControlIn(int flowcontrol) {
    m_FlowControlIn = flowcontrol;
  }//setFlowControl

  /**
   * Sets the type of flow control for the input
   * as given by the passed in String.
   *
   * @param flowcontrol the flow control for reading type.
   */
  public void setFlowControlIn(String flowcontrol) {
    m_FlowControlIn = stringToFlow(flowcontrol);
  }//setFlowControlIn

  /**
   * Returns the input flow control type as int.
   *
   * @return the input flow control type as int.
   */
  public int getFlowControlIn() {
    return m_FlowControlIn;
  }//getFlowControlIn

  /**
   * Returns the input flow control type as String.
   *
   * @return the input flow control type as String.
   */
  public String getFlowControlInString() {
    return flowToString(m_FlowControlIn);
  }//getFlowControlIn

  /**
   * Sets the output flow control type as given
   * by the passed in int.
   *
   * @param flowControlOut new output flow control type as int.
   */
  public void setFlowControlOut(int flowControlOut) {
    m_FlowControlOut = flowControlOut;
  }//setFlowControlOut

  /**
   * Sets the output flow control type as given
   * by the passed in String.
   *
   * @param flowControlOut the new output flow control type as String.
   */
  public void setFlowControlOut(String flowControlOut) {
    m_FlowControlOut = stringToFlow(flowControlOut);
  }//setFlowControlOut

  /**
   * Returns the output flow control type as int.
   *
   * @return the output flow control type as int.
   */
  public int getFlowControlOut() {
    return m_FlowControlOut;
  }//getFlowControlOut

  /**
   * Returns the output flow control type as String.
   *
   * @return the output flow control type as String.
   */
  public String getFlowControlOutString() {
    return flowToString(m_FlowControlOut);
  }//getFlowControlOutString

  /**
   * Sets the number of data bits.
   *
   * @param databits the new number of data bits.
   */
  public void setDatabits(int databits) {
    m_Databits = databits;
  }//setDatabits

  /**
   * Sets the number of data bits from the given String.
   *
   * @param databits the new number of data bits as String.
   */
  public void setDatabits(String databits) {
    if (databits.equals("5")) {
      m_Databits = SerialPort.DATABITS_5;
    }
    if (databits.equals("6")) {
      m_Databits = SerialPort.DATABITS_6;
    }
    if (databits.equals("7")) {
      m_Databits = SerialPort.DATABITS_7;
    }
    if (databits.equals("8")) {
      m_Databits = SerialPort.DATABITS_8;
    }
  }//setDatabits

  /**
   * Returns the number of data bits as int.
   *
   * @return the number of data bits as int.
   */
  public int getDatabits() {
    return m_Databits;
  }//getDatabits

  /**
   * Returns the number of data bits as String.
   *
   * @return the number of data bits as String.
   */
  public String getDatabitsString() {
    switch (m_Databits) {
      case SerialPort.DATABITS_5:
        return "5";
      case SerialPort.DATABITS_6:
        return "6";
      case SerialPort.DATABITS_7:
        return "7";
      case SerialPort.DATABITS_8:
        return "8";
      default:
        return "8";
    }
  }//getDataBits

  /**
   * Sets the number of stop bits.
   *
   * @param stopbits the new number of stop bits setting.
   */
  public void setStopbits(int stopbits) {
    m_Stopbits = stopbits;
  }//setStopbits

  /**
   * Sets the number of stop bits from the given String.
   *
   * @param stopbits the number of stop bits as String.
   */
  public void setStopbits(String stopbits) {
    if (stopbits.equals("1")) {
      m_Stopbits = SerialPort.STOPBITS_1;
    }
    if (stopbits.equals("1.5")) {
      m_Stopbits = SerialPort.STOPBITS_1_5;
    }
    if (stopbits.equals("2")) {
      m_Stopbits = SerialPort.STOPBITS_2;
    }
  }//setStopbits

  /**
   * Returns the number of stop bits as int.
   *
   * @return the number of stop bits as int.
   */
  public int getStopbits() {
    return m_Stopbits;
  }//getStopbits

  /**
   * Returns the number of stop bits as String.
   *
   * @return the number of stop bits as String.
   */
  public String getStopbitsString() {
    switch (m_Stopbits) {
      case SerialPort.STOPBITS_1:
        return "1";
      case SerialPort.STOPBITS_1_5:
        return "1.5";
      case SerialPort.STOPBITS_2:
        return "2";
      default:
        return "1";
    }
  }//getStopbitsString

  /**
   * Sets the parity schema.
   *
   * @param parity the new parity schema as int.
   */
  public void setParity(int parity) {
    m_Parity = parity;
  }//setParity

  /**
   * Sets the parity schema from the given
   * String.
   *
   * @param parity the new parity schema as String.
   */
  public void setParity(String parity) {
    parity = parity.toLowerCase();
    if (parity.equals("none")) {
      m_Parity = SerialPort.PARITY_NONE;
    }
    if (parity.equals("even")) {
      m_Parity = SerialPort.PARITY_EVEN;
    }
    if (parity.equals("odd")) {
      m_Parity = SerialPort.PARITY_ODD;
    }
  }//setParity

  /**
   * Returns the parity schema as int.
   *
   * @return the parity schema as int.
   */
  public int getParity() {
    return m_Parity;
  }//getParity

  /**
   * Returns the parity schema as String.
   *
   * @return the parity schema as String.
   */
  public String getParityString() {
    switch (m_Parity) {
      case SerialPort.PARITY_NONE:
        return "none";
      case SerialPort.PARITY_EVEN:
        return "even";
      case SerialPort.PARITY_ODD:
        return "odd";
      default:
        return "none";
    }
  }//getParityString

  /**
   * Sets the encoding to be used.
   *
   * @param enc the encoding as string.
   * @see Modbus#SERIAL_ENCODING_ASCII
   * @see Modbus#SERIAL_ENCODING_RTU
   * @see Modbus#SERIAL_ENCODING_BIN
   */
  public void setEncoding(String enc) {
    enc = enc.toLowerCase();
    if (enc.equals(Modbus.SERIAL_ENCODING_ASCII) ||
        enc.equals(Modbus.SERIAL_ENCODING_RTU) ||
        enc.equals(Modbus.SERIAL_ENCODING_BIN)
    ) {
      m_Encoding = enc;
    } else {
      m_Encoding = Modbus.DEFAULT_SERIAL_ENCODING;
    }
  }//setEncoding

  /**
   * Returns the encoding to be used.
   *
   * @return the encoding as string.
   * @see Modbus#SERIAL_ENCODING_ASCII
   * @see Modbus#SERIAL_ENCODING_RTU
   * @see Modbus#SERIAL_ENCODING_BIN
   */
  public String getEncoding() {
    return m_Encoding;
  }//getEncoding

  /**
   * Get the Echo value.
   *
   * @return the Echo value.
   */
  public boolean isEcho() {
    return m_Echo;
  }//getEcho

  /**
   * Set the Echo value.
   *
   * @param newEcho The new Echo value.
   */
  public void setEcho(boolean newEcho) {
    m_Echo = newEcho;
  }//setEcho

  /**
   * Returns the receive timeout for serial communication.
   *
   * @return the timeout in milliseconds.
   */
  public int getReceiveTimeout() {
    return m_ReceiveTimeout;
  }//getReceiveTimeout

  /**
   * Sets the receive timeout for serial communication.
   *
   * @param receiveTimeout the receiveTimeout in milliseconds.
   */
  public void setReceiveTimeout(int receiveTimeout) {
    m_ReceiveTimeout = receiveTimeout;
  }//setReceiveTimeout

  /**
   * Sets the receive timeout for the serial communication
   * parsing the given String using Integer.parseInt(String).
   *
   * @param str the timeout as String.
   */
  public void setReceiveTimeout(String str) {
   m_ReceiveTimeout = Integer.parseInt(str);
  }//setReceiveTimeout

  /**
   * Converts a String describing a flow control type to the
   * int which is defined in SerialPort.
   *
   * @param flowcontrol the String describing the flow control type.
   * @return the int describing the flow control type.
   */
  private int stringToFlow(String flowcontrol) {
    flowcontrol = flowcontrol.toLowerCase();
    if (flowcontrol.equals("none")) {
      return SerialPort.FLOWCONTROL_NONE;
    }
    if (flowcontrol.equals("xon/xoff out")) {
      return SerialPort.FLOWCONTROL_XONXOFF_OUT;
    }
    if (flowcontrol.equals("xon/xoff in")) {
      return SerialPort.FLOWCONTROL_XONXOFF_IN;
    }
    if (flowcontrol.equals("rts/cts in")) {
      return SerialPort.FLOWCONTROL_RTSCTS_IN;
    }
    if (flowcontrol.equals("rts/cts out")) {
      return SerialPort.FLOWCONTROL_RTSCTS_OUT;
    }
    return SerialPort.FLOWCONTROL_NONE;
  }//stringToFlow

  /**
   * Converts an int describing a flow control type to a
   * String describing a flow control type.
   *
   * @param flowcontrol the int describing the
   *                    flow control type.
   * @return the String describing the flow control type.
   */
  private String flowToString(int flowcontrol) {
    switch (flowcontrol) {
      case SerialPort.FLOWCONTROL_NONE:
        return "none";
      case SerialPort.FLOWCONTROL_XONXOFF_OUT:
        return "xon/xoff out";
      case SerialPort.FLOWCONTROL_XONXOFF_IN:
        return "xon/xoff in";
      case SerialPort.FLOWCONTROL_RTSCTS_IN:
        return "rts/cts in";
      case SerialPort.FLOWCONTROL_RTSCTS_OUT:
        return "rts/cts out";
      default:
        return "none";
    }
  }//flowToString

  /**
   * Populates the settings from an Proper
   * that reads from a properties file or contains a
   * set of properties.
   *
   * @param in the InputStream to read from.
   *
   private void loadFrom(InputStream in) throws IOException {
   Properties props = new Properties();
   props.load(in);
   setPortName(props.getProperty("portName"));
   setBaudRate(props.getProperty("baudRate"));
   setFlowControlIn(props.getProperty("flowControlIn"));
   setFlowControlOut(props.getProperty("flowControlOut"));
   setParity(props.getProperty("parity"));
   setDatabits(props.getProperty("databits"));
   setStopbits(props.getProperty("stopbits"));
   setEncoding(props.getProperty("encoding"));
   setEcho(new Boolean(props.getProperty("echo")).booleanValue());
   }//loadFrom

   */

}//class SerialParameters