- CS-Script tools are no longer distributed with the extension but deployed and managed independently.
- Added the flow for auutomatically detecting the absence of CS-Script integration and invoking
CS-Script: Integrate...
command. - Added
CS-Script: Integrate with CS-Script tools
command to detect and integrate external CS-Script tools. - Removed all VB use-cases.
- Added option to reset script busy status from the warning prompt.
- #39: Run in Terminal Button doesn't work
- Updated CS-Script (v4.8.16) engine and CS-Syntaxer (v3.1.4)
- Updated CS-Script (v4.6.2) engine and CS-Syntaxer (v3.1.1)
- Added command
CS-Script: Reset busy status
. It's useful for cases when the script execution hangs for whatever reason. - Issue #33: Does not work with non-ascii characters in file or folder names.
- Fixed copying .vscode folder on
cs-script.load_project
command when external CS-SCript deployment is used. - Fixed problem with JS object not being properly cast to TS
Settings
type instance (utils.ts) - Added unconditional exception handling for syntaxer communication failures (syntaxer.ts)
- Updated CS-Script engine and Syntaxer to target .NET 6
- Removed all obsolete (e.g. Mono) settings
- Added the following settings to allow re-targeting the extension to the external (not embedded) engine (
cscs.dll
) and syntax service/provider (syntaxer.dll
)cs-script.engine.cscs_path
cs-script.engine.syntaxer_path
cs-script.engine.syntaxer_port
- Created wiki to help setting up the environment for the CS-Script CLI integration with the major IDEs like VS Code: CLI Environment Specicfication
- Updated CS-Script engine and Syntaxer
- Addressed GitHub flagged vulnerability concerns
- Extra arguments to be always passed to the script engine (e.g.
-cd
for treating script as a dll source file). It allows addressing inconvenience of "Issue #26: Check syntax in scripts lacking Main method"
- Migrated on CS-Script.Core v1.4.5 targeting .NET 5
This release delivers hosting script execution under .NET Core. Meaning that raw VSCode deployment with the extension extension "ms-dotnettools.csharp" is enough to edit, run and debug C# script. Mono and Mono extension are no longer required. Mono support is still available via settings but it will be eventually phased out.
- Migrated on .NET Core
- Hosting on Mono is still supported. If required it needs to be enabled via settings specific for the type of the activity:
- cs-script.engine_run.dotnet
- cs-script.engine_debug.dotnet
- cs-script.engine_project.dotnet
- Fixed #21: Removed unnecessary check for presence of Mono
- Fixed #22: folder
runtimes
(of the syntaxer) is added to the package - Fixed
Load Project
use-case
- Issue #20: Extension Stopped Working after "C# for Visual Studio" (dependency) extension update
- Issue #19: How to Run CSScript in VSCode using latest Extension.
Fixed problem with
process = exec(command);
accidentally modifying global variableprocess
, which was probably introduced in the latest VSCode.
- Issue #15: CS-Script for VS Code Portable.
- Fixed problem with the "Unable to open" error at startup when
open_file_at_startup
is set to empty string. - Added work around for failure of Roslyn- based
ICodeCompiler
to run on OSX. Implemented by settinguseAlternativeCompiler:none
and effectively downgrading C# syntax support to version 6. - Fixed problem with
Settings
not being saved in case of the instance being load from the JSON file.
- Added support for debugging classless scripts directly (without decorated source file).
- Added support for freestyle classless scripts without any entry point defined:
//css_ac freestyle
using System;
using System.IO;
foreach (var file in Directory.GetFiles(@".\"))
Console.WriteLine(file);
- Fixed problem with the injected
//css_syntaxer
directives not being cleared after CS-Script document formatting.
- Added option to
cs-script.enable_code_formatting
enable/disable document formatting provider. - Added handling the case of MONO being installed but not added to PATH. Note, this only helps for running the scripts but not for debugging, which is handled entirely by VSCode.
- Added handling/processing unsaved changes in the source files without creating a
<file>.$temp$.cs
file in the script directory.
- Added "!inDebugMode" condition for "cs-script.debug" command.
- Issue #10: CSSConfig: searchDirs parameter not working.
- Edit engine setting command now opens both .NET and Mono settings' files
- Add option to suppress execute/debug in workspace mode (
cs-script.suppress_script_debug_for_workspaces
). - Add option to tunnel CS-Script StartDebug request to the workspace launch.json algorithm (
cs-script.fallback_to_launch_json
). - Start Debug now activates DebugConsole output panel.
- Issue #9: Add an option to hide "CS-Script: About" from the context menu.
- Default CS-Script config file now contains
-l
switch, which sets the current directory to the location of the script at the start of the execution.
- Added the logo icon into the package/distro
- Implemented Intellisense for standalone C# files:
- Rename symbol
- Signature help
- Assignment completion
- Reduced embedded Roslyn runtime footprint.
- Implemented Intellisense for standalone C# files:
- Code completion
- Go to definition
- Hover/tooltip
- Find all references
- VS style of "Find all references" result in output panel
- Added VB.NET syntax support (Windows only)
- Added explicit extension dependency on
mono-debug
. Seems the disclaimer "to add Mono" in the extension description does not convince users users to do so.
- Fixed problem project tree not being updated on saving the script.
- Fixed problem with the original VSCode debugging API being deprecated (vscode.commands.executeCommand("vscode.startDebug") vs vscode.debug.startDebugging(...)).
- 'Check syntax' action that became in conflict with the new "scripted arg" support.
- Issue #4: Project fails to load if the script has cs-script directive invalid syntax.
- Issue #5: Executing detached script (Ctrl+F5) work OK but sometimes trigger "is busy" warning message.
- Updated cs-script engine to v3.27.3 (assorted Linux improvements)
- Added project tree view
- Implemented CS-Script execution with standard F5 via on-fly generated specific launch.json
- Implemented CS-Script specific intellisense
- Added 'Go to definition' for CS-Script directives
- Added auto-completion for CS-Script directives
- Added auto-completion for path items in CS-Script
//css_include
directive - Added 'on hover' support for CS-Script directives
- Added "Show project info" tree view button
- Fixed problem with generating debug info for Mono-Debug on Windows
- C# 7 support out of box
- New commands:
- "help"
- "build exe"
- "new script"
- "run in terminal"
- "engine settings"
- Added dedicated toolbar buttons for the most common CS-Script commands.
- Revoked extensionDependencies to the manifest file. Currently VSCode does not automatically installs specified dependencies but instead silently fails loading the extension if any dependency is not found. This all dependencies in the manifest file are removed so the extension can validate environment and clearly communicate the initialization failure reason(s).
- Implemented work around to allow single-step loading of OmniSharp project for enabling Intellisense.
- Implemented navigation to the file location on a single click (on error info) in the output panel.
- Added
extensionDependencies
to the manifest file. This should bring C# and Mono Debug plugins if they are not installed.
- Support for C# script execution (with cscs.exe)
- Support for C# script syntax checking (with cscs.exe)
- Support for C# script debugging (with Mono Debug extension)
- Integration with VSCode IntelliSense (with OmniSharp extension)
- Printing C# script dependencies ('print project' command)