//License /*** * Java Modbus Library (jamod) * Copyright (c) 2002-2004, jamod development team * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are * met: * * Redistributions of source code must retain the above copyright notice, * this list of conditions and the following disclaimer. * * Redistributions in binary form must reproduce the above copyright notice, * this list of conditions and the following disclaimer in the documentation * and/or other materials provided with the distribution. * * Neither the name of the author nor the names of its contributors * may be used to endorse or promote products derived from this software * without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDER AND CONTRIBUTORS ``AS * IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE * POSSIBILITY OF SUCH DAMAGE. ***/ 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 1.2rc2 (14/04/2014) */ 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 <tt>SerialParameters</tt> 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 <tt>SerialParameters<tt> 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 <tt>SerialParameters</tt> instance with * parameters obtained from a <tt>Properties</tt> instance. * * @param props a <tt>Properties</tt> 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 <tt>int</tt>. * * @return the baud rate as <tt>int</tt>. */ public int getBaudRate() { return m_BaudRate; }//getBaudRate /** * Returns the baud rate as a <tt>String</tt>. * * @return the baud rate as <tt>String</tt>. */ public String getBaudRateString() { return Integer.toString(m_BaudRate); }//getBaudRateString /** * Sets the type of flow control for the input * as given by the passed in <tt>int</tt>. * * @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 <tt>String</tt>. * * @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 <tt>int</tt>. * * @return the input flow control type as <tt>int</tt>. */ public int getFlowControlIn() { return m_FlowControlIn; }//getFlowControlIn /** * Returns the input flow control type as <tt>String</tt>. * * @return the input flow control type as <tt>String</tt>. */ public String getFlowControlInString() { return flowToString(m_FlowControlIn); }//getFlowControlIn /** * Sets the output flow control type as given * by the passed in <tt>int</tt>. * * @param flowControlOut new output flow control type as <tt>int</tt>. */ public void setFlowControlOut(int flowControlOut) { m_FlowControlOut = flowControlOut; }//setFlowControlOut /** * Sets the output flow control type as given * by the passed in <tt>String</tt>. * * @param flowControlOut the new output flow control type as <tt>String</tt>. */ public void setFlowControlOut(String flowControlOut) { m_FlowControlOut = stringToFlow(flowControlOut); }//setFlowControlOut /** * Returns the output flow control type as <tt>int</tt>. * * @return the output flow control type as <tt>int</tt>. */ public int getFlowControlOut() { return m_FlowControlOut; }//getFlowControlOut /** * Returns the output flow control type as <tt>String</tt>. * * @return the output flow control type as <tt>String</tt>. */ 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 <tt>String</tt>. * * @param databits the new number of data bits as <tt>String</tt>. */ 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 <tt>int</tt>. * * @return the number of data bits as <tt>int</tt>. */ public int getDatabits() { return m_Databits; }//getDatabits /** * Returns the number of data bits as <tt>String</tt>. * * @return the number of data bits as <tt>String</tt>. */ 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 <tt>String</tt>. * * @param stopbits the number of stop bits as <tt>String</tt>. */ 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 <tt>int</tt>. * * @return the number of stop bits as <tt>int</tt>. */ public int getStopbits() { return m_Stopbits; }//getStopbits /** * Returns the number of stop bits as <tt>String</tt>. * * @return the number of stop bits as <tt>String</tt>. */ 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 <tt>int</tt>. */ public void setParity(int parity) { m_Parity = parity; }//setParity /** * Sets the parity schema from the given * <tt>String</tt>. * * @param parity the new parity schema as <tt>String</tt>. */ 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 <tt>int</tt>. * * @return the parity schema as <tt>int</tt>. */ public int getParity() { return m_Parity; }//getParity /** * Returns the parity schema as <tt>String</tt>. * * @return the parity schema as <tt>String</tt>. */ 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 <tt>Integer.parseInt(String)</tt>. * * @param str the timeout as String. */ public void setReceiveTimeout(String str) { m_ReceiveTimeout = Integer.parseInt(str); }//setReceiveTimeout /** * Converts a <tt>String</tt> describing a flow control type to the * <tt>int</tt> which is defined in SerialPort. * * @param flowcontrol the <tt>String</tt> describing the flow control type. * @return the <tt>int</tt> 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 <tt>int</tt> describing a flow control type to a * String describing a flow control type. * * @param flowcontrol the <tt>int</tt> describing the * flow control type. * @return the <tt>String</tt> 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 <tt>Proper</tt> * that reads from a properties file or contains a * set of properties. * * @param in the <tt>InputStream</tt> 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