-
Notifications
You must be signed in to change notification settings - Fork 3.3k
/
CustomMutablePlugin.cs
79 lines (65 loc) · 3.43 KB
/
CustomMutablePlugin.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
// Copyright (c) Microsoft. All rights reserved.
using System.Diagnostics.CodeAnalysis;
using Microsoft.SemanticKernel;
namespace Plugins;
/// <summary>
/// This example shows how to create a mutable <see cref="KernelPlugin"/>.
/// </summary>
public class CustomMutablePlugin(ITestOutputHelper output) : BaseTest(output)
{
[Fact]
public async Task RunAsync()
{
var plugin = new MutableKernelPlugin("Plugin");
plugin.AddFunction(KernelFunctionFactory.CreateFromMethod(() => "Plugin.Function", "Function"));
var kernel = new Kernel();
kernel.Plugins.Add(plugin);
var result = await kernel.InvokeAsync(kernel.Plugins["Plugin"]["Function"]);
Console.WriteLine($"Result: {result}");
}
/// <summary>
/// Provides an <see cref="KernelPlugin"/> implementation around a collection of functions.
/// </summary>
public class MutableKernelPlugin : KernelPlugin
{
/// <summary>The collection of functions associated with this plugin.</summary>
private readonly Dictionary<string, KernelFunction> _functions;
/// <summary>Initializes the new plugin from the provided name, description, and function collection.</summary>
/// <param name="name">The name for the plugin.</param>
/// <param name="description">A description of the plugin.</param>
/// <param name="functions">The initial functions to be available as part of the plugin.</param>
/// <exception cref="ArgumentNullException"><paramref name="functions"/> contains a null function.</exception>
/// <exception cref="ArgumentException"><paramref name="functions"/> contains two functions with the same name.</exception>
public MutableKernelPlugin(string name, string? description = null, IEnumerable<KernelFunction>? functions = null) : base(name, description)
{
this._functions = new Dictionary<string, KernelFunction>(StringComparer.OrdinalIgnoreCase);
if (functions is not null)
{
foreach (KernelFunction f in functions)
{
ArgumentNullException.ThrowIfNull(f);
var cloned = f.Clone(name);
this._functions.Add(cloned.Name, cloned);
}
}
}
/// <inheritdoc/>
public override int FunctionCount => this._functions.Count;
/// <inheritdoc/>
public override bool TryGetFunction(string name, [NotNullWhen(true)] out KernelFunction? function) =>
this._functions.TryGetValue(name, out function);
/// <summary>Adds a function to the plugin.</summary>
/// <param name="function">The function to add.</param>
/// <exception cref="ArgumentNullException"><paramref name="function"/> is null.</exception>
/// <exception cref="ArgumentNullException"><paramref name="function"/>'s <see cref="KernelFunction.Name"/> is null.</exception>
/// <exception cref="ArgumentException">A function with the same <see cref="KernelFunction.Name"/> already exists in this plugin.</exception>
public void AddFunction(KernelFunction function)
{
ArgumentNullException.ThrowIfNull(function);
var cloned = function.Clone(this.Name);
this._functions.Add(cloned.Name, cloned);
}
/// <inheritdoc/>
public override IEnumerator<KernelFunction> GetEnumerator() => this._functions.Values.GetEnumerator();
}
}