2003-02-13 Anders Carlsson <andersca@codefactory.se>
[platform/upstream/dbus.git] / ChangeLog
index 6b3a014..aa82d19 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
+2003-02-13  Anders Carlsson  <andersca@codefactory.se>
+
+       * bus/desktop-file.c: (parse_section_start), (parse_key_value),
+       (report_error), (bus_desktop_file_load), (lookup_section),
+       (lookup_line), (bus_desktop_file_get_raw),
+       (bus_desktop_file_get_string):
+       * bus/desktop-file.h:
+       Some fixes, and new functions for getting a key value from a section.
+       
+2003-02-13  Havoc Pennington  <hp@pobox.com>
+
+       * test/data/auth/fail-after-n-attempts.auth-script: new test
+
+       * dbus/dbus-auth.c (send_rejected): shutdown_mech() when we
+       reject the client.
+
+2003-02-13  Havoc Pennington  <hp@pobox.com>
+
+       * dbus/dbus-auth.c (handle_server_data_external_mech): args to
+       dbus_credentials_match were backward
+
+       * dbus/dbus-auth-script.c (_dbus_auth_script_run): support
+       NO_CREDENTIALS and ROOT_CREDENTIALS
+
+       * dbus/dbus-auth.c (_dbus_auth_do_work): move get_state() routine 
+       into here. Never process more commands after we've reached an 
+       end state; store further data as unused bytes.
+
+       * test/data/auth/*: add more auth tests
+       
+       * dbus/dbus-auth-script.c (_dbus_auth_script_run): support EXPECT
+       command to match exact string and EXPECT_UNUSED to match unused
+       bytes
+
+       * test/Makefile.am (dist-hook): fix to dist all the test stuff
+
+2003-02-12  Havoc Pennington  <hp@pobox.com>
+
+       * dbus/dbus-string.c (_dbus_string_pop_line): fix to also strip
+       \r off of popped lines
+
+       * dbus/dbus-auth.c (_dbus_auth_test): write code to run auth
+       scripts
+
+       * dbus/dbus-auth-script.c (_dbus_auth_script_run): when doing a
+       SEND, append \r\n
+
+2003-02-12  Havoc Pennington  <hp@pobox.com>
+
+       * dbus/Makefile.am: remove break-loader from the build, since it
+       moved.
+
+       * configure.in: add --enable-gcov to turn on coverage profiling
+       flags and disable optimization
+
+2003-02-10  Havoc Pennington  <hp@pobox.com>
+
+        * dbus/dbus-auth-script.c, dbus/dbus-auth-script.h: sync 
+       initial cut at test framework for DBusAuth from laptop.
+       Doesn't quite work yet but it compiles and I need to get 
+       it off the 266mhz laptop. ;-)
+       
+       * dbus/dbus-server-debug.c (_dbus_server_debug_accept_transport):
+       fix a memleak in error case
+
+2003-02-12  Anders Carlsson  <andersca@codefactory.se>
+
+       * bus/Makefile.am:
+       * bus/desktop-file.c:
+       * bus/desktop-file.h:
+       Add a desktop file parser.
+
+2003-02-11  Zack Rusin  <zack@kde.org>
+
+       * qt/message.[h|cpp]: sample implementation
+       of the KDE wrapper for DBusMessage
+
+2003-02-09  Zack Rusin  <zack@kde.org>
+
+       * test/bus-test.c: make_it_compile
+       * doc/dbus-specification.sgml: minimal semantic fix
+
+2003-02-06  Anders Carlsson  <andersca@codefactory.se>
+
+       Release 0.3
+       
+       * NEWS: Update
+
+2003-02-06  Anders Carlsson  <andersca@codefactory.se>
+
+       * dbus/Makefile.am:
+       * dbus/dbus-break-loader.c:
+       * test/Makefile.am:
+       * test/break-loader.c:
+       Move dbus-break-loader to test/ and rename it to break-loader.
+
+2003-02-02  Havoc Pennington  <hp@pobox.com>
+
+       * dbus/dbus-keyring.c, dbus/dbus-keyring.h: template files 
+       for code to manage cookies in your home directory
+
+       * dbus/dbus-sysdeps.c (_dbus_generate_random_bytes): new function
+
+       * dbus/dbus-auth.c (get_state): impose a maximum number of tries
+       to authenticate, then disconnect the client.
+
+2003-02-03  Alexander Larsson  <alexl@redhat.com>
+
+       * dbus/dbus-message.c (dbus_message_append_fields):
+       Correct docs.
+
+2003-02-02  Anders Carlsson  <andersca@codefactory.se>
+
+       * doc/dbus-specification.sgml:
+       Update address format section.
+       
+2003-02-02  Anders Carlsson  <andersca@codefactory.se>
+
+       * test/Makefile.am:
+       * test/bus-test.c: (get_time), (add_timeout), (remove_timeout),
+       (message_handler), (new_connection_callback), (loop_quit),
+       (loop_run), (main):
+       Add bus test.
+       
+2003-02-02  Anders Carlsson  <andersca@codefactory.se>
+
+       * bus/driver.c: (bus_driver_handle_service_exists):
+       Simplify the code a bit.
+       
+       * dbus/dbus-bus.c: (dbus_bus_service_exists):
+       Fix a silly. 
+       
+2003-02-02  Anders Carlsson  <andersca@codefactory.se>
+
+       * bus/Makefile.am:
+       Add libdbus-daemon.la and link to it.
+
+2003-02-01  James Willcox  <jwillcox@gnome.org>
+
+       * bus/driver.c: (bus_driver_handle_own_service):
+       Actually include the service reply code in the message.
+
+2003-02-02  Anders Carlsson  <andersca@codefactory.se>
+
+       * bus/driver.c: (bus_driver_handle_service_exists):
+       Don't unref the incoming message.
+       
+2003-02-02  Anders Carlsson  <andersca@codefactory.se>
+
+       * dbus/dbus.h: Add dbus-address.h and dbus-bus.h
+
+2003-02-02  Anders Carlsson  <andersca@codefactory.se>
+
+       * dbus/dbus-server.c: (dbus_server_listen):
+       * dbus/dbus-transport.c: (_dbus_transport_open):
+       ifdef out the calls to the debug transport and server.
+       
+2003-02-02  Alexander Larsson  <alexl@redhat.com>
+
+       * dbus/dbus-watch.c (dbus_watch_get_flags):
+       Add note in the docs that ERROR or HANGUP won't be returned
+       and are assumed always on.
+
+       * glib/dbus-gmain.c (add_watch):
+       Always add IO_ERR | IO_HUP
+
+       * dbus/dbus-message.h:
+       Add semicolon after dbus_message_iter_get_string_array().
+       Makes qt code build again
+
+2003-02-01  Anders Carlsson  <andersca@codefactory.se>
+
+       * bus/driver.c: (create_unique_client_name),
+       (bus_driver_handle_hello):
+       Don't take a name, just use a numeric id to identify
+       each client.
+       
+       * dbus/Makefile.am:
+       * dbus/dbus-bus.c: (dbus_bus_register_client),
+       (dbus_bus_acquire_service), (dbus_bus_service_exists):
+       * dbus/dbus-bus.h:
+       Add new convenience functions for communicating with the bus.
+       
+       * dbus/dbus-message.h:
+       
+       * dbus/dbus-protocol.h:
+       Fix a typo.
+       
+2003-02-01  Alexander Larsson  <alexl@redhat.com>
+
+       * dbus/dbus-message.c (dbus_message_append_fields):
+       Add some more doc comments.
+
+2003-02-01  Havoc Pennington  <hp@pobox.com>
+
+       * dbus/dbus-break-loader.c (randomly_modify_length): change 
+       a 4-byte value in the message as if it were a length
+
+       * dbus/dbus-sysdeps.c (_dbus_string_save_to_file): don't set
+       execute bit on saved files
+
+2003-02-01  Havoc Pennington  <hp@pobox.com>
+
+       * dbus/dbus-break-loader.c (main): new program to find messages
+       that break the loader.
+
+       * dbus/dbus-sysdeps.c (_dbus_string_append_uint): new function
+       * dbus/dbus-sysdeps.c (_dbus_string_save_to_file): new function
+
+       * dbus/dbus-string.c (_dbus_string_set_byte): new
+       
+2003-01-31  Havoc Pennington  <hp@pobox.com>
+
+       * dbus/dbus-message.c: refactor the test code to be more general, 
+       in preparation for writing a "randomly permute test cases to 
+       try to break the loader" program.
+
+2003-01-31  Havoc Pennington  <hp@pobox.com>
+       
+       * doc/dbus-specification.sgml: work on the specification
+
+       * dbus/dbus-message.c (_dbus_message_loader_return_buffer): check 
+       the protocol version of the message.
+
+       * dbus/dbus-protocol.h: drop special _REPLY names, the spec 
+       no longer specifies that.
+       (DBUS_SERVICE_REPLY_SERVICE_EXISTS): fix flags (1/2/4/8 not 
+       1/2/3/4)
+
+       * dbus/dbus-marshal.c (_dbus_marshal_get_arg_end_pos): add missing
+       "break" for DBUS_TYPE_NIL, remove @todo
+
+2003-01-31  Havoc Pennington  <hp@pobox.com>
+
+       * dbus/dbus-message.c (dbus_message_set_is_error_reply): rename 
+       just set_is_error/get_is_error as this is a commonly-used
+       function, and write docs.
+
+2003-01-31  Anders Carlsson  <andersca@codefactory.se>
+
+       * dbus/dbus-address.c: (dbus_address_entry_free):
+       Free key and value lists.
+       
+       * dbus/dbus-internals.c: (_dbus_type_to_string):
+       Add the types we didn't have.
+       
+       * dbus/dbus-marshal.c: (_dbus_marshal_get_arg_end_pos),
+       (_dbus_marshal_validate_arg):
+       Add NIL types.
+       
+       * dbus/dbus-message.c: (dbus_message_set_sender):
+       Remove todo about being able to set sender to NULL.
+       
+       (dbus_message_set_is_error_reply),
+       (dbus_message_get_is_error_reply):
+       * dbus/dbus-message.h:
+       New functions.
+       
+       * dbus/dbus-protocol.h:
+       Add error reply flag.
+       
+       * test/data/valid-messages/opposite-endian.message:
+       Add NIL type to test.
+       
+2003-01-31  Havoc Pennington  <hp@pobox.com>
+
+       * doc/dbus-specification.sgml: fully specify the header.  Add
+       flags and major protocol version, and change header/body len to
+       unsigned.
+
+       * dbus/dbus-message-builder.c (append_saved_length): append length
+       as uint32
+
+       * dbus/dbus-message.c (dbus_message_create_header): change header
+       length and body length to unsigned. Add the new fields from the
+       spec
+       (_dbus_message_loader_return_buffer): unsigned header/body len
+
+2003-01-30  Havoc Pennington  <hp@pobox.com>
+
+       * dbus/dbus-auth.c: rework to use only REJECTED, no 
+       MECHANISMS
+
+       * doc/dbus-sasl-profile.txt: drop MECHANISMS and just 
+       use REJECTED, suggested by Mark McLoughlin
+
+2003-01-30  Havoc Pennington  <hp@pobox.com>
+
+       * dbus/dbus-server.c (dbus_server_listen): @todo about how we need
+       a better way to report errors here. e.g.  "unix address lacks
+       path" or something. also "no such file" when the path doesn't
+       exist, etc.
+
+       * dbus/dbus-address.c (dbus_address_entries_free): add @todo about
+       leaking list nodes
+       (dbus_parse_address): add @todo about documenting address format, 
+       and allowing , and ; to be escaped
+
+2003-01-30  Anders Carlsson  <andersca@codefactory.se>
+
+       * dbus/Makefile.am:
+       Add dbus-address.[ch]
+       
+       * dbus/dbus-address.c: (dbus_address_entry_free),
+       (dbus_address_entries_free), (create_entry),
+       (dbus_address_entry_get_method), (dbus_address_entry_get_value),
+       (dbus_parse_address), (_dbus_address_test):
+       * dbus/dbus-address.h:
+       New files for dealing with address parsing.
+       
+       * dbus/dbus-connection.c:
+       Document timeout functions.
+       
+       * dbus/dbus-message.c:
+       Document dbus_message_new_from_message.
+       
+       * dbus/dbus-server-debug.c:
+       Document.
+       
+       * dbus/dbus-server.c: (dbus_server_listen):
+       Parse address and use correct server implementation.
+       
+       * dbus/dbus-string.c: (_dbus_string_find_to), (_dbus_string_test):
+       * dbus/dbus-string.h:
+       New function with test.
+       
+       * dbus/dbus-test.c: (dbus_internal_symbol_do_not_use_run_tests):
+       * dbus/dbus-test.h:
+       Add address tests.
+       
+       * dbus/dbus-transport-debug.c:
+       Document.
+       
+       * dbus/dbus-transport.c: (_dbus_transport_open):
+       Parse address and use correct transport implementation. 
+
+2003-01-30  Havoc Pennington  <hp@pobox.com>
+
+       * dbus/dbus-message.c: use message->byte_order instead of 
+       DBUS_COMPILER_BYTE_ORDER throughout.
+       (dbus_message_create_header): pad header to align the 
+       start of the body of the message to 8-byte boundary
+
+       * dbus/dbus-marshal.h: make all the demarshalers take const 
+       DBusString arguments.
+
+       * dbus/dbus-message.c (_dbus_message_loader_return_buffer):
+       validate message args here, so we don't have to do slow validation
+       later, and so we catch bad messages as they are incoming. Also add
+       better checks on header_len and body_len. Also fill in
+       message->byte_order
+
+       * dbus/dbus-string.c (_dbus_string_validate_utf8): new (not
+       implemented properly)
+       (_dbus_string_validate_nul): new function to check all-nul
+
+       * dbus/dbus-marshal.c (_dbus_marshal_get_field_end_pos): rename 
+       get_arg_end_pos and remove all validation
+       (_dbus_marshal_validate_arg): actually do validation here.
+
+2003-01-29  Havoc Pennington  <hp@pobox.com>
+
+       * dbus/dbus-message.c (check_message_handling): fix assertion
+       failure on set_client_serial
+
+2003-01-28  Havoc Pennington  <hp@pobox.com>
+
+       * dbus/dbus-server-debug.c: Add doc section comments
+       
+       * dbus/dbus-transport-debug.c: add doc section comments
+       
+2003-01-28  Havoc Pennington  <hp@redhat.com>
+
+       * dbus/dbus-string.c (_dbus_string_base64_decode): append bytes in
+       the reverse order from how I had it
+       (_dbus_string_base64_encode): reverse encoding order. I was
+       basically byteswapping everything during encoding.
+
+2003-01-28  Anders Carlsson  <andersca@codefactory.se>
+
+       * dbus/dbus-connection-internal.h:
+       * dbus/dbus-connection.c: (_dbus_connection_add_timeout),
+       (_dbus_connection_remove_timeout):
+       Add functions for adding and removing timeouts.
+       
+       * dbus/dbus-message.c: (dbus_message_new_from_message):
+       Add new function that takes a message and creates an exact
+       copy of it, but with the refcount set to 1.
+       (check_message_handling):
+       Fix build error.
+       
+       * dbus/dbus-server-protected.h:
+       * dbus/dbus-server.c: (_dbus_server_init_base),
+       (_dbus_server_finalize_base), (_dbus_server_add_timeout),
+       (dbus_server_set_timeout_functions):
+       (_dbus_server_remove_timeout):
+       New functions so that a server can add and remove timeouts.
+
+       (dbus_server_listen):
+       Add commented out call to dbus_server_debug_new.
+
+       * dbus/dbus-timeout.c: (_dbus_timeout_new):
+       Actually set the handler, doh.
+       
+       * dbus/dbus-transport.c: (_dbus_transport_open):
+       Add commented out call to dbus_transport_debug_client_new.
+       
+       * dbus/Makefile.am:
+       Add dbus-transport-debug.[ch] and dbus-server-debug.[ch]
+       
+2003-01-28  Havoc Pennington  <hp@pobox.com>
+
+       * dbus/dbus-message.c (check_message_handling): function to check 
+       on the loaded message, iterates over it etc.
+
+2003-01-28  Havoc Pennington  <hp@pobox.com>
+
+       * test/Makefile.am (dist-hook): fix make distdir
+
+       * dbus/Makefile.am (TESTS_ENVIRONMENT): fix make check
+
+2003-01-27  Havoc Pennington  <hp@pobox.com>
+
+       * dbus/dbus-mempool.c (time_for_size): replace printf with 
+       _dbus_verbose
+
+       * dbus/dbus-message-builder.c (_dbus_message_data_load): allow
+       empty lines; fix the SAVE_LENGTH stuff to be
+       START_LENGTH/END_LENGTH so it actually works; couple other 
+       bugfixes
+       
+       * test/Makefile.am (dist-hook): add dist-hook for .message files
+
+       * dbus/dbus-string.c (DBUS_STRING_COPY_PREAMBLE): source of a copy
+       can be constant or locked.
+       (_dbus_string_free): allow freeing a const string as
+       documented/intended
+
+       * dbus/dbus-sysdeps.c (_dbus_concat_dir_and_file): utility
+
+       * dbus/dbus-test-main.c (main): take an argument which is the 
+       directory containing test data
+
+       * dbus/dbus-message.c (_dbus_message_test): pass a test_data_dir
+       argument to this and load all the messages in test/data/
+       checking that they can be loaded or not loaded as appropriate.
+
+2003-01-27  Anders Carlsson  <andersca@codefactory.se>
+
+       * bus/dispatch.c: (bus_dispatch_message_handler):
+       Dispatch messages sent to services.
+       
+       * bus/driver.c: (bus_driver_send_service_deleted),
+       (bus_driver_send_service_created), (bus_driver_send_service_lost),
+       (bus_driver_send_service_acquired):
+       Add helper functions for sending service related messages.
+
+       (bus_driver_send_welcome_message):
+       Send HELLO_REPLY instead of WELCOME.
+       
+       (bus_driver_handle_list_services):
+       Send LIST_SERVICES_REPLY instead of SERVICES.
+       
+       (bus_driver_handle_own_service),
+       (bus_driver_handle_service_exists):
+       New message handlers.
+       
+       (bus_driver_handle_message):
+       Invoke new message handlers.
+       
+       (bus_driver_remove_connection):
+       Don't remove any services here since that's done automatically
+       by bus_service_remove_owner now.
+       
+       * bus/driver.h:
+       New function signatures.
+       
+       * bus/services.c: (bus_service_add_owner):
+       Send ServiceAcquired message if we're the only primary owner.
+       
+       (bus_service_remove_owner):
+       Send ServiceAcquired/ServiceLost messages.
+       
+       (bus_service_set_prohibit_replacement),
+       (bus_service_get_prohibit_replacement):
+       Functions for setting prohibit replacement.
+       
+       (bus_service_has_owner):
+       New function that checks if a connection is in the owner queue of 
+       a certain service.
+       
+       * bus/services.h:
+       Add new function signatures.
+       
+       * dbus/dbus-list.c: (_dbus_list_test):
+       Add tests for _dbus_list_remove_last and traversing the list backwards.
+       
+       * dbus/dbus-list.h:
+       Fix a typo in _dbus_list_get_prev_link, if we're at the first element we can't
+       go any further, so return NULL then.
+       
+       * dbus/dbus-protocol.h:
+       Add new messages, service flags and service replies.
+       
+2003-01-26  Havoc Pennington  <hp@pobox.com>
+
+       * dbus/dbus-message-builder.c: implement, completely untested.
+
+       * test/data/*: add data to be used in testing. 
+       ".message" files are our simple loadable text format.
+       ".message-raw" will be binary dumps of messages.
+
+       * dbus/dbus-string.c (_dbus_string_starts_with_c_str): new
+
+2003-01-26  Havoc Pennington  <hp@pobox.com>
+
+       * dbus/dbus-sysdeps.c (_dbus_file_get_contents): new function
+
+       * dbus/dbus-errors.c (dbus_result_to_string): add
+       file errors
+
+       * dbus/dbus-message-builder.c: new file, will contain code to load
+       up messages from files. Not implemented yet.
+
+2003-01-26  Havoc Pennington  <hp@pobox.com>
+
+       * dbus/dbus-message.c (dbus_message_set_sender): support deleting
+       the sender by setting to NULL
+
+2003-01-26  Havoc Pennington  <hp@pobox.com>
+
+        The unit tests pass, but otherwise untested.  If it breaks, the
+       tests should have been better. ;-)
+       
+       * bus/driver.c (bus_driver_handle_hello): return if we disconnect
+       the connection.
+
+       * dbus/dbus-message.c: redo everything so we maintain 
+       message->header as the only copy of the various fields.
+       This avoids the possibility of out-of-memory in some cases,
+       for example dbus_message_lock() can't run out of memory anymore,
+       and avoids extra copying. Figured I may as well go ahead and do 
+       this since it was busted for dbus_message_lock to not return 
+       failure on OOM, and dbus_message_write_header was totally
+       unchecked for OOM. Also fixed some random other bugs.
+
+       * dbus/dbus-marshal.c (_dbus_marshal_get_field_end_pos): verify
+       that strings are nul-terminated. Also, end_pos can be equal 
+       to string length just not greater than, I think.
+       (_dbus_marshal_set_int32): new function
+       (_dbus_marshal_set_uint32): new function
+       (_dbus_marshal_set_string): new function
+
+       * dbus/dbus-connection.c (_dbus_connection_new_for_transport): fix
+       a warning, init timeout_list to NULL
+       (dbus_connection_send_message): don't use uninitialized variable
+       "serial"
+
+       * dbus/dbus-string.c (_dbus_string_replace_len): new function
+
+2003-01-26  Anders Carlsson  <andersca@codefactory.se>
+
+       * bus/driver.c: (bus_driver_handle_hello),
+       (bus_driver_send_welcome_message):
+       Plug leaks
+       
+2003-01-26  Anders Carlsson  <andersca@codefactory.se>
+
+       * dbus/dbus-auth.c: (process_auth), (_dbus_auth_unref):
+       * dbus/dbus-connection.c: (_dbus_connection_new_for_transport),
+       (dbus_connection_unref):
+       * dbus/dbus-marshal.c: (_dbus_marshal_test):
+       * dbus/dbus-message.c: (dbus_message_unref),
+       Plug memory leaks.
+       
+       (dbus_message_get_fields): 
+       Remove debugging printout.
+
+       (_dbus_message_loader_return_buffer):
+       Don't store the header string.
+       
+       (_dbus_message_test):
+       Plug leaks.
+
+2003-01-26  Richard Hult  <rhult@codefactory.se>
+
+       * glib/dbus-gmain.c (dbus_connection_dispatch): Traverse a copy of
+       the file descriptor list, since it can change under us.
+
+2003-01-25  Anders Carlsson  <andersca@codefactory.se>
+
+       * glib/dbus-gmain.c: (dbus_connection_prepare),
+       (dbus_connection_check), (dbus_connection_dispatch), (add_watch),
+       (remove_watch), (dbus_connection_hookup_with_g_main):
+       Rewrite the glib handling to use its own GSource instead of a 
+       GIOChannel so we can catch messages put in the queue while waiting
+       for a reply.
+       
+2003-01-25  Anders Carlsson  <andersca@codefactory.se>
+
+       * bus/Makefile.am:
+       * bus/connection.c: (connection_disconnect_handler),
+       (connection_watch_callback), (bus_connection_setup):
+       * bus/dispatch.c: (send_one_message),
+       (bus_dispatch_broadcast_message), (bus_dispatch_message_handler),
+       (bus_dispatch_add_connection), (bus_dispatch_remove_connection):
+       * bus/dispatch.h:
+       * bus/driver.c: (bus_driver_send_service_deleted),
+       (bus_driver_send_service_created), (bus_driver_handle_hello),
+       (bus_driver_send_welcome_message),
+       (bus_driver_handle_list_services), (bus_driver_remove_connection),
+       (bus_driver_handle_message):
+       * bus/driver.h:
+       Refactor code, put the message dispatching in its own file. Use 
+       _DBUS_HANDLE_OOM. Also send ServiceDeleted messages when a client
+       is disconnected.
+       
+2003-01-25  Anders Carlsson  <andersca@codefactory.se>
+
+       * dbus/dbus-internals.h:
+       Add _DBUS_HANDLE_OOM macro, it doesn't do anything currently.
+       
+       * dbus/dbus-message.c: (dbus_message_get_sender):
+       * dbus/dbus-message.h:
+       Implement dbus_message_get_sender.
+       
+       * dbus/dbus-protocol.h:
+       Add message and service defines.
+       
+2003-01-25  Anders Carlsson  <andersca@codefactory.se>
+
+       * dbus/dbus-connection.c: (dbus_connection_send_message):
+       * dbus/dbus-message-internal.h:
+       * dbus/dbus-message.c: (_dbus_message_get_client_serial),
+       (dbus_message_write_header):
+       Remove _dbus_messag_unlock and don't set the client serial on a 
+       message if one already exists.
+       
+2003-01-24  Havoc Pennington  <hp@pobox.com>
+
+       * dbus/dbus-list.c (alloc_link): put a thread lock on the global
+       list_pool
+
+       * bus/driver.c (bus_driver_handle_list_services): fix a leak 
+       on OOM
+
+2003-01-25  Anders Carlsson  <andersca@codefactory.se>
+
+       * dbus/dbus-list.c: (alloc_link), (free_link):
+       Use a memory pool for the links.
+       
+2003-01-25  Anders Carlsson  <andersca@codefactory.se>
+
+       * bus/connection.c: (bus_connection_foreach):
+       * bus/connection.h:
+       Add new bus_connection_foreach function.
+       
+       * bus/driver.c: (send_one_message), (bus_driver_broadcast_message):
+       Add function that broadcasts a message to all clients.
+       
+       (bus_driver_send_service_created), (bus_driver_handle_hello),
+       (bus_driver_send_welcome_message),
+       (bus_driver_handle_list_services), (bus_driver_message_handler):
+       Implement functions that take care of listing services, and notifying
+       clients when new services are created.
+       
+       * bus/services.c: (bus_services_list):
+       * bus/services.h:
+       Add new function that returns an array of strings with the currently
+       registered services.
+       
+       * glib/dbus-glib.h:
+       * glib/dbus-gmain.c:
+       Update copyright year.
+       
+2003-01-25  Anders Carlsson  <andersca@codefactory.se>
+
+       * dbus/dbus-connection.c: (dbus_connection_send_message):
+       Unlock the message in case it was sent earlier.
+       
+       (dbus_connection_send_message_with_reply_and_block):
+       Remove the reply message from the list.
+       
+       * dbus/dbus-marshal.c: (_dbus_demarshal_string_array):
+       Set array_len and new_pos correctly.
+       
+       (_dbus_marshal_test):
+       Remove debug output.
+       
+       * dbus/dbus-message-internal.h:
+       * dbus/dbus-message.c: (_dbus_message_get_reply_serial):
+       New function that returns the reply serial.
+       
+       (_dbus_message_unlock):
+       New function that unlocks a message and resets its header.
+
+       (dbus_message_append_string_array), 
+       (dbus_message_get_fields_valist),
+       (dbus_message_iter_get_field_type),
+       (dbus_message_iter_get_string_array),   
+       (dbus_message_get_fields),      
+       (dbus_message_append_fields_valist):
+       Handle string arrays.
+       
+       (dbus_message_set_sender):
+       Make this function public since the bus daemon needs it.
+       
+       (decode_header_data):
+       Set the reply serial to -1 initially.
+
+       * dbus/dbus-message.h:
+       Add dbus_message_set_sender.    
+
+2003-01-24  Havoc Pennington  <hp@pobox.com>
+
+       * doc/dbus-specification.sgml: add some stuff
+
+2003-01-22  Havoc Pennington  <hp@pobox.com>
+
+       * doc/dbus-specification.sgml: Start to document the protocol.
+
+2003-01-22  Havoc Pennington  <hp@pobox.com>
+
+       * dbus/dbus-connection.c
+       (dbus_connection_send_message_with_reply_and_block): add some @todo
+
+       * bus/driver.c (bus_driver_add_connection): add a FIXME about memleak
+
+2003-01-21  Havoc Pennington  <hp@pobox.com>
+
+        (patch untested because can't compile)
+       
+       * bus/driver.c (create_unique_client_name): make this function
+       never recycle client names. Also, caller should initialize 
+       the DBusString.
+
+       * dbus/dbus-sysdeps.c (_dbus_get_current_time): new function
+
+2003-01-21  Anders Carlsson  <andersca@codefactory.se>
+
+       * dbus/dbus-marshal.c: (_dbus_marshal_double),
+       (_dbus_marshal_int32), (_dbus_marshal_uint32),
+       (_dbus_marshal_int32_array), (_dbus_marshal_uint32_array),
+       (_dbus_marshal_double_array), (_dbus_marshal_string_array),
+       (_dbus_demarshal_int32_array), (_dbus_demarshal_uint32_array),
+       (_dbus_demarshal_double_array), (_dbus_demarshal_string_array),
+       (_dbus_marshal_get_field_end_pos), (_dbus_marshal_test):
+       * dbus/dbus-marshal.h:
+       * dbus/dbus-protocol.h:
+       Add support for marshalling and demarshalling integer, double
+       and string arrays.
+       
+2003-01-21  Anders Carlsson  <andersca@codefactory.se>
+
+       * bus/Makefile.am:
+       Add driver.[ch]
+       
+       * bus/connection.c: (connection_disconnect_handler):
+       Remove the connection from the bus driver's list.
+       
+       (connection_watch_callback): Dispatch messages.
+
+       (free_connection_data): Free connection name.
+       
+       (bus_connection_setup): Add connection to the bus driver's list.
+       (bus_connection_remove_owned_service): 
+       (bus_connection_set_name), (bus_connection_get_name):
+       Add functions for setting and getting the connection's name.
+       
+       * bus/connection.h:
+       Add function headers.
+       
+       * bus/driver.c: (create_unique_client_name),
+       (bus_driver_handle_hello_message),
+       (bus_driver_send_welcome_message), (bus_driver_message_handler),
+       (bus_driver_add_connection), (bus_driver_remove_connection):
+       * bus/driver.h:
+       * bus/main.c:
+       * bus/services.c: (bus_service_free):
+       * bus/services.h:
+       New file that handles communication and registreation with the bus
+       itself. 
+       
+2003-01-21  Anders Carlsson  <andersca@codefactory.se>
+
+       * dbus/dbus-connection.c: (dbus_connection_send_message):
+       Add a new client_serial parameter.
+       
+       (dbus_connection_send_message_with_reply):
+       Remove a @todo since we've implemented the blocking function.
+       
+       (dbus_connection_send_message_with_reply_and_block):
+       New function that sends a message and waits for a reply and
+       then returns the reply.
+       
+       * dbus/dbus-connection.h:
+       Add new functions.
+       
+       * dbus/dbus-errors.c: (dbus_result_to_string):
+       * dbus/dbus-errors.h:
+       Add new DBUS_RESULT.
+       
+       * dbus/dbus-message-internal.h:
+       * dbus/dbus-message.c: (_dbus_message_get_reply_serial),
+       (_dbus_message_set_sender), (dbus_message_write_header),
+       (dbus_message_new_reply), (decode_header_data),
+       (_dbus_message_loader_return_buffer), (_dbus_message_test):
+       * dbus/dbus-message.h:
+       Add new functions that set the reply serial and sender.
+       Also marshal and demarshal them correctly and add test.
+       
+       * dbus/dbus-protocol.h:
+       Add new DBUS_MESSAGE_TYPE_SENDER.
+       
+       * glib/dbus-glib.h:
+       * glib/dbus-gmain.c: (watch_callback), (free_callback_data),
+       (add_watch), (remove_watch), (add_timeout), (remove_timeout),
+       (dbus_connection_hookup_with_g_main):
+       * glib/test-dbus-glib.c: (main):
+       Rewrite to use GIOChannel and remove the GSource crack.
+       
+       * test/echo-client.c: (main):
+       * test/watch.c: (check_messages):
+       Update for changed APIs
+       
+2003-01-19  Anders Carlsson  <andersca@codefactory.se>
+
+       * dbus/Makefile.am: Add dbus-timeout.[cħ]
+       
+       * dbus/dbus-connection.c: (_dbus_connection_new_for_transport):
+       Create a DBusTimeoutList.       
+       (dbus_connection_set_timeout_functions): Add new function to
+       set timeout callbacks
+       
+       * dbus/dbus-connection.h: Add public DBusTimeout API.
+       
+       * dbus/dbus-message.c: (dbus_message_get_service):
+       * dbus/dbus-message.h:  New function.
+
+       * dbus/dbus-server.c: Fix small doc typo.
+       
+       * dbus/dbus-timeout.[ch]: New files for mainloop timeouts.
+
+2003-01-19  Anders Carlsson  <andersca@codefactory.se>
+
+       * dbus/dbus-string.c (_dbus_string_move_len): Don't delete all
+       of the string, just as long as specified.
+
+2003-01-19  Havoc Pennington  <hp@pobox.com>
+
+       * dbus/dbus-connection.c (dbus_connection_get_is_authenticated):
+       new function
+
+       * dbus/dbus-server.c (dbus_server_set_max_connections)
+       (dbus_server_get_max_connections, dbus_server_get_n_connections):
+       keep track of current number of connections, and add API for
+       setting a max (but haven't implemented enforcing the max yet)
+
+2003-01-18  Havoc Pennington  <hp@pobox.com>
+
+       * dbus/dbus-transport-unix.c (unix_do_iteration): only do the
+       reading/writing if read_watch != NULL or write_watch != NULL.
+
+       * dbus/dbus-message.c (_dbus_message_loader_return_buffer): fix
+       the message loader code to actually load message->header and
+       message->body into the newly-created message.
+
+       * dbus/dbus-transport-unix.c (check_write_watch): fix a mem leak
+       in OOM case
+
+       * dbus/dbus-connection.c (dbus_connection_set_max_message_size) 
+       (dbus_connection_get_max_message_size) 
+       (dbus_connection_set_max_live_messages_size) 
+       (dbus_connection_get_max_live_messages_size): implement some
+       resource limitation functions
+
+       * dbus/dbus-resources.c: new file implementing some of the
+       resource limits stuff
+
+       * dbus/dbus-message.c (dbus_message_iter_get_byte_array): add
+       missing docs, add @todo to handle OOM etc.
+
+       * dbus/dbus-marshal.c (_dbus_demarshal_byte_array): add missing
+       docs
+       
+2003-01-18  Havoc Pennington  <hp@pobox.com>
+
+       * dbus/dbus-connection.c (dbus_connection_unref): disconnect the 
+       connection if it hasn't been already.
+
+       * dbus/dbus-connection.h: kill off the idea of an ErrorFunction,
+       replace with DisconnectFunction.
+
+2003-01-18  Havoc Pennington  <hp@pobox.com>
+
+        Building --disable-verbose-mode --disable-asserts --disable-tests
+       cuts the library from 112K to 45K or so
+       
+       * configure.in: check for varargs macro support, 
+       add --enable-verbose-mode, --enable-asserts. 
+
+       * dbus/dbus-internals.h (_dbus_assert): support
+       DBUS_DISABLE_ASSERT
+       (_dbus_verbose): support DBUS_ENABLE_VERBOSE_MODE
+
+2003-01-18  Havoc Pennington  <hp@pobox.com>
+
+       * dbus/dbus-test.c: include config.h so that tests actually run
+
+       * dbus/dbus-string.c: add assertions that stuff is 8-byte aligned,
+       so the failure mode when that assumption fails will be plenty
+       obvious.
+
+2003-01-18  Havoc Pennington  <hp@pobox.com>
+
+       * configure.in: default --enable-tests to $USE_MAINTAINER_MODE
+
+       * dbus/Makefile.am: fix it up so dubs-test-main.c is included in
+       the distribution
+
+       * test/Makefile.am: don't use special variable "TESTS" for echo-*
+       since we don't want to use those in make check
+
+2003-01-15  Havoc Pennington  <hp@redhat.com>
+
+        Release 0.2
+       
+       * NEWS: update
+
+2003-01-15  Havoc Pennington  <hp@redhat.com>
+
+       * test/Makefile.am: fix so that test source code ends up in the
+       distribution on make distcheck
+
+2003-01-15  Havoc Pennington  <hp@redhat.com>
+
+        Release 0.1.
+       
+       * NEWS: update  
+
+2003-01-15  Havoc Pennington  <hp@redhat.com>
+
+       * dbus/dbus-test.c (dbus_internal_symbol_do_not_use_run_tests):
+       fix build when --disable-tests
+
+       * Makefile.am (EXTRA_DIST): put HACKING in here
+
+       * HACKING: document procedure for making a tarball release.
+
+2003-01-14  Anders Carlsson  <andersca@codefactory.se>
+
+       * bus/connection.c: (connection_error_handler),
+       (bus_connection_setup):
+       * bus/main.c: (main):
+       Make sure that the DBusConnectionData struct is NULLed
+       out to prevent a segfault.
+       
+       * dbus/dbus-errors.c: (dbus_result_to_string):
+       * dbus/dbus-errors.h:
+       * dbus/dbus-message.c: (dbus_message_get_fields),
+       (dbus_message_get_fields_valist), (_dbus_message_test):
+       * dbus/dbus-message.h:
+       Make dbus_message_get_fields return a result code so we can
+       track invalid fields as well as oom.
+       
+2003-01-11  Havoc Pennington  <hp@pobox.com>
+
+       * configure.in: change --enable-test/--enable-ansi action-if-given
+       to enable_foo=$enableval instead of enable_foo=yes
+
+2003-01-08  Havoc Pennington  <hp@pobox.com>
+
+       * dbus/dbus-string.c (_dbus_string_align_length): new function
+
+       * dbus/dbus-test-main.c: move main() for test app here
+       * dbus/dbus-test.c
+       (dbus_internal_symbol_do_not_use_run_tests): we have to export a
+       symbol to run tests, because dbus-test isn't in the main 
+       library
+
+        Code review nitpicks.
+       
+       * dbus/dbus-message.c (dbus_message_write_header): add newlines
+       for people with narrow emacs ;-). Assert client_serial was filled
+       in. Assert message->name != NULL.
+       (dbus_message_append_fields): have "first_field_type" arg separate
+       from va list, needed for C++ binding that also uses varargs IIRC
+       and helps with type safety
+       (dbus_message_new): add @todo about using DBusString to store
+       service/name internally
+       (dbus_message_new): don't leak ->service and ->name on OOM later
+       in the function
+       (dbus_message_unref): free the service name
+       (dbus_message_get_fields): same change to varargs
+       i.e. first_field_type
+       (_dbus_message_loader_return_buffer): assert that the message data
+       is aligned (if not it's a bug in our code). Put in verbose griping
+       about why we set corrupted = TRUE.
+       (decode_header_data): add FIXME that char* is evil.  Was going to
+       add FIXME about evil locale-specific string.h strncmp, but just
+       switched to wacky string-as-uint32 optimization. Move check for
+       "no room for field name" above get_const_data_len() to avoid
+       assertion failure in get_const_data_len if we have trailing 2
+       bytes or the like. Check for service and name fields being
+       provided twice. Don't leak service/name on error. Require field
+       names to be aligned to 4 bytes.
+
+       * dbus/dbus-marshal.c: move byte swap stuff to header
+       (_dbus_pack_int32): uscore-prefix
+       (_dbus_unpack_int32): uscore-prefix
+       (_dbus_unpack_uint32): export
+       (_dbus_demarshal_string): add @todo complaining about use of
+       memcpy()
+       (_dbus_marshal_get_field_end_pos): add @todo about bad error
+       handling allowing corrupt data to go unchecked
+
+2003-01-08  Havoc Pennington  <hp@redhat.com>
+
+       * dbus/dbus-transport-unix.c (unix_do_iteration): add read/write 
+       to the select() as needed for authentication. (should be using
+       _dbus_poll() not select, but for another day)
+
+       * dbus/dbus.h: include dbus/dbus-protocol.h
+
+2003-01-08  Anders Carlsson  <andersca@codefactory.se>
+
+       * dbus/Makefile.am (dbusinclude_HEADERS): Install
+       dbus-connection.h
+
+2003-01-08  Anders Carlsson  <andersca@codefactory.se>
+
+       * dbus/dbus-internals.c: (_dbus_type_to_string):
+       New function that returns a string describing a type.
+       
+       * dbus/dbus-marshal.c: (_dbus_demarshal_byte_array):
+       * dbus/dbus-marshal.h:
+       * dbus/dbus-message.c: (dbus_message_get_fields_valist),
+       (dbus_message_iter_get_field_type), (dbus_message_iter_get_double),
+       (dbus_message_iter_get_byte_array):
+       * dbus/dbus-message.h:
+       Add new convenience functions for appending and getting message fields.
+       Also add demarshalling routines for byte arrays.
+
+2003-01-07  Anders Carlsson  <andersca@codefactory.se>
+
+       * dbus/dbus-connection-internal.h:
+       * dbus/dbus-connection.c: (_dbus_connection_new_for_transport),
+       (_dbus_connection_get_next_client_serial),
+       (dbus_connection_send_message):
+       * dbus/dbus-internals.h:
+       * dbus/dbus-marshal.c: (unpack_uint32), (dbus_unpack_int32),
+       (dbus_pack_int32), (_dbus_marshal_double), (_dbus_marshal_int32),
+       (_dbus_marshal_uint32), (_dbus_demarshal_double),
+       (_dbus_demarshal_int32), (_dbus_demarshal_uint32),
+       (_dbus_demarshal_string), (_dbus_marshal_get_field_end_pos),
+       (_dbus_verbose_bytes), (_dbus_marshal_test):
+       * dbus/dbus-marshal.h:
+       * dbus/dbus-message-internal.h:
+       * dbus/dbus-message.c: (_dbus_message_set_client_serial),
+       (dbus_message_write_header), (_dbus_message_lock),
+       (dbus_message_new), (dbus_message_ref), (dbus_message_unref),
+       (dbus_message_get_name), (dbus_message_append_int32),
+       (dbus_message_append_uint32), (dbus_message_append_double),
+       (dbus_message_append_string), (dbus_message_append_byte_array),
+       (dbus_message_get_fields_iter), (dbus_message_iter_ref),
+       (dbus_message_iter_unref), (dbus_message_iter_has_next),
+       (dbus_message_iter_next), (dbus_message_iter_get_field_type),
+       (dbus_message_iter_get_string), (dbus_message_iter_get_int32),
+       (dbus_message_iter_get_uint32), (dbus_message_iter_get_double),
+       (decode_header_data), (_dbus_message_loader_return_buffer),
+       (message_iter_test), (_dbus_message_test):
+       * dbus/dbus-message.h:
+       * dbus/dbus-protocol.h:
+       * dbus/dbus-test.c: (main):
+       * dbus/dbus-test.h:
+       * glib/test-dbus-glib.c: (message_handler), (main):
+       * test/echo-client.c: (main):
+       * test/watch.c: (check_messages):
+       Make messages sendable and receivable for real.
+       
+2003-01-07  Anders Carlsson  <andersca@codefactory.se>
+
+       * dbus/dbus-marshal.c: (_dbus_marshal_double),
+       (_dbus_marshal_string), (_dbus_marshal_byte_array):
+       * dbus/dbus-message.c: (dbus_message_append_int32),
+       (dbus_message_append_uint32), (dbus_message_append_double),
+       (dbus_message_append_string), (dbus_message_append_byte_array):
+       Handle OOM restoration.
+       
+2003-01-07  Anders Carlsson  <andersca@codefactory.se>
+
+       * dbus/dbus-marshal.c: (_dbus_marshal_string),
+       (_dbus_demarshal_string), (_dbus_marshal_test):
+       * dbus/dbus-marshal.h:
+       * dbus/dbus-message.c: (dbus_message_get_name),
+       Document these functions.
+       
+       (dbus_message_append_int32), (dbus_message_append_uint32),
+       (dbus_message_append_double), (dbus_message_append_string),
+       (dbus_message_append_byte_array):
+       * dbus/dbus-message.h:
+       Add functions for adding message fields of different types.
+       
+       * dbus/dbus-protocol.h:
+       Add the different types.
+
+2003-01-05  Havoc Pennington  <hp@pobox.com>
+
+       * bus/connection.c: implement routines for handling connections,
+       first thing is keeping a list of owned services on each connection
+       and setting up watches etc.
+
+       * bus/services.c: implement a mapping from service names to lists
+       of connections
+
+       * dbus/dbus-hash.c: add DBUS_HASH_POINTER
+
+       * dbus/dbus-threads.c (dbus_static_mutex_lock): add functions
+       to use static mutexes for global data
+
+       * dbus/dbus-connection.c (dbus_connection_set_data): add new
+       collection of functions to set/get application-specific data
+       on the DBusConnection.
+
+2003-01-04  Havoc Pennington  <hp@pobox.com>
+
+       * dbus/dbus-sysdeps.c (_dbus_sleep_milliseconds): new function
+       (_dbus_poll): new function
+
+       * dbus/dbus-internals.h (_DBUS_STRUCT_OFFSET): new macro
+       copied from GLib
+
+       * bus/loop.c: initial code for the daemon main loop
+
+2003-01-04  Havoc Pennington  <hp@pobox.com>
+
+       * test/watch.c (error_handler): make it safe if the error handler 
+       is called multiple times (if we s/error handler/disconnect
+       handler/ we should just guarantee it's called only once)
+
+       * dbus/dbus-transport.c (_dbus_transport_disconnect): call the
+       error handler on disconnect (it's quite possible we should
+       just change the error handler to a "disconnect handler," I'm 
+       not sure we have any other meaningful errors)
+
+       * configure.in: check for getpwnam_r
+
+       * dbus/dbus-transport.c, dbus/dbus-transport-unix.c,
+       dbus/dbus-auth.c: add credentials support, add EXTERNAL auth
+       mechanism as in SASL spec, using socket credentials
+
+       * dbus/dbus-sysdeps.c (_dbus_read_credentials_unix_socket): new function
+       (_dbus_send_credentials_unix_socket): new function
+
+       * dbus/dbus-sysdeps.c (_dbus_accept_unix_socket): rename just
+       dbus_accept()
+       (_dbus_write): only check errno if <0 returned
+       (_dbus_write_two): ditto
+
+2003-01-02  Anders Carlsson  <andersca@codefactory.se>
+
+       * dbus/dbus-marshal.c: (_dbus_marshal_utf8_string),
+       (_dbus_marshal_byte_array), (_dbus_demarshal_utf8_string),
+       (_dbus_marshal_test):
+       * dbus/dbus-marshal.h:
+       Add _dbus_marshal_byte_array and rename _dbus_marshal_string
+       to _dbus_marshal_utf8_string. Also fix some tests.
+       
+2002-12-28  Harri Porten  <porten@kde.org>
+
+       * configure.in: added check for C++ compiler and a very cheesy
+       check for the Qt integration
+
+       * Makefile.am (SUBDIRS): compile qt subdir if support is enabled
+
+       * qt/Makefile.am: added 
+
+       * qt/.cvsignore: added  
+
+       * qt/dbus-qthread.cc, qt/dbus-qthread.cpp: renamed former to
+       latter, added #ifdef QT_THREAD_SUPPORT guard.
+
+       * dbus/Makefile.am: added missing headers for make dist
+
+2002-12-28  Kristian Rietveld  <kris@gtk.org>
+
+       * dbus/Makefile.am: fixup export-symbols-regex.
+
+2002-12-27  Anders Carlsson  <andersca@codefactory.se>
+
+       * acinclude.m4: Add this file and put the 
+       PKG_CHECK_MODULE macro in it.
+
 2002-12-27  Anders Carlsson  <andersca@codefactory.se>
 
        * dbus/dbus-marshal.c: (_dbus_marshal_string),