Extending the debugger through moldable exceptions
In Glamorous Toolkit exceptions are moldable. They can define custom debugging views and actions shown in a domain-specific debugger tailored to that exception.
To achieve this, exception can define debugging views simply by defining normal inspector views and annotating them with the pragma gtExceptionView
. When an exception defines one or more such views, a domain-specific debugger is enabled that directly shows those views.
For more details on how to configure the domain-specific debugger attached to an exception see Configuring moldable exceptions.
The exception GtExampleExceptionWithDebuggingView
defines a view in that method #selector
that shows a comparison betwen an expected and an obtained value.
The debugging view is defined as a normal inspector view attached to the exception object. This means that we can see the view also when inspecting the exception object.
data:image/s3,"s3://crabby-images/f8d2a/f8d2aed9328bc6cae075fe03ff9e4f26e98e3f2f" alt=""
Whenever the exception is not handled, a new domain-specific debugger is enabled that shows the debugging view defined by this exception.
data:image/s3,"s3://crabby-images/8e28f/8e28fe93bf0de8c93b87969209884c6d7569525f" alt=""
The normal debugger is also available. Above, there is a tab labeled "GT Debugger"
that switches to the default debugger.
We are not limited to a single debugging view within an exception. Exceptions can define multiple debugging views. The exception GtExampleComparisonExceptionWithDebuggingViews
defines two debugging views, #selector
and #selector
.
Both these views are then shown when we encounter this exception, by using a tab widget.
data:image/s3,"s3://crabby-images/3723b/3723b063711a7ec28e25e2e0b0d58dfd46fb027c" alt=""