SourceExpander.Console
                             
                            
                                5.0.0-beta1
                            
                        
                    See the version list below for details.
dotnet tool install --global SourceExpander.Console --version 5.0.0-beta1
dotnet new tool-manifest
dotnet tool install --local SourceExpander.Console --version 5.0.0-beta1
#tool dotnet:?package=SourceExpander.Console&version=5.0.0-beta1&prerelease
nuke :add-package SourceExpander.Console --version 5.0.0-beta1
SourceExpander
README languages:
Table of Contents
Packages
SourceExpander(library)
Library that expand embedded source codes.
SourceExpander.Console
Console application that expand embedded source codes.
SourceExpander.Generator
Source generator that expand embedded source codes.
SourceExpander.Embedder
Source generator that embed source codes.
Status
| Library | NuGet | 
|---|---|
| SourceExpander | |
| SourceExpander.Core | |
| SourceExpander.Embedder | |
| SourceExpander.Generator | |
| SourceExpander.Console | 
Getting started
This library require .NET 5 SDK or Visual Studio 16.8 or later because this library use Source Generators.
For library user
Use SourceExpander.Console
Install:
dotnet tool install -g SourceExpander.Console
Run:
# minimum run
dotnet-source-expand Sample/SampleProject2/Program.cs
# specified project
dotnet-source-expand Sample/SampleProject/Put.cs -p Sample/SampleProject2/SampleProject2.csproj
Use SourceExpander.Generator
see Sample or https://github.com/kzrnm/ac-library-csharp
Install-Package SourceExpander
Install-Package <A library with embedded source>
using System;
class Program
{
    static void Main()
    {
        SourceExpander.Expander.Expand();
        // Your code
    }
}
When you run the code, SourceExpander.Expander.Expand() create new file that combined library code.
using System;
class Program
{
    static void Main()
    {
        SourceExpander.Expander.Expand();
        // Your code
    }
}
#region Expanded by https://github.com/kzrnm/SourceExpander
namespace SourceExpander { public class Expander { [Conditional("EXPANDER")] public static void Expand(string inputFilePath = null, string outputFilePath = null, bool ignoreAnyError = true) { } public static string ExpandString(string inputFilePath = null, bool ignoreAnyError = true) { return ""; } } } 
// library code
#endregion Expanded by https://github.com/kzrnm/SourceExpander
For library developer
It's easy, just install SourceExpander.Embedder.
Install-Package SourceExpander.Embedder
Avoid embedding some type
Embedding is skipped for type that have SourceExpander.NotEmbeddingSourceAttribute.
Notes
Because SourceExpander.Embedder run at compile time, the embedded source code cannot be used in the same project.
Embedded data
SourceExpander.Embedder embed some data like below.
using System.Reflection;
[assembly: AssemblyMetadata("SourceExpander.EmbedderVersion", "2.5.0.101")]
[assembly: AssemblyMetadata("SourceExpander.EmbeddedLanguageVersion", "2")]
[assembly: AssemblyMetadata("SourceExpander.EmbeddedAllowUnsafe", "true")]
[assembly: AssemblyMetadata("SourceExpander.EmbeddedSourceCode.GZipBase32768", "㘅桠ҠҠԀᏕ䴾阺㹈斪筟楸厮嫉盆炚磈臤梽胍㦬竂帙詪煩㔬樄ᗗ踜鲯诇ᠩ珱䪜䐽闾鱏珣茙灸䏙⨧㤄寨砳⬅ស䮙松Ꝉ㥅䱀餯ꃣ虱嫁榏㪰糰蝃技夛䥘谼礞䐿斄禕蚷屔彺㪪賳鱥䝢鰨覶⬴誼⬼獬鞨胒宝䭴摺眚䅗䃝䚏隻嫻痛簴Ꜿ変⇣㇋聼欈Ꭽ墷霶勎嶐窢銖㤁┠䁺⠛缧䋹凬☂䁸栣僼邐䑹瘜蛭諠賿㨚咈鍂ꄱ禱唨毊崨叼緭䥜榄闺䦖麷䘘㨵ᖶ琜鎎ᰇ髎飭㪬採ꅈ㥞盧䢽䃘煃⬘喔渻莖案ᯋ硟ꋛ叝谴缄ꍢ⋗溁ᣒ颂浢ꍈꉭ㑆焤鹠杳煄㾳䴡䂱㙽楯裦鷬梙掫取颤⩑㰑㕋ꂤ碎麓㾕昖啘繅餬簚盎鍣䨽籭詽绑襌硲❞擧ꌥ膩辪聫㭒珥㴟囓䓖焜铽痢ꊆꍼᓥ囦纇維Ⲡ㤬垇螇感縋㼎砾褳強襓瀕樥阵瀭蜺兔峃絻藈萢饑㶬櫊綖嶅鏕㻶坶禵䓓Ⴐ咇詤煑⬐毱㱒獅鐥椳䖑ᙋ冄㴼㗭隯顑命貽职葅苫⢸栚䀹䢳噂槝䲰䰮⇷ᔈ⎙䕪絑㝖垿䞉場珟䉛㰭䵶日憭蕼馣㸩涴䓋䃇懚鹯琥镌ⴊ電萞猛流癊⏔恚Ԉң")]
//[assembly: AssemblyMetadata("SourceExpander.EmbeddedSourceCode", "[{\"CodeBody\":\"namespace SampleLibrary { public static class Bit { [MethodImpl(MethodImplOptions.AggressiveInlining)] public static int ExtractLowestSetBit(int n) { if (Bmi1.IsSupported) { return (int)Bmi1.ExtractLowestSetBit((uint)n); } return n & -n; } } } \",\"Dependencies\":[],\"FileName\":\"_SampleLibrary>Bit.cs\",\"TypeNames\":[\"SampleLibrary.Bit\"],\"Usings\":[\"using System.Runtime.CompilerServices;\",\"using System.Runtime.Intrinsics.X86;\"]},{\"CodeBody\":\"namespace SampleLibrary { public static class Put { private static readonly Xorshift rnd = new Xorshift(); public static void WriteRandom() { Trace.WriteLine(rnd.Next()); } } } \",\"Dependencies\":[\"_SampleLibrary>Xorshift.cs\"],\"FileName\":\"_SampleLibrary>Put.cs\",\"TypeNames\":[\"SampleLibrary.Put\"],\"Usings\":[\"using System.Diagnostics;\"]},{\"CodeBody\":\"namespace SampleLibrary { public class Xorshift : Random { private uint x = 123456789; private uint y = 362436069; private uint z = 521288629; private uint w; private static readonly Random rnd = new Random(); public Xorshift() : this(rnd.Next()) { } public Xorshift(int seed) { w = (uint)seed; } protected override double Sample() { return InternalSample() * (1.0 \\/ uint.MaxValue); } private uint InternalSample() { uint t = x ^ (x << 11); x = y; y = z; z = w; return w = (w ^ (w >> 19)) ^ (t ^ (t >> 8)); } } } \",\"Dependencies\":[],\"FileName\":\"_SampleLibrary>Xorshift.cs\",\"TypeNames\":[\"SampleLibrary.Xorshift\"],\"Usings\":[\"using System;\"]}]")]
EmbedderVersion
AssemblyVersion of SourceExpander.Embedder.
EmbeddedLanguageVersion
C# version of embbeded source code.
EmbeddedAllowUnsafe
if true, embbeded source code allow unsafe code.
EmbeddedSourceCode
Actually, this metadata does not embedded. for explanation.
json seriarized array of SourceFileInfo.
public class SourceFileInfo
{
    /// <summary>
    /// Unique name of file
    /// </summary>
    public string FileName { get; set; }
    /// <summary>
    /// Defined types like class, struct, record, enum, delegate
    /// </summary>
    public IEnumerable<string> TypeNames { get; set; }
    /// <summary>
    /// Using directives
    /// </summary>
    public IEnumerable<string> Usings { get; set; }
    /// <summary>
    /// FileNames that the this depending on
    /// </summary>
    public IEnumerable<string> Dependencies { get; set; }
    /// <summary>
    /// Code body that removed using directives
    /// </summary>
    public string CodeBody { get; set; }
}
EmbeddedSourceCode.GZipBase32768
gzip and base32768 encoded json.
| Product | Versions 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 was computed. 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. | 
This package has no dependencies.
| Version | Downloads | Last Updated | 
|---|---|---|
| 8.2.0 | 308 | 4/18/2025 | 
| 8.1.0 | 176 | 1/20/2025 | 
| 8.0.0 | 155 | 1/17/2025 | 
| 7.0.0 | 215 | 5/10/2024 | 
| 6.0.0 | 259 | 1/29/2024 | 
| 5.5.1 | 408 | 10/21/2023 | 
| 5.5.0 | 349 | 10/21/2023 | 
| 5.4.0 | 304 | 10/18/2023 | 
| 5.3.1 | 293 | 9/12/2023 | 
| 5.3.0 | 303 | 9/12/2023 | 
| 5.2.0 | 481 | 1/20/2023 | 
| 5.1.0 | 384 | 12/24/2022 | 
| 5.0.0 | 907 | 3/16/2022 | 
| 5.0.0-beta3 | 483 | 3/16/2022 | 
| 5.0.0-beta2 | 449 | 3/16/2022 | 
| 5.0.0-beta1 | 440 | 3/15/2022 | 
| 4.2.0-beta1 | 391 | 3/15/2022 | 
| 4.2.0-alpha3 | 417 | 3/15/2022 | 
| 4.2.0-alpha2 | 410 | 3/15/2022 | 
| 4.1.1 | 568 | 2/26/2022 | 
| 4.1.0 | 578 | 2/26/2022 | 
| 4.0.2 | 602 | 1/23/2022 | 
| 4.0.1 | 607 | 1/22/2022 | 
| 4.0.0 | 598 | 1/22/2022 | 
| 4.0.0-beta4 | 482 | 1/21/2022 |