summaryrefslogtreecommitdiff
Commit message (Collapse)AuthorAgeFilesLines
* Remove all nicks and blurbs from param specswip/sophie-h/remove-nick-blurbSophie Herold2023-04-2895-896/+307
| | | | | | | Nicks and blurbs don't have any practical use for gio/gobject libraries. Leaving tests untouched since this features is still used by other libraries. Closes #2991
* Merge branch 'thread-pool-docs-fix' into 'main'Patrick Griffis2023-04-271-0/+3
|\ | | | | | | | | gthreadpool: Clarify that item_free_func is not normally called See merge request GNOME/glib!3406
| * gthreadpool: Clarify that item_free_func is not normally calledPhilip Withnall2023-04-271-0/+3
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | If you’re only quickly looking at the API signature, it looks like `item_free_func` will be called for all items enqueued to the thread pool. As it happens, it’s actually only called for the items which are still enqueued when the thread pool is destroyed. The user’s `GFunc` is responsible for freeing items which are successfully dequeued and processed during the lifetime of the thread pool. That’s a bit of a gotcha, so document it more explicitly. Signed-off-by: Philip Withnall <pwithnall@endlessos.org>
* | Merge branch 'threaded-resolver-assertion-fix' into 'main'Michael Catanzaro2023-04-271-3/+0
|\ \ | |/ |/| | | | | gthreadedresolver: Remove some incorrect assertions See merge request GNOME/glib!3405
| * gthreadedresolver: Remove some incorrect assertionsPhilip Withnall2023-04-271-3/+0
|/ | | | | | | | | | If a timeout executes on the same main context iteration as completion or cancellation of a resolver lookup, `has_returned` will be set multiple times. That’s fine (the `GCond` will be notified multiple times, but that’s fine). It was triggering an incorrect assertion, so remove that. Signed-off-by: Philip Withnall <pwithnall@endlessos.org>
* Merge branch 'resolver-thread-pool' into 'main'Philip Withnall2023-04-276-134/+626
|\ | | | | | | | | gthreadedresolver: Switch to using a separate thread pool and support timeouts See merge request GNOME/glib!3397
| * gresolver: Set timeout on default resolver to 30sPhilip Withnall2023-04-271-1/+7
| | | | | | | | | | | | | | | | | | | | | | | | | | The default for the class is still to have no timeout, but it seems more practical for most use cases to set a non-infinite timeout on the default resolver. If applications have a more specific use case, they can change the timeout or replace the default resolver. See https://gitlab.gnome.org/GNOME/glib/-/merge_requests/3397#note_1731387 Signed-off-by: Philip Withnall <pwithnall@endlessos.org>
| * tests: Fix cancellation source handling in resolver manual testPhilip Withnall2023-04-271-4/+7
| | | | | | | | | | | | | | | | | | | | If `async_cancel()` was invoked, it would remove the IO watch source, which would cause the `g_source_remove()` call at the end of `main()` to warn about an unknown source ID. Fix that by handling the source as a pointer instead of a handle. Signed-off-by: Philip Withnall <pwithnall@endlessos.org>
| * tests: Support --timeout argument in resolver manual testPhilip Withnall2023-04-271-0/+5
| | | | | | | | | | | | For testing timeouts. Signed-off-by: Philip Withnall <pwithnall@endlessos.org>
| * gthreadedresolver: Document design of GThreadedResolverPhilip Withnall2023-04-271-0/+41
| | | | | | | | Signed-off-by: Philip Withnall <pwithnall@endlessos.org>
| * gthreadedresolver: Re-add cancellation and add timeout supportPhilip Withnall2023-04-271-0/+97
| | | | | | | | Signed-off-by: Philip Withnall <pwithnall@endlessos.org>
| * gthreadedresolver: Switch to using a separate thread poolPhilip Withnall2023-04-271-36/+162
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Rather than running lookups in the global shared thread pool belonging to `GTask`, run them in a private thread pool. This is needed because the global shared thread pool is constrained to only 14 threads. If there are 14 ongoing calls to `g_task_run_in_thread()` from any library/code in the process, and then one of them asks to do a DNS lookup, the lookup will block forever. Under certain circumstances, particularly where there are a couple of deep chains of dependent tasks running with `g_task_run_in_thread()`, this can livelock the program. Since `GResolver` is likely to be called as a frequent leaf call in certain workloads, and in particular there are likely to be several lookups requested at the same time, it makes sense to move resolver lookups to a private thread pool. Signed-off-by: Philip Withnall <pwithnall@endlessos.org>
| * gthreadedresolver: Centralise GTask return handling in worker threadsPhilip Withnall2023-04-271-63/+113
| | | | | | | | | | | | | | | | | | | | | | | | This will make it simpler to handle timeouts and cancellation in future, as all the logic for working out whether to return will all be in one place, and all the lookup-specific code is now implemented in simple sync functions which don’t need to care about `GTask`s. This commit introduces no functional changes, it’s just setting up for the following commit. Signed-off-by: Philip Withnall <pwithnall@endlessos.org>
| * gthreadedresolver: Combine closure structs for different lookup typesPhilip Withnall2023-04-271-51/+93
| | | | | | | | | | | | | | | | | | | | This introduces no functional changes, but will make a reorganisation of the code simpler in the next commit. Rather than dealing with three different closure types, this changes the code to deal with one which is a tagged union of the three. Signed-off-by: Philip Withnall <pwithnall@endlessos.org>
| * gthreadedresolver: Port to G_DECLARE_FINAL_TYPEPhilip Withnall2023-04-272-15/+14
| | | | | | | | | | | | | | | | | | | | The class and its header are not public, so this should not be an API or ABI break. This just simplifies the code a little and allows for easy extension of the object’s private data in future commits. Signed-off-by: Philip Withnall <pwithnall@endlessos.org>
| * gresolver: Add GResolver:timeout propertyPhilip Withnall2023-04-273-2/+121
| | | | | | | | | | | | | | | | | | | | | | | | | | Without a timeout, some lookup requests can go on forever, typically due to bugs in underlying systems. This can have particularly significant effects on the Happy Eyeballs algorithm in `GSocketClient`, which relies on multiple name lookups as its first step. Signed-off-by: Philip Withnall <pwithnall@endlessos.org> Helps: #2866
| * gthreadedresolver: Add some additional debug printsPhilip Withnall2023-04-251-0/+4
| | | | | | | | | | | | | | These make it a bit easier to track the ongoing resolver tasks, as the tasks and/or their closures are not tracked in a big list somewhere. Signed-off-by: Philip Withnall <pwithnall@endlessos.org>
* | Merge branch 'task-tracking' into 'main'Philip Withnall2023-04-272-0/+71
|\ \ | | | | | | | | | | | | gtask: Track pending GTasks if G_ENABLE_DEBUG is defined See merge request GNOME/glib!3404
| * | gtask: Track pending GTasks if G_ENABLE_DEBUG is definedPhilip Withnall2023-04-272-0/+71
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Track the `GTask`s which are still alive (not finalised) in a shared list, and provide a secret debugging function for printing that list. Too often when debugging apps, I have found that a ‘leaked’ object is actually still (validly) referenced by an ongoing `GTask` which hasn’t completed for whatever reason. Or I have found that an operation has obviously stalled, but there are no pointers available to the `GTask` which is stalled, because it’s being tracked as a collection of closure pointers from some `GSource` which is hard to get to in the debugger. It will be very useful for debugging apps, if there’s a list of all the still alive `GTask`s somewhere. This is that list. The code is disabled if `G_ENABLE_DEBUG` is not defined, to avoid every `GTask` construction/finalisation imposing a global locking penalty. To use the new list, break in `gdb` while running your app, and call `g_task_print_alive_tasks()`, or inspect the `task_list` manually: ``` (gdb) print g_task_print_alive_tasks() 16:44:17:788 GLib-GIO 5 GTasks still alive: • GTask 0x6100000ac740, gs_plugin_appstream_setup_async, ref count: 1, ever_returned: 0, completed: 0 • GTask 0x6100000bf940, [gio] D-Bus read, ref count: 2, ever_returned: 0, completed: 0 • GTask 0x6100000aac40, gs_plugin_loader_setup_async, ref count: 1, ever_returned: 0, completed: 0 • GTask 0x61000006d940, gs_plugin_loader_job_process_async GsPluginJobRefine, ref count: 1, ever_returned: 0, completed: 0 • GTask 0x610000118c40, [gio] D-Bus read, ref count: 2, ever_returned: 0, completed: 0 ``` Signed-off-by: Philip Withnall <pwithnall@endlessos.org>
* | | Merge branch '2951-reinstate-fileinfo-criticals' into 'main'Philip Withnall2023-04-271-4/+4
|\ \ \ | | | | | | | | | | | | | | | | | | | | | | | | Revert "gfileinfo: Temporarily downgrade missing attribute criticals to debugs" Closes #2951 See merge request GNOME/glib!3379
| * | | Revert "gfileinfo: Temporarily downgrade missing attribute criticals to debugs"Philip Withnall2023-04-141-4/+4
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This reverts commit 4cad66580b698e01d196cddc3b9950940a41fee9. Downgrading the criticals was only temporary. Now we’ve branched for GLib 2.78, the criticals can be reinstated early this cycle, so people have the maximum time to fix latent bugs in their code. Fixes: #2951
* | | | Merge branch '98-current-path' into 'main'Marco Trevisan2023-04-271-10/+14
|\ \ \ \ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | gfileutils: Fix potential integer overflow in g_get_current_dir() Closes #98 See merge request GNOME/glib!3375
| * | | | gfileutils: Fix potential integer overflow in g_get_current_dir()Philip Withnall2023-04-141-10/+14
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | In practice, this will never happen. If `getcwd()` returns `ERANGE` whenever the working directory is ≥ `PATH_MAX`, though, the previous implementation of the loop would run until `max_len == G_MAXULONG`, and would then overflow when adding `1` to it for a nul terminator in the allocation. Avoid that problem by always keeping `buffer_len` as a power of two, and relying on `getcwd()` to write a nul terminator within the buffer space it’s given. It seems to do this on all platforms we care about, because the previous version of the code never explicitly wrote a nul terminator anywhere. Signed-off-by: Philip Withnall <pwithnall@endlessos.org> Fixes: #98
* | | | | Update Galician translationFran Dieguez2023-04-271-255/+255
| | | | | | | | | | | | | | | | | | | | (cherry picked from commit 665d01fbca7a1d0bbe98d95fbcb3ee925b5d03b4)
* | | | | Merge branch 'disable-coverity' into 'main'Michael Catanzaro2023-04-261-1/+1
|\ \ \ \ \ | |_|_|/ / |/| | | | | | | | | | | | | | ci: Disable the Coverity CI job See merge request GNOME/glib!3401
| * | | | ci: Disable the Coverity CI jobPhilip Withnall2023-04-261-1/+1
| | |_|/ | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | It’s not produced anything but false positives for several years now, and it would be better to save the CI/analysis/triage resources and instead focus on `scan_build` reports, which generally seem to be more useful. Signed-off-by: Philip Withnall <pwithnall@endlessos.org>
* | | | Merge branch 'update-errfmt-in-gunixconnection-part3' into 'main'Philip Withnall2023-04-261-14/+20
|\ \ \ \ | | | | | | | | | | | | | | | | | | | | restore error messages in gunixconnection while maintaining older compiler support See merge request GNOME/glib!3400
| * | | | gio: switch gunixconnection ngettext with g_dngettext callsJames Knight2023-04-251-10/+13
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This commit changes the use of `ngettext` with `g_dngettext`. The project defined `g_dngettext` (with domain support) provides the same functionality as `ngettext` with a NULL domain provided. The purpose of this change is to help address a build error for certain compilers that trigger a `format-nonliteral` error-promoted-warning when using `ngettext` (see also [1][2]). The benefit of switching to use `g_dngettext` is that the function is defined with `G_GNUC_FORMAT`. This provides a hint to GNU GCC compilers to still sanity check these arguments, but not generate a `format-nonliteral`. [1]: 4ae8606b6f80f9764e1f0a82cea7e23c8af487ae [2]: 0ca660315a9044696f778da087a6e3dd8910a765 Signed-off-by: James Knight <james.d.knight@live.com>
| * | | | Revert "Fix error format in gio/gunixconnection.c (part 2)"James Knight2023-04-251-14/+17
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This reverts commit 4ae8606b6f80f9764e1f0a82cea7e23c8af487ae. The idea for the change [1] was to address a build error for certain compilers that trigger a `format-nonliteral` error-promoted-warning since these compilers do not gracefully support `ngettext` usage. The changes following a pattern from an old commit [2]; however, James Hilliard has pointed out these changes do not work as intended. A deeper inspection of the commit showed that the commit was from an old merge request that was not pulled in, detailing why the changes did not work (see also [3][4]). Manipulating the sockets unit test confirms that the format values no longer get a proper value: ... ok 9 /socket/address ok 10 /socket/unix-from-fd ok 11 /socket/unix-connection ** GLib-GIO:ERROR:../gio/tests/socket.c:1493:test_unix_connection_ancillary_data: assertion failed (err == NULL): Expecting one fd, but got %d (g-io-error-quark, 0) ... And reverting this change restores the original functionality: ... ok 9 /socket/address ok 10 /socket/unix-from-fd ok 11 /socket/unix-connection ** GLib-GIO:ERROR:../gio/tests/socket.c:1493:test_unix_connection_ancillary_data: assertion failed (err == NULL): Expecting 1 control message, got 0 (g-io-error-quark, 0) ... [1]: https://gitlab.gnome.org/GNOME/glib/-/merge_requests/3390 [2]: 44b3d5d80445234041f6c59feb89645f7102c3a4 [3]: https://gitlab.gnome.org/GNOME/glib/-/merge_requests/770 [4]: https://gitlab.gnome.org/GNOME/glib/-/issues/1744 Signed-off-by: James Knight <james.d.knight@live.com>
* | | | | Merge branch 'task-shared-resource-docs' into 'main'Philip Withnall2023-04-261-0/+7
|\ \ \ \ \ | | | | | | | | | | | | | | | | | | | | | | | | gtask: Document that g_task_run_in_thread() uses a shared resource See merge request GNOME/glib!3395
| * | | | | gtask: Document that g_task_run_in_thread() uses a shared resourcePhilip Withnall2023-04-251-0/+7
| | |/ / / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | It’s a bad idea to use it without some care for how much it’s being called in parallel, or dependencies between tasks. If the thread pool gets exhausted by too many inter-dependent calls to `g_task_run_in_thread()` then the process will livelock. Signed-off-by: Philip Withnall <pwithnall@endlessos.org>
* | | | | Merge branch 'unix-fd-source-docs' into 'main'Philip Withnall2023-04-261-3/+6
|\ \ \ \ \ | | | | | | | | | | | | | | | | | | | | | | | | glib-unix: Improve documentation for g_unix_fd_source_new() See merge request GNOME/glib!3396
| * | | | | glib-unix: Improve documentation for g_unix_fd_source_new()Philip Withnall2023-04-251-3/+6
| |/ / / / | | | | | | | | | | | | | | | | | | | | | | | | | In particular, document the type of the callback function. Signed-off-by: Philip Withnall <pwithnall@endlessos.org>
* | | | | Merge branch 'pkj/fix-g_futex_simple' into 'main'Sebastian Dröge2023-04-261-1/+5
|\ \ \ \ \ | |_|/ / / |/| | | | | | | | | | | | | | Avoid having g_futex_simple() inadvertently modify errno See merge request GNOME/glib!3398
| * | | | Avoid having g_futex_simple() inadvertently modify errnoPeter Kjellerstedt2023-04-261-1/+5
|/ / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | If both __NR_futex and __NR_futex_time64 are defined, g_futex_simple() will first call futex_time64(). If that fails with ENOSYS, then futex_time() is called instead. However, errno was not saved and restored in this case, which would result in g_futex_simple() returning with errno set to ENOSYS, even if futex_time() succeeded.
* | | | Merge branch 'doc-indentation' into 'main'Philip Withnall2023-04-242-2/+2
|\ \ \ \ | | | | | | | | | | | | | | | | | | | | Fix small issues in docs See merge request GNOME/glib!3393
| * | | | Fix small issues in docsArjan Molenaar2023-04-242-2/+2
| |/ / / | | | | | | | | | | | | | | | | This will make converting the docs to another format (say, rst) somewhat easier.
* | | | Merge branch 'context-checks' into 'main'Philip Withnall2023-04-241-2/+19
|\ \ \ \ | | | | | | | | | | | | | | | | | | | | gmain: More explicitly document g_main_context_release() prereqs See merge request GNOME/glib!3314
| * | | | gmain: Add precondition assertions to g_main_context_release()Philip Withnall2023-04-241-1/+15
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | As with the previous commit. The logic has to be a little contorted here to avoid leaving the context locked after emitting the critical warning. Execution does (and should) continue after a critical warning by default, so we should do our best to recover. Inspired by https://gitlab.gnome.org/GNOME/glib/-/merge_requests/3302. Signed-off-by: Philip Withnall <pwithnall@endlessos.org>
| * | | | gmain: More explicitly document g_main_context_release() prereqsPhilip Withnall2023-04-241-1/+4
| |/ / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The documentation was fairly clear before, but we can make it clearer: it’s a programming error to call `g_main_context_release()` if you have not received a true return value from `g_main_context_acquire()` before. Inspired by https://gitlab.gnome.org/GNOME/glib/-/merge_requests/3302. Signed-off-by: Philip Withnall <pwithnall@endlessos.org>
* | | | Merge branch 'ebassi/refcount-init-macros' into 'main'Philip Withnall2023-04-242-0/+56
|\ \ \ \ | |/ / / |/| | | | | | | | | | | Add init macros for refcounting types See merge request GNOME/glib!3366
| * | | Add init macros for refcounting typesEmmanuele Bassi2023-04-242-0/+56
|/ / / | | | | | | | | | | | | | | | We need a way to initialise refcounted types placed in static storage, or on the stack. Using proper macros avoids knowing the magic constant used for grefcount and gatomicrefcount.
* | | Merge branch 'gmain-less-locks' into 'main'Philip Withnall2023-04-242-83/+206
|\ \ \ | | | | | | | | | | | | | | | | gmain: Avoid some lock/unlock dance during g_main_context_iterate See merge request GNOME/glib!3235
| * | | gmain: Do not dead-look if calling g_main_loop_run from a GSourceMarco Trevisan (Treviño)2023-04-192-1/+73
| | | | | | | | | | | | | | | | | | | | | | | | | | | | This should fail and warn but not leaving the context acquired and locked. Add tests.
| * | | gmain: Avoid locking dance in g_main_loop_run()Marco Trevisan (Treviño)2023-04-191-9/+8
| | | | | | | | | | | | | | | | | | | | We do it during initialization, this may be if necessary handled by GCond in case we need to acquire the lock.
| * | | gmain: Avoid some lock/unlock dance during g_main_context_iterateMarco Trevisan (Treviño)2023-04-191-73/+125
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | A context iteration we're doing lots of lock/unlocks and that's fine to give other threads contexts a chance to run, but we're doing it also just to call other functions that require locking, and this can be avoided. Other threads can still have a chance to run while releasing the ownership of the context.
* | | | Merge branch 'mutex-tests-more' into 'main'Philip Withnall2023-04-242-2/+2
|\ \ \ \ | | | | | | | | | | | | | | | | | | | | glib/tests/[rec-]mutex: Allow each thread to work See merge request GNOME/glib!3389
| * | | | glib/tests/[rec-]mutex: Allow each thread to workMarco Trevisan (Treviño)2023-04-202-2/+2
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | In non-perf mode, we were making only one thread to win the race to increase the value, but since we're launching more threads anyways let's allow more of them to have a chance to do something, to make the test more valuable, even if it's still quick enough.
* | | | | Merge branch ↵Philip Withnall2023-04-241-0/+14
|\ \ \ \ \ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 'pgorszkowski/add_tests_for_g_signal_handlers_disconnect_matched' into 'main' Test g_signal_handlers_disconnect_matched for G_SIGNAL_MATCH_ID match See merge request GNOME/glib!3384
| * | | | | Test g_signal_handlers_disconnect_matched for G_SIGNAL_MATCH_ID matchPrzemyslaw Gorszkowski2023-04-181-0/+14
| | | | | | | | | | | | | | | | | | | | | | | | Signed-off-by: Przemyslaw Gorszkowski <pgorszkowski@igalia.com>