-
Notifications
You must be signed in to change notification settings - Fork 12
CLI User Guide
As many other tools CS-Script provides an intensive command line interface that can be used from shell/terminal (e.g. Bash, PowerShell, command-prompt). This interface is particularly useful fo environments like Linux, where working from terminal is a predominate development approach.
CS-Script deployment model exist in two distinctive distribution forms:
-
Simple
Applicable for Windows, Linux, Mac. Basically it is an XCopy approach when yuo can bring on the target system CS-Script binaries that you need. Typically it is the script engine executable (cscs.exe). While you may also want to bring CSSRoslynProvider.dll along but strictly speaking cscs.exe is all you need ro run C# scripts. -
Complete
Applicable for Windows only. This model involves much dipper integration with the host OS. It involves bringing the software package (7z archive) from GitHub Releases folder unpacking it and launching the config console (css_config.exe), which performs all necessary configuration steps. Alternatively you can perform a single step deployment via the Chocolatey CS-Script package. The Complete deployment/distro contains much more than CS-Script binaries (Simple distro). It also includes extra utilities and binaries targeting various rintimes and the documentation.Full distro content (click to expand)
- Integration with OS: system path, envars, shell-extensions, default editor association
- GUI configuration console
- NuGet and Wsdl third-party tools
- Collection of utility scripts
- Binaries targeting legacy runtimes (e.g. .NET 3.5)
- Complete set of Roslyn binaries
- Intensive _Samples_ library
- Documentation
While Complete distro contains many useful resources the Simple one is what you would need in 90% of the cases. The script engine CLI is designed in such a way that it (single executable) can produce the minimal set of CS-Script documentation, samples and required configuration. The Simple distro is applicable for all OSs and as such it is perfect as a basic environment for a crash-course in CS-Script.
Note, if you are running CS-Script on Mono you will always need to supply the mono
token for all commands: mono cscs.exe -ver
instead of cscs -ver
. However this document contains all samples written in the short form for the sake of simplicity.
-
cscs -s
- prints sample script. For C# 7 sample use-s:7
switch. -
cscs -s > sample.cs
- redirects sample script content into sample.cs file. -
cscs sample.cs
- execute sample.cs file
Produced sample.cs file
using System;
using System.Windows.Forms;
class Script
{
static void Main(string[] args)
{
for (int i = 0; i < args.Length; i++)
Console.WriteLine(args[i]);
MessageBox.Show("Just a test!");
}
}
-
You can print the list of all supported commands with
cscs -cmd
-
You can access help for a specific command by typing
?
after the command name (e.g.cscs -syntax -?
) -
You can print the whole overview of CS-Script specific C# directives with
cscs -syntax
-
The most common/useful CS-Script directives that you can specify directly in the script are:
-
//css_ref *
- reference assembly -
//css_inc *
- include/import another script -
//css_nuget *
- reference nuget package
-
-
With the
-pc
switch you can define a precompiler script that allows pre-processing the primary script content prior its execution. Precompilation allows achieving pretty advanced functionality usually available in some advanced AOP framework. For example code decoration, macros unfolding etc. -
Instead of passing arguments from the command line you specify them directly in the script code with
//css_args
directive. -
The most frequently used command line arguments can be specified in the global configuration so they will be automatically added during an the execution for all scripts (e.g. suppressing warnings).
-
On Windows/.NET you can pass
//x
as the very last argument of the script and this will trigger a Debug.Assert on entering the script code. This way you can attach system wide debugger and debug the script:cscs print.cs "Hello World!" //x
CS-Script uses at runtime C# compiling infrastructure available with .NET/Mono. The highest supported C# syntax version available out of box is C# 5 on .NET and C# 6 on Mono. The support for C# 7 on both platforms is available via a separate compiling infrastructure - Roslyn. Read more...
CS-Script integrates with Roslyn via special CS-Script code provider assembly CSSRoslynProvider.dll
This is how you can enable CS-Script C# 7 support (Roslyn integration):
-
On Mono:
Since Roslyn is a part of Mono you only need to place CSSRoslynProvider.dll in the same location where your cscs.exe is.
Alternatively specify the location of the provider dll in the global configuration as theUseAlternativeCompiler
config value. -
On .NET:
Roslyn is not a part of .NET binaries and it needs to be installed separately. CS-Script Complete Distro includes Rolsyn and it is enabled by default on all fresh installations. If you need to enable Roslyn manually read about the procedure in this dedicated guide
Note, this section does not cover the whole CLI but only highlights its most important elements. The whole CLI documentation can be generated with cscs -?
command. You can also access its latest copy here.
Command: version
Syntax: cscs -ver
(or just cscs
)
Description: Prints full information about the current CS-Script environment.
Command: commands
Syntax: cscs -cmd
Description: Prints list of supported commands (arguments).
Syntax: cscs -cmd ?
Description: Prints description of an individual command.
Syntax: cscs -e <script_file>
Description: Compiles script into an application executable.
Syntax: cscs -co:<options>
Description: Passes user specified options into C# compiler.
The sample below demonstrates how to compile unsafe code. Any unsafe code requires passing /unsafe
parameter to the C# compiler:
using System;
using static dbg;
unsafe void main()
{
int i = 25;
SquarePtrParam(&i);
print(i);
}
unsafe void SquarePtrParam(int* p)
{
*p *= *p;
}
Syntax: cscs -ac[:<0|1|2>]
Description: Decorates classless C# script code with a class definition prior the execution.
-ac enables auto-class decoration (which might be disabled globally);
-ac:0 disables auto-class decoration (which might be enabled globally);
-ac:1 same as as `-ac`
-ac:2 same as '-ac' adn `-ac:1` but also injects break point enables at the start of the
user code (useful for IDEs);
In this mode script engine automatically generates 'static entry point' class if the script doesn't define any.
The engine inserts two "merged" unformatted lines of decoration code that define a class start and class end. The injected lines are clearly marked with the special line ending so they can be excluded from the line counting when classless code is handle by IDEs.
using System;
void Main()
{
Console.WriteLine("Hello World!";
}
Thus the code above will be decorated just before passing it to the C# compiler as below:
using System;public class ScriptClass { public static ///CS-Script auto-class generationvoid Main() { Console.WriteLine("Hello World!"); }} ///CS-Script auto-class generation
You can always test the decoration outcome with -ac:out
switch:
Using an alternative 'instance entry point' is even more convenient (and reliable). The acceptable 'instance entry point' signatures are:
void main()
void main(string[] args)
int main()
int main(string[] args)
Note, having any active code above entry point is acceptable though it complicates the troubleshooting if such a code contains errors. (see http://www.csscript.net/help/AutoClass.html)
Syntax: cscs -pc
Syntax: cscs -pvdr
Still Under Development