2008-09-26 15:55:51 +02:00
|
|
|
@008-09-26 Matthias Clasen <mclasen@redhat.com>
|
|
|
|
|
|
|
|
* glib/giochannel.c: Move more docs inline, and improve them
|
|
|
|
on the way.
|
|
|
|
|
2008-09-25 21:59:49 +02:00
|
|
|
2008-09-25 Tor Lillqvist <tml@novell.com>
|
|
|
|
|
|
|
|
Bug 553820 - gpoll.c: undeclared identifier
|
|
|
|
|
|
|
|
* glib/gmain.c
|
|
|
|
* glib/gpoll.c: Make the g_poll() function non-static also on
|
|
|
|
Windows. Prefix an underscore to the g_main_poll_debug variable
|
|
|
|
and make it non-static in gmain.c so that it can be used in
|
|
|
|
gpoll.c. Add back missing variable declaration.
|
|
|
|
|
2008-09-25 10:05:41 +02:00
|
|
|
2008-09-25 Tor Lillqvist <tml@novell.com>
|
|
|
|
|
|
|
|
* glib/gspawn-win32.c (do_spawn_with_pipes) (do_spawn_directly):
|
|
|
|
Just ignore the child_setup function, never call it. The is no
|
|
|
|
situation in which it could be useful on Windows. Do print a
|
|
|
|
warning, like before.
|
|
|
|
|
|
|
|
* glib/gspawn.c (g_spawn_async_with_pipes): Corresponding change
|
|
|
|
in documentation.
|
|
|
|
|
2008-09-24 15:44:27 +02:00
|
|
|
2008-09-24 Sven Herzberg <sven@imendio.com>
|
|
|
|
|
|
|
|
Be a little more explcit in the docs. Includes Owen's requested
|
|
|
|
changes.
|
|
|
|
|
|
|
|
* glib/gmain.c: improved documentation for g_source_attach() and
|
|
|
|
g_source_destroy()
|
|
|
|
|
2008-09-23 20:56:31 +02:00
|
|
|
2008-09-23 Michael Natterer <mitch@imendio.com>
|
|
|
|
|
|
|
|
* glib/glib.h: #include <glib/gpoll.h>
|
|
|
|
|
|
|
|
* glib/gpoll.h: #error out if gpoll.h is included directly.
|
|
|
|
|
|
|
|
* glib/gpoll.c: remove trailing whitespace.
|
|
|
|
|
2008-09-23 18:41:37 +02:00
|
|
|
2008-09-23 Dan Winship <danw@gnome.org>
|
|
|
|
|
2008-09-23 20:56:31 +02:00
|
|
|
* glib/gpoll.[ch] (g_poll): Move this out of gmain.c and make it part
|
2008-09-23 18:41:37 +02:00
|
|
|
of the public API. (Part of Bug 505361 - gunixinputstream.c assumes
|
|
|
|
poll() available.)
|
|
|
|
|
2008-09-23 17:35:12 +02:00
|
|
|
2008-09-23 Tor Lillqvist <tml@novell.com>
|
|
|
|
|
|
|
|
* glib/gmain.c (poll_rest) [Win32]: Fix embarrassing bug: I was
|
|
|
|
passing an incorrect third parameter to memmove(), had forgotten
|
|
|
|
to multiply by the size of the table entry. Just use a for loop
|
|
|
|
instead, clearer. Odd I didn't notice when testing this code.
|
|
|
|
|
Rewrite most of GHashTable to use open addressing with quadratic probing
2008-09-19 Hans Petter Jansson <hpj@novell.com>
Rewrite most of GHashTable to use open addressing with quadratic
probing instead of chaining. This has the potential to reduce memory
fragmentation significantly, while being slightly faster due to
better locality and no need to call alloc/free functions for nodes.
Benchmarks suggest it also uses less memory overall.
* glib/ghash.c (prime_mod): Table of suitable primes for
initial-probe distribution.
(g_hash_table_set_shift): New function.
(g_hash_table_find_closest_shift): New function.
(g_hash_table_set_shift_from_size): New function.
(g_hash_table_lookup_node_for_insertion): New function.
(g_hash_table_lookup_node): Rewritten to return node index instead of
pointer, use quadratic probe on flat table, and not return insertion
data. The latter saves some computation for read-only lookups.
(g_hash_table_remove_node): Rewrite to take a pointer directly to the
node structure to remove, and clear that. Remove unlinking code.
(g_hash_table_remove_all_nodes): Rewrite to not clear nodes
individually, but en masse using memset () after potentially calling
notify functions.
(iter_remove_or_steal): Use new data structure and algorithm. Vastly
simplified - now just a call to g_hash_table_remove_node ().
(g_hash_table_resize): New resize code, re-indexing with new prime
and cleaning up tombstones.
(g_hash_table_maybe_resize): Table may hold 8 buckets minimum, no less
than 1/4 load excluding tombstones, and no more than 15/16 load
including tombstones. These numbers are the results of a lot of
benchmarking with multiple complex applications, and should not be
changed lightly.
(g_hash_table_iter_next)
(g_hash_table_lookup)
(g_hash_table_lookup_extended)
(g_hash_table_insert_internal)
(g_hash_table_remove_internal)
(g_hash_table_foreach_remove_or_steal)
(g_hash_table_foreach)
(g_hash_table_find)
(g_hash_table_get_keys)
(g_hash_table_get_values): Use new data structure and algorithm,
fairly trivial changes.
svn path=/trunk/; revision=7518
2008-09-20 06:05:11 +02:00
|
|
|
2008-09-19 Hans Petter Jansson <hpj@novell.com>
|
|
|
|
|
|
|
|
Rewrite most of GHashTable to use open addressing with quadratic
|
|
|
|
probing instead of chaining. This has the potential to reduce memory
|
|
|
|
fragmentation significantly, while being slightly faster due to
|
|
|
|
better locality and no need to call alloc/free functions for nodes.
|
|
|
|
Benchmarks suggest it also uses less memory overall.
|
|
|
|
|
|
|
|
* glib/ghash.c (prime_mod): Table of suitable primes for
|
|
|
|
initial-probe distribution.
|
|
|
|
(g_hash_table_set_shift): New function.
|
|
|
|
(g_hash_table_find_closest_shift): New function.
|
|
|
|
(g_hash_table_set_shift_from_size): New function.
|
|
|
|
(g_hash_table_lookup_node_for_insertion): New function.
|
|
|
|
(g_hash_table_lookup_node): Rewritten to return node index instead of
|
|
|
|
pointer, use quadratic probe on flat table, and not return insertion
|
|
|
|
data. The latter saves some computation for read-only lookups.
|
|
|
|
(g_hash_table_remove_node): Rewrite to take a pointer directly to the
|
|
|
|
node structure to remove, and clear that. Remove unlinking code.
|
|
|
|
(g_hash_table_remove_all_nodes): Rewrite to not clear nodes
|
|
|
|
individually, but en masse using memset () after potentially calling
|
|
|
|
notify functions.
|
|
|
|
(iter_remove_or_steal): Use new data structure and algorithm. Vastly
|
|
|
|
simplified - now just a call to g_hash_table_remove_node ().
|
|
|
|
(g_hash_table_resize): New resize code, re-indexing with new prime
|
|
|
|
and cleaning up tombstones.
|
|
|
|
(g_hash_table_maybe_resize): Table may hold 8 buckets minimum, no less
|
|
|
|
than 1/4 load excluding tombstones, and no more than 15/16 load
|
|
|
|
including tombstones. These numbers are the results of a lot of
|
|
|
|
benchmarking with multiple complex applications, and should not be
|
|
|
|
changed lightly.
|
|
|
|
(g_hash_table_iter_next)
|
|
|
|
(g_hash_table_lookup)
|
|
|
|
(g_hash_table_lookup_extended)
|
|
|
|
(g_hash_table_insert_internal)
|
|
|
|
(g_hash_table_remove_internal)
|
|
|
|
(g_hash_table_foreach_remove_or_steal)
|
|
|
|
(g_hash_table_foreach)
|
|
|
|
(g_hash_table_find)
|
|
|
|
(g_hash_table_get_keys)
|
|
|
|
(g_hash_table_get_values): Use new data structure and algorithm,
|
|
|
|
fairly trivial changes.
|
|
|
|
|
2008-09-19 12:20:41 +02:00
|
|
|
2008-09-19 Tor Lillqvist <tml@novell.com>
|
|
|
|
|
2008-09-19 12:42:04 +02:00
|
|
|
* glib-zip.in: Look for man pages in share/man.
|
|
|
|
|
2008-09-19 12:20:41 +02:00
|
|
|
* glib/gutils.c (_glib_get_dll_directory)
|
|
|
|
* glib/gspawn-win32.c (do_spawn_with_pipes): Be a bit less
|
|
|
|
restrictive, look for the helper programs in the same folder where
|
|
|
|
the GLib DLL is, not necessarily in a "bin" subfolder of the top
|
|
|
|
GLib installation folder.
|
|
|
|
|
2008-09-18 16:47:14 +02:00
|
|
|
2008-09-18 Matthias Clasen <mclasen@redhat.com>
|
2008-09-18 00:52:48 +02:00
|
|
|
|
2008-09-18 16:47:14 +02:00
|
|
|
* configure.in: Bump version to 2.19.0
|
2008-09-18 01:58:48 +02:00
|
|
|
|
2008-09-18 16:47:14 +02:00
|
|
|
* ChangeLog.pre-2-18: rotate ChangeLog
|
2007-11-08 03:54:39 +01:00
|
|
|
|
2008-09-18 16:47:14 +02:00
|
|
|
* === branch for 2.18 ===
|