Snoop https://github.com/snoopwpf
winget install --id=SnoopWpf.Snoop -e
A Windows Presentation Foundation (WPF) tool which allows you to spy/browse the visual tree of a running application (without the need for a debugger) and change properties, view triggers, set breakpoints on property changes and many more things.
README
Snoop
Snoop is an open source WPF spying utility originally created by Pete Blois and is currently maintained by Bastian Schmidt.
It allows you to spy/browse the visual, logical and automation tree of any running WPF application (without the need for a debugger).
You can change property values, view triggers, set breakpoints on property changes and many more things.
Contact
Where can i download Snoop?/How can i install Snoop?
- Chocolatey for stable and some preview versions
- GitHub releases for stable versions
- AppVeyor for the latest preview versions (built on every code change)
- You need at least .NET Framework 4.5.2 to run Snoop
Supported .NET versions
- .NET Framework >= 4.5.2
- .NET >= 3.1
- Tested with 3.1, 5, 6 and 7. Future versions might just work.
- Restrictions: Self-Contained single file applications are not supported as there is no reliable way to get a handle to the .NET runtime
Versions
You can read the changelog for details on what changed in which version.
5.0.0
Highlights:
- Improved settings system that does not rely on
System.Configuration
The new system allows sharing of settings between different snooped applications.
It also allows to define settings for whole directory trees. - It's now possible to hide properties from Snoop in it's default view.
Just annotate your properties with[System.ComponentModel.BrowsableAttribute(false)]
. - Added the ability to show browser dev tools on browser controls.
WebView2
andCefSharp
are currently supported. - Added dark theme
Breaking:
- Dropped support for all .NET Framework versions prior to .NET 4.5.2
- Dropped support for .NET 3.0
- Added support for .NET versions >= 6.0 (by not explicitly blocking versions greater than 6.0)
4.0.0
Highlights:
- Support for .NET 6.0
- Support for ARM/ARM64
- New "Diagnostics" view
- Settings for highlighting
- Artifacts are digitally signed thanks to SignPath.io (MSI, Chocolatey NUPKG and zip)
Breaking:
- Dropped support for all .NET versions prior to .NET 4.5.1
3.0.0
Highlights:
- Support for .NET Core (3.0, 3.1 and 5.0) (including self contained and single file applications)
- Rewritten injector code
- You no longer have to have installed any Microsoft Visual C++ Redistributable(s)
- Snooping disabled controls when holding
CTRL + SHIFT
works now - Snoop now filters uncommon properties by default
- Snoop is now able to show
MergedDictionaries
fromResourceDictionary
- Snoop now has two tracking modes.
- Holding
CTRL
tries to skip template parts => this is changed toCTRL + ALT
in newer versions - Holding
CTRL + SHIFT
does not skip template parts
- Holding
- Drastically improved performance of
AppChooser.Refresh()
(thanks @mikel785) - Usability improvements for process dropdown (thanks @mikel785)
- Support for displaying the logical tree and the tree of WPF automation peers
- Ability to inspect
Popup
without opening it Snoop.exe
and the injector launcher now support commandline args- Global hotkey support (just start snoop, focus a WPF application and hit
CTRL + WIN + ALT + F12
)
Known issues:
- Trying to snoop a trimmed single file application might not work as trimming might have removed things Snoop relies on
2.11.0
Highlights:
- Support for multiple app domains
- Auto elevation to enable spying of elevated processes without running Snoop as administrator
- Persistent settings for various settings
- Improved error dialog and issue reporting
- Rewritten window finder
2.10.0
Was released on September 19th, 2018. In this version we finally got rid of support for snooping WPF 3.5 applications. This allowed us to move the Snoop projects forward to Visual Studio 2017 which should make it much easier to work with Snoop's source code.
2.9.0
Was released on July 27th, 2018. The big addition in this version was the inclusion of the triggers tab which was a useful feature of another WPF spying utility called WPF Inspector (written by Christan Moser). It was ported to Snoop by Bastian Schmidt.
Documentation on how to use Snoop
Unfortunately there isn't any exhaustive documentation on how to use Snoop and there are plenty of hidden features. If someone is willing to work on this, please let me know. On the bright side, it is a pretty easy utility to use and learn. I have made three videos which should get most people quick started.
Here are the links to the current Snoop Tips & Tricks:
- http://www.cplotts.com/2011/02/10/snoop-tips-tricks-1-ctrl-shift-mouse-over
- http://www.cplotts.com/2011/02/14/snoop-tips-tricks-2-snooping-transient-visuals
- http://www.cplotts.com/2012/05/31/snoop-tips-tricks-3-the-crosshairs
Why can't I snoop .NET 3.5 applications?
Well, you can! You will just need to use Snoop 2.9.0 and earlier, in order to do so. As part of the process of moving to Visual Studio 2019, we have dropped support for .NET 3.5 applications. The minimum supported .NET version is 4.0 as of Snoop version 3.0.
Why can't I snoop .NET 4.0 and 4.5.0 applications?
Well, you can! You will just need to use Snoop 3.0.0 and earlier, in order to do so. As part of the process of moving to Visual Studio 2022, support for .NET 4.0 and 4.5.0 applications was dropped. The minimum supported .NET version is 4.5.1 as of Snoop 4.0. The minimum supported .NET version is 4.5.2 as of Snoop 5.0.
How do i build Snoop?
Just open Snoop.sln
with Visual Studio and build it.
Requirements:
- Visual Studio 2022
- C++ payloads (x86/x64 and optionally ARM/ARM64)
- You can import the .vsconfig file in the Visual Studio installer to let it install all required components
- .NET Core SDK 6.0.300 or later
Contributors
Over time contributions have been added by several people, most notably:
- Bastian Schmidt, batzen.dev (current maintainer)
- Cory Plotts, cplotts.com
- Dan Hanan
- Andrei Kashcha
- Maciek Rakowski
- Bailey Ling
Code Signing
Snoop uses free code signing provided by SignPath.io and a free code signing certificate by the SignPath Foundation