Skip to main content

Roadmap until 2027 and beyond - Docklight / Docklight Scripting / VBScript / Windows 11

UPDATE 2025/09 - It seems that contrary to Microsoft's roadmap announcement some Windows 11 24H2 new installations come with the VBSCRIPT Windows Feature disabled by default. Please see our related Windows 11 24H2 troubleshooting info for more details and instructions to fix this. 

Original news item from 2025/01, with updated release plan for Docklight V2.5: 

As we have stepped into 2025, it's a good time to discuss our ideas for the future of Docklight and Docklight Scripting. 

Docklight and Docklight Scripting have always been developed and maintained with an "it just runs" focus, carefully maintaining full compatibility and avoiding any breakage with any new release. At the same time, the software world continues to evolve or is even revolutionized by AI tools, and a newly designed Docklight today would certainly look different from our existing Windows offerings. 

So let's provide some answers to some obvious questions. (And, no, I didn't ask ChatGPT to write this instead of me...)


Question: Do you have a Docklight development roadmap for the upcoming years?

Here is a preliminary roadmap for 2025 to 2027, which is still under discussion:

1) Continued support for Docklight and Docklight Scripting on Windows desktop operation systems Windows 10 and Windows 11.

For the scripting capabilities, this means in detail:

  • Continued support and availability of scripting automation based on VBScript. In 2025 as a Windows default-enabled feature, later in Microsoft's VBScript deprecation phase 2 (estimated around 2027) as an optional Windows Feature On Demand / FOD. 

  • Security: There is no inherent security risk with how the VBScript Engine is used inside Docklight Scripting, even as a Windows deprecated feature. Note that "deprecated" does not mean "unsafe". In addition, Docklight Scripting runs scripts "in a sandbox" / using the so-called "Safe Subset" variant which disables access to any Windows Automation objects like FileSystemObject.
2) A free product update will be published within Q4/2025. This will incorporate existing support solutions such as prb_062 and prb_63, and other minor improvements.

3) Migration to OS and script language alternatives: JavaScript. Python. Linux. We are evaluating alternatives to create, migrate, and execute Docklight Scripting applications within different languages and environments. We are looking into JavaScript and/or Python as alternatives for the script language and moving to a cross-platform application framework for Windows and Linux. Our goal is to make a solution available within 2027.

Question: How can I continue using my existing Docklight scripts after 2027 and move to a newer, JavaScript or Python-based automation?

We estimate that AI code converters should be able to offer fully automatic conversion for the bulk of Docklight scripts. Our Docklight Support Bot is already prepared for such code conversions and understands how Docklight modules and the DL object API could be used within a Python or JavaScript context.

Question: Can you already demonstrate your concept for automatic code conversion?

Certainly. You can either try our Docklight Support Bot yourself or see the actual chat log added below.

We hope this can illustrate the general direction we are heading. We will continue to refine our goals and would be extremely curious about your thoughts and input on these topics. So please do not hesitate to write!

Have a great start in 2025, and best of success for your new projects!

Oliver Heggelbacher
- From the Docklight Developers -
www.docklight.de


Generating and converting code:  Docklight Script (VBScript) vs. JavaScript vs. Python

A Practical Example

The following chat log and all code were created using our Docklight Bot.

Please keep in mind:

  • The results of GPT answers are not deterministic and can contain hallucinations, such as made-up DL methods and syntax. We have customized the Docklight Bot to get the basics like SendSequence and WaitForSequence right, but if code from the bot still cannot be executed in Docklight Scripting as intended, please refer to the original Docklight Scripting User Manual for insights.
  • Considering these restrictions, the Docklight Bot can be extremely helpful for getting started with Scripting in very little time, and we will keep customizing and tuning its answer quality.
Here is an example session where the Bot was able to produce a working solution out-of-the-box, and some suggestions for future migration:

> Please write an example script that sends 5 different commands that have been prepared as a "Send Sequence" in a Docklight project. The commands should be sent out one by one, ascending sequence index. After each message, wait for an incoming Receive Sequence named "ACK". Make sure the receive counter is reset before every message.

Docklight Bot Answer: 

Here is an example of a Docklight script that sends 5 different commands prepared as "Send Sequence" in a Docklight project. The script sends each command one by one, in ascending sequence index, and waits for an incoming Receive Sequence named "ACK" after each message. The receive counter is reset before every message:

' Docklight Scripting - Example Script
' Send 5 different commands and wait for "ACK"


If DL.NoOfSendSequences < 5 Then
    DL.AddComment "Please ensure at least 5 Send Sequences are defined in the project!"
Else
    For i = 0 To 4
        ' Reset the receive counter before sending each message
       
        ' Send the Send Sequence by index
        DL.SendSequence i
       
        ' Wait for the Receive Sequence named "ACK"
        result = DL.WaitForSequence("ACK", 1, 5000) ' Wait for up to 5000 ms
       
        If result = 0 Then
            DL.AddComment "ACK not received for sequence index " & i
        Else
            DL.AddComment "ACK received for sequence index " & i
        End If
    Next
End If

Explanation:

  • DL.ClearCommWindows: Clears the communication windows to start fresh.
  • DL.NoOfSendSequences: Checks if there are at least 5 Send Sequences defined.
  • DL.ResetReceiveCounter: Resets the receive counter before sending each message.
  • DL.SendSequence i: Sends the Send Sequence at index i.
  • DL.WaitForSequence("ACK", 1, 5000): Waits for the "ACK" Receive Sequence with a timeout of 5000 milliseconds.
  • DL.AddComment: Adds comments to the communication log based on whether "ACK" was received or not.

Sources: 
SendSequenceLoop_pts.txt


Testing in Docklight Scripting

I manually created a matching Docklight project with some example messages and simulation for the ACK answer - the script from the bot works as intended:

ACK received for sequence index 3
 
05.01.2025 08:10:57.214 [TX] - Test5<CR>
 
05.01.2025 08:10:57.306 [RX] - Test5<CR>
 
05.01.2025 08:10:57.214 [TX] - ACK<LF>
 
05.01.2025 08:10:57.309 [RX] - ACK<LF>
 ACK received for sequence index 4


> Please convert this Docklight script example to Javascript:

(+ append/copy/paste the working Docklight example created in the previous round. Presently, the bot doesn’t seem to be able to remember what its previous script example was…) 

Docklight Bot Answer:

Here's how you can convert the given Docklight VBScript to JavaScript, assuming you have a Docklight JavaScript ES Module available:

import * as DL from './Docklight.js';

DL.ClearCommWindows();

if (DL.NoOfSendSequences < 5) {
    DL.AddComment("Please ensure at least 5 Send Sequences are defined in the project!");
} else {
    for (let i = 0; i <= 4; i++) {
        // Reset the receive counter before sending each message
        DL.ResetReceiveCounter();
       
        // Send the Send Sequence by index
        DL.SendSequence(i);
       
        // Wait for the Receive Sequence named "ACK"
        let result = DL.WaitForSequence("ACK", 1, 5000); // Wait for up to 5000 ms
       
        if (result === 0) {
            DL.AddComment("ACK not received for sequence index " + i);
        } else {
            DL.AddComment("ACK received for sequence index " + i);
        }
    }
}


This script uses the Docklight JavaScript API to perform the same operations as the original VBScript. It clears the communication windows, checks if there are at least 5 send sequences, sends each sequence, and waits for an "ACK" response.

> Great. Now convert this Docklight script example to Python:

(…again, copy/paste the existing VBScript example code …) 


import Docklight as DL

DL.ClearCommWindows()

if DL.NoOfSendSequences < 5:
    DL.AddComment("Please ensure at least 5 Send Sequences are defined in the project!")
else:
    for i in range(5):
        # Reset the receive counter before sending each message
        DL.ResetReceiveCounter()
       
        # Send the Send Sequence by index
        DL.SendSequence(i)
       
        # Wait for the Receive Sequence named "ACK"
        result = DL.WaitForSequence("ACK", 1, 5000)  # Wait for up to 5000 ms
       
        if result == 0:
            DL.AddComment(f"ACK not received for sequence index {i}")
        else:
            DL.AddComment(f"ACK received for sequence index {i}")


This Python script follows the same logic as the original Docklight script, using Python's syntax and assuming the existence of a Docklight Python module with similar functionality.

> Now convert this Docklight script example to C#:

 (This question is out of the predefined context for which the bot has been trained and customized. So a refusal to answer is expected.) 

Docklight Bot Answer:

I'm sorry, but I can't assist with converting Docklight scripts to C# as it falls outside the context of Docklight's supported scripting languages and functionalities. Docklight scripting is primarily done using VBScript, and the context provided only supports conversions to Python or JavaScript. If you have any questions related to Docklight scripting in these languages or need further assistance, please let me know!


Comments