mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-13 15:56:23 +01:00
gappinfo: Clarify one-shot behaviour of GAppInfoMonitor::changed in docs
Signed-off-by: Philip Withnall <pwithnall@endlessos.org> Fixes: #799
This commit is contained in:
parent
0be2555704
commit
c62643adc3
@ -1658,19 +1658,34 @@ g_app_launch_context_launch_failed (GAppLaunchContext *context,
|
|||||||
* @short_description: Monitor application information for changes
|
* @short_description: Monitor application information for changes
|
||||||
*
|
*
|
||||||
* #GAppInfoMonitor is a very simple object used for monitoring the app
|
* #GAppInfoMonitor is a very simple object used for monitoring the app
|
||||||
* info database for changes (ie: newly installed or removed
|
* info database for changes (newly installed or removed applications).
|
||||||
* applications).
|
|
||||||
*
|
*
|
||||||
* Call g_app_info_monitor_get() to get a #GAppInfoMonitor and connect
|
* Call g_app_info_monitor_get() to get a #GAppInfoMonitor and connect
|
||||||
* to the "changed" signal.
|
* to the #GAppInfoMonitor::changed signal. The signal will be emitted once when
|
||||||
|
* the app info database changes, and will not be emitted again until after the
|
||||||
|
* next call to g_app_info_get_all() or another `g_app_info_*()` function. This
|
||||||
|
* is because monitoring the app info database for changes is expensive.
|
||||||
|
*
|
||||||
|
* The following functions will re-arm the #GAppInfoMonitor::changed signal so
|
||||||
|
* it can be emitted again:
|
||||||
|
* - g_app_info_get_all()
|
||||||
|
* - g_app_info_get_all_for_type()
|
||||||
|
* - g_app_info_get_default_for_type()
|
||||||
|
* - g_app_info_get_fallback_for_type()
|
||||||
|
* - g_app_info_get_recommended_for_type()
|
||||||
|
* - g_desktop_app_info_get_implementations()
|
||||||
|
* - g_desktop_app_info_new()
|
||||||
|
* - g_desktop_app_info_new_from_filename()
|
||||||
|
* - g_desktop_app_info_new_from_keyfile()
|
||||||
|
* - g_desktop_app_info_search()
|
||||||
*
|
*
|
||||||
* In the usual case, applications should try to make note of the change
|
* In the usual case, applications should try to make note of the change
|
||||||
* (doing things like invalidating caches) but not act on it. In
|
* (doing things like invalidating caches) but not act on it. In
|
||||||
* particular, applications should avoid making calls to #GAppInfo APIs
|
* particular, applications should avoid making calls to #GAppInfo APIs
|
||||||
* in response to the change signal, deferring these until the time that
|
* in response to the change signal, deferring these until the time that
|
||||||
* the data is actually required. The exception to this case is when
|
* the updated data is actually required. The exception to this case is when
|
||||||
* application information is actually being displayed on the screen
|
* application information is actually being displayed on the screen
|
||||||
* (eg: during a search or when the list of all applications is shown).
|
* (for example, during a search or when the list of all applications is shown).
|
||||||
* The reason for this is that changes to the list of installed
|
* The reason for this is that changes to the list of installed
|
||||||
* applications often come in groups (like during system updates) and
|
* applications often come in groups (like during system updates) and
|
||||||
* rescanning the list on every change is pointless and expensive.
|
* rescanning the list on every change is pointless and expensive.
|
||||||
@ -1728,8 +1743,10 @@ g_app_info_monitor_class_init (GAppInfoMonitorClass *class)
|
|||||||
/**
|
/**
|
||||||
* GAppInfoMonitor::changed:
|
* GAppInfoMonitor::changed:
|
||||||
*
|
*
|
||||||
* Signal emitted when the app info database for changes (ie: newly installed
|
* Signal emitted when the app info database changes, when applications are
|
||||||
* or removed applications).
|
* installed or removed.
|
||||||
|
*
|
||||||
|
* Since: 2.40
|
||||||
**/
|
**/
|
||||||
g_app_info_monitor_changed_signal = g_signal_new (I_("changed"), G_TYPE_APP_INFO_MONITOR, G_SIGNAL_RUN_FIRST,
|
g_app_info_monitor_changed_signal = g_signal_new (I_("changed"), G_TYPE_APP_INFO_MONITOR, G_SIGNAL_RUN_FIRST,
|
||||||
0, NULL, NULL, g_cclosure_marshal_VOID__VOID, G_TYPE_NONE, 0);
|
0, NULL, NULL, g_cclosure_marshal_VOID__VOID, G_TYPE_NONE, 0);
|
||||||
@ -1747,6 +1764,10 @@ g_app_info_monitor_class_init (GAppInfoMonitorClass *class)
|
|||||||
* thread-default main context whenever the list of installed
|
* thread-default main context whenever the list of installed
|
||||||
* applications (as reported by g_app_info_get_all()) may have changed.
|
* applications (as reported by g_app_info_get_all()) may have changed.
|
||||||
*
|
*
|
||||||
|
* The #GAppInfoMonitor::changed signal will only be emitted once until
|
||||||
|
* g_app_info_get_all() (or another `g_app_info_*()` function) is called. Doing
|
||||||
|
* so will re-arm the signal ready to notify about the next change.
|
||||||
|
*
|
||||||
* You must only call g_object_unref() on the return value from under
|
* You must only call g_object_unref() on the return value from under
|
||||||
* the same main context as you created it.
|
* the same main context as you created it.
|
||||||
*
|
*
|
||||||
|
Loading…
Reference in New Issue
Block a user