Juxtapose 1.0.0-dev-026

This is a prerelease version of Juxtapose.
There is a newer version of this package available.
See the version list below for details.
dotnet add package Juxtapose --version 1.0.0-dev-026                
NuGet\Install-Package Juxtapose -Version 1.0.0-dev-026                
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="Juxtapose" Version="1.0.0-dev-026" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Juxtapose --version 1.0.0-dev-026                
#r "nuget: Juxtapose, 1.0.0-dev-026"                
#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.
// Install Juxtapose as a Cake Addin
#addin nuget:?package=Juxtapose&version=1.0.0-dev-026&prerelease

// Install Juxtapose as a Cake Tool
#tool nuget:?package=Juxtapose&version=1.0.0-dev-026&prerelease                

Juxtapose

1. Intro

基于 SourceGenerator 的硬编码 .Net进程运行库。

2. Features

  • 可以为类型接口静态类生成代理,无需手动编写RPC相关代码,即可进行多进程开发;
  • 编译时生成所有代码,运行时无显式的反射调用和动态构造;
  • 支持委托CancellationToken类型的方法参数(其余类型未特殊处理,将会进行序列化,目前回调委托不支持嵌套和CancellationToken);
  • 支持LinuxWindows(其它未测试);

注意事项

  • 目前参数不支持定义为父类型,实际传递子类型,序列化时将会按照定义的类型进行序列化和反序列化,会导致具体类型丢失;
  • 目前所有的参数都不应该在方法完成后进行保留,CancellationToken等在方法完成后会被释放;

3. Requirement

  • .Net5.0+(其它版本没有尝试过)

4. 使用方法

4.1 引用包

<ItemGroup>
  <PackageReference Include="Juxtapose" Version="1.0.*-*" />
  <PackageReference Include="Juxtapose.SourceGenerator" Version="1.0.*-*" />
</ItemGroup>

4.2 建立上下文

[Illusion(typeof(Greeter), typeof(IGreeter), "Juxtapose.Test.GreeterAsIGreeterIllusion")]
public partial class GreeterJuxtaposeContext : JuxtaposeContext
{
}

示例代码将为Greeter生成IGreeter接口的代理类型Juxtapose.Test.GreeterAsIGreeterIllusion

Note!!!

  • 必须继承JuxtaposeContext
  • 必须标记partial关键字;

4.3 添加入口点

Main方法中添加入口点代码,并使用指定上下文

await JuxtaposeEntryPoint.TryAsEndpointAsync(args, GreeterJuxtaposeContext.SharedInstance);

到此已完成开发,创建类型Juxtapose.Test.GreeterAsIGreeterIllusion的对象,并调用其方法,其实际逻辑将在子进程中运行;

5. 调试子进程(Windows&&VisualStudio Only)

5.1 引用调试包

在Host项目文件中添加包引用

<ItemGroup Condition="'$(Configuration)' == 'Debug'">
  <PackageReference Include="Juxtapose.VsDebugger" Version="1.0.*-*" />
</ItemGroup>
建议和示例代码一样,添加条件引用,只在Debug环境下引用调试包

5.2 添加入口点

Main方法中添加调试入口点代码

JuxtaposeDebuggerAttacher.TryAttachToParent(args);

在代码中打上断点,运行时将会正确命中断点(只在 VisualStudio2022 17.0.5 && Win11 21TH2 中进行了测试,理论上是通用)

6. 工作逻辑

SourceGenerator在编译时生成代理类型,封装通信消息。默认使用命名管道进行进程间通信,使用System.Text.Json进行消息的序列化与反序列化。

参见示例,未完待续......


示例列表

项目 内容
SampleLibrary 基于库的使用示例,可由其它程序直接使用
SampleConsoleApp 基于控制台的使用示例,可使用当前程序集生成的类,或使用其他库生成的类
ResourceBasedObjectPool 基于系统资源的动态对象池示例
Product Compatible and additional computed target framework versions.
.NET net5.0 is compatible.  net5.0-windows was computed.  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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.4.4 115 11/23/2024
1.4.3 9,733 8/10/2024
1.4.2 5,639 6/11/2024
1.4.1 1,101 6/1/2024
1.4.0 8,242 11/21/2023
1.3.0 315 11/15/2023
1.2.2 27,783 12/19/2022
1.2.1 814 10/12/2022
1.2.0 848 10/11/2022
1.1.2 780 9/16/2022
1.1.1 826 7/29/2022
1.1.0 864 7/23/2022
1.1.0-beta0001 604 7/6/2022
1.0.2 875 6/19/2022
1.0.1 878 5/26/2022
1.0.0 981 1/24/2022
1.0.0-dev-028 543 1/24/2022
1.0.0-dev-027 567 1/23/2022
1.0.0-dev-026 652 1/22/2022
1.0.0-dev-025 592 1/18/2022
1.0.0-dev-024 543 1/16/2022
1.0.0-dev-023 627 1/11/2022
1.0.0-dev-022 660 1/5/2022
1.0.0-dev-021 596 12/29/2021
1.0.0-dev-020 611 12/7/2021
1.0.0-dev-019 570 12/7/2021
1.0.0-dev-018 565 12/7/2021
1.0.0-dev-017 600 12/6/2021
1.0.0-dev-016 561 12/5/2021
1.0.0-dev-015 593 12/3/2021
1.0.0-dev-014 512 12/2/2021
1.0.0-dev-013 606 12/2/2021
1.0.0-dev-012 618 12/1/2021
1.0.0-dev-011 581 12/1/2021
1.0.0-dev-010 539 11/30/2021