pushThreadDefault
Acquires @context and sets it as the thread-default context for the current thread. This will cause certain asynchronous operations (such as most gio-based I/O) which are started in this thread to run under @context and deliver their results to its main loop, rather than running under the global default main context in the main thread. Note that calling this function changes the context returned by func@GLib.MainContext.get_thread_default, not the one returned by func@GLib.MainContext.default, so it does not affect the context used by functions like func@GLib.idle_add.
Normally you would call this function shortly after creating a new thread, passing it a struct@GLib.MainContext which will be run by a struct@GLib.MainLoop in that thread, to set a new default context for all async operations in that thread. In this case you may not need to ever call method@GLib.MainContext.pop_thread_default, assuming you want the new struct@GLib.MainContext to be the default for the whole lifecycle of the thread.
If you don't have control over how the new thread was created (e.g. in the new thread isn't newly created, or if the thread life cycle is managed by a #GThreadPool), it is always suggested to wrap the logic that needs to use the new struct@GLib.MainContext inside a method@GLib.MainContext.push_thread_default / method@GLib.MainContext.pop_thread_default pair, otherwise threads that are re-used will end up never explicitly releasing the struct@GLib.MainContext reference they hold.
In some cases you may want to schedule a single operation in a non-default context, or temporarily use a non-default context in the main thread. In that case, you can wrap the call to the asynchronous operation inside a method@GLib.MainContext.push_thread_default / method@GLib.MainContext.pop_thread_default pair, but it is up to you to ensure that no other asynchronous operations accidentally get started while the non-default context is active.
Beware that libraries that predate this function may not correctly handle being used from a thread with a thread-default context. Eg, see g_file_supports_thread_contexts().
Since
2.22