Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
The

Image AddedScripts Module

enables the easy creation of server-client programming and parallel execution. Allowing interoperability of .NET (C#, VB) and Python 3, it it the foundation module to hight performance and flexible application. 

The Script Module implements:

  • Tasks: code execute in reaction to events, or time-based.
  • Classes: Library of methods for server and client execution 
  • Expressions: optimized event execution or tags changes, and other trigger conditions. 

Image Removed

(Concept) provides the automation intelligence layer for FrameworX solutions, enabling custom business logic, data processing, and system integration through modern programming languages.

Image Added

In this page

On this Page

:

Table of Contents
maxLevel2
minLevel2
indent10px
exclude

Introduction

Steps
stylenone




Scripts → Tutorial | Concept | How-to Guide | Reference



Key Concepts

  • ScriptTask:
Defines code that executes in reaction to an event (trigger) or periodically at specified intervals.
  • ScriptClass A library of functions and methods that can be used in Script Tasks, Expressions, or from the Code Behind on graphical Displays.
  • ScriptExpression: One line of code in response to an event, when the entire script isn't necessary.Script
  • References:  External DLLs included for a script or display code compilation.
  • Configuration Workflow

    Scripts Module configuration workflow

    Action

    Comments

    Create ScriptClasses

    Create a library of functions to your solution. 

    Create ScriptTasks

    Implement the business logic and data normalization, and data enrichment

    Create ScriptExpressions

    For simple event or time driven actions, use simples Expressions.

    Runtime Execution

    The server computer open a process and multi-threads to execute all tasks, and expressions, according the triggers and time-cycles. 

    A Service is created to allow Client Displays, and other distributed modules, to request server side execution of classes.

    Build-in diagnostic tools, including performance monitoring of each task, enable fine-tuning for reliable performance.

    • Script unit triggered by events or timers for automated execution
    • ScriptClass: Reusable C#/VB.NET/Python class library used by scripts and displays
    • ScriptExpression: Single-line expression for lightweight event-driven actions
    • ScriptReference: External .NET assemblies referenced by scripts and displays

    What It Does

    The Scripts Module enables server-client programming and parallel execution through:

    • Event-Driven Automation - Execute code in response to tag changes, alarms, or system events
    • Time-Based Processing - Run tasks on schedules, intervals, or specific times
    • Reusable Libraries - Create method collections for consistent calculations across the solution
    • Expression Evaluation - Perform simple calculations and updates without full task overhead
    • External Integration - Import third-party .NET assemblies and Python packages
    • Multi-Threaded Execution - Run tasks in parallel for maximum performance

    Configuration Workflow

    StepActionDescription
    Create ScriptClassesBuild function librariesDefine reusable methods for your solution
    Create ScriptTasksImplement business logicAdd data processing and automation code
    Create ScriptExpressionsAdd simple actionsSingle-line responses to events
    Add ScriptReferencesInclude external librariesImport DLLs for extended functionality

    Runtime Behavior

    Execution Environment

    The server creates dedicated processes with multi-threading to execute tasks and expressions based on configured triggers. Each process runs in isolated application domains for security and performance.

    Client-Server Architecture

    Scripts execute primarily server-side for consistency across all clients. Client-side execution available for WPF displays when web compatibility not required.

    Performance Monitoring

    Built-in diagnostics track execution time, CPU usage, and error states for each task, enabling optimization and troubleshooting.


    Feature Highlights

    • Multi-Language Support - C#, VB.NET, and Python 3 in a single solution
    • Integrated Code Editor - IntelliSense, debugging, breakpoints, and step-through execution
    • Server and Client Domains - Scripts execute globally (server) or locally (client)
    • Flexible Triggers - Date, time, condition, tag change, or interval-based execution
    • Native Object Access - Direct IntelliSense access to tags, datasets, alarms as .NET objects
    • Python Integration - Configure any Python interpreter version per project
    • Code Translation - Convert between C# and VB.NET automatically
    • Exception Protection - Automatic error handling prevents script failures from affecting system
    • Multi-Threaded Processing - Parallel task execution with thread pool management

    In this section...

    Page Tree
    root@parent
    spaces93DRAF

    Features Highlights

    Built-in Code Editor

    Our platform features an integrated script editor designed for developers to craft custom functionality for the application. This editor offers a robust set of tools to aid in testing and evaluating scripts. Debugging capabilities include setting breakpoints, stepping into and over code, executing line by line, and monitoring object values as they change with each step. Our code editor supports multiple languages such as C#, VB.NET, JavaScript, and Python, as well as XML and JSON documents.

    Server and Client Domains

    With our platform’s script editor, you have the flexibility to create scripts that execute either on the server for global accessibility or on the client side for local execution.

    Tasks, Classes and Expressions

    Module Highlights

    • Built-in Code Editor: Our code editor supports C#, VB.NET, JavaScript, and Python languages.

    • Server and Client Domains: Create scripts that execute on the server for global reach or on the client side for local reach.

    • Events and Scheduling: Tasks and expressions can be triggered by date, time, condition, calendar, tag change, or interval. Execution is distributed among processes, each running in its own application domain, isolated from the real-time database, ensuring maximum system security and performance.

    • Object Orientation and Solution Object: All solution objects, including tags, datasets, alarms, devices, and communication statuses, are immediately accessible via IntelliSense as native .NET objects. No temporary tags or function calls are required. With a single command, move data from tags to .NET objects and external data tables.

    • Configure Your Python Interpreter: The Scripts Module delivers exceptional scripting capabilities across various programming languages with seamless integration of Python. You can configure any version of the Python interpreter for each project.

    You have the option to create tasks, .NET classes, and function libraries. Sometimes, it's more efficient or preferable to create one-line expressions instead of full methods. For this purpose, our platform offers an expression editor that grants access to all .NET operands and classes.

    C#, VB.NET, Python and Javascript

    Our platform supports industry-standard languages like C#, Python, JavaScript, and VB.NET, so engineers no longer have to struggle with old proprietary, single-threaded, or interpreted scripting editors. You can also translate your code between C# and VB.NET anytime.  

    Events and Scheduling 

    You can trigger tasks and expressions to execute based on various factors like date, time, conditions, calendar events, tag changes, or intervals. The execution is distributed among processes, with each running in its own application domain, isolated from the real-time database. This ensures maximum system security and performance.

    Object Orientation, Project Elements

    You can access all project elements such as Tags, Datasets, Alarms, and devices instantly through IntelliSense, as they are native .NET objects. There's no need for temporary tags or function calls. With just one command, you can seamlessly transfer data from Tags to .NET objects and external Data-tables.

    Configure your Python Interpreter

    The Script module seamlessly integrates Python language and applications, providing exceptional scripting capabilities across various programming languages. You also have the flexibility to configure any version of the Python interpreter for each project.

    The Scripts Module allows:

  • Multi-Threaded Task Execution
  • Event-Driven Actions 
  • Library Creation for Methods and Classes
  • Intermixing C#, VB.NET and Python classes.
  • Integration with Third-Party Libraries.