# OpenModSim **Repository Path**: brillywu/OpenModSim ## Basic Information - **Project Name**: OpenModSim - **Description**: No description available - **Primary Language**: Unknown - **License**: MIT - **Default Branch**: main - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2026-04-25 - **Last Updated**: 2026-04-25 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # Open ModSim [![GitHub all releases](https://img.shields.io/github/downloads/sanny32/OpenModSim/total?logo=github&cacheSeconds=3600)](https://github.com/sanny32/OpenModSim/releases) [![GitHub release (latest by date)](https://img.shields.io/github/v/release/sanny32/OpenModSim?logo=github&cacheSeconds=3600)](https://github.com/sanny32/OpenModSim/releases/latest) [![License](https://img.shields.io/github/license/sanny32/OpenModSim)](LICENSE.md) Open ModSim is a free implimentation of modbus slave (server) utility for modbus-tcp and modbus-rtu protocols. image image # Features The following Modbus functions are available: - Discrete Coils/Flags ``` 0x01 - Read Coils 0x02 - Read Discrete Inputs 0x05 - Write Single Coil 0x0F - Write Multiple Coils ``` - Registers ``` 0x03 - Read Holding Registers 0x04 - Read Input Registers 0x06 - Write Single Register 0x10 - Write Multiple Registers 0x16 - Mask Write Register ``` The following simulations are available: - Discrete Coils/Flags ``` Random - simulate flag randomly Toggle - simulate flag on/off periodicaly ``` - Registers ``` Random - simulate register randomly Increment - simulate register from Low Limit to High Limit with a given Step Decrement - simulate register from High Limit to Low Limit with a given Step ``` # Modbus Logging image # Extended Featues - Modbus Message Parser image - Modbus Definitions image - Error Simualtions image # Scripting From version 1.2.0 Open ModSim supports scripting. Qt runtime implements the [ECMAScript Language Specification](http://www.ecma-international.org/publications/standards/Ecma-262.htm) standard, so Javascript is used to write code. image Scripts can be launched in two modes: Once or Periodically. If you run script in Once mode the script will stop after it finishes executing. In Periodically mode, the script will start after a certain period of time until the user stops it or the method is called ```javascript Script.stop(); ``` Here is an example of using the script in the Periodically mode ```javascript /**************************************************************************/ /* /* Example script that store value after 3 seconds /* ***************************************************************************/ /* Set the server address base starts from one (1-based) */ Server.addressBase = AddressBase.Base1; let deviceId = 1; let address1 = 1; let address10 = 10; function reset() { /* Write to a Holding register at address1 zero value */ Server.writeHolding(address1, 0, deviceId); } /* init function */ function init() { reset(); /* Print server error if occured and stop script execution */ Server.onError(deviceId, (error)=> { console.error(error); Script.stop(); }); /* Runs when Hodling register value at address1 was changed */ Server.onChange(deviceId, Register.Holding, address1, (value)=> { if(value === 1) { /* Runs after 3 seconds and increase Holding register value at address10 * Then reset register value at address1 and stop script execution */ Script.setTimeout(function() { Server.writeHolding(address10, Server.readHolding(address10, deviceId) + 1, deviceId); reset(); Script.stop(); }, 3000); } }); } /* Runs once when script started */ Script.onInit(init); ``` # Building Building is available via cmake (with installed Qt version 5.15 and above) or Qt Creator. Supports Microsoft Windows, Linux and macOS. ## Microsoft Windows Building The minimum supported version of Microsoft Windows for building OpenModSim from sources is Windows 10. 1. Install latest [git](https://git-scm.com/downloads/win) version 2. Run Windows PowerShell terminal as an Administrator 3. Clone OpenModSim sources from github repository ```powershell git clone https://github.com/sanny32/OpenModSim.git ``` 4. Go to OpenModSim folder ```powershell cd OpenModSim ``` 5. Allow script execution in PowerShell terminal ```powershell Set-ExecutionPolicy -Scope Process -ExecutionPolicy Bypass ``` 6. Run the build script ```powershell .\build.ps1 ``` If you need to specify Qt framework major version (5 or 6), you can do it in the parameters - `.\build.ps1 -qt5` or `.\build.ps1 -qt6` The build script supports building the application only for 64-bit architecture. ## Linux Building 1. Install [git](https://git-scm.com/downloads/linux) for your Linux distribution 2. Run the following commands from the console: ```bash git clone https://github.com/sanny32/OpenModSim.git ``` ```bash cd OpenModSim ``` ```bash ./build.sh ``` If you need to specify Qt framework major version (5 or 6), you can do it in the parameters - `./build.sh -qt5` or `./build.sh -qt6` ## macOS Building The minimum supported version of macOS for building OpenModSim from sources is macOS 11 (Big Sur). 1. Install [Homebrew](https://brew.sh) if not already installed 2. Install required dependencies: ```bash brew install qt@6 cmake ninja ``` 3. Clone OpenModSim sources from github repository: ```bash git clone https://github.com/sanny32/OpenModSim.git ``` 4. Go to OpenModSim folder: ```bash cd OpenModSim ``` 5. Run the build script: ```bash ./build-macos.sh ``` The build script generates a macOS application bundle (`omodsim.app`). To run the application: ```bash open build-omodsim-Qt_*/omodsim.app ``` # About supported operating systems The following minimum operating system versions are supported for OpenModSim: - **Microsoft Windows 7** - **macOS 11 (Big Sur)** (experimental support) - **Debian Linux 11** - **Ubuntu Linux 22.04** - **Mint Linux 22** - **Zorin OS 18** - **Fedora Linux 41** - **Rocky Linux 9.7** - **OpenSuse Linux 15.6** - **Alt Linux 11** - **Astra Linux 1.7** - **RedOS 8** # Install from [binary distributions](https://github.com/sanny32/OpenModSim/releases/latest) Below are the methods for installing the OpenModSim for different OS ## Microsoft Windows Run the installer: - For 32-bit Windows: `qt5-omodsim_1.12.1_x86.exe` - For 64-bit Windows: `qt5-omodsim_1.12.1_x64.exe` or `qt6-omodsim_1.12.1_x64.exe` ## Debian / Ubuntu / Mint / Zorin / Astra Linux ### Install Install the DEB package from the command line: ```bash sudo apt install ./qt6-omodsim_1.12.1-1_amd64.deb ``` or if you want to use Qt5 libraries: ```bash sudo apt install ./qt5-omodsim_1.12.1-1_amd64.deb ``` ### Remove To remove the DEB package run: ```bash sudo apt remove qt6-omodsim ``` or for Qt5 package: ```bash sudo apt remove qt5-omodsim ``` ## RedHat / Fedora / Rocky / RedOS Linux ### Install Install the RPM package from the command line: ```bash sudo dnf install ./qt6-omodsim-1.12.1-1.x86_64.rpm ``` ### Remove To remove the RPM package run: ```bash sudo dnf remove qt6-omodsim ``` ## Alt Linux ### Install Install the RPM package from the command line as root user: ```bash apt-get install ./qt6-omodsim-1.12.1-1.x86_64.rpm ``` ### Remove To remove the RPM package run as root user: ```bash apt-get remove qt6-omodsim ``` ## SUSE / OpenSUSE Linux ### Install Import qt6-omodsim.rpm.pubkey to rpm repository: ```bash sudo rpm --import qt6-omodsim.rpm.pubkey ``` Install the RPM package using Zypper: ```bash sudo zypper install ./qt6-omodsim-1.12.1-1.x86_64.rpm ``` ### Remove To remove the RPM package run: ```bash sudo zypper remove qt6-omodsim ``` # Code Signing Sponsor Windows binaries for this project are signed thanks to **SignPath Foundation**. * 🔐 **Free code signing service:** [SignPath.io](https://signpath.io) * 📜 **Certificate provider:** [SignPath Foundation](https://signpath.org) # MIT License Copyright 2023-2026 Alexandr Ananev [mail@ananev.org] Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.