Skip to content

Latest commit

 

History

History
43 lines (28 loc) · 2.52 KB

README.md

File metadata and controls

43 lines (28 loc) · 2.52 KB

GitExtensions Plugin Template

An example/empty repository for building a GitExtensions plugin that can be installed using GitExtensions.PluginManager.

The package is going to be published on NuGet.org feed.

Files to keep an eye on

Nuspec

  • Place all content under lib folder. Custom nested folders are supported and path is preserved.
  • Add dependency on "virtual" package GitExtensions.Extensibility and target version [3.0,3.1) *.
  • Real package dependencies are not supported, so everything should be packed with the plugin.
  • Keep in mind that sharing common libraries can be cumbersome as these must match across all plugins and also Git Extensions itself. So my current recommendation is not to do so.

* This is just my own eperience. Git Extensions follow SemVer, but it's public plugin API is not so rich that sometimes you need to kind a hack it using APIs that are not ment to be public. For these reasons its better to check compatibility with every single feature update.

Csproj

  • I'm using powershell script to download a selected version of Git Extensions from GitHub releases. This script runs before every build and checks if Git Extensions binaries are donwloaded.
  • CSproj references selected binaries from the downloaded Git Extensions.
  • After build a newly created binaries of the plugin is copied to Git Extensions plugins directory.
  • F5 is setup to start downloaded GitExtensions.exe for easy debugging.

Plugin.cs

  • Nothing special, but ordinary Git Extensions plugin :-)

Good practices

Here are some advices that we learned over the time.

Always target single Git Extensions version

Until Git Extensions provides a stable API for developing plugins, most of the plugins must use un stable API that may change in every Git Extensions version. So it is good to always target single version when defining a package reference on GitExtensions.Extensibility.

Follow semantic versioning

Primarily when target Git Extensions version change. It gives you the options for possible patches of previous versions.

Icons

Some icons by Yusuke Kamiyamane.