Skip to main content

Github Copilot Edits

I continue my journey on getting the most out of Github Copilot. Today I want to take a look at Copilot Edits as another way to use AI in your day-to-day coding experience. Until recently, you either had to use completions or the chat experience. 

With Copilot Edits, a third option is added to the list.

Why Copilot Edits?

Where the completions or the chat experience are a great fit for single file changes, they can be cumbersome for bigger changes that span multiple files. When using Copilot Edits, you can specify a set of files that should edited and then ask Copilot to do some changes. 

Remark: At the moment of writing Copilot Edits seems only to be available inside VS Code and not (yet) in Visual Studio.

Let’s give it a try…

  • Click on the Github Copilot icon at the top and choose Open Copilot Edits from the dropdown(or just hit CTRL-Shift-I)


  • This will open up the Copilot Edits view where we can start a new editing session.

 

  • First we need to add a set of files to our Working Set. Therefore click on + Add Files and choose the files that should be part of the working set. Copilot will only apply changes to these files.
    • Remark: At the moment the working set is limited to 10 files.

 

  • Now we can enter a chat prompt telling the change that we want taking our working set into account.

 

  • We now have the option to go through all the changes and either Accept or Discard them.

 

  • The edits are not saved to disk automatically. You can save the files by clicking on the Save icon.
    • Remark: This doesn’t mean that the changes are accepted automatically.

 

  • If you are happy with the final set of changes you can click Accept.
  • Click on Done to end the editing session.

This first experience of this new feature was certainly positive. Would be nice if I could define the working set by just specifying it as text(e.g. Edit all razor files...).

Update:  
  • I was able to mimic the behavior I mentioned above by first entering my request in the Copilot Chat experience:


  • And then I hit the Edit with Copilot button:
  • Copilot automatically added all impacted files to the working set and when I click on Rerun in the Chat window it starts to apply the change. Nice!

More information

Copilot Edits

Popular posts from this blog

Azure DevOps/ GitHub emoji

I’m really bad at remembering emoji’s. So here is cheat sheet with all emoji’s that can be used in tools that support the github emoji markdown markup: All credits go to rcaviers who created this list.

.NET 8–Keyed/Named Services

A feature that a lot of IoC container libraries support but that was missing in the default DI container provided by Microsoft is the support for Keyed or Named Services. This feature allows you to register the same type multiple times using different names, allowing you to resolve a specific instance based on the circumstances. Although there is some controversy if supporting this feature is a good idea or not, it certainly can be handy. To support this feature a new interface IKeyedServiceProvider got introduced in .NET 8 providing 2 new methods on our ServiceProvider instance: object? GetKeyedService(Type serviceType, object? serviceKey); object GetRequiredKeyedService(Type serviceType, object? serviceKey); To use it, we need to register our service using one of the new extension methods: Resolving the service can be done either through the FromKeyedServices attribute: or by injecting the IKeyedServiceProvider interface and calling the GetRequiredKeyedServic...

Kubernetes–Limit your environmental impact

Reducing the carbon footprint and CO2 emission of our (cloud) workloads, is a responsibility of all of us. If you are running a Kubernetes cluster, have a look at Kube-Green . kube-green is a simple Kubernetes operator that automatically shuts down (some of) your pods when you don't need them. A single pod produces about 11 Kg CO2eq per year( here the calculation). Reason enough to give it a try! Installing kube-green in your cluster The easiest way to install the operator in your cluster is through kubectl. We first need to install a cert-manager: kubectl apply -f https://github.com/cert-manager/cert-manager/releases/download/v1.14.5/cert-manager.yaml Remark: Wait a minute before you continue as it can take some time before the cert-manager is up & running inside your cluster. Now we can install the kube-green operator: kubectl apply -f https://github.com/kube-green/kube-green/releases/latest/download/kube-green.yaml Now in the namespace where we want t...