As a little finger exercise, I thought that a Visual Studio extension that explains the code would be good – thanks to OpenAI, that shouldn’t be a problem.
And it wasn’t.
First, I installed the Extensibilty Template Pack 2022 for Visual Studio 2022.
Then I could get started:
Firstly, I added a tool window. A tool window is basically nothing more than an XAML user control and a class that derives from BaseToolWindow
public class ExplicareToolWindow : BaseToolWindow<ExplicareToolWindow>
{
public override string GetTitle(int toolWindowId) => "Explicare";
public override Type PaneType => typeof(Pane);
public override async Task<FrameworkElement> CreateAsync(int toolWindowId, CancellationToken cancellationToken)
{
var dte = await Package.GetServiceAsync(typeof(EnvDTE.DTE)) as EnvDTE80.DTE2;
return new ExplicareToolWindowControl(dte,Package);
}
[Guid("b8381bcb-59d1-4b5c-9951-fdbfb44990c9")]
internal class Pane : ToolWindowPane
{
public Pane()
{
BitmapImageMoniker = KnownMonikers.ToolWindow;
}
}
}
ExplicareToolWindowControl(dte,Package); is the actual UserControl – in which we can insert any UI elements.
I have now only added one button which I have called ‘Explain to me’.
I made a quick and dirty button click event in the code-behind.
Now read the text from the Visual Studio Editor with :
var textSelection = (TextSelection)MyDTE.ActiveDocument.Selection;
if (String.IsNullOrEmpty(textSelection.Text))
{
TextDocument doc = (TextDocument)(MyDTE.ActiveDocument.Object("TextDocument"));
var p = doc.StartPoint.CreateEditPoint();
TextToExplain = p.GetText(doc.EndPoint);
}
else
{
TextToExplain = textSelection.Text;
}
So the most difficult part is now behind me: calling the OpenAI API. This is actually quite simple
var content = new StringContent(jsonContent, Encoding.UTF8, "application/json");
var response = client.PostAsync("https://api.openai.com/v1/completions", content).Result;
if (response.IsSuccessStatusCode)
{
string responseStr = await response.Content.ReadAsStringAsync();
var result = JsonConvert.DeserializeObject<OpenAIResponse>(responseStr);
explained = result.choices[0].text;
}
else
{
throw new BadRequestExecption();
}
Source code Git Hub gpiwonka/Explicare: A small extension for Visual Studio to better understand code using OpenAI. (github.com)
Extension: Explicare – Visual Studio Marketplace
Schreibe einen Kommentar