The underlying DesktopAppInfo instance.
A short human-readable description of the application.
The desktop file ID (e.g. "org.gnome.Calculator.desktop").
The executable command from the desktop entry.
How many times this application has been launched.
The icon name from the desktop entry.
Check if service has been disposed
The display name of the application.
The WM_CLASS hint used for window matching.
Optionalfrequency: numberCreates a Binding for a property on this service.
The property to bind
A Binding that can be used in widget constructors
Notifies listeners that a property changed and emits the 'changed' signal.
The property name that changed
Connects a callback to a signal on this service.
The signal name (defaults to 'changed')
The callback to invoke when the signal is emitted
The signal connection ID
Creates an incremental list binding that reuses existing widgets.
Instead of recreating all widgets on every update, this method caches widgets by a key function and only creates new widgets for new items, destroying widgets for removed items.
A Binding that produces an array of widgets
ProtecteddisconnectClean up all tracked signal connections Call this in service-specific dispose implementations
Dispose of service resources Override in subclasses to add specific cleanup
Emits a signal, warning if the signal was not registered via Service.register.
The warning is cheap (a Set lookup per emit) and helps catch typos
and missing signal declarations that silently break .bind().
ReadonlygetRetrieves a string value from the desktop entry by key.
The desktop entry key to look up
The string value or null
ReadonlylaunchLaunches the application and increments its frequency counter.
ReadonlymatchTests whether the application matches the given search term.
Case-insensitive search string matched against name, desktop, executable, and description
True if any field contains the search term
ProtectedretryProtectedtrackTrack a signal connection for automatic cleanup
The object the signal is connected to (defaults to this)
The signal connection ID
Track a signal connection for automatic cleanup
The signal connection ID
Updates a property value and emits a notify signal if the value changed.
Performs a deep equality check via JSON serialization to avoid unnecessary notifications.
The property name in kebab-case
The new value
StaticimportStaticpspecStaticregister
Application
Represents a single desktop application entry with launch frequency tracking.
Fires
changed - Emitted when application properties change