SharpShell makes it easy to create Windows Shell Extensions using the .NET Framework.
- Official NuGet Packages
- Documentation
- Deploying SharpShell Servers
- Supported Shell Extensions
- Developer Guide
- Building & Testing
- Testimonials
- Projects that use SharpShell
- Thanks
- License
Component | Package |
---|---|
SharpShell |
|
ServerRegistrationManager |
Documentation is in the process of being moved to:
Please open an issue if there is missing documentation and I will try to prioritise it!
A guide on deploying SharpShell servers is available at:
The following extensions are supported by SharpShell.
Shell Context Menus allow the context menus used in Windows Explorer to be customised.
Step by Step Tutorial on the CodeProject.
Shell Icon Handlers are DLLs that are registered in the system to customise the appearance of icons.
Step by Step Tutorial on the CodeProject.
Shell Info Tip Handlers are DLLs that are registered in the system to customise tooltips for items in the shell.
Step by Step Tutorial on the CodeProject.
Shell Drop Handlers are DLLs that are registered in the system to extend the drag and drop functionality in the Shell.
Step by Step Tutorial on the CodeProject.
Shell PreviewHandlers are dlls that can be registered in the system to allow you to create visually rich previews for items that are displayed directly in Windows Explorer.
Step by Step Tutorial on the CodeProject.
Shell Icon Overlay Handlers can be really useful. They let you display an icon overlay over shell objects to provide extra information. Programs like Dropbox use these overlays to show whether files are synchronised or not.
Step by Step Tutorial on the CodeProject.
Shell Thumbnail Handlers (or as they're sometimes known, Shell Thumbnail Providers) are COM servers that you can write to customise the appearance of the thumbnail icons in the Windows Shell.
Step by Step Tutorial on the CodeProject.
These are extensions that add extra pages to the property sheets shown for shell items such as files, network shares, folders and so on.
These are extensions which add custom functionality to the Windows Desktop or Task Bar.
SharpShell is currently developed in Visual Studio 2017, and can be built using the Community Edition.
In order to maximize compatibility, we do not use the latest version of each SDK. The following components are needed:
- Windows Universal CRT SDK
- Windows 8.1 SDK
- .NET Core runtime
- Windows Universal C Runtime
- Microsoft Visual Studio 2017 Installer Projects
Note: Not tested on VS2017 for Mac.
As long as the correct components have be installed for Visual Studio, you should be able to just open the main ./SharpShell/SharpShell.sln
solution to build, test and run any of the code or samples.
You can also use the following scripts to run the processes:
Script | Notes |
---|---|
config.ps1 |
Ensure your machine can run builds by installing necessary components such as nunit . Should only need to be run once. |
build.ps1 |
Build all solutions. Ensures that we build both 32/64 bit versions of native components. |
test.ps1 |
Run all tests, including those in samples. |
coverage.ps1 |
Create a coverage report for the main SharpShell project (samples are not included). Reports are written to ./artifacts/coverage |
These scripts will generate various artifacts which may be useful to review:
artifacts\
\build
\SharpNativeBridge # 32/64 bit native binaries for the bridge.
\SharpShell # The SharpShell assembly.
\tests # NUnit Test Reportsd
\coverage # Coverage Reports
Only assemblies and binaries which need to be copied into other projects are added to the artifacts/build
folder. This makes chaining more complex dependencies manageable. The solution is fairly standard, but be aware that:
SharpShell
depends onSharpNativeBridge
SharpNativeBridge
should be built inx64
mode. When successful, thex64
build will trigger ax32
build, and both 32/64 bit binaries are copied to theartifacts/build/SharpNativeBridge
folder.SharpShell
copies the latest native bridge binaries to its ownNativeBridge
folder - these are then embedded in theSharpShell
assembly.- The
SharpShell
assembly is copied toartifacts/build/SharpShell
folder after a successful build. - The
SharpShell
assembly is embedded in theServerRegistrationManager
binary. The assembly is copied fromartifacts/build/SharpShell
prior to the server registration manager build.
All of the above steps are automated, and will run whether a build is trigger from Visual Studio, the build.ps1
script or msbuild
.
A detailed guide explaining how to configure and use logging for SharpShell is at:
You can also use the SharpShell-Easy-Log tool to quickly enable/disable logging options and view the logs realtime:
The tool is available at: github.com/ElektroStudios/SharpShell-Easy-Log
CI/CD is currently handled by AppVeyor. AppVeyor will:
- Build the project
- Run the tests
- Create the core SharpShell Nuget Package
- Publish the package to nuget.org if a version tag is pushed
- Create a GitHub release with the package if a version tag is pushed
Some work is still needed on the CI/CD side:
- Look at handing the changelog more effectively, with somelike like the node release tool used in my other projects.
- Look into automatic notifications for package publication.
- Deploy SRM as a NuGet package.
To create a release:
- Update the version number in
SharedAssemblyInfo.cs
- Update the
CHANGELOG.md
- Create a new version tag, then push
AppVeyor will build and publish a new NuGet package and as long as a new semver tag is pushed.
If you've used SharpShell and would like to add a testimonial, just send me a message!
CmisSync, our Dropbox-like client for Enterprise Content Management servers, just switched to SharpShell, and we are extremely pleased with this library. Our previous custom-built Windows Explorer integration was buggy, unreliable and hard to maintain, and SharpShell is really rock-solid in comparison. The best part: It only took 2 days to integrate SharpShell into our software, testing and installer included. Thanks SharpShell!
Nicolas Raoul - CmisSync.com
Send me a message to add a project to this list:
- Trello Context Menu
- REAL Shuffle Player 2.0
- The CmisSync context menu
- TenClips
- Checksum Inspector
- VSIX PowerToys
- FileSystemScanner
- Windows Explorer Thumbnails for MagicaVoxel .vox files
- Markdown Preview
- SharePoint Shell Extensions by Archon Gnosis
- .NET Assembly Info Shell Extension by ElektroStudios
- Modern UI BreadCrumbs WPF Control by Dirkster99
Many thanks to JetBrains for providing an Open Source License for their products!
SharpShell is licensed under the MIT License - the details are at LICENSE.md