Ecng.Compilation 1.0.286

There is a newer version of this package available.
See the version list below for details.
dotnet add package Ecng.Compilation --version 1.0.286
                    
NuGet\Install-Package Ecng.Compilation -Version 1.0.286
                    
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Ecng.Compilation" Version="1.0.286" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Ecng.Compilation" Version="1.0.286" />
                    
Directory.Packages.props
<PackageReference Include="Ecng.Compilation" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add Ecng.Compilation --version 1.0.286
                    
#r "nuget: Ecng.Compilation, 1.0.286"
                    
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package Ecng.Compilation@1.0.286
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=Ecng.Compilation&version=1.0.286
                    
Install as a Cake Addin
#tool nuget:?package=Ecng.Compilation&version=1.0.286
                    
Install as a Cake Tool

Ecng.Compilation

Dynamic code compilation infrastructure for C#, F#, and Python. Compile code at runtime, manage references, and cache assemblies.

Overview

This library provides a unified interface for runtime code compilation supporting multiple languages through specialized providers.

Core Types

ICompiler Interface

The main abstraction for compilers.

public interface ICompiler
{
    string Extension { get; }           // e.g., ".cs", ".fs", ".py"
    bool IsAssemblyPersistable { get; } // Can save compiled assembly
    bool IsTabsSupported { get; }       // Language supports tabs
    bool IsCaseSensitive { get; }       // Language is case-sensitive
    bool IsReferencesSupported { get; } // Supports external references

    ICompilerContext CreateContext();

    Task<CompilationResult> Compile(
        string name,
        IEnumerable<string> sources,
        IEnumerable<(string name, byte[] body)> refs,
        CancellationToken ct = default);

    Task<CompilationError[]> Analyse(
        object analyzer,
        IEnumerable<object> analyzerSettings,
        string name,
        IEnumerable<string> sources,
        IEnumerable<(string name, byte[] body)> refs,
        CancellationToken ct = default);
}

CompilationResult

Result of a compilation operation.

var result = await compiler.Compile("MyCode", sources, references);

if (result.HasErrors)
{
    foreach (var error in result.Errors)
    {
        Console.WriteLine($"{error.Type}: {error.Message}");
        Console.WriteLine($"  Line {error.Line}, Column {error.Column}");
    }
}
else
{
    // Get compiled assembly
    Assembly assembly = result.Assembly;

    // Or get as bytes for storage
    byte[] assemblyBytes = result.AssemblyBytes;
}

CompilationError

Represents a compilation error or warning.

public class CompilationError
{
    public CompilationErrorTypes Type { get; }  // Error, Warning, Info
    public string Id { get; }                    // e.g., "CS0001"
    public string Message { get; }
    public int Line { get; }
    public int Column { get; }
}

Reference Types

AssemblyReference

Reference to a .NET assembly.

// From file path
var fileRef = new AssemblyReference("path/to/assembly.dll");

// From loaded assembly
var loadedRef = new AssemblyReference(typeof(SomeClass).Assembly);

NuGetReference

Reference to a NuGet package.

var nugetRef = new NuGetReference
{
    PackageId = "Newtonsoft.Json",
    Version = "13.0.1"
};

Compiler Provider

Manages available compilers and provides access to them.

// Get registered compilers
IEnumerable<ICompiler> compilers = CompilerProvider.Compilers;

// Get compiler by extension
ICompiler csCompiler = CompilerProvider.GetCompiler(".cs");
ICompiler fsCompiler = CompilerProvider.GetCompiler(".fs");
ICompiler pyCompiler = CompilerProvider.GetCompiler(".py");

Compiler Implementations

Package Language Extension
Ecng.Compilation.Roslyn C# .cs
Ecng.Compilation.FSharp F# .fs
Ecng.Compilation.Python Python .py

Expression Formulas

Parse and evaluate mathematical expressions at runtime.

using Ecng.Compilation.Expressions;

// Parse expression
var formula = ExpressionHelper.Parse("(a + b) * 2");

// Get variables used
IEnumerable<string> vars = formula.Variables; // ["a", "b"]

// Evaluate with values
var values = new Dictionary<string, decimal>
{
    ["a"] = 10,
    ["b"] = 5
};
decimal result = formula.Calculate(values); // 30

Supported Operations

  • Arithmetic: +, -, *, /, %
  • Comparison: <, >, <=, >=, ==, !=
  • Logical: &&, ||, !
  • Functions: abs, sqrt, min, max, pow, etc.

Assembly Load Context

Manage assembly loading for isolation.

using Ecng.Compilation;

// Track loaded assemblies
var tracker = new AssemblyLoadContextTracker();

// Load assembly in isolated context
var context = tracker.CreateContext("MyPlugin");
Assembly asm = context.LoadFromAssemblyPath("plugin.dll");

// Unload when done
tracker.Unload("MyPlugin");

Compiler Cache

Cache compiled assemblies for reuse.

public interface ICompilerCache
{
    bool TryGet(string key, out byte[] assembly);
    void Set(string key, byte[] assembly);
    void Remove(string key);
    void Clear();
}

Usage Examples

Compile C# Code

var compiler = CompilerProvider.GetCompiler(".cs");

string code = @"
public class Calculator
{
    public int Add(int a, int b) => a + b;
}";

var result = await compiler.Compile(
    name: "Calculator",
    sources: new[] { code },
    refs: Array.Empty<(string, byte[])>());

if (!result.HasErrors)
{
    var type = result.Assembly.GetType("Calculator");
    var instance = Activator.CreateInstance(type);
    var method = type.GetMethod("Add");
    int sum = (int)method.Invoke(instance, new object[] { 2, 3 });
    Console.WriteLine(sum); // 5
}

Compile with References

var refs = new List<(string, byte[])>();

// Add reference
var asmBytes = File.ReadAllBytes("MyLibrary.dll");
refs.Add(("MyLibrary.dll", asmBytes));

var result = await compiler.Compile("MyCode", sources, refs);

NuGet

Install-Package Ecng.Compilation
Install-Package Ecng.Compilation.Roslyn   # For C# support
Install-Package Ecng.Compilation.FSharp   # For F# support
Install-Package Ecng.Compilation.Python   # For Python support
Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed.  net10.0 is compatible.  net10.0-android was computed.  net10.0-browser was computed.  net10.0-ios was computed.  net10.0-maccatalyst was computed.  net10.0-macos was computed.  net10.0-tvos was computed.  net10.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (7)

Showing the top 5 NuGet packages that depend on Ecng.Compilation:

Package Downloads
StockSharp.Algo

Trading algorithms. More info on web site https://stocksharp.com/store/

Ecng.Compilation.Roslyn

Ecng system framework

Ecng.Roslyn

Ecng system framework

Ecng.Compilation.Python

Ecng system framework

Ecng.Compilation.FSharp

Ecng system framework

GitHub repositories (1)

Showing the top 1 popular GitHub repositories that depend on Ecng.Compilation:

Repository Stars
StockSharp/StockSharp
Algorithmic trading and quantitative trading open source platform to develop trading robots (stock markets, forex, crypto, bitcoins, and options).
Version Downloads Last Updated
1.0.287 0 1/26/2026
1.0.286 39 1/26/2026
1.0.285 59 1/22/2026
1.0.284 58 1/22/2026
1.0.283 146 1/21/2026
1.0.282 252 1/19/2026
1.0.281 190 1/19/2026
1.0.280 182 1/18/2026
1.0.279 177 1/18/2026
1.0.278 198 1/16/2026
1.0.277 259 1/14/2026
1.0.276 190 1/13/2026
1.0.275 194 1/13/2026
1.0.274 197 1/12/2026
1.0.273 287 1/9/2026
1.0.272 233 1/9/2026
1.0.271 188 1/8/2026
1.0.270 193 1/8/2026
1.0.269 206 1/7/2026
1.0.268 220 1/6/2026
1.0.267 146 1/6/2026
1.0.266 293 1/4/2026
1.0.265 239 1/1/2026
1.0.264 178 12/31/2025
1.0.263 192 12/30/2025
1.0.262 175 12/30/2025
1.0.261 172 12/29/2025
1.0.260 179 12/29/2025
1.0.259 184 12/26/2025
1.0.258 168 12/26/2025
1.0.257 175 12/26/2025
1.0.256 185 12/26/2025
1.0.255 263 12/25/2025
1.0.254 261 12/25/2025
1.0.253 268 12/24/2025
1.0.252 272 12/22/2025
1.0.251 249 12/21/2025
1.0.250 332 12/19/2025
1.0.249 328 12/19/2025
1.0.248 429 12/17/2025
1.0.247 434 12/16/2025
1.0.246 353 12/15/2025
1.0.245 341 12/15/2025
1.0.244 311 12/14/2025
1.0.243 254 12/14/2025
1.0.242 272 12/13/2025
1.0.241 263 12/13/2025
1.0.240 255 12/12/2025
1.0.239 217 12/12/2025
1.0.238 226 12/12/2025
1.0.237 219 12/12/2025
1.0.236 217 12/12/2025
1.0.235 225 12/12/2025
1.0.234 220 12/12/2025
1.0.233 908 12/2/2025
1.0.232 787 12/2/2025
1.0.231 780 12/2/2025
1.0.230 406 11/30/2025
1.0.229 250 11/29/2025
1.0.228 249 11/28/2025
1.0.227 254 11/28/2025
1.0.226 321 11/27/2025
1.0.225 409 11/24/2025
1.0.224 328 11/24/2025
1.0.223 340 11/23/2025
1.0.222 312 11/23/2025
1.0.221 388 11/22/2025
1.0.220 622 11/20/2025
1.0.219 571 11/18/2025
1.0.218 528 11/18/2025
1.0.217 523 11/13/2025
1.0.216 420 11/10/2025
1.0.215 1,297 11/1/2025
1.0.214 399 10/28/2025
1.0.213 406 10/27/2025
1.0.212 352 10/27/2025
1.0.211 283 10/25/2025
1.0.210 327 10/24/2025
1.0.209 527 10/20/2025
1.0.208 549 10/12/2025
1.0.207 320 10/11/2025
1.0.206 610 10/7/2025
1.0.205 425 10/6/2025
1.0.204 645 10/3/2025
1.0.203 449 10/1/2025
1.0.202 357 10/1/2025
1.0.201 379 9/30/2025
1.0.200 404 9/28/2025
1.0.199 442 9/25/2025
1.0.198 3,095 9/5/2025
1.0.197 456 9/2/2025
1.0.196 1,176 8/30/2025
1.0.195 438 8/30/2025
1.0.194 474 8/20/2025
1.0.193 361 8/20/2025
1.0.192 408 8/19/2025
1.0.191 420 8/15/2025
1.0.190 2,553 7/16/2025
1.0.189 836 7/14/2025
1.0.188 443 7/13/2025
1.0.187 377 7/13/2025
1.0.186 366 7/12/2025
1.0.185 701 7/8/2025
1.0.184 674 7/4/2025
1.0.183 417 7/2/2025
1.0.182 827 6/24/2025
1.0.181 1,448 6/16/2025
1.0.180 570 6/9/2025
1.0.179 448 6/8/2025
1.0.178 840 5/25/2025
1.0.177 413 5/21/2025
1.0.176 396 5/21/2025
1.0.175 359 5/17/2025
1.0.174 355 5/17/2025
1.0.173 365 5/17/2025
1.0.172 895 5/12/2025
1.0.171 487 5/12/2025
1.0.170 445 5/12/2025
1.0.169 391 5/11/2025
1.0.168 378 5/11/2025
1.0.167 351 5/10/2025
1.0.166 341 5/10/2025
1.0.165 362 5/3/2025
1.0.164 521 4/17/2025
1.0.163 483 4/15/2025
1.0.162 405 4/12/2025
1.0.161 440 4/9/2025
1.0.160 1,660 3/22/2025
1.0.159 421 3/20/2025
1.0.158 398 3/20/2025
1.0.157 403 3/19/2025
1.0.156 1,365 2/26/2025
1.0.155 379 2/26/2025
1.0.154 1,595 2/8/2025
1.0.153 377 2/8/2025
1.0.152 368 2/8/2025
1.0.151 383 2/6/2025
1.0.150 382 2/6/2025
1.0.149 386 2/6/2025
1.0.148 374 2/6/2025
1.0.147 365 2/6/2025
1.0.146 404 2/5/2025
1.0.145 400 2/5/2025
1.0.144 395 2/5/2025
1.0.143 421 2/3/2025
1.0.142 378 2/2/2025
1.0.141 391 2/1/2025
1.0.140 400 1/31/2025
1.0.139 395 1/30/2025
1.0.138 408 1/26/2025
1.0.137 494 1/21/2025
1.0.136 375 1/21/2025
1.0.135 414 1/20/2025
1.0.134 374 1/20/2025
1.0.133 467 1/19/2025
1.0.132 415 1/19/2025
1.0.131 525 1/17/2025
1.0.130 398 1/17/2025
1.0.129 449 1/14/2025
1.0.128 676 1/12/2025
1.0.127 465 1/12/2025
1.0.126 466 1/12/2025
1.0.125 482 1/12/2025
1.0.124 465 1/12/2025
1.0.123 436 1/12/2025
1.0.122 443 1/12/2025
1.0.121 460 1/11/2025
1.0.120 490 1/10/2025
1.0.119 498 1/10/2025
1.0.118 492 1/9/2025
1.0.117 424 1/9/2025
1.0.116 398 1/9/2025
1.0.115 423 1/9/2025
1.0.114 1,630 12/27/2024
1.0.113 461 12/19/2024
1.0.112 486 11/20/2024
1.0.111 1,307 11/18/2024
1.0.110 705 11/7/2024
1.0.109 347 11/7/2024
1.0.108 376 11/7/2024
1.0.107 350 11/7/2024
1.0.106 351 11/7/2024
1.0.105 349 11/7/2024
1.0.104 350 11/7/2024
1.0.103 373 11/6/2024
1.0.102 387 10/31/2024
1.0.101 468 10/19/2024
1.0.100 1,069 10/12/2024
1.0.99 710 10/9/2024
1.0.98 634 10/5/2024
1.0.97 1,341 9/18/2024
1.0.96 400 9/17/2024
1.0.95 1,078 9/3/2024
1.0.94 386 9/1/2024
1.0.93 1,562 8/8/2024
1.0.92 2,609 6/12/2024
1.0.91 846 5/28/2024
1.0.90 1,477 5/4/2024
1.0.89 1,070 4/23/2024
1.0.88 382 4/21/2024
1.0.87 438 4/14/2024
1.0.86 1,256 3/28/2024
1.0.85 451 3/17/2024
1.0.84 1,445 2/23/2024
1.0.83 423 2/23/2024
1.0.82 1,170 2/18/2024
1.0.81 363 2/18/2024
1.0.80 373 2/16/2024
1.0.79 1,008 2/13/2024
1.0.78 839 2/8/2024
1.0.77 1,122 2/5/2024
1.0.76 385 2/4/2024
1.0.75 1,127 1/23/2024
1.0.74 374 1/23/2024
1.0.73 1,079 1/12/2024
1.0.72 1,198 1/2/2024
1.0.71 428 12/29/2023
1.0.70 1,399 12/15/2023
1.0.69 488 12/15/2023
1.0.68 454 12/13/2023
1.0.67 476 12/13/2023
1.0.66 2,424 11/12/2023
1.0.65 472 11/10/2023
1.0.64 454 11/10/2023
1.0.63 450 11/9/2023
1.0.62 463 11/3/2023
1.0.61 470 11/1/2023
1.0.60 483 11/1/2023
1.0.59 4,178 9/8/2023
1.0.58 428 9/8/2023
1.0.57 438 9/8/2023
1.0.56 503 9/8/2023
1.0.55 464 9/8/2023
1.0.54 458 9/7/2023
1.0.53 566 9/3/2023
1.0.52 616 8/21/2023
1.0.51 600 8/15/2023
1.0.50 532 8/14/2023
1.0.49 518 8/14/2023
1.0.48 534 8/10/2023
1.0.47 3,880 7/1/2023
1.0.46 544 6/29/2023
1.0.45 2,127 5/27/2023
1.0.44 605 5/21/2023
1.0.43 630 5/19/2023
1.0.42 2,445 5/8/2023
1.0.41 653 5/1/2023
1.0.40 636 4/22/2023
1.0.39 635 4/21/2023
1.0.38 4,313 4/3/2023
1.0.37 755 3/27/2023
1.0.36 812 3/21/2023
1.0.35 788 3/13/2023
1.0.34 668 3/12/2023
1.0.33 713 3/11/2023
1.0.32 2,244 3/6/2023
1.0.31 789 2/26/2023
1.0.30 2,590 2/21/2023
1.0.29 782 2/20/2023
1.0.28 807 2/15/2023
1.0.27 814 2/14/2023
1.0.26 3,339 2/9/2023
1.0.25 2,438 2/7/2023
1.0.24 850 2/4/2023
1.0.23 2,589 2/2/2023
1.0.22 2,637 1/30/2023
1.0.21 894 1/18/2023
1.0.20 5,216 12/30/2022
1.0.19 903 12/23/2022
1.0.18 868 12/23/2022
1.0.17 22,971 12/12/2022
1.0.16 66,352 11/11/2022
1.0.15 2,710 11/11/2022
1.0.14 5,125 11/5/2022
1.0.13 29,196 11/1/2022
1.0.12 26,916 10/16/2022
1.0.11 58,866 9/8/2022
1.0.10 3,045 9/8/2022
1.0.9 2,992 9/8/2022
1.0.8 99,288 8/24/2022
1.0.7 17,205 7/26/2022
1.0.6 103,241 7/18/2022
1.0.5 111,289 4/30/2022
1.0.4 23,854 3/29/2022
1.0.3 462,535 12/29/2021
1.0.2 31,409 12/20/2021
1.0.1 63,367 12/6/2021
1.0.0 4,333 12/2/2021