Release Notes

Filter
SDI - 2026.02.1098
February 5, 2026

Visual Studio Integration

Synergy .NET now supports params parameters on selected collection types--e.g., Span<T> (cf. https://learn.microsoft.com/en-us/dotnet/csharp/whats-new/csharp-13#params-collections)--in addition to arrays. This works like params T[], but instead of collecting arguments into an array, the compiler collects them directly into the specified collection type.

public class Totals
    public static method Total, int

        params values, Span<int>
    proc
        data sum, int, 0
        foreach data v in values
            sum += v
        endforeach
        mreturn sum
    endmethod
endclass

main
proc
    Console.WriteLine(Totals.Total(1, 2, 3))   ;6

end

We added support in Synergy .NET for the OverloadResolutionPriority attribute, which allows you to influence method overload resolution. When multiple overloaded methods are applicable to a method call, the overload with the highest priority value is selected. (The default priority is 0, and higher values indicate higher priority.) This attribute can be helpful when introducing a newer overload (e.g., a more performant implementation) and you want future builds to prefer it without requiring changes to existing calls. For example, in the code below, both overloads of PrintValue are applicable for the call Example.PrintValue(5). Because the short overload has a higher priority, it is selected:

public class Example

    public static method PrintValue, void
       value, int

    proc
        Console.WriteLine("int overload")
    endmethod

    {OverloadResolutionPriority(1)}

    public static method PrintValue, void
        value, short
    proc
        Console.WriteLine("short overload")
    endmethod

endclass
main

proc
    Example.PrintValue(5)
end


Synergy .NET now supports invoking user-defined compound assignment operators (e.g., +=, -=, *=, /=) implemented in C#, producing the same results as equivalent C# code. For example, given a C# class that defines a compound assignment operator:

class class1
{
    public int fld1;

    public void operator +=(int val)
    {
        fld1 += val;
    }
}

A Synergy .NET program can now use it:

main
    data cvar = new class1()
    cvar += 3
endmain

The Synergy .NET compiler no longer reports an invalid E_PROTOMISMC error when a static class is validated against its prototype.
The Reference Manager dialog for traditional Synergy projects had a known issue in our initial Visual Studio 2026 support. Adding and removing project, file, and Synergy-specific references via the Reference Manager dialog should now function as expected.
We improved implicit typing logic for generic method calls for methods with default or optional parameters. Previously, such calls prevented the Synergy .NET compiler from performing implicit typing for type arguments when one or more default or optional parameters were omitted.
Using Find All References in a solution with script projects, multiple mainline projects, or projects with no source files no longer causes IntelliSense failures 30 minutes after the operation was invoked.
Calling a ^val function in a compound conditional statement--e.g., "if (%my_hatval_function .and. myvar) then..."--no longer causes an ilverify error.
Synergy .NET mainline projects now correctly publish their associated PDB files when appropriate. This should significantly improve the debugging experience for published projects on all platforms.
SDI - 2025.12.2909
December 3, 2025

Visual Studio Integration

The Repository page of project properties has been updated for improved usability and to support automatic generation of schema files when exiting the Repository program.
  • Options on the Repository  page have been reorganized and reworded for clarity and ease of use. Settings are now easier to understand and follow, making it simpler to configure and manage Repository projects efficiently.
  • The Repository page now includes options for automatically generating repository schema files when exiting the Repository program. When the new option "Automatically generate schemas on exiting Repository UI" is selected, the following options are available:
    • "Generate a single schema file" creates one schema file for the entire repository project.
    • "Generate separate schema files" results in a separate schema file for each repository element, providing greater flexibility in the management of schema files and repository elements.
SDI now supports SDK projects, which can be built on both Windows and Linux. These projects represent a major overhaul of how build tools are packaged for Synergy projects, aligning them with modern .NET SDK practices. SDK projects provide tighter control over toolset versions, are smaller and more portable, and enable cross-platform builds through self-contained tooling.

SDI now includes SDK project templates for several Synergy .NET and traditional Synergy project types:

Class Library SDK (.NET)
Console App SDK (.NET)
Executable Library SDK (ELB)
Multiple Mainline SDK (.NET)
Multiple Mainline SDK (DBR)
Object Library SDK (OLB)
Synergy/DE Repository SDK
Traditional Application SDK (DBR)
Unit Test SDK (Traditional)

To support these templates, we’ve also published the following NuGet packages:

Synergy.Net
Synergy.Repository
Synergy.Traditional
Synergy.Traditional.UnitTest
Background compile operations now include safeguards to prevent pop-ups for certain internal errors.
We resolved an issue where projects using circular proto-only references would produce false duplicate symbol errors during builds in some cases. The build process now correctly handles these scenarios.
The Synergy .NET compiler now reports a level 3 warning ("%DBL-W-URESULT, Precedence of operator <operator> may cause unexpected results at runtime") when an assignment operator (+=,-=,*=,/=,|=,&=) is used in combination with a Boolean comparison that could produce unexpected results. Because assignment operators have the lowest precedence, such expressions may not evaluate as expected. To resolve the warning, add parentheses around the expression to ensure the intended behavior.
The E_TYPPARM error message now includes information on the argument type and parameter type: "Cannot pass type argumentType to type parameterType." For example:

%DBL-E-TYPPARM, Type mismatch for parameter 1 in routine sub1. Cannot pass type d to type a.
The Synergy .NET compiler now reports an E_ACCESS error when a delegate call is made to a delegate that isn’t visible in the context.
We updated the Synergy .NET compiler so that a local variable declared in a FOREACH loop will no longer inadvertently set some other local variable to null when compiled in debug mode. Previously, this could occur and could cause unexpected results at runtime.
The Synergy Method Definition Utility (MDU), Synergy Composer, and the x86 and x64 command prompts launched from the Tools menu in Visual Studio are now configured with the appropriate repository project reference information. In the case of MDU, this prevents silent failures during method exports when the repository is not configured.
We resolved an issue which caused build error reporting to display all errors as being at the same location.
The Synergy .NET compiler no longer incorrectly reports a PRNRQD error when a method name is used as the initial value for a class field whose type is a delegate.
The Synergy .NET compiler now reports an E_BADSTATIC error when the initial value of a static class field references an instance.
With Synergy .NET, you can now use XSUBR to call a routine in another assembly using a literal string name. If the routine is found at compile time, the compiler validates its arguments and generates a direct call to the routine. Otherwise, the call is deferred to runtime. Additionally, literal support has been extended to allow the assembly name to be specified before the routine name, separated by a colon (e.g., "myassembly:mysubroutine").
Renaming a multiple-mainline file in Solution Explorer no longer causes issues, such as constant attempts to load the project and incorrect entries in IntelliSense dropdowns.
We fixed an issue that caused SDI installations and upgrades to fail on machines with both Visual Studio 2022 and Visual Studio 2026 Insiders, potentially leaving the system in an inconsistent state.
We fixed an issue in multiple-mainline projects where adding a file using Add > Reference Existing Item for an item in a location outside the project directory caused an exception (“Object reference not set to an instance of an object”) when the file was selected in Solution Explorer. This now works correctly, and IntelliSense functions as expected for the newly added file.
If a local variable with the same name as a reserved keyword (e.g., "store") is used in a statement (e.g., MRETURN), an unexpected E_INVSTMT error is no longer reported.
We resolved an issue with multiple mainline projects where selecting newly added or previously existing files in Solution Explorer caused errors and prevented IntelliSense from loading properly.
We added better safeguards against invalid SDI package states during shutdown, which can cause null reference exceptions to be displayed.
We fixed a Synergy .NET compiler issue that resulted in a NullReferenceException at runtime when a base class constructor invoked a virtual method implemented in a derived class.
SDI - 2025.10.2527
October 7, 2025

Visual Studio Integration

SDI 25.8.227 introduced an issue with referenced projects that has several symptoms, including failing to load or persist reference nodes in the Solution Explorer, as well as build errors related to the CreateManifestResourceNames target. This has been resolved.
We fixed a regression (discovered in SDI version 2025.06.1647) where IntelliSense triggered the closest completion option when a completion character (e.g., a comma) was typed in a context where an identifier was expected. In this situation, the IntelliSense completion list sometimes included entries that were irrelevant.
When used with certain Synergy DBL keywords, Find All References now correctly reports that no results were found instead of showing an empty window. This fix also prevents IntelliSense failures that could occur up to 30 minutes after the Find All References operation.
We fixed a background compilation issue that could cause exceptions and lead to a bad IntelliSense state.
SDI - 2025.08.2277
August 14, 2025

Visual Studio Integration

We added safeguards to prevent Visual Studio from crashing when processing assembly reference nodes.
We fixed an issue where clearing the "Use common properties" checkbox on the Common Properties page of project properties could cause settings to disappear. Previously, if you cleared this checkbox, saved the page, closed it, and then reopened it, settings on this page would disappear, and saving the page in this state would also remove the settings from the Common.props file. This behavior has been corrected. Additionally, the Common Properties page now updates correctly when the Common.props file is modified outside of Visual Studio.
Editor performance while typing in a very large file has been improved to reduce hangs and increase responsiveness in operations such as colorizing tokens and offering completion IntelliSense.
We resolved an issue where using the "Any CPU" platform configuration for traditional Synergy projects caused IntelliSense failures. This included failures with features such as Go To Definition, code highlighting, and member dropdowns, along with a persistent "IntelliSense build in progress" message in the status bar. Additionally, the required .dbp file was not correctly generated in the .intellisense folder. These issues no longer occur when using "Any CPU" platform settings.
We fixed an issue with Synergy .NET that caused a NullReferenceException when FRETURN returned a non-CLS structure from an alpha function.
We fixed an issue that prevented echo commands in pre-build and post-build events from displaying to the Output window.
In Synergy .NET, the maximum number of descriptor literals allowed in a DBL program has been increased from 65,535 to 121,999. To prevent issues with the .NET runtime, a warning (W-NOTSUPT) is now reported when more than 60,000 descriptor literals are used, indicating that debug symbols will be reduced at runtime. If 122,000 or more descriptor literals are used, an error (E-NOTSUPT) will be reported.
We resolved an issue where insert/toggle comment commands (ctrl+k, ctrl+c and ctrl+/) were incorrectly inserting the ! character as the comment character.
We fixed an issue where assigning a scoped decimal structure (e.g., mystructure[]) to an alpha variable caused an InvalidProgramException at runtime.

structure struct1
    nocode3, 9d1
endstructure
main
record
    applycodes, a9, "101010101"
    svar, struct1
proc
    applycodes = svar.nocode3[]    ;No longer causes exception
The Synergy .NET compiler now correctly reports an E_INVTYP error when a type name is used as an instance to an extension method call.
We fixed a runtime exception that could occur in non-debug builds when a program contained a subroutine with a local record and another subroutine with both a non-local record of the same structure and a reference to a field in that record.

System.MissingMethodException: Method not found: 'Void $$_wrap_myrec@sub1.$init(Int32, Int32, Int32)
The ILASM error "unable to find forward reference label" is no longer mistakenly reported when an EXIT statement is in a FINALY block in Synergy .NET code.
We fixed an issue with Synergy .NET where assigning an alpha to a scoped decimal array (e.g., myarray[]) caused an InvalidProgramException at runtime.
We resolved an intermittent issue with the internal access control mechanism for IntelliSense symbol files, which could prevent background compilation from completing.
We fixed an issue that caused an "index out of range" exception when faster.core.dll was referenced by a project.
We fixed issues that prevented IntelliSense Hover and Go To Definition from working correctly in the following cases:
  •  When hovering over structure fields.
  •  When used on statements that use parentheses to specify an array element, such as myarray(dvar) in the following:
myarray    ,13[d1]
dvar       ,d2
.
.
.
myvar = myarray(dvar)
The first time you open Visual Studio after installing or updating SDI, a dialog opens with options that enable you to either participate in or opt out of the Synergy DBL Integration Improvement Program. We fixed an issue that caused this dialog to continue to open even after the opt-in option was selected if this option was selected after updating SDI when the opt-out option had been selected for the previous version of SDI.
Referencing a record with no fields in Synergy .NET code no longer incorrectly results in an INTCMPERR error ("curDataDiv is 0: variable not hoisted").
SDI - 2025.03.1285
March 5, 2025

Visual Studio Integration

We added support for displaying "mismatch" for parameters when hovering over subroutines/functions.
We added the ability for a user to disable the SDI update notification window by setting a registry value named SkipUpdateCheck on HKEY_CURRENT_USER\Software\Synergex\SDI to true.
The obj\proto directory is now platform specific: an obj\proto directory is created for each built platform. Prior to this enhancement, any build, regardless of platform, would overwrite files in this directory, causing compiler directives and D_ADDR to result in changes in symbol behavior, which led to build and IntelliSense failures.
We improved build message handling from the script compiler in SDI.
We fixed an issue where "Other options" specified on the Compile page for traditional Synergy projects were not passed to background compile operations, preventing IntelliSense from reflecting these settings.
A build error previously occurred while building .NET multiple mainline projects on an environment with .NET 9 installed for a missing _ChooseAppHost target. The target dependencies for .NET multiple mainline projects have been updated to include a different target that exists in both .NET 8 and .NET 9.
We improved the build error that is generated for a Synergy project when the "Working directory" field (on the Application page of project properties) specifies an invalid directory.
We fixed a concurrency issue that would intermittently cause a type that was designated as a boxed structure (such as @System.Guid) for a field, property, or parameter from an assembly to be resolved as @System.ValueType, which caused various type mismatch compiler errors.
The "Committed by pressing the space bar" option on the IntelliSense page for Synergy DBL text editor options has been removed because it was conflicting with the "Default IntelliSense completion mode" option in the Visual Studio Advanced text editor options. (It would sometimes prevent this default from being used.) Synergy completion mode behavior is now controlled by the "Switch between automatic and tab-only IntelliSense completion" command (on the Edit > IntelliSense menu), which derives its initial state for every Visual Studio session from the "Default IntelliSense completion mode" setting. This determines whether an item is selected (boxed with a background highlight) or suggested (boxed without a background highlight) by default in completion sessions. When an item is selected, any valid commit character should complete the session with the selected item. When an item is suggested, only tab should complete the session with the suggested item. Any character or key other than those should close the session without completing the selected or suggested item. This behavior may be slightly different than in previous releases but should be more consistent going forward.
The dblnet compiler now emits a code that ensures a static constructor is run when compiling with -netcore, even if no static fields in that class are being set.
We fixed a compatibility issue that was causing a build failure for Script projects on machines with SDE versions lower than 12.3.1.
We updated our NuGet dependencies for SDI to address moderate/high severity vulnerabilities. As a result of these updates, we have increased our minimum supported version of Visual Studio to 17.8. To be able to install newer versions of SDI, you must use Visual Studio versions 17.8 or higher.
When you are offline or if there are service disruptions, the SDI update window will display "N/A" for the version and message, and the window will not display automatically.
Previously in certain scenarios, .NET/.NET Framework multiple mainline projects could incorrectly write background compile input and log files to directories other than the multiple mainline project's intermediate output directory. This has been resolved.
When a Synergy .NET multiple mainline project is built from the command line, the mainline files that are built in the process are now listed in the output.
Go To Definition no longer fails to execute for repository and library includes when they are placed in the global scope.
We fixed an issue that prevented linker errors from causing build failures for traditional Synergy projects.
A warning will now be produced when a referenced project does not exist, making error reporting more user-friendly.
An issue was found where using whitespace in front of a code line prevented the warning "W-NOTSUPT: Continuation character & is not supported after comment" from appearing. This has been fixed so that using a continuation character on the line after a comment will still report the warning regardless of whitespace or indentation on those lines. This change was applied to both traditional Synergy and Synergy .NET.
We resolved an unexpected failure that occurred when building a solution with an ELB project with the "-qvariant" option set on the project's compile property page.
We resolved an issue that sometimes caused projects to be skipped during Visual Studio builds. This issue primarily affected Visual Studio builds of Synergy repository projects, which use the SynergyDE build NuGet package, after a fresh clone of a code repository and prior to running a NuGet restore.
Handling for build error and warning messages has been updated to produce messages for all mainlines in a .NET multiple mainline project instead of just one.
For the Synergy .NET compiler, using the -doc option to produce XML documentation files will no longer generate multiple XML elements that have the same name attribute. This applies to documentation comments (starting with three semicolons on each line) that precede partial classes, partial interfaces, partial structures, and partial methods. For partial methods, the documentation comment on the method's implementation will be used for XML, and the documentation comment on the method's declaration will be ignored. For partial types (classes, interfaces, and structures), any partial type having a particular name (e.g., ExampleClass) will only use the last partial definition with a documentation comment to produce XML. The documentation comment for all other previous partial types with that same name (e.g., ExampleClass) will be ignored. Whenever a comment is ignored, a W-XMLDOC level 4 warning is reported, indicating the method or type associated with that comment. This change supports utilities that read XML documents but can't process duplicate names.
.NET multiple mainline projects now base the output directory for documentation files off of the synproj file location rather than the location of the mainline file.
A decimal descriptor can now be passed to an alpha parameter when -qrelaxed:param is specified.
The .intellisense folder is no longer generated in the same location as the multi-mainline source files. It will now always be generated in the same directory as the multi-mainline .synproj.
We resolved an issue where multi-mainline projects were failing to trigger a minimal analyze after loading or when edits were made to the multi-mainline file.
A FOREACH iteration over a generic previously caused a TYPMISMCH error when the generic was used before it was declared. This has been fixed.
For multiple mainline projects that do not have a StartupObject set, selecting mainline files from Solution Explorer will no longer display the following error message: "Object reference not set to an instance of an object."
The compiler now reports a W_URESULT warning (1046, "Empty alpha literal may cause unexpected results at runtime") for an empty alpha literal within a USING statement, because it will match everything and subsequent USING statements will never be executed. To avoid this warning, we recommend that you examine and potentially remove empty alpha strings from USING statements and test them at runtime. 
When the ^VARIANT, or -qvariant, option is set in the project's compile property page, it will display the number that was input when hovering over the compiler directive in the Visual Studio editor.
We fixed an issue that caused "DBP is already in use" errors during the background compilations used to generate IntelliSense information. These errors prevented the creation of new DBP files, which are necessary for the generation of new symbols.
Compiling a file that contained a global non-CLS structure and whose name included a hyphen character caused an unexpected ILASM error. This has been fixed.
SDI - 2024.10.2239
October 25, 2024

Visual Studio Integration

The Synergy .NET complier now reports an E_ATOS error when a group or record is passed as an argument to a parameter that's a larger structure. Previously, this caused an exception (SynDataException).
We fixed the "Using" snippet so that it now results in valid code.
The Synergy .NET compiler no longer mistakenly reports an INVCALL error on a %MEM_PROC call when a subsequent lambda expression includes a subroutine call of MEM_PROC.
We fixed an issue that caused inconsistent red squiggle behavior for erroneous code in Synergy code files when these files were opened, as code was modified on the same line as erroneous code (which sometimes caused red squiggles to briefly appear), and when modifying code on other lines.
New .NET and .NET Standard class library projects will now have "3 - Don't display warning levels higher than 3" as the default "Set the warning level" setting. ("Set the warning level" is a setting on the Compile page of project properties.) Previously, the default setting for this was "0 - Don't generate any warnings" for these project types.
We updated the Synergy .NET compiler so that it now supports D_ADDR as a default parameter type.
We fixed an issue that caused hover-over IntelliSense for an "i" data type with a set size (e.g., "testvar, [4]i4") to display incorrectly (e.g., as "testvar, [#]i44").
The SDI Update window is no longer displayed in Visual Studio when the latest version of SDI is installed.
Startup Object highlighting now persists when an multiple mainline project is closed and then reopened. Previously, the highlighting would disappear when the project was reopened, though the Startup Object setting was still in force.
The Synergy .NET compiler now reports an E_NOFXD level 3 warning when performing # rounding on an expression that includes implied-decimal (d.) operands.
The default runtime is now 12030100 for dbl, dblnet, and dblink. This is the default version if -qrntcompat is not specified.
With Synergy .NET, when INIT was used on a fixed or pseudo array that had no initial value, it cleared only the first element of the array. This has been fixed so that it now clears the entire array, which matches INIT's behavior with traditional Synergy.
The "Latest" setting for "Target Synergy runtime" (on the Build page of project properties) now selects version 12.5.1, which currently corresponds to the 12.4 feature release. Previously "Latest" targeted 12.3.1.
The Synergy .NET compiler now reports a level 4 E_PASSUR warning when a field, record, or group is passed to a group parameter that is larger. (Without this, accessing a field in the group outside of the size of the passed-in alpha would cause a runtime exception.)
The continuation character is correctly reported as a level 3 warning rather than a NOTSUPT error for -qrntcompat values of 12030100 (12.3.1) and higher.
The Synergy .NET compiler no longer mistakenly reports a level-4 NARROWING warning when assigning an i2 value to a d5.
We fixed an issue that caused Solution Explorer to indicate that it was infinitely loading (it displayed a continuously spinning icon) when a multiple mainline project was expanded in Solution Explorer.
Synergy .NET now supports ^REF parameter types that are value types, including non-descriptor integer types and CLS structures. (Other ^REF types cause E_NOTSUPT errors.) Note that the caller must also encapsulate argument with ^REF and the type must match exactly; otherwise an E_TYPPARM error will be reported.
With traditional Synergy projects, the following settings (set on the Compile page of project properties) were not passed to background compilations used behind the scenes for IntelliSense: 
  • Require prototype usage (-qreqproto), 
  • Define all undefined functions as ^VAL (-X, -qimplicit_functions). 
This issue sometimes caused unexpected red squiggles when editing in Visual Studio while these options were set.
The syn_reportevent() routine is now supported for Synergy .NET when qrntcompat is set to12050100.
We added diagnostic logging to dblnet to report information about asm2dbp. The asm2dbp program is a utility related to the Synergy .NET compiler that takes .NET assemblies and generates DBP files (prototype files). These diagnostics can be enabled by setting the environment variable ASM2DBP_DIAG to 1. To disable the diagnostics, delete the ASM2DBP_DIAG environment variable. Log files are written to the Synergex directory under the LocalAppData path (i.e. navigate to LocalAppData/Synergex where LocalAppData is an environment variable containing a directory path on Windows).
We fixed an issue that sometimes caused a SynergyTasks.DBLinkT error when a multiple mainline project had more than one mainline with the same name but different file extensions (e.g., mymain.dbl and mymain.abc).
SDI - 2024.09.2004
September 5, 2024

Visual Studio Integration

Microsoft is ending support for .NET 6 in November of 2024 (https://dotnet.microsoft.com/en-us/platform/support/policy/dotnet-core), so we have updated Synergy .NET project types to default to .NET 8.
Previously, if a build failed for a mainline in a multiple mainline project due to link errors, the other mainlines were not built. Additionally, builds did not occur in parallel. We updated this behavior so that builds for multiple mainline projects occur as if each mainline were an individual project. Mainlines are now built in parallel, and a mainline build failure due to link errors does not prevent other mainlines from building.
We fixed an issue that prevented the build system from detecting when a script project was out of date due to updates to the referenced repository.
We fixed an issue that prevented the WPF designer from loading for C# projects. The WPF designer no longer loads by default for Synergy WPF projects (because these project types are deprecated), but it does load for Synergy WPF projects when you select the designer view from the XAML view, and it now loads for C# projects when a solution includes both C# and Synergy projects. 
When a routine call is used for an initialization value in the data section, the compiler now provides more detailed and descriptive error text ("Feature not yet implemented: Runtime initialization of <field> not supported"for the E_NOTIMPLE error that it reports on the offending line.
We fixed an issue with the way the SDI Update window retrieved values from the Windows registry. This issue would sometimes result in NullReferenceException and cause Visual Studio to crash
When Visual Studio instances are running under different user contexts (e.g., a non-admin instance and an admin instance), attempts to retrieve the version information no longer result in unexpected exceptions due to permission restrictions. We enhanced SDI to handle such cases gracefully, ensuring reliable version information retrieval regardless of the user context.
We fixed an issue that prevented .NET and .NET Framework multiple mainline projects from building when the project folder name included a space.
We fixed issues with paths and output file handling that prevented the up-to-date check for Synergy .NET and .NET Framework multiple mainline projects from functioning correctly, causing these types of projects to rebuild with every solution build. 
The debugger now steps correctly for a conditional statement for a single line at the end of a begin/end block in Synergy .NET code. Previously, the debugger would incorrectly step to the single line even if the conditional statement evaluated to false. For example, the debugger would step to the Console.Writeline line of the following:

begin
   data ok, boolean, true
   if (!ok)
      Console.WriteLine("Fail")
end
The Go To Definition feature now works for .NET multiple mainline projects. Previously if you used this feature for a function for which another version existed in another project, Go To Definition would not always go to the correct file.
When opening a Synergy .NET solution in Visual Studio, an extra console window with the title asm2dbp.exe briefly appeared and disappeared upon loading the solution. This has been fixed so the extra window is no longer shown. To obtain this bug fix, both SDI and the Synergex.SynergyDE.Build NuGet package must be updated.
We fixed an issue that sometimes caused the Visual Studio UI to hang due to processing colorization changes when editing Synergy files. This was particularly true for large files with many method calls, and it resulted in delays when scrolling through the file or when typing. 
We fixed an issue that caused "invalid output path" build errors when building .NET Multiple Mainline projects.
With a Synergy project that is source controlled via TFS (Team Foundation Server), using the "Get Latest Version (Recursive)" function with the Synergy project would fail with an "Unspecified Error". This has been corrected.
The compiler for Synergy .NET no longer mistakenly reports an E_INVTYPSIZ error on a line that follows a FOREACH AS statement. The workaround for this issue was to eliminate the AS part of the FOREACH.
For Synergy .NET projects, the option to permanently delete a file from the Solution Explorer did not update the .synproj file, causing subsequent attempts to build or rebuild to result in an error stating that "Source file 'filename' does not exist". (This option is invoked by right-clicking the file, selecting Delete from the context menu, and then clicking the Delete button.)
When the get or set method of a property had capitalized letters (e.g. Get/Set or GET/SET), an unexpected E-NOOVR error ("No suitable method/property found to override") would occur when trying to override the property. This has been fixed so that the E-NOOVR error will no longer occur, but a W-CHGCASE (change case) warning will be issued instead. The W-CHGCASE warning indicates that the case of the overriding get or set method was automatically changed to match the base property. To remove this warning, make sure that the case of the base property methods exactly match those of the overriding property methods.
D_NETCORE is now displayed for .IFDEF IntelliSense completion. 
We fixed an issue with IntelliSense for Synergy .NET programs that was causing intermittent delays and missing display data. 
Using a global common in Synergy .NET no longer causes an unexpected ILASM error.
We fixed an issue that caused debugger information to fail to appear when Break All was used immediately after launching the Visual Studio debugger for traditional Synergy code. For instance, the Call Stack window would sometimes be blank, and in some cases the editor would become blank.
PEVerify is now run for all build outputs, including DLL and EXE build outputs, for .NET Framework multiple mainline projects.
SDI - 2024.07.1696
July 3, 2024

Visual Studio Integration

We added templates for the "Multiple Mainline (.NET)" and "Multiple Mainline (.NET Framework)" project types to the Synergex.Projects.Templates NuGet package.
The "dotnet add" and "dotnet add reference" commands are now supported for all project templates in Synergex.Projects.Templates.
An access violation no longer occurs when returning a literal string for a method whose return type is a boxed alpha array.
We improved SDI's problem manager logging by implementing a log rotation mechanism that prevents memory leaks.
New and unexpected %DBL-E-REFTYPMSMC errors no longer occur after updating SDI when there have been no source changes.
We fixed an issue that prevented Start Debugging from working in Visual Studio 2022 version 17.10.x.
We fixed a Synergy .NET compiler issue that resulted in an access violation for an overloaded method with a parameter that was an array of boxed bytes.
We fixed an issue that caused Visual Studio to crash intermittently when editing DBL files in traditional Synergy projects. This issue was caused by a threading-related access violation in DBL’s IntelliSense processing.
We fixed an issue with IntelliSense-related processing for SDI that caused unintended errors and red squiggles to appear intermittently (though these did not affect builds).
We fixed an issue that prevented conditional breakpoints from working with Synergy .NET projects. 
We fixed an issue that caused a "missing method" exception at runtime when using JsonElement's indexer. This fix also prevents NOPRPMTH errors from occurring when property method names differ in case from "get" and "set" (e.g., "Get" or "Set") and the property is from another assembly.
We fixed an issue that sometimes caused an error when a build was stareted in Visual Studio while project property pages were open. 
We fixed a mismatch between the name of the .dbl file that's added to a newly created traditional Synergy unit test project created using the syTradUnitTestProj template (in the Synergex.Projects.Templates NuGet package) and the .dbl file specified in the .synproj file for the project.
We fixed a problem with the SynNETUnitTest project template (in the Synergex.Projects.Templates NuGet package) that caused projects created from this template to have an incorrect import statement.
SDI - 2024.05.1447
May 3, 2024

Visual Studio Integration

SDI now supports Synergy .NET projects with multiple Synergy mainline programs. As part of this support, SDI includes two new project templates, “Multiple Mainline (.NET)” and “Multiple Mainline (.NET Framework)”, that enable you to create .NET 6+ or .NET Framework projects with multiple Synergy mainline programs that share project settings and references. A project created with one of these templates results in an application that is distributed as multiple EXEs. Each mainline source file results in a separate executable that can be run and debugged separately.
We added an experimental option to reduce load times for Synergy projects. To invoke this feature, set the SDI_FAST_MODE environment variable to any value before starting Visual Studio. Note that this functionality may cause project references to load in an incorrect order, which could put a project in an invalid state.
With Synergy .NET, the "Working Directory" setting, which is set on the Application page of project properties, is now stored as a relative path (relative to the solution directory).
We fixed the parser to properly report a lambda syntax error when the return type is incorrectly declared on a lambda.
We fixed an issue that caused unexpected results for arithmetic operations such as subtraction with two i4 variables that had been cast to i8.
Casting an enumeration property to an integer no longer causes an error to occur when the compiled program is checked with PEVerify or ILVerify.
We reinstituted a warning message the displays when prototype files (.dbp files that are used internally for IntelliSense symbols) are locked for I/O for extended periods. 
We fixed an issue that prevented colorization from being refreshed for code in an .IFDEF statement when the .IFDEF condition was modified.
When the final parameter for a routine call is "end", and this is on a separate line that begins with an ampersand (&), IntelliSense no longer mistakenly interprets "end" as the conclusion of a BEGIN-END block. Previously, this was misinterpreted, resulting in incorrect indentation for subsequent lines of code.
We now prevent a NullReferenceException error at runtime when declaring a sized descriptor parameter on an ASYNC method.
We resolved problems with IntelliSense showing unexpected errors/red squiggles on the wrong line when opening a file in the Visual Studio editor.
The compiler for Synergy .NET now reports an IVBAD error if an initial value is provided for a boxed enum or an array of boxed enums.
We fixed an issue that prevented the debugger from breaking on breakpoints that precede a lambda in an ASYNC method.
A FOREACH loop with an implicit element type sometimes caused an internal compiler error if the element type was a user-defined nested class declared after the loop in the same file. FOREACH loops now infer the type properly regardless of where the element class is placed in the file.
The compiler for Synergy .NET now reports an E_NOSPECL error when the braces for an inline lambda expression are missing.
We improved logging that occurs when a catastrophic failure occurs while a background compile is running to generate IntelliSense symbols for a .NET or .NET Framework project. This logging now writes the error text to the background.log file to make it easier to diagnose background compile failures with these platforms.
Synergy .NET Framework projects now support the PackageReferences NuGet package management format. 
We fixed an issue that caused a NOTSUPT error ("due to incorrect size...") when there is a structure is within a record, group, or structure. Additionally, the workaround for this issue (DBLDIR:\bin\dblnet.hcs) is no longer supported.
The Synergy .NET compiler no longer mistakenly reports an E_NTTREF error for a parameter that is a structure from an assemble and that structure is defined in a namespace that has a class with the same name as the namespace.
We fixed an issue that sometimes caused the error "SynergyTasks.DBLinkT task failed unexpectedly" when building a solution.
We fixed an issue that occurred when casting multiple function arguments to a Synergy integer type. Previously, a value cast in the last argument replaced values for the previous arguments in the same statement.
We fixed an issue where the Synergy DBL text editor formatting options did not get applied until the Tools > Options dialog page had been opened.
We fixed an issue that sometimes prevented IntelliSense from loading for Synergy .NET projects.