2004-04-13 Michael Meeks <michael@ximian.com>
[platform/upstream/dbus.git] / ChangeLog
1 2004-04-13  Michael Meeks  <michael@ximian.com>
2
3         * test/glib/Makefile.am: use the absolute path so the bus
4         daemon's chdir ("/") doesn't kill us dead.
5
6         * configure.in: subst ABSOLUTE_TOP_BUILDDIR
7
8 2004-04-12  Jon Trowbridge  <trow@ximian.com>
9
10         * bus/config-parser.c (struct BusConfigParser): Added
11         included_files field.
12         (seen_include): Added.  Checks whether or not a file has already
13         been included by any parent BusConfigParser.
14         (bus_config_parser_new): Copy the parent's included_files.
15         (include_file): Track which files have been included, and fail on
16         circular inclusions.
17         (process_test_valid_subdir): Changed printf to report if we are
18         testing valid or invalid conf files.
19         (all_are_equiv): Changed printf to be a bit clearer about
20         what we are actually doing.
21         (bus_config_parser_test): Test invalid configuration files.
22
23 2004-04-09  Jon Trowbridge  <trow@ximian.com>
24
25         * bus/config-parser.c (bus_config_parser_new): Added a 'parent'
26         argument.  If non-null, the newly-constructed BusConfigParser will
27         be initialized with the parent's BusLimits instead of the default
28         values.
29         (include_file): When including a config file, pass in
30         the current parser as the parent and then copy the BusLimits
31         from the included BusConfigParser pack to the current parser.
32         (process_test_valid_subdir): Renamed from process_test_subdir.
33         (process_test_equiv_subdir): Added.  Walks through a directory,
34         descending into each subdirectory and loading the config files
35         it finds there.  If any subdirectory contains two config files
36         that don't produce identical BusConfigParser structs, fail.
37         For now, the BusConfigParser's BusPolicies are not compared.
38         (bus_config_parser_test): Call both process_test_valid_subdir and
39         process_test_equiv_subdir.
40
41         * bus/config-loader-libxml.c (bus_config_load): Take a parent
42         argument and pass it along to the call to bus_config_parser_new.
43         Also made a few small changes to allow this code to compile.
44
45         * bus/config-loader-expat.c (bus_config_load): Take a parent
46         argument and pass it along to the call to bus_config_parser_new.
47
48         * bus/bus.c (bus_context_new): Load the config file
49         with a NULL parent argument.
50
51 2004-03-29  Michael Meeks  <michael@ximian.com>
52
53         * glib/dbus-gobject.c (introspect_properties): split
54         out, fix mangled 'while' flow control.
55         (introspect_signals): implement.
56         (handle_introspect): update.
57
58 2004-03-29  Michael Meeks  <michael@ximian.com>
59
60         * glib/dbus-gobject.c (set_object_property): split out / 
61         re-work, use the property type, and not the message type(!)
62         (get_object_property): ditto.
63
64         * glib/dbus-gvalue.c (dbus_gvalue_demarshal),
65         (dbus_gvalue_marshal): make this code re-usable, needed
66         for signals too, also on both proxy and server side.
67         Re-write for more efficiency / readability.
68
69 2004-03-29  Michael Meeks  <michael@ximian.com>
70
71         * dbus/dbus-message.c
72         (dbus_message_new_error_printf): impl.
73
74         * dbus/dbus-connection.c
75         (dbus_connection_unregister_object_path): fix warning.
76
77         * configure.in: fix no-mono-installed situation.
78
79 2004-03-27  Havoc Pennington  <hp@redhat.com>
80
81         Patch from Timo Teräs:
82         
83         * tools/dbus-send.c (main): if --print-reply, assume type is
84         method call; support boolean type args
85         
86         * dbus/dbus-connection.c (dbus_connection_send_with_reply): fix a
87         bunch of memleak and logic bugs
88         
89 2004-03-23  Owen Fraser-Green  <owen@discobabe.net>
90
91         * mono/Arguments.cs:
92         * mono/Introspector.cs:
93         * mono/Handler.cs:
94         * mono/InterfaceProxy.cs:
95         * mono/Message.cs
96         * mono/ProxyBuilder.cs:
97         * mono/Service.cs:
98         Added InterfaceProxy class to avoid building proxies for every
99         object.
100
101         * dbus-message.h:
102         * dbus-message.c (dbus_message_append_args_valist)
103         (dbus_message_iter_get_object_path)
104         (dbus_message_iter_get_object_path_array)
105         (dbus_message_iter_append_object_path)
106         (dbus_message_iter_append_object_path_array):
107         Added object_path iter functions to handle OBJECT_PATH arguments
108         
109 2004-03-23  Owen Fraser-Green  <owen@discobabe.net>
110
111         First checkin of mono bindings.
112         * configure.in:
113         * Makefile.am:
114         Build stuff for the bindings
115         * dbus-sharp.pc.in: Added for pkgconfig
116         
117 2004-03-21  Havoc Pennington  <hp@redhat.com>
118
119         * test/test-service.c (main): remove debug spew
120
121 2004-03-21  Olivier Andrieu  <oliv__a@users.sourceforge.net>
122
123         * dbus/dbus-marshal.c (_dbus_marshal_validate_arg): accept empty
124         arrays
125
126         * dbus/dbus-message.h, bus/dbus-message.c (dbus_message_iter_init)
127         (dbus_message_iter_init_array_iterator)
128         (dbus_message_iter_init_dict_iterator): return a dbus_bool_t to
129         indicate whether the iterator is empty
130
131         * dbus/dbus-pending-call.c, dbus/dbus-server.c: silence compiler
132         warnings
133
134 2004-03-19  Havoc Pennington  <hp@redhat.com>
135
136         * NEWS: 0.21 updates
137
138         * configure.in: 0.21
139
140         * doc/Makefile.am: add all XMLTO usage to DBUS_XML_DOCS_ENABLED
141         
142         * python/Makefile.am: change to avoid dist of dbus_bindings.c so
143         you don't need pyrex to make dist
144
145         * qt/Makefile.am (libdbus_qt_1_la_SOURCES): add integrator.h to
146         sources; run moc
147         
148 2004-03-18  Richard Hult  <richard@imendio.com>
149
150         * dbus/dbus-message.c (dbus_message_get_auto_activation) 
151         (dbus_message_set_auto_activation): Add doxygen docs.
152
153 2004-03-16  Richard Hult  <richard@imendio.com>
154
155         * bus/activation.c: (bus_activation_service_created),
156         (bus_activation_send_pending_auto_activation_messages),
157         (bus_activation_activate_service):
158         * bus/activation.h:
159         * bus/dispatch.c: (bus_dispatch),
160         (check_nonexistent_service_auto_activation),
161         (check_service_auto_activated),
162         (check_segfault_service_auto_activation),
163         (check_existent_service_auto_activation), (bus_dispatch_test):
164         * bus/driver.c: (bus_driver_handle_activate_service):
165         * bus/services.c: (bus_registry_acquire_service):
166         * dbus/dbus-message.c: (dbus_message_set_auto_activation),
167         (dbus_message_get_auto_activation):
168         * dbus/dbus-message.h:
169         * dbus/dbus-protocol.h: Implement auto-activation.
170         
171         * doc/dbus-specification.xml: Add auto-activation to the spec.
172
173 2004-03-12  Olivier Andrieu  <oliv__a@users.sourceforge.net>
174
175         * dbus/dbus-marshal.c (_dbus_marshal_get_arg_end_pos):
176         fix a bug with CUSTOM types.
177
178         * dbus/dbus-message.c (message_iter_test, _dbus_message_test): add
179         a unit test for this bug (used to fail).
180
181 2004-03-12  Mikael Hallendal  <micke@imendio.com>
182
183         * bus/activation.c:
184         (babysitter_watch_callback): notify all pending activations waiting for
185           the same exec that the activation failed.
186         (bus_activation_activate_service): shortcut the activation if we 
187           already waiting for the same executable to start up.
188
189 2004-03-12  Mikael Hallendal  <micke@imendio.com>
190
191         * bus/activation.c: 
192         - Added service file reloading. 
193           Each service files directory is kept in an hash table in 
194           BusActivation and each BusActivationEntry knows what .service-file it
195           was read from. So when you try to activate a service the bus will 
196           check if it's been updated, removed or if new .service-files has 
197           been installed.
198         - Test code at the bottom for the service file reloading.
199         * bus/test-main.c: (main):
200         * bus/test.h:
201         - added service reloading test.
202         * dbus/dbus-sysdeps.c: 
203         * dbus/dbus-sysdeps.h: (_dbus_delete_directory): Added.
204
205 2004-03-08  Michael Meeks  <michael@ximian.com>
206
207         * dbus/dbus-connection.c (_dbus_connection_block_for_reply): 
208         bail immediately if disconnected, to avoid busy loop.
209
210         * dbus/dbus-message.c (dbus_message_iter_get_args_valist):
211         cleanup cut/paste/inefficiency.
212
213 2004-03-01  David Zeuthen  <david@fubar.dk>
214
215         * dbus/dbus-string.c (_dbus_string_append_printf_valist): Fix a
216         bug where args were used twice. This bug resulted in a segfault
217         on a Debian/PPC system when starting the messagebus daemon. Include
218         dbus-sysdeps.h for DBUS_VA_COPY
219
220         * dbus/dbus-sysdeps.h: Define DBUS_VA_COPY if neccessary. From GLib
221
222         * configure.in: Check for va_copy; define DBUS_VA_COPY to the
223         appropriate va_copy implementation. From GLib
224         
225 2004-02-24  Joe Shaw  <joe@ximian.com>
226
227         * bus/services.c (bus_registry_acquire_service): We need to pass
228         in the service name to dbus_set_error() to prevent a crash.
229
230 2003-12-26  Anders Carlsson  <andersca@gnome.org>
231
232         * AUTHORS: Reveal my True identity.
233
234 2003-12-17  Mikael Hallendal  <micke@imendio.com>
235
236         * dbus/dbus-message.c: (dbus_message_append_args_valist): 
237         - Added case for DBUS_TYPE_BYTE, patch from Johan Hedberg.
238
239 2003-12-13  Mikael Hallendal  <micke@imendio.com>
240
241         * doc/TODO: Added not about better error check of configuration files.
242
243 2003-12-02  Richard Hult  <richard@imendio.com>
244
245         * Update AFL version to 2.0 throughout the source files to reflect
246         the update that was done a while ago.
247
248 2003-12-02  Richard Hult  <richard@imendio.com>
249
250         * dbus/dbus-message.c (dbus_message_iter_append_dict): Set
251         wrote_dict_key to FALSE on the iter that the dict is appended to,
252         just like when appending other types. Fixes a bug where a dict
253         couldn't be put inside a dict.
254         (dbus_message_iter_append_dict_key): Fix typo in warning message.
255         (message_iter_test, _dbus_message_test): Add test case for dict
256         inside dict.
257
258 2003-12-01  David Zeuthen  <david@fubar.dk>
259
260         * python/dbus.py: Add the actual message when calling the reciever
261         of a signal such that parameters can be inspected. Add the method
262         remove_signal_receiver
263         
264 2003-11-26  Mikael Hallendal  <micke@imendio.com>
265
266         * bus/*.[ch]:
267         * dbus/*.[ch]:
268         * glib/*.[ch]: Made ref functions return the pointer
269
270 2003-11-25  Zack Rusin  <zack@kde.org>
271
272         * qt/integrator.h, qt/integrator.cpp: Adding handling of DBusServer,
273
274         * qt/server.h, qt/server.cpp, qt/Makefile.am: Adding DBusServer 
275         wrappers,
276
277         * qt/connection.h, qt/connection.cpp: Adjusting to changes in 
278         the Integrator and to better fit with the server,
279
280 2003-11-24  Zack Rusin  <zack@kde.org>
281
282         * qt/connection.h, qt/connection.cpp: removing initDbus method since
283         the integrator handles it now
284
285         * qt/integrator.h, qt/integrator.cpp: reworking handling of timeouts,
286         since QTimer wasn't really meant to be used the way DBusTimeout is
287
288 2003-11-24  Zack Rusin  <zack@kde.org>
289
290         * qt/integrator.h, qt/integrator.cpp, Makefile.am: Adding 
291         Integrator class which integrates D-BUS with the Qt event loop,
292
293         * qt/connection.h, qt/connection.cpp: Move all the code which
294         was dealing with D-BUS integration to the Integrator class,
295         and start using Integrator,
296
297 2003-11-23  Zack Rusin  <zack@kde.org>
298
299         * qt/connection.h, qt/connection.cpp: Adding the DBusConnection 
300         wrapper
301
302         * qt/message.h, qt/message.cpp: updating to the current D-BUS api,
303         switching namespaces to DBusQt, reworking the class,
304
305         * Makefile.cvs: switching dependencies so that it matches KDE 
306         schematics,
307         
308         * qt/Makefile.am: adding connection.{h,cpp} and message.{h,cpp} to 
309         the library
310
311 2003-11-19  Havoc Pennington  <hp@redhat.com>
312
313         * NEWS: update
314
315         * configure.in: bump version to 0.20
316
317         * configure.in (have_qt): add yet another place to look for qt
318         (someone hand trolltech a .pc file...)
319
320 2003-11-01  Havoc Pennington  <hp@redhat.com>
321
322         * doc/dbus-specification.xml: add state machine docs on the auth
323         protocol; just a first draft, I'm sure it's wrong.      
324
325 2003-10-28  David Zeuthen  <david@fubar.dk>
326
327         * python/dbus_bindings.pyx.in: add get_dict to handle dictionaries
328         return types. Fixup TYPE_* to reflect changes in dbus/dbus-protocol.h
329         
330 2003-10-28  Havoc Pennington  <hp@redhat.com>
331
332         * dbus/dbus-message.c (get_next_field): delete unused function
333
334 2003-10-28  Havoc Pennington  <hp@redhat.com>
335
336         * bus/expirelist.c (do_expiration_with_current_time): detect
337         failure of the expire_func due to OOM
338
339         * bus/connection.c (bus_pending_reply_expired): return FALSE on OOM
340
341         * bus/dispatch.c (check_send_exit_to_service): fix to handle the
342         NoReply error that's now created by the bus when the service exits
343
344 2003-10-28  Havoc Pennington  <hp@redhat.com>
345
346         * dbus/dbus-message.c (_dbus_message_test): enable and fix the
347         tests for set_path, set_interface, set_member, etc.
348
349         * dbus/dbus-string.c (_dbus_string_insert_bytes): allow 0 bytes
350
351         * dbus/dbus-message.c (set_string_field): always just delete and
352         re-append the field; accept NULL for deletion
353         (re_align_fields_recurse): reimplement
354         
355 2003-10-26  Havoc Pennington  <hp@redhat.com>
356
357         * dbus/dbus-connection.c: fix docs to properly describe the
358         disconnected message
359         (_dbus_connection_notify_disconnected): remove this function; 
360         we can't synchronously add the disconnected message, we have to 
361         do it after we've queued any remaining real messages
362         (_dbus_connection_get_dispatch_status_unlocked): queue the
363         disconnect message only if the transport has finished queueing all
364         its real messages and is disconnected.
365         (dbus_connection_disconnect): update the dispatch status here
366
367 2003-10-22  Havoc Pennington  <hp@redhat.com>
368
369         * bus/bus.c (bus_context_check_security_policy): fix up assertion
370
371         * bus/connection.c (bus_transaction_send_from_driver): set the
372         destination to the connection's base service
373
374 2003-10-20  Havoc Pennington  <hp@redhat.com>
375
376         hmm, make check is currently not passing.
377         
378         * doc/dbus-specification.xml: add requirement that custom type
379         names follow the same rules as interface names.
380
381         * dbus/dbus-protocol.h: change some of the byte codes, to avoid
382         duplication and allow 'c' to be 'custom'; dict is now 'm' for
383         'map'
384
385         * doc/dbus-specification.xml: update type codes to match
386         dbus-protocol.h, using the ASCII byte values. Rename type NAMED to
387         CUSTOM. Add type OBJECT_PATH to the spec.
388
389 2003-10-17  Havoc Pennington  <hp@redhat.com>
390
391         * bus/driver.c (create_unique_client_name): use "." as separator
392         in base service names instead of '-'
393
394         * dbus/dbus-string.c (_dbus_string_get_byte): allow getting nul
395         byte at the end of the string
396
397         * dbus/dbus-internals.h (_DBUS_LIKELY, _DBUS_UNLIKELY): add
398         optimization macros since string validation seems to be a slow
399         point.
400         
401         * doc/dbus-specification.xml: restrict valid
402         service/interface/member/error names. Add test suite code for the
403         name validation.
404
405         * dbus/dbus-string.c: limit service/interface/member/error names 
406         to [0-9][A-Z][a-z]_
407
408         * dbus/dbus-connection.c (dbus_connection_dispatch): add missing
409         format arg to verbose spew
410
411         * glib/dbus-gproxy.c (dbus_gproxy_call_no_reply): if not out of
412         memory, return instead of g_error
413
414         * test/test-service.c (path_message_func): support emitting a
415         signal on request
416
417         * dbus/dbus-bus.c (init_connections_unlocked): only fill in
418         activation bus type if DBUS_BUS_ACTIVATION was set; default to
419         assuming the activation bus was the session bus so that services
420         started manually will still register.
421         (init_connections_unlocked): fix so that in OOM situation we get
422         the same semantics when retrying the function
423         
424         * test/test-service.c (main): change to use path registration, to
425         test those codepaths; register with DBUS_BUS_ACTIVATION rather
426         than DBUS_BUS_SESSION
427
428 2003-10-16  Havoc Pennington  <hp@redhat.com>
429
430         * glib/dbus-gtest-main.c: bracket with #ifdef DBUS_BUILD_TESTS
431
432         * Makefile.am (GCOV_DIRS): remove "test", we don't care about test
433         coverage of the tests
434         (coverage-report.txt): don't move the .da and .bbg files around
435
436 2003-10-16  Havoc Pennington  <hp@redhat.com>
437
438         * bus/bus.c (struct BusContext): remove struct field I didn't mean
439         to put there
440
441 2003-10-16  Havoc Pennington  <hp@redhat.com>
442
443         * bus/connection.c (bus_pending_reply_expired): either cancel or
444         execute, not both
445         (bus_connections_check_reply): use unlink, not remove_link, as we
446         don't want to free the link; fixes double free mess
447
448         * dbus/dbus-pending-call.c (dbus_pending_call_block): fix in case
449         where no reply was received
450
451         * dbus/dbus-connection.c (_dbus_pending_call_complete_and_unlock):
452         fix a refcount leak
453
454         * bus/signals.c (match_rule_matches): add special cases for the
455         bus driver, so you can match on sender/destination for it.
456
457         * dbus/dbus-sysdeps.c (_dbus_abort): print backtrace if
458         DBUS_PRINT_BACKTRACE is set
459
460         * dbus/dbus-internals.c: add pid to assertion failure messages
461
462         * dbus/dbus-connection.c: add message type code to the debug spew
463
464         * glib/dbus-gproxy.c (gproxy_get_match_rule): match rules want
465         sender=foo not service=foo
466
467         * dbus/dbus-bus.c (dbus_bus_get): if the activation bus is the
468         session bus but DBUS_SESSION_BUS_ADDRESS isn't set, use 
469         DBUS_ACTIVATION_ADDRESS instead
470
471         * bus/activation.c: set DBUS_SESSION_BUS_ADDRESS,
472         DBUS_SYSTEM_BUS_ADDRESS if appropriate
473
474         * bus/bus.c (bus_context_new): handle OOM copying bus type into
475         context struct
476
477         * dbus/dbus-message.c (dbus_message_iter_get_object_path): new function
478         (dbus_message_iter_get_object_path_array): new function (half
479         finished, disabled for the moment)
480         
481         * glib/dbus-gproxy.c (dbus_gproxy_end_call): properly handle
482         DBUS_MESSAGE_TYPE_ERROR
483
484         * tools/dbus-launch.c (babysit): support DBUS_DEBUG_OUTPUT to
485         avoid redirecting stderr to /dev/null
486         (babysit): close stdin if not doing the "exit_with_session" thing
487
488         * dbus/dbus-sysdeps.c (_dbus_become_daemon): delete some leftover
489         debug code; change DBUS_DEBUG_OUTPUT to only enable stderr, not
490         stdout/stdin, so things don't get confused
491         
492         * bus/system.conf.in: fix to allow replies, I modified .conf
493         instead of .conf.in again.
494
495 2003-10-14  David Zeuthen  <david@fubar.dk>
496
497         * python/dbus_bindings.pyx.in (MessageIter.get): fixed typo in
498         argtype to arg_type when raising unknown arg type exception.
499         Changed type list to reflect the changes in dbus-protocol.h so 
500         the bindings actually work.
501
502 2003-10-14  Havoc Pennington  <hp@redhat.com>
503
504         * test/decode-gcov.c: support gcc 3.3 also, though gcc 3.3 seems
505         to have a bug keeping it from outputting the .da files sometimes
506         (string_get_string): don't append garbage nul bytes to the string.
507
508 2003-10-15  Seth Nickell  <seth@gnome.org>
509
510         * python/Makefile.am:
511
512         Include dbus_h_wrapper.h in the dist tarball.
513
514 2003-10-14  Havoc Pennington  <hp@redhat.com>
515
516         * bus/bus.c (bus_context_check_security_policy): revamp this to
517         work more sanely with new policy-based requested reply setup
518
519         * bus/connection.c (bus_transaction_send_from_driver): set bus
520         driver messages as no reply
521
522         * bus/policy.c (bus_client_policy_check_can_receive): handle a
523         requested_reply attribute on allow/deny rules
524
525         * bus/system.conf: add <allow requested_reply="true"/>
526
527         * bus/driver.c (bus_driver_handle_message): fix check for replies
528         sent to the bus driver, which was backward. How did this ever work
529         at all though? I think I'm missing something.
530
531         * dbus/dbus-message.c (decode_header_data): require error and
532         method return messages to have a reply serial field to be valid
533         (_dbus_message_loader_queue_messages): break up this function;
534         validate that reply serial and plain serial are nonzero; 
535         clean up the OOM/error handling.
536         (get_uint_field): don't return -1 from this
537         (dbus_message_create_header): fix signed/unsigned bug
538
539         * bus/connection.c (bus_connections_expect_reply): save serial of
540         the incoming message, not reply serial
541
542 2003-10-14  Havoc Pennington  <hp@redhat.com>
543
544         * bus/connection.c: implement pending reply tracking using
545         BusExpireList
546
547         * bus/bus.c (bus_context_check_security_policy): verify that a
548         reply is pending in order to allow a reply to be sent. Deny 
549         messages of unknown type.
550
551         * bus/dbus-daemon-1.1.in: update to mention new resource limits
552
553         * bus/bus.c (bus_context_get_max_replies_per_connection): new
554         (bus_context_get_reply_timeout): new
555
556 2003-10-13  Seth Nickell  <seth@gnome.org>
557
558         * python/Makefile.am:
559
560         Pass "make distcheck": remove a couple files from DIST_FILES
561         that weren't included in the final version.
562
563 2003-10-12  Havoc Pennington  <hp@pobox.com>
564
565         Added test code that 1) starts an actual bus daemon and 2) uses
566         DBusGProxy; fixed bugs that were revealed by the test. Lots 
567         more testing possible, but this is the basic framework.
568         
569         * glib/dbus-gproxy.c (dbus_gproxy_manager_unregister): remove
570         empty proxy lists from the proxy list hash
571
572         * dbus/dbus-message.c (dbus_message_iter_get_args_valist): add a
573         couple of return_if_fail checks
574
575         * dbus/dbus-pending-call.c (_dbus_pending_call_new): use dbus_new0
576         to allocate, so everything is cleared to NULL as it should be.
577
578         * glib/dbus-gmain.c (dbus_connection_setup_with_g_main): pass
579         source as data to dbus_connection_set_timeout_functions() as the 
580         timeout functions expected
581
582         * test/glib/run-test.sh: add a little script to start up a message
583         bus and run tests using it
584
585         * tools/dbus-launch.1: updates
586
587         * tools/dbus-launch.c (main): add --config-file option
588
589         * tools/dbus-launch.c (main): remove confusing else if (runprog)
590         that could never be reached.
591
592         * dbus/dbus-message.c (dbus_message_new_method_return) 
593         (dbus_message_new_error, dbus_message_new_signal): set the
594         no-reply-expected flag on all these. Redundant, but may
595         as well be consistent.
596
597 2003-10-11  Havoc Pennington  <hp@pobox.com>
598
599         * test/decode-gcov.c (function_solve_graph): make broken block
600         graph a nonfatal error since it seems to be broken. Need to debug
601         this.
602
603         * dbus/dbus-marshal.c (_dbus_type_is_valid): new function since we
604         can't just check type > INVALID < LAST anymore
605
606         * dbus/dbus-message.c (dbus_message_get_signature): new function
607         (dbus_message_has_signature): new function
608         (struct DBusMessage): add signature field (right now it isn't sent
609         over the wire, just generated on the fly)
610         (dbus_message_copy): copy the signature, and init strings to
611         proper length to avoid some reallocs
612         (dbus_message_iter_init_array_iterator): return void, since it
613         can't fail
614         (dbus_message_iter_init_dict_iterator): return void since it can't fail
615         (_dbus_message_loader_queue_messages): add silly temporary hack to
616         fill in message->signature on load
617
618         * dbus/dbus-protocol.h: change DBUS_TYPE_* values to be ASCII
619         characters, so they are relatively human-readable.
620
621 2003-10-11  Havoc Pennington  <hp@pobox.com>
622
623         * dbus/dbus-message.c (_dbus_message_test): add more test
624         coverage, but #if 0 for now since they uncover a bug 
625         not fixed yet; I think in re_align_field_recurse()
626         (re_align_field_recurse): add FIXME about broken assertion
627
628         * dbus/dbus-sysdeps.c (_dbus_sysdeps_test): add more test coverage
629
630         * bus/connection.c: share a couple code bits with expirelist.c
631
632         * bus/expirelist.h, bus/expirelist.c: implement a generic
633         expire-items-after-N-seconds facility, was going to share between
634         expiring connections and replies, decided not to use for expiring
635         connections for now.
636
637         * COPYING: include AFL 2.0 (still need to change all the file headers)
638
639 2003-10-09  Havoc Pennington  <hp@redhat.com>
640
641         * configure.in: define DBUS_HAVE_GCC33_GCOV if we have
642         gcc 3.3. Not that we do anything about it yet.
643
644         * bus/signals.c (bus_match_rule_parse): impose max length on the
645         match rule text
646
647         * dbus/dbus-protocol.h: add DBUS_MAXIMUM_MATCH_RULE_LENGTH
648
649 2003-10-09  Havoc Pennington  <hp@redhat.com>
650
651         Make matching rules theoretically work (add parser).
652         
653         * bus/bus.c (bus_context_check_security_policy): fix up to handle
654         the case where destination is explicitly specified as bus driver
655         and someone else is eavesdropping.
656         
657         * bus/policy.c (bus_client_policy_check_can_receive): fix up
658         definition of eavesdropping and assertion
659
660         * tools/dbus-send.c (main): use dbus_message_type_from_string
661
662         * bus/signals.c (bus_match_rule_parse): implement
663
664         * dbus/dbus-message.c (dbus_message_type_from_string): new
665
666         * dbus/dbus-errors.h (DBUS_ERROR_MATCH_RULE_INVALID): add
667
668 2003-10-02  Havoc Pennington  <hp@pobox.com>
669
670         * glib/dbus-gproxy.c (dbus_gproxy_call_no_reply): rename from
671         dbus_gproxy_oneway_call
672
673         * glib/dbus-gmain.c (dbus_connection_setup_with_g_main) 
674         (dbus_server_setup_with_g_main): fix to allow calling them more
675         than once on the same args
676         (dbus_bus_get_with_g_main): new function
677
678 2003-10-02  Havoc Pennington  <hp@redhat.com>
679
680         * doc/dbus-tutorial.xml: write some stuff
681
682 2003-09-29  Havoc Pennington  <hp@pobox.com>
683
684         * configure.in: split checks for Doxygen from XML docs, check for
685         xmlto
686
687         * doc/Makefile.am: XML-ify all the docs, and add a blank
688         dbus-tutorial.xml
689
690 2003-09-29  Havoc Pennington  <hp@pobox.com>
691
692         * Merge dbus-object-names branch. To see the entire patch 
693         do cvs diff -r DBUS_OBJECT_NAMES_BRANCHPOINT -r dbus-object-names,
694         it's huuuuge though.
695         To revert, I tagged DBUS_BEFORE_OBJECT_NAMES_MERGE.
696         
697 2003-09-28  Havoc Pennington  <hp@pobox.com>
698
699         * HACKING: update to reflect new server
700
701 2003-09-26  Seth Nickell  <seth@gnome.org>
702
703         * python/dbus.py:
704         * python/examples/example-signals.py:
705
706         Start implementing some notions of signals. The API
707         is really terrible, but they sort of work (with the
708         exception of being able to filter by service, and to
709         transmit signals *as* a particular service). Need to
710         figure out how to make messages come from the service
711         we registered :-(
712         
713         * python/dbus_bindings.pyx.in:
714
715         Removed duplicate message_handler callbacks.
716         
717 2003-09-25  Havoc Pennington  <hp@redhat.com>
718
719         * bus/session.conf.in: fix my mess
720
721 2003-09-25  Havoc Pennington  <hp@pobox.com>
722
723         * bus/session.conf.in: fix security policy, reported by Seth Nickell
724
725 2003-09-25  Seth Nickell  <seth@gnome.org>
726
727         * python/examples/example-service.py:
728
729         Johan notices complete wrong code in example-service, but
730         completely wrong in a way that works exactly the same (!).
731         Johan is confused, how could this possibly work? Example
732         code fails to serve purpose of making things clear.
733         Seth fixes.
734
735 2003-09-25  Mark McLoughlin  <mark@skynet.ie>
736
737         * doc/dbus-specification.sgml: don't require header fields
738         to be 4-byte aligned and specify that fields should be
739         distinguished from padding by the fact that zero is not
740         a valid field name.
741         
742         * doc/TODO: remove re-alignment item and add item to doc
743         the OBJECT_PATH type.
744         
745         * dbus/dbus-message.c:
746         (HeaderField): rename the original member to value_offset
747         and introduce a name_offset member to keep track of where
748         the field actually begins.
749         (adjust_field_offsets): remove.
750         (append_int_field), (append_uint_field),
751         (append_string_field): don't align the start of the header
752         field to a 4-byte boundary.
753         (get_next_field): impl finding the next marhsalled field
754         after a given field.
755         (re_align_field_recurse): impl re-aligning a number of
756         already marshalled fields.
757         (delete_field): impl deleting a field of any type and
758         re-aligning any following fields.
759         (delete_int_or_uint_field), (delete_string_field): remove.
760         (set_int_field), (set_uint_field): no need to re-check
761         that we have the correct type for the field.
762         (set_string_field): ditto and impl re-aligning any
763         following fields.
764         (decode_header_data): update to take into account that
765         the fields aren't 4-byte aligned any more and the new
766         way to distinguish padding from header fields. Also,
767         don't exit when there is too much header padding.
768         (process_test_subdir): print the directory.
769         (_dbus_message_test): add test to make sure a following
770         field is re-aligned correctly after field deletion.
771         
772         * dbus/dbus-string.[ch]:
773         (_dbus_string_insert_bytes): rename from insert_byte and
774         allow the insert of multiple bytes.
775         (_dbus_string_test): test inserting multiple bytes.
776
777         * dbus/dbus-marshal.c: (_dbus_marshal_set_string): add
778         warning note to docs about having to re-align any
779         marshalled values following the string.
780         
781         * dbus/dbus-message-builder.c:
782         (append_string_field), (_dbus_message_data_load):
783         don't align the header field.
784         
785         * dbus/dbus-auth.c: (process_test_subdir): print the
786         directory.
787         
788         * test/break-loader.c: (randomly_add_one_byte): upd. for
789         insert_byte change.
790         
791         * test/data/invalid-messages/bad-header-field-alignment.message:
792         new test case.
793         
794         * test/data/valid-messages/unknown-header-field.message: shove
795         a dict in the unknown field.
796
797 2003-09-25  Seth Nickell  <seth@gnome.org>
798
799         * python/dbus.py:
800         * python/dbus_bindings.pyx.in:
801
802         Handle return values.
803         
804         * python/examples/example-client.py:
805         * python/examples/example-service.py:
806
807         Pass back return values from the service to the client.
808         
809 2003-09-24  Seth Nickell  <seth@gnome.org>
810
811         * python/dbus.py:
812
813         Connect Object methods (when you are sharing an object) up... pass
814         in a list of methods to be shared. Sharing all the methods just
815         worked out too weird. You can now create nice Services over the
816         DBus in Python. :-)
817         
818         * python/dbus_bindings.pyx.in:
819
820         Keep references to user_data tuples passed into C functions so 
821         Python doesn't garbage collect on us.
822
823         Implement MethodReturn and Error subclasses of Message for creating
824         DBusMessage's of those types.
825         
826         * python/examples/example-client.py:
827         * python/examples/example-service.py:
828
829         Simple example code showing both how create DBus services and objects,
830         and how to use them.
831
832 2003-09-23  Havoc Pennington  <hp@pobox.com>
833
834         * glib/dbus-gproxy.c (dbus_gproxy_manager_filter): implement
835
836 2003-09-23  Havoc Pennington  <hp@redhat.com>
837
838         * glib/dbus-gproxy.c (dbus_gproxy_connect_signal): implement
839         (dbus_gproxy_disconnect_signal): implement
840         (dbus_gproxy_manager_remove_signal_match): implement
841         (dbus_gproxy_manager_add_signal_match): implement
842         (dbus_gproxy_oneway_call): implement
843
844 2003-09-23  Havoc Pennington  <hp@pobox.com>
845
846         * glib/dbus-gproxy.c (struct DBusGProxy): convert to a GObject
847         subclass. This means dropping the transparent thread safety of the
848         proxy; you now need a separate proxy per-thread, or your own
849         locking on the proxy. Probably right anyway.
850         (dbus_gproxy_ref, dbus_gproxy_unref): nuke, just use g_object_ref
851
852 2003-09-22  Havoc Pennington  <hp@redhat.com>
853
854         * glib/dbus-gproxy.c (dbus_gproxy_manager_get): implement
855
856 2003-09-21  Seth Nickell  <seth@gnome.org>
857
858         First checkin of the Python bindings.
859         
860         * python/.cvsignore:
861         * python/Makefile.am:
862         * python/dbus_bindings.pyx.in:
863         * python/dbus_h_wrapper.h:
864
865         Pieces for Pyrex to operate on, building a dbus_bindings.so
866         python module for low-level access to the DBus APIs.
867         
868         * python/dbus.py:
869
870         High-level Python module for accessing DBus objects.
871
872         * configure.in:
873         * Makefile.am:
874
875         Build stuff for the python bindings.
876
877         * acinclude.m4:
878
879         Extra macro needed for finding the Python C header files.
880
881 2003-09-21  Havoc Pennington  <hp@pobox.com>
882
883         * glib/dbus-gproxy.c (dbus_gproxy_manager_new): start
884         implementing the proxy manager, didn't get very far.
885
886         * dbus/dbus-bus.c (dbus_bus_add_match): new
887         (dbus_bus_remove_match): new
888
889         * glib/dbus-gproxy.c (dbus_gproxy_new_for_service): add a
890         path_name argument; adjust the other not-yet-implemented 
891         gproxy constructors to be what I think they should be.
892
893 2003-09-21  Havoc Pennington  <hp@pobox.com>
894
895         * dbus/dbus-bus.c (dbus_bus_get): set exit_on_disconnect to TRUE
896         by default for message bus connections.
897
898         * dbus/dbus-connection.c (dbus_connection_dispatch): exit if
899         exit_on_disconnect flag is set and we process the disconnected
900         signal.
901         (dbus_connection_set_exit_on_disconnect): new function
902
903 2003-09-21  Havoc Pennington  <hp@pobox.com>
904
905         Get matching rules mostly working in the bus; only actually
906         parsing the rule text remains. However, the client side of
907         "signal connections" hasn't been started, this patch is only the
908         bus side.
909         
910         * dbus/dispatch.c: fix for the matching rules changes
911         
912         * bus/driver.c (bus_driver_handle_remove_match)
913         (bus_driver_handle_add_match): send an ack reply from these
914         method calls
915
916         * glib/dbus-gproxy.c (dbus_gproxy_begin_call): fix order of
917         arguments, reported by Seth Nickell
918
919         * bus/config-parser.c (append_rule_from_element): support
920         eavesdrop=true|false attribute on policies so match rules 
921         can be prevented from snooping on the system bus.
922
923         * bus/dbus-daemon-1.1.in: consistently use terminology "sender"
924         and "destination" in attribute names; fix some docs bugs; 
925         add eavesdrop=true|false attribute
926
927         * bus/driver.c (bus_driver_handle_add_match)
928         (bus_driver_handle_remove_match): handle AddMatch, RemoveMatch
929         messages
930
931         * dbus/dbus-protocol.h (DBUS_SERVICE_ORG_FREEDESKTOP_BROADCAST): get
932         rid of broadcast service concept, signals are just always broadcast
933
934         * bus/signals.c, bus/dispatch.c, bus/connection.c, bus/bus.c:
935         mostly implement matching rules stuff (currently only exposed as signal
936         connections)
937
938 2003-09-21  Mark McLoughlin  <mark@skynet.ie>
939
940         * doc/dbus-specification.sgml: Change the header field name
941         to be an enum and update the rest of the spec to reference
942         the fields using the conventinal name.
943
944         * dbus/dbus-protocol.h: update to reflect the spec.
945
946         * doc/TODO: add item to remove the 4 byte alignment requirement.
947         
948         * dbus/dbus-message.c: Remove the code to generalise the
949         header/body length and serial number header fields as named
950         header fields so we can reference field names using the 
951         protocol values.
952         (append_int_field), (append_uint_field), (append_string_field):
953         Append the field name as a byte rather than four chars.
954         (delete_int_or_uint_field), (delete_string_field): reflect the
955         fact that the field name and typecode now occupy 4 bytes instead
956         of 8.
957         (decode_string_field), (decode_header_data): update to reflect
958         protocol changes and move the field specific encoding from
959         decode_string_field() back into decode_header_data().
960         
961         * dbus/dbus-internals.[ch]: (_dbus_header_field_to_string):
962         Add utility to aid debugging.
963         
964         * dbus/dbus-message-builder.c:
965         (append_string_field), (_dbus_message_data_load): Update to
966         reflect protocol changes; Change the FIELD_NAME directive
967         to HEADER_FIELD and allow it to take the field's conventional
968         name rather than the actual value.
969         
970         * test/data/*/*.message: Update to use HEADER_FIELD instead
971         of FIELD_NAME; Always align the header on an 8 byte boundary
972         *before* updating the header length.
973
974 2003-09-15  Havoc Pennington  <hp@pobox.com>
975
976         * dbus/dbus-pending-call.c: add the get/set object data
977         boilerplate as for DBusConnection, etc. Use generic object data
978         for the notify callback.
979
980         * glib/dbus-gparser.c (parse_node): parse child nodes
981
982         * tools/dbus-viewer.c: more hacking on the dbus-viewer
983         
984         * glib/dbus-gutils.c (_dbus_gutils_split_path): add a file to
985         contain functions shared between the convenience lib and the
986         installed lib
987
988         * glib/Makefile.am (libdbus_glib_1_la_LDFLAGS): add
989         -export-symbols-regex to the GLib library
990
991         * dbus/dbus-object-tree.c (_dbus_object_tree_dispatch_and_unlock):
992         fix the locking in here, and add a default handler for
993         Introspect() that just returns sub-nodes.
994
995 2003-09-14  Havoc Pennington  <hp@pobox.com>
996
997         * glib/dbus-gthread.c (dbus_g_thread_init): rename to make g_foo
998         rather than gfoo consistent
999
1000         * glib/dbus-gproxy.h: delete for now, move contents to
1001         dbus-glib.h, because the include files don't work right since we
1002         aren't in the dbus/ subdir.
1003         
1004         * glib/dbus-gproxy.c (dbus_gproxy_send): finish implementing
1005         (dbus_gproxy_end_call): finish
1006         (dbus_gproxy_begin_call): finish
1007
1008         * glib/dbus-gmain.c (dbus_set_g_error): new
1009
1010         * glib/dbus-gobject.c (handle_introspect): include information
1011         about child nodes in the introspection
1012
1013         * dbus/dbus-connection.c (dbus_connection_list_registered): new
1014         function to help in implementation of introspection
1015
1016         * dbus/dbus-object-tree.c
1017         (_dbus_object_tree_list_registered_and_unlock): new function
1018
1019 2003-09-12  Havoc Pennington  <hp@pobox.com>
1020
1021         * glib/dbus-gidl.h: add common base class for all the foo_info
1022         types
1023
1024         * tools/dbus-viewer.c: add GTK-based introspection UI thingy
1025         similar to kdcop
1026
1027         * test/Makefile.am: try test srcdir -ef . in addition to test
1028         srcdir = ., one of them should work (yeah lame)
1029         
1030         * glib/Makefile.am: build the "idl" parser stuff as a convenience
1031         library
1032         
1033         * glib/dbus-gparser.h: make description_load routines return
1034         NodeInfo* not Parser*
1035
1036         * Makefile.am (SUBDIRS): build test dir after all library dirs
1037
1038         * configure.in: add GTK+ detection
1039
1040 2003-09-07  Havoc Pennington  <hp@pobox.com>
1041
1042         * Make Doxygen contented.
1043
1044 2003-09-07  Havoc Pennington  <hp@pobox.com>
1045
1046         * doc/dbus-specification.sgml: more updates
1047
1048 2003-09-06  Havoc Pennington  <hp@pobox.com>
1049
1050         * doc/dbus-specification.sgml: partial updates
1051
1052         * bus/dbus-daemon-1.1.in: fix the config file docs for the
1053         zillionth time; hopefully I edited the right file this time.
1054
1055         * bus/config-parser.c (append_rule_from_element): support
1056         send_type, send_path, receive_type, receive_path
1057
1058         * bus/policy.c: add message type and path to the list of things
1059         that can be "firewalled"
1060
1061 2003-09-06  Havoc Pennington  <hp@pobox.com>
1062
1063         * dbus/dbus-connection.c (dbus_connection_register_fallback): add this
1064         (dbus_connection_register_object_path): make this not handle
1065         messages to paths below the given path
1066
1067 2003-09-03  Havoc Pennington  <hp@pobox.com>
1068
1069         * test/glib/Makefile.am: add this with random glib-linked test
1070         programs
1071
1072         * glib/Makefile.am: remove the random test programs from here,
1073         leave only the unit tests
1074
1075         * glib/dbus-gobject.c (_dbus_gobject_test): add test for 
1076         uscore/javacaps conversion, and fix     
1077         (get_object_property, set_object_property): change to .NET
1078         convention for mapping props to methods, set_FooBar/get_FooBar, 
1079         since one language has such a convention we may as well copy it. 
1080         Plus real methods in either getFooBar or get_foo_bar style won't 
1081         collide with this convention.
1082
1083 2003-09-01  Havoc Pennington  <hp@pobox.com>
1084
1085         * glib/dbus-gparser.c: implement
1086
1087         * glib/dbus-gobject.c: start implementing skeletons support
1088
1089         * configure.in: when disabling checks/assert, also define
1090         G_DISABLE_ASSERT and G_DISABLE_CHECKS
1091
1092 2003-09-01  Havoc Pennington  <hp@pobox.com>
1093
1094         * glib/Makefile.am: rearrange a bunch of files and get "make
1095         check" framework set up
1096
1097 2003-08-31  Havoc Pennington  <hp@pobox.com>
1098
1099         * fix build with --disable-tests
1100
1101 2003-08-30  Havoc Pennington  <hp@pobox.com>
1102
1103         * dbus/dbus-connection.c: purge DBusMessageHandler
1104
1105         * dbus/dbus-message-handler.c: remove DBusMessageHandler, just 
1106         use callbacks everywhere
1107
1108 2003-08-30  Havoc Pennington  <hp@pobox.com>
1109
1110         * test/data/valid-config-files/system.d/test.conf: change to 
1111         root for the user so warnings don't get printed
1112
1113         * dbus/dbus-message.c: add dbus_message_get_path,
1114         dbus_message_set_path
1115         
1116         * dbus/dbus-object-tree.c (do_test_dispatch): add test of
1117         dispatching to a path
1118
1119         * dbus/dbus-string.c (_dbus_string_validate_path): add
1120
1121         * dbus/dbus-marshal.c (_dbus_demarshal_object_path): implement
1122         (_dbus_marshal_object_path): implement
1123
1124         * dbus/dbus-protocol.h (DBUS_HEADER_FIELD_PATH): new header field 
1125         to contain the path to the target object
1126         (DBUS_HEADER_FIELD_SENDER_SERVICE): rename
1127         DBUS_HEADER_FIELD_SENDER to explicitly say it's the sender service
1128
1129 2003-08-30  Havoc Pennington  <hp@pobox.com>
1130
1131         * dbus/dbus-object-tree.c: write tests and fix the discovered bugs
1132
1133 2003-08-29  Havoc Pennington  <hp@pobox.com>
1134
1135         * dbus/dbus-object-tree.c: modify to allow overlapping paths to be
1136         registered
1137         (struct DBusObjectSubtree): shrink this
1138         a lot, since we may have a lot of them
1139         (_dbus_object_tree_free_all_unlocked): implement
1140         (_dbus_object_tree_dispatch_and_unlock): implement
1141
1142 2003-08-29  Havoc Pennington  <hp@pobox.com>
1143
1144         * dbus/dbus-internals.h: fix _DBUS_N_GLOBAL_LOCKS
1145
1146 2003-08-28  Havoc Pennington  <hp@pobox.com>
1147
1148         purge DBusObjectID
1149         
1150         * dbus/dbus-connection.c: port to no ObjectID, create a
1151         DBusObjectTree, rename ObjectTree to ObjectPath in public API
1152
1153         * dbus/dbus-connection.h (struct DBusObjectTreeVTable): delete 
1154         everything except UnregisterFunction and MessageFunction
1155         
1156         * dbus/dbus-marshal.c: port away from DBusObjectID, 
1157         add DBUS_TYPE_OBJECT_PATH
1158         
1159         * dbus/dbus-object-registry.[hc], dbus/dbus-object.[hc], 
1160         dbus/dbus-objectid.[hc]: remove these, we are moving to 
1161         path-based object IDs
1162
1163 2003-08-25  Havoc Pennington  <hp@pobox.com>
1164
1165         Just noticed that dbus_message_test is hosed, I wonder when I
1166         broke that. I thought make check was passing earlier...
1167         
1168         * dbus/dbus-object-tree.c: add new "object tree" to match DCOP 
1169         container tree, will replace most of dbus-object-registry
1170
1171         * dbus/dbus-string.c (_dbus_string_append_printf_valist): fix C99
1172         screwup
1173
1174 2003-08-19  Havoc Pennington  <hp@pobox.com>
1175
1176         * dbus/dbus-message.c (decode_string_field): support FIELD_SENDER
1177         (dbus_message_is_error): fix this function
1178
1179         * bus/dbus-daemon-1.1: clarify logic on when <deny>/<allow> rules
1180         match
1181
1182         * bus/policy.c (bus_client_policy_check_can_receive): fix code to
1183         reflect clarified man page
1184         (bus_client_policy_check_can_send): ditto
1185         
1186         * bus/session.conf.in: fixup
1187
1188         * bus/system.conf.in: fixup
1189
1190 2003-08-18  Havoc Pennington  <hp@redhat.com>
1191
1192         * dbus/dbus-hash.c (_dbus_hash_table_insert_two_strings): fix
1193
1194         * dbus/dbus-message.c (_dbus_message_loader_queue_messages): fix
1195         dumb bug created earlier (wrong order of args to
1196         decode_header_data())
1197         
1198         * tools/dbus-send.c: port
1199
1200         * tools/dbus-print-message.c (print_message): port
1201
1202         * test/data/*messages: port all messages over
1203         
1204         * dbus/dbus-message-builder.c: support including 
1205         message type
1206         
1207         * bus/driver.c: port over
1208         
1209         * bus/dispatch.c: port over to new stuff
1210
1211         * dbus/dbus-connection.c (_dbus_connection_new_for_transport):
1212         rename disconnect signal to "Disconnected"
1213
1214 2003-08-17  Havoc Pennington  <hp@pobox.com>
1215
1216         This doesn't compile yet, but syncing up so I can hack on it from
1217         work. What are branches for if not broken code? ;-)
1218         
1219         * dbus/dbus-protocol.h: remove DBUS_HEADER_FIELD_NAME, add
1220         DBUS_HEADER_FIELD_INTERFACE, DBUS_HEADER_FIELD_MEMBER,
1221         DBUS_HEADER_FIELD_ERROR_NAME
1222         
1223         * dbus/dbus-hash.c: Introduce DBUS_HASH_TWO_STRINGS as hack to use
1224         for the interface+member pairs
1225         (string_hash): change to use g_str_hash algorithm
1226         (find_direct_function, find_string_function): refactor these to
1227         share most code.
1228         
1229         * dbus/dbus-message.c: port all of this over to support 
1230         interface/member fields instead of name field
1231
1232         * dbus/dbus-object-registry.c: port over
1233         
1234         * dbus/dbus-string.c (_dbus_string_validate_interface): rename
1235         from _dbus_string_validate_name
1236
1237         * bus/dbus-daemon-1.1: change file format for the 
1238         <deny>/<allow> stuff to match new message naming scheme
1239
1240         * bus/policy.c: port over
1241
1242         * bus/config-parser.c: parse new format
1243         
1244 2003-08-16  Havoc Pennington  <hp@pobox.com>
1245
1246         * dbus/dbus-object-registry.c (add_and_remove_objects): remove
1247         broken assertion
1248
1249         * glib/dbus-gproxy.c: some hacking
1250
1251 2003-08-15  Havoc Pennington  <hp@redhat.com>
1252
1253         * dbus/dbus-pending-call.c (dbus_pending_call_block): implement
1254
1255         * dbus/dbus-connection.c
1256         (dbus_connection_send_with_reply_and_block): factor out internals;
1257         change to convert any error replies to DBusError instead of 
1258         returning them as a message
1259
1260 2003-08-15  Havoc Pennington  <hp@pobox.com>
1261
1262         * dbus/dbus-connection.c, 
1263         dbus/dbus-pending-call.c: Finish the pending call stuff
1264
1265 2003-08-14  Havoc Pennington  <hp@redhat.com>
1266
1267         * dbus/dbus-pending-call.c: start on new object that will replace
1268         DBusMessageHandler and ReplyHandlerData for tracking outstanding
1269         replies
1270
1271         * dbus/dbus-gproxy.c: start on proxy object used to communicate
1272         with remote interfaces
1273
1274         * dbus/dbus-gidl.c: do the boring boilerplate in here
1275         
1276 2003-08-12  Havoc Pennington  <hp@pobox.com>
1277
1278         * bus/dispatch.c (bus_dispatch): make this return proper 
1279         DBusHandlerResult to avoid DBUS_ERROR_UNKNOWN_METHOD
1280
1281         * dbus/dbus-errors.c (dbus_set_error): use
1282         _dbus_string_append_printf_valist
1283
1284         * dbus/dbus-string.c (_dbus_string_append_printf_valist)
1285         (_dbus_string_append_printf): new
1286
1287         * dbus/dbus-errors.h (DBUS_ERROR_UNKNOWN_MESSAGE): change to
1288         UNKNOWN_METHOD
1289
1290         * dbus/dbus-connection.c (dbus_connection_dispatch): handle
1291         DBUS_HANDLER_RESULT_NEED_MEMORY; send default error reply if a
1292         message is unhandled.
1293
1294 2003-08-11  Havoc Pennington  <hp@pobox.com>
1295
1296         * bus/test.c (client_disconnect_handler): change to return
1297         HANDLED (would have been REMOVE_MESSAGE)
1298
1299         * dbus/dbus-object.h (enum DBusHandlerResult): rename to
1300         HANDLED/NOT_YET_HANDLED instead of
1301         REMOVE_MESSAGE/ALLOW_MORE_HANDLERS to make it clearer how it 
1302         should be used.
1303
1304 2003-08-10  Havoc Pennington  <hp@pobox.com>
1305
1306         * tools/dbus-send.c (main): add --type argument, for now
1307         supporting only method_call and signal types.
1308
1309         * tools/dbus-print-message.c: print message type
1310
1311         * dbus/dbus-connection.c (_dbus_connection_new_for_transport):
1312         init connection->objects
1313
1314         * doc/dbus-specification.sgml: fix sgml
1315
1316         * bus/*.c: port over to object-instance API changes
1317
1318         * test/test-service.c: ditto
1319         
1320         * dbus/dbus-message.c (dbus_message_create_header): allow #NULL
1321         name, we will have to fix up the rest of the code to also handle
1322         this
1323         (dbus_message_new): generic message-creation call
1324         (set_string_field): allow appending name field
1325
1326 2003-08-06  Havoc Pennington  <hp@pobox.com>
1327
1328         * dbus/dbus-object-registry.c: implement signal connection 
1329         and dispatch
1330
1331         * dbus/dbus-connection.c (_dbus_connection_unref_unlocked): new
1332
1333         * dbus/dbus-internals.c (_dbus_memdup): new function
1334
1335 2003-08-02  Havoc Pennington  <hp@pobox.com>
1336
1337         * dbus/dbus-message.c (dbus_message_get_no_reply)
1338         (dbus_message_set_no_reply): add these and remove
1339         set_is_error/get_is_error
1340
1341         * dbus/dbus-protocol.h, doc/dbus-specification.sgml: 
1342         remove the ERROR flag, since there's now an ERROR type
1343
1344 2003-08-01  Havoc Pennington  <hp@pobox.com>
1345
1346         * dbus/dbus-object-registry.c (_dbus_object_registry_handle_and_unlock):
1347         implement
1348
1349         * dbus/dbus-message.c (dbus_message_get_type): new function
1350
1351         * doc/dbus-specification.sgml: add "type" byte to messages
1352
1353 2003-08-01  Havoc Pennington  <hp@pobox.com>
1354
1355         * dbus/dbus-protocol.h (DBUS_MESSAGE_TYPE_*): introduce
1356         a message type enum to distinguish kinds of message
1357         (DBUS_HEADER_FLAG_NO_REPLY_EXPECTED): flag for a message 
1358         that need not be replied to
1359
1360 2003-08-01  Havoc Pennington  <hp@pobox.com>
1361
1362         * dbus/dbus-marshal.c: adapt to DBusObjectID changes
1363         (unpack_8_octets): fix no-64-bit-int bug
1364
1365         * dbus/dbus-object-registry.c (validate_id): validate the 
1366         connection ID bits, not just the instance ID.
1367
1368         * dbus/dbus-connection.c (_dbus_connection_init_id): initialize
1369         the connection-global 33 bits of the object ID
1370
1371         * dbus/dbus-object-registry.c (info_from_entry): fill in 
1372         object ID in the new way
1373
1374         * dbus/dbus-objectid.h: rather than high/low bits, specifically 
1375         define server/client/instance bits.
1376
1377 2003-07-30  Havoc Pennington  <hp@pobox.com>
1378
1379         * dbus/dbus-connection.c (dbus_connection_register_object): fix
1380         build
1381
1382 2003-07-13  Havoc Pennington  <hp@pobox.com>
1383
1384         * dbus/dbus-object.h (struct DBusObjectVTable): add padding
1385         fields to DBusObjectVTable and DBusObjectInfo
1386
1387 2003-07-12  Havoc Pennington  <hp@pobox.com>
1388
1389         * dbus/dbus-object-registry.c: implement unit test,
1390         fix bugs discovered in process
1391
1392         * dbus/dbus-connection.c: remove handler_table and
1393         register_handler(), add DBusObjectRegistry usage
1394
1395         * dbus/dbus-objectid.c (dbus_object_id_is_null)
1396         (dbus_object_id_set_null): new functions
1397
1398 2003-07-08  Havoc Pennington  <hp@pobox.com>
1399
1400         * dbus/dbus-object.c: implement some of this
1401
1402         * dbus/dbus-object-registry.c
1403         (_dbus_object_registry_add_and_unlock): fill in the object_id out
1404         param
1405         (_dbus_object_registry_new): handle OOM
1406
1407 2003-07-08  Havoc Pennington  <hp@pobox.com>
1408
1409         * dbus/dbus-object.h: sketch out an API for registering objects
1410         with a connection, that allows us to use as little as 24 bytes
1411         per object and lets application code represent an object in 
1412         any conceivable way.
1413
1414         * dbus/dbus-object-registry.c: implement the hard bits of the
1415         DBusConnection aspect of object API. Not yet wired up.
1416         
1417 2003-07-06  Havoc Pennington  <hp@pobox.com>
1418
1419         * dbus/dbus-marshal.c (_dbus_marshal_set_object_id): new function
1420         (_dbus_marshal_object_id): new
1421         (_dbus_demarshal_object_id): new
1422         (_dbus_marshal_get_arg_end_pos): support object ID type, and
1423         consolidate identical switch cases. Don't conditionalize handling
1424         of DBUS_TYPE_UINT64, need to handle the type always.
1425         (_dbus_marshal_validate_arg): consolidate identical cases, and
1426         handle DBUS_TYPE_OBJECT_ID
1427
1428         * dbus/dbus-objectid.c: new file with DBusObjectID data type.
1429
1430         * dbus/dbus-protocol.h: add DBUS_TYPE_OBJECT_ID
1431
1432 2003-09-28  Havoc Pennington  <hp@pobox.com>
1433
1434         * real 0.13 release
1435
1436 2003-09-28  Havoc Pennington  <hp@pobox.com>
1437
1438         * doc/Makefile.am (dbus-specification.html): testing a funky hack
1439         to work with Debian db2html
1440
1441 2003-09-28  Havoc Pennington  <hp@pobox.com>
1442
1443         * configure.in: 0.13
1444
1445         * doc/Makefile.am (dbus-test-plan.html): accept nonexistence of
1446         stylesheet-images for benefit of Debian
1447         
1448         Change back to using filesystem-linked sockets for the system
1449         bus, so only root can create the default system bus address.
1450         
1451         * bus/system.conf.in: change to use
1452         DBUS_SYSTEM_BUS_DEFAULT_ADDRESS
1453
1454         * dbus/Makefile.am (INCLUDES): remove DBUS_SYSTEM_BUS_PATH define
1455         from here.
1456
1457         * configure.in: define DBUS_SYSTEM_BUS_DEFAULT_ADDRESS
1458         here, and AC_DEFINE DBUS_SYSTEM_PATH
1459
1460 2003-08-09  Anders Carlsson  <andersca@codefactory.se>
1461
1462         * doc/TODO:
1463         * doc/busconfig.dtd:
1464         Add busconfig DTD.
1465         
1466 2003-08-09  Anders Carlsson  <andersca@codefactory.se>
1467
1468         * doc/dbus-specification.sgml:
1469         Add activation reply values.
1470         
1471 2003-08-05  Havoc Pennington  <hp@redhat.com>
1472
1473         * configure.in: 0.12
1474
1475 2003-08-05  Anders Carlsson  <andersca@codefactory.se>
1476
1477         * glib/dbus-gmain.c: (watch_fd_new), (watch_fd_ref),
1478         (watch_fd_unref), (dbus_gsource_check), (dbus_gsource_dispatch),
1479         (add_watch), (remove_watch), (create_source):
1480         Refcount fds, fixes some reentrancy issues.
1481         
1482 2003-07-30  Havoc Pennington  <hp@redhat.com>
1483
1484         * dbus/dbus-bus.c (init_connections_unlocked): fix default system
1485         bus address to be abstract if we have abstract sockets
1486
1487         * NEWS: update
1488
1489 2003-07-28  Havoc Pennington  <hp@redhat.com>
1490
1491         * bus/messagebus.in: fix to avoid processname/servicename 
1492         confusion, from Michael Kearey
1493         https://bugzilla.redhat.com/bugzilla/show_bug.cgi?id=100965
1494         
1495 2003-07-23  Havoc Pennington  <hp@pobox.com>
1496
1497         * dbus/dbus-message.c (dbus_message_iter_get_named): 
1498         fix from Andy Hanton to remove broken "+1"
1499
1500 2003-07-16  Havoc Pennington  <hp@pobox.com>
1501
1502         * tools/dbus-launch.c (babysit): close stdout/stderr in the
1503         babysitter process, as suggested by Thomas Leonard, so 
1504         an "eval `dbus-launch --exit-with-session`" will actually 
1505         return
1506
1507 2003-07-16  Havoc Pennington  <hp@pobox.com>
1508
1509         * configure.in: print out EXPANDED_* variables in the summary at
1510         the end; clean up the code that computes EXPANDED_ variables and
1511         get the ones using exec_prefix right. Should make things work
1512         when you build without --prefix
1513
1514 2003-06-29  Havoc Pennington  <hp@pobox.com>
1515
1516         * mono/Test.cs (class Test): fire up a main loop and run it
1517
1518         * mono/DBus.cs (DBus): don't g_thread_init since it can only be
1519         done once, the app has to do it
1520
1521 2003-06-26  Havoc Pennington  <hp@pobox.com>
1522
1523         * mono/Connection.cs: set up connection with the glib main loop
1524
1525 2003-07-01  Havoc Pennington  <hp@redhat.com>
1526
1527         * doc/dbus-specification.sgml: clarify the format of a type code,
1528         change suggested by Jim Blandy
1529
1530 2003-06-29  Miloslav Trmac  <mitr@volny.cz>
1531
1532         * doc/Makefile.am:
1533         * tools/Makefile.am: Don't assume srcdir == builddir.
1534
1535         * dbus/dbus-memory.c (dbus_realloc): Don't check guards after shrinking
1536         the allocated block.
1537         (_dbus_memory_test): New function.
1538         * dbus/dbus-test.h: Add _dbus_memory_test ().
1539         * dbus/dbus-test.c (dbus_internal_do_not_use_run_tests): Call it.
1540
1541         * dbus/dbus-message.c (decode_header_data): Use %.4s instead
1542         of %c%c%c%c.
1543         (dbus_message_new): Remove obsolete @todo.
1544
1545         * dbus/dbus-marshal.c (_dbus_marshal_set_int64)
1546         (_dbus_marshal_set_uint64): Fix comment.
1547
1548         * dbus/dbus-message.c (append_int_field, append_uint_field): Don't
1549         hardcode FIELD_REPLY_SERIAL.
1550
1551         * dbus/dbus-mainloop.c (_dbus_loop_remove_watch)
1552         (_dbus_loop_remove_timeout): Cast function pointers to (void *) for %p
1553
1554         * configure.in: Add -D_POSIX_C_SOURCE=199309L -DBSD_SOURCE to CFLAGS
1555         and disable DBUS_USE_ATOMIC_INT_486 when --enable-ansi is used
1556
1557 2003-06-24  Havoc Pennington  <hp@pobox.com>
1558
1559         * mono/*.cs: Use IntPtr.Zero instead of ((IntPtr) 0)
1560
1561 2003-06-23  Anders Carlsson  <andersca@codefactory.se>
1562
1563         * configure.in:
1564         * gcj/.cvsignore:
1565         * gcj/Hello.java:
1566         * gcj/Makefile.am:
1567         * gcj/TestMessage.java: (TestMessage), (TestMessage.main):
1568         * gcj/org/.cvsignore:
1569         * gcj/org/Makefile.am:
1570         * gcj/org/freedesktop/.cvsignore:
1571         * gcj/org/freedesktop/Makefile.am:
1572         * gcj/org/freedesktop/dbus/.cvsignore:
1573         * gcj/org/freedesktop/dbus/Makefile.am:
1574         * gcj/org/freedesktop/dbus/Message.java: (Message),
1575         (Message.Message):
1576         * gcj/org/freedesktop/dbus/natMessage.cc:
1577         Fix the build system.
1578
1579 2003-06-22  Havoc Pennington  <hp@pobox.com>
1580
1581         * mono/Connection.cs: add more bindings
1582
1583         * dbus/dbus-threads.c (dbus_threads_init): allow calling this
1584         more than once.
1585
1586 2003-06-22  Havoc Pennington  <hp@pobox.com>
1587
1588         * mono/Connection.cs, mono/DBus.cs, mono/Error.cs:
1589         Start wrapping more stuff.
1590
1591 2003-06-22  Havoc Pennington  <hp@pobox.com>
1592
1593         * mono/Message.cs: implement Message.Wrap() that ensures we only
1594         have a single C# wrapper per DBusMessage, assuming it works which
1595         it probably doesn't.
1596
1597         * dbus/dbus-message.c (dbus_message_allocate_data_slot): new
1598         (dbus_message_free_data_slot): new
1599         (dbus_message_set_data): new
1600         (dbus_message_get_data): new
1601
1602 2003-06-22  Havoc Pennington  <hp@pobox.com>
1603
1604         * dbus/dbus-dataslot.c (_dbus_data_slot_allocator_unref)
1605         (_dbus_data_slot_allocator_alloc): rework these to keep a
1606         reference count on each slot and automatically manage a global
1607         slot ID variable passed in by address
1608
1609         * bus/bus.c: convert to new dataslot API
1610
1611         * dbus/dbus-bus.c: convert to new dataslot API
1612
1613         * dbus/dbus-connection.c: convert to new dataslot API
1614
1615         * dbus/dbus-server.c: convert to new dataslot API
1616
1617         * glib/dbus-gmain.c: ditto
1618
1619         * bus/test.c: ditto
1620
1621         * bus/connection.c: ditto
1622
1623 2003-06-22  Anders Carlsson  <andersca@codefactory.se>
1624
1625         * configure.in: Add AM_PROG_GCJ and move AM_PROG_LIBTOOL
1626         after the gcj checks so that the correct configuration tags
1627         will be added to libtool.
1628
1629         * dbus-glib-1.pc.in: No need to specify any includes since
1630         dbus-1.pc.in has those.
1631
1632 2003-06-22  Havoc Pennington  <hp@pobox.com>
1633
1634         * mono/*, gcj/*, configure.in, Makefile.am:
1635         Check in makefiles and subdirs for mono and gcj bindings.
1636         Neither binding actually exists, just trying to get through
1637         all the build and other boring bits.
1638
1639 2003-06-21  Philip Blundell  <philb@gnu.org>
1640
1641         * tools/dbus-monitor.1: Updated.
1642
1643         * tools/dbus-send.1: Likewise.
1644
1645 2003-06-20  Anders Carlsson  <andersca@codefactory.se>
1646
1647         * dbus/dbus-transport-unix.c (unix_handle_watch): Check
1648         for hangup and error after checking read so we won't discard
1649         pending data if both hangup and read are set.
1650
1651 2003-06-19  Philip Blundell  <philb@gnu.org>
1652
1653         * tools/dbus-print-message.c (print_message): Handle BOOLEAN.
1654
1655         * tools/dbus-send.c: Accept both --system and --session.
1656
1657         * tools/dbus-monitor.c: Same here.
1658
1659 2003-06-19  Anders Carlsson  <andersca@codefactory.se>
1660
1661         * glib/dbus-glib.h: Fix so that dbus-glib.h can be used
1662         from C++ (Patch by Miloslav Trmac).
1663
1664 2003-06-15  Joe Shaw  <joe@assbarn.com>
1665
1666         * configure.in: Check for socklen_t.
1667
1668         * dbus/dbus-sysdeps.c: Define socklen_t if it's not defined.
1669
1670         * test/test-segfault.c: Add #include <sys/time.h>
1671
1672         * tools/Makefile.am: Add DBUS_X_CFLAGS to the INCLUDES since
1673         dbus-launch needs it.
1674
1675 2003-06-09  Havoc Pennington  <hp@redhat.com>
1676
1677         * dbus/dbus-sysdeps.c (_dbus_listen_unix_socket): don't use
1678         SUN_LEN, it breaks abstract socket usage
1679
1680         * dbus/dbus-internals.c (_dbus_verbose_real): only print PID at
1681         starts of lines.
1682
1683 2003-06-04  Havoc Pennington  <hp@pobox.com>
1684
1685         * dbus/dbus-server.c (dbus_server_listen): allow abstract sockets
1686         using unix:abstract=/foo, and when listening in a tmpdir
1687         i.e. unix:tmpdir=/tmp, always use abstract sockets if we can.
1688
1689         * dbus/dbus-transport.c (_dbus_transport_open): support
1690         unix:abstract=/foo
1691
1692         * dbus/dbus-server-unix.c (_dbus_server_new_for_domain_socket):
1693         support abstract sockets
1694
1695         * dbus/dbus-transport-unix.c
1696         (_dbus_transport_new_for_domain_socket): support abstract sockets
1697
1698         * dbus/dbus-sysdeps.c (_dbus_connect_unix_socket): add "abstract"
1699         toggle as an argument, implement abstract namespace support
1700         (_dbus_listen_unix_socket): ditto
1701
1702         * configure.in: add --enable-abstract-sockets and implement
1703         a configure check for autodetection of the right value.
1704
1705 2003-06-01  Havoc Pennington  <hp@pobox.com>
1706
1707         * tools/dbus-cleanup-sockets.c: add utility to clean up sockets
1708         in /tmp (though on Linux this will end up being useless,
1709         when we add abstract namespace support)
1710
1711         * configure.in: define DBUS_SESSION_SOCKET_DIR in addition to
1712         subst'ing it
1713
1714 2003-05-28  Colin Walters  <walters@verbum.org>
1715
1716         * tools/dbus-monitor.c (main): Fix silly typo (s/--session/--system/).
1717
1718 2003-05-18  Anders Carlsson  <andersca@codefactory.se>
1719
1720         * dbus/dbus-message.c (dbus_message_new): Remove @todo.
1721
1722 2003-05-17  Colin Walters  <walters@gnu.org>
1723
1724         * tools/dbus-send.c: Don't exit with an error code if --help was
1725         passed.  Default to using the session bus instead of the system
1726         one.
1727
1728         * tools/dbus-launch.c: Ditto.
1729
1730         * tools/dbus-monitor.c: Ditto.
1731
1732         * tools/dbus-send.1: Update with new arguments.
1733
1734         * tools/dbus-launch.c: Emit code to export variables.  New
1735         arguments -s and -c to specify shell syntax, and a bit of code to
1736         autodetect syntax.  Also, allow specifying a program to run.
1737
1738         * tools/dbus-launch.1: Update with new arguments.
1739
1740         * tools/dbus-send.1: Ditto.
1741
1742         * tools/dbus-monitor.1: Ditto.
1743
1744 2003-05-17  Havoc Pennington  <hp@pobox.com>
1745
1746         * bus/config-parser.c (merge_included): merge in policies from
1747         child configuration file.
1748
1749         * bus/policy.c (bus_policy_merge): function to merge two policies
1750         together
1751
1752 2003-05-16  Havoc Pennington  <hp@redhat.com>
1753
1754         * dbus/dbus-connection.c: disable verbose lock spew
1755
1756         * tools/dbus-send.c: add --print-reply command line option
1757
1758         * tools/dbus-print-message.h (print_message): new util function
1759         shared by dbus-send and dbus-monitor
1760
1761         * tools/dbus-monitor.c (handler_func): exit on disconnect
1762
1763         * dbus/dbus-transport-unix.c (do_reading): if the transport is
1764         disconnected, don't try to use the read_watch
1765
1766         * dbus/dbus-watch.c (dbus_watch_get_enabled): assert watch != NULL
1767         so we can find this bug more easily
1768
1769 2003-05-16  Havoc Pennington  <hp@redhat.com>
1770
1771         * bus/policy.c (free_rule_list_func): avoid a crash when passed
1772         NULL as DBusHashTable is annoyingly likely to do.
1773
1774 2003-05-16  Colin Walters  <walters@verbum.org>
1775
1776         * tools/dbus-monitor.c: Add --session argument and usage()
1777         function.
1778
1779         * tools/dbus-monitor.1: Update with new --session arg.
1780
1781         * bus/Makefile.am (install-data-hook): Create
1782         $(libdir)/dbus-1.0/services so that the session bus is happy.
1783
1784 2003-05-15  Havoc Pennington  <hp@redhat.com>
1785
1786         * dbus/dbus-sysdeps.c (_dbus_atomic_dec, _dbus_atomic_inc): work
1787         on non-x86. ifdef's are evil.
1788
1789 2003-05-15  Havoc Pennington  <hp@redhat.com>
1790
1791         * configure.in: 0.11
1792
1793         * NEWS: update
1794
1795         * bus/Makefile.am (initddir): apparently we are supposed to put
1796         init scripts in /etc/rc.d/init.d not /etc/init.d
1797
1798         * bus/Makefile.am: remove the "you must --enable-tests to make
1799         check" as it broke distcheck
1800
1801         * bus/Makefile.am (install-data-hook): create /etc/dbus-1/system.d
1802
1803 2003-05-13  James Willcox  <jwillcox@gnome.org>
1804
1805         * configure.in:
1806         * bus/activation.c: (bus_activation_service_created),
1807         (bus_activation_activate_service):
1808         * bus/driver.c: (bus_driver_send_service_deleted),
1809         (bus_driver_send_service_created), (bus_driver_send_service_lost),
1810         (bus_driver_send_service_acquired),
1811         (bus_driver_send_welcome_message),
1812         (bus_driver_handle_list_services):
1813         * bus/session.conf.in:
1814         * dbus/dbus-bus.c: (dbus_bus_acquire_service),
1815         (dbus_bus_service_exists), (dbus_bus_activate_service):
1816         * dbus/dbus-bus.h:
1817
1818         Add some convenience API which lets you activate a service, and did a
1819         bunch of s/0/DBUS_TYPE_INVALID/ in calls to dbus_message_append_args()
1820         and dbus_message_get_args()
1821
1822 2003-05-11  Havoc Pennington  <hp@pobox.com>
1823
1824         * dbus/dbus-marshal.c (_dbus_marshal_validate_arg): fix to avoid
1825         calling _dbus_marshal_validate_arg() for every byte in a byte
1826         array, etc.
1827
1828         * dbus/dbus-message-handler.c: use atomic reference counting to
1829         reduce number of locks slightly; the global lock in here sucks
1830
1831         * dbus/dbus-connection.c
1832         (_dbus_connection_update_dispatch_status_and_unlock): variant of
1833         update_dispatch_status that can be called with lock held; then use
1834         in a couple places to reduce locking/unlocking
1835         (dbus_connection_send): hold the lock over the whole function
1836         instead of acquiring it twice.
1837
1838         * dbus/dbus-timeout.c (_dbus_timeout_new): handle OOM
1839
1840         * bus/connection.c (bus_connections_setup_connection): fix access
1841         to already-freed memory.
1842
1843         * dbus/dbus-connection.c: keep a little cache of linked list
1844         nodes, to avoid using the global linked list alloc lock in the
1845         normal send-message case. Instead we just use the connection lock
1846         that we already have to take.
1847
1848         * dbus/dbus-list.c (_dbus_list_find_last): new function
1849
1850         * dbus/dbus-sysdeps.c (_dbus_atomic_inc, _dbus_atomic_dec):
1851         change to use a struct for the atomic type; fix docs,
1852         they return value before increment, not after increment.
1853
1854         * dbus/dbus-string.c (_dbus_string_append_4_aligned)
1855         (_dbus_string_append_8_aligned): new functions to try to
1856         microoptimize this operation.
1857         (reallocate_for_length): break this out of set_length(), to
1858         improve profile info, and also so we can consider inlining the
1859         set_length() part.
1860
1861         * dbus/dbus-message.c (dbus_message_new_empty_header): init data
1862         strings with some preallocation, cuts down on our calls to realloc
1863         a fair bit. Though if we can get the "move entire string to empty
1864         string" optimization below to kick in here, it would be better.
1865
1866         * dbus/dbus-string.c (_dbus_string_move): just call
1867         _dbus_string_move_len
1868         (_dbus_string_move_len): add a special case for moving
1869         an entire string into an empty string; we can just
1870         swap the string data instead of doing any reallocs.
1871         (_dbus_string_init_preallocated): new function
1872
1873 2003-05-11  Havoc Pennington  <hp@pobox.com>
1874
1875         Write a "test-profile" that does echo client-server with threads;
1876         profile reveals lock contention, memcpy/realloc of buffers, and
1877         UTF-8 validation as hot spots. 20% of lock contention eliminated
1878         with dbus_atomic_inc/dec implementation on x86.  Much remaining
1879         contention is global mempool locks for GList and DBusList.
1880
1881         * dbus/dbus-sysdeps.c (_dbus_atomic_inc, _dbus_atomic_dec): add
1882         x86 implementation
1883
1884         * dbus/dbus-connection.c (struct DBusConnection): use
1885         dbus_atomic_t for the reference count
1886
1887         * dbus/dbus-message.c (struct DBusMessage): declare
1888         dbus_atomic_t values as volatile
1889
1890         * configure.in: code to detect ability to use atomic integer
1891         operations in assembly, from GLib patch
1892
1893         * dbus/dbus-internals.c (_dbus_verbose_real): call getpid every
1894         time, tired of it being wrong in threads and forked processes
1895
1896         * glib/test-profile.c: a little program to bounce messages back
1897         and forth between threads and eat CPU
1898
1899         * dbus/dbus-connection.c: add debug spew macros for debugging
1900         thread locks; include config.h at top; fix deadlock in
1901         dbus_connection_flush()
1902
1903 2003-05-08  Havoc Pennington  <hp@pobox.com>
1904
1905         * dbus/dbus-spawn.c: s/_exit/exit/ because it was keeping gcov
1906         data from getting written, and there wasn't a good reason to
1907         use _exit really.
1908
1909         * test/decode-gcov.c (mark_inside_dbus_build_tests): don't count
1910         dbus_verbose lines in test coverage
1911         (main): add list of functions sorted by # of untested blocks
1912         to the coverage report
1913
1914         * dbus/dbus-mempool.c: put some test-only code in DBUS_BUILD_TESTS
1915
1916         * dbus/dbus-marshal.c (_dbus_marshal_test): extend test coverage
1917
1918         * dbus/dbus-message-handler.c (_dbus_message_handler_test):
1919         extend test coverage
1920
1921         * test/data/auth/cancel.auth-script: test canceling an
1922         authentication
1923
1924         * dbus/Makefile.am: remove dbus-server-debug.[hc] for now, as they
1925         aren't used. in CVS history if we end up needing them.
1926
1927 2003-05-04  Havoc Pennington  <hp@pobox.com>
1928
1929         * dbus/dbus-message-handler.c (_dbus_message_handler_test): add
1930         unit test
1931
1932         * dbus/dbus-marshal.c (_dbus_demarshal_string_array): fix this
1933         function, which assumed length was in # of strings, not bytes
1934
1935         * dbus/dbus-message.c (_dbus_message_test): add tests for some
1936         missing coverage
1937
1938         * dbus/dbus-connection.c
1939         (_dbus_connection_queue_received_message): disable function for
1940         now, we are only using it in test mode
1941
1942         * dbus/dbus-message.c (_dbus_message_loader_queue_messages):
1943         remove a mistaken FIXME
1944
1945 2003-05-04  Havoc Pennington  <hp@pobox.com>
1946
1947         * dbus/dbus-connection.c (dbus_connection_preallocate_send):
1948         unlock mutex on successful return, patch from Anders Gustafsson
1949
1950 2003-05-04  Havoc Pennington  <hp@pobox.com>
1951
1952         * dbus-glib-1.pc.in (Requires): fix dependencies, from
1953         Anders Gustafsson
1954
1955 2003-05-04  Havoc Pennington  <hp@pobox.com>
1956
1957         * tools/dbus-launch.c: implement
1958
1959         * bus/main.c (main), bus/bus.c (bus_context_new):
1960         implement --print-pid and --fork
1961
1962 2003-05-03  Havoc Pennington  <hp@redhat.com>
1963
1964         * dbus/dbus-address.c (dbus_parse_address): fix bug when a key in
1965         the address had no value, and add to test suite. Fix and
1966         regression test from Miloslav Trmac
1967
1968 2003-05-03  Havoc Pennington  <hp@pobox.com>
1969
1970         * dbus/dbus-watch.c (dbus_watch_handle): warn and return if a
1971         watch is invalid when handled
1972
1973         * tools/Makefile.am, tools/dbus-launch.c, tools/dbus-launch.1: add
1974         dbus-launch utility to launch the bus from a shell script.  Didn't
1975         actually implement dbus-launch yet, it's just a placeholder still.
1976
1977 2003-05-03  Havoc Pennington  <hp@pobox.com>
1978
1979         * bus/Makefile.am, bus/dbus-daemon-1.1.in: man page for the
1980         daemon; also documents daemon config file, so replaces
1981         doc/config-file.txt. Corrected some stuff from config-file.txt in
1982         the process of moving it.
1983
1984 2003-05-03  Havoc Pennington  <hp@pobox.com>
1985
1986         * tools/Makefile.am, tools/dbus-send.1, tools/dbus-monitor.1:
1987         add some man pages
1988
1989 2003-05-03  Colin Walters  <walters@verbum.org>
1990
1991         * dbus/dbus-sysdeps.c (fill_user_info): Test against
1992         DBUS_UID_UNSET to determine whether to do a uid lookup or not.
1993
1994         * Makefile.am: Update to use new .pc versioning scheme.
1995
1996 2003-05-02  Havoc Pennington  <hp@redhat.com>
1997
1998         * bus/system.conf.in: allow send/receive to/from message bus
1999         service
2000
2001 2003-04-30  Havoc Pennington  <hp@redhat.com>
2002
2003         * configure.in: print a note when building with unit tests and
2004         without assertions
2005
2006 2003-04-30  Havoc Pennington  <hp@redhat.com>
2007
2008         * Makefile.am: add a check-local that complains if you didn't
2009         configure with --enable-tests
2010
2011 2003-04-29  Havoc Pennington  <hp@redhat.com>
2012
2013         * glib/dbus-gmain.c: docs cleanups
2014
2015         * dbus/dbus-types.h: add docs on int64 types
2016
2017         * dbus/dbus-memory.c: fix docs to avoid putting private API in
2018         public API docs section
2019
2020 2003-04-29  Havoc Pennington  <hp@redhat.com>
2021
2022         * dbus-1.pc.in, dbus-glib-1.pc.in: rename these from
2023         dbus-1.0.pc.in, dbus-glib-1.0.pc.in. As these change with the
2024         parallel install API version, not with the D-BUS package version.
2025
2026         * HACKING: move some of README over here
2027
2028         * README: updates, and document API/ABI policy
2029
2030         * configure.in: reindentation
2031
2032 2003-04-29  Havoc Pennington  <hp@redhat.com>
2033
2034         * dbus/dbus.h: add "you have to define DBUS_API_SUBJECT_TO_CHANGE
2035         to use this library" to be sure people have the right
2036         expectations.
2037
2038 2003-04-28  Havoc Pennington  <hp@redhat.com>
2039
2040         * configure.in: add --enable-docs which by default is auto yes if
2041         doxygen and db2html found, no otherwise; but can be forced on/off
2042
2043         * doc/Makefile.am: conditionalize whether to build docs on
2044         --enable-docs
2045
2046 2003-04-28  Havoc Pennington  <hp@redhat.com>
2047
2048         * configure.in: 0.10
2049
2050         * NEWS: update
2051
2052         * bus/system.conf.in: add <includedir>system.d</includedir>
2053
2054         * dbus/dbus-userdb.c (_dbus_user_database_lookup): fix bug when
2055         username was provided but not uid
2056
2057         * bus/config-parser.c (struct BusConfigParser): keep track of
2058         whether the parser is toplevel or was included; change some
2059         of the error handling if it's included.
2060
2061 2003-04-27  Havoc Pennington  <hp@pobox.com>
2062
2063         Unbreak my code...
2064
2065         * dbus/dbus-transport.c (_dbus_transport_get_dispatch_status):
2066         report correct status if we finish processing authentication
2067         inside this function.
2068
2069         * bus/activation.c (try_send_activation_failure): use
2070         bus_transaction_send_error_reply
2071
2072         * bus/connection.c (bus_connection_get_groups): return an error
2073         explaining the problem
2074
2075         * bus/bus.c (bus_context_check_security_policy): implement
2076         restriction here that inactive connections can only send the
2077         hello message. Also, allow bus driver to send anything to
2078         any recipient.
2079
2080         * bus/connection.c (bus_connection_complete): create the
2081         BusClientPolicy here instead of on-demand.
2082         (bus_connection_get_policy): don't return an error
2083
2084         * dbus/dbus-message.c (dbus_message_new_error_reply): allow NULL
2085         sender field in message being replied to
2086
2087         * bus/bus.c (bus_context_check_security_policy): fix silly typo
2088         causing it to return FALSE always
2089
2090         * bus/policy.c (bus_client_policy_check_can_send): fix bug where
2091         we checked sender rather than destination
2092
2093 2003-04-25  Havoc Pennington  <hp@redhat.com>
2094
2095         test suite is slightly hosed at the moment, will fix soon
2096
2097         * bus/connection.c (bus_connections_expire_incomplete): fix to
2098         properly disable the timeout when required
2099         (bus_connection_set_name): check whether we can remove incomplete
2100         connections timeout after we complete each connection.
2101
2102         * dbus/dbus-mainloop.c (check_timeout): fix this up a bit,
2103         probably still broken.
2104
2105         * bus/services.c (bus_registry_acquire_service): implement max
2106         number of services owned, and honor allow/deny rules on which
2107         services a connection can own.
2108
2109         * bus/connection.c (bus_connection_get_policy): report errors here
2110
2111         * bus/activation.c: implement limit on number of pending
2112         activations
2113
2114 2003-04-25  Havoc Pennington  <hp@redhat.com>
2115
2116         * dbus/dbus-transport.c (_dbus_transport_get_unix_user): fix bug
2117         where we used >= 0 instead of != DBUS_UID_UNSET.
2118
2119 2003-04-25  Havoc Pennington  <hp@redhat.com>
2120
2121         * glib/dbus-gmain.c (remove_watch): fix for a crash when watches
2122         were toggled without add/remove, fix from Anders Gustafsson
2123
2124 2003-04-24  Havoc Pennington  <hp@redhat.com>
2125
2126         * test/data/valid-config-files/basic.conf: add <limit> tags to
2127         this test
2128
2129         * bus/config-parser.h, bus/config-parser.c, bus/bus.c: Implement
2130         <limit> tag in configuration file.
2131
2132 2003-04-24  Havoc Pennington  <hp@redhat.com>
2133
2134         * bus/dispatch.c: somehow missed some name_is
2135
2136         * dbus/dbus-timeout.c (_dbus_timeout_set_enabled)
2137         (_dbus_timeout_set_interval): new
2138
2139         * bus/connection.c (bus_connections_setup_connection): record time
2140         when each connection is first set up, and expire them after the
2141         auth timeout passes.
2142
2143 2003-04-24  Havoc Pennington  <hp@redhat.com>
2144
2145         * dbus/dbus-message.c (dbus_message_name_is): rename
2146         (dbus_message_service_is): rename
2147         (dbus_message_sender_is): rename
2148         (dbus_message_get_service): rename
2149
2150 2003-04-24  Havoc Pennington  <hp@redhat.com>
2151
2152         * configure.in: add --enable-checks
2153
2154         * dbus/dbus-message.c (dbus_message_new): reverse name/service arguments
2155
2156         * dbus/dbus-connection.c (dbus_connection_preallocate_send): fix
2157         to use thread locks.
2158         (_dbus_connection_handler_destroyed_locked): move some private
2159         functions into proper docs group
2160
2161         * dbus/dbus-internals.h: add _dbus_return_if_fail,
2162         _dbus_return_val_if_fail
2163
2164         Throughout: use dbus_return_if_fail
2165
2166 2003-04-23  James Willcox  <jwillcox@gnome.org>
2167
2168         * glib/dbus-glib.h:
2169         * glib/dbus-gmain.c: (add_timeout), (wakeup_main), (create_source),
2170         (dbus_connection_setup_with_g_main),
2171         (dbus_server_setup_with_g_main):
2172         * glib/test-dbus-glib.c: (main):
2173         * glib/test-thread-client.c: (main):
2174         * glib/test-thread-server.c: (new_connection_callback), (main):
2175         * tools/dbus-monitor.c: (main):
2176
2177         Added a GMainContext argument to dbus_connection_setup_with_g_main()
2178         and dbus_server_setup_with_g_main().
2179
2180 2003-04-20  Havoc Pennington  <hp@pobox.com>
2181
2182         * doc/dbus-specification.sgml: document the restrictions on
2183         message and service names
2184
2185 2003-04-22  Havoc Pennington  <hp@redhat.com>
2186
2187         * dbus/dbus-message.c, dbus/dbus-marshal.c: add 64-bit integer
2188         support, and do some code cleanups to share more code and
2189         speed up array marshal/demarshal.
2190
2191         * dbus-1.0.pc.in (Cflags): put libdir include file in cflags
2192
2193         * configure.in: generate dbus-arch-deps.h
2194
2195         * dbus/dbus-protocol.h (DBUS_TYPE_INT64, DBUS_TYPE_UINT64): add
2196         64-bit typecodes
2197
2198 2003-04-22  Havoc Pennington  <hp@redhat.com>
2199
2200         * test/data/valid-messages/opposite-endian.message: fix test
2201         to use proper type for rply field
2202
2203         * test/data/invalid-messages: add tests for below validation
2204
2205         * dbus/dbus-message.c (decode_header_data): validate field types,
2206         and validate that named fields are valid names
2207         (decode_name_field): consider messages in the
2208         org.freedesktop.Local. namespace to be invalid.
2209
2210         * dbus/dbus-string.c (_dbus_string_validate_name): new
2211
2212 2003-04-19  Havoc Pennington  <hp@pobox.com>
2213
2214         * bus/driver.c (bus_driver_handle_hello): check limits and
2215         return an error if they are exceeded.
2216
2217         * bus/connection.c: maintain separate lists of active and inactive
2218         connections, and a count of each. Maintain count of completed
2219         connections per user. Implement code to check connection limits.
2220
2221         * dbus/dbus-list.c (_dbus_list_unlink): export
2222
2223         * bus/bus.c (bus_context_check_security_policy): enforce a maximum
2224         number of bytes in the message queue for a connection
2225
2226 2003-04-18  Havoc Pennington  <hp@pobox.com>
2227
2228         * dbus/dbus-auth.c (record_mechanisms): memleak fixes
2229
2230         * dbus/dbus-sysdeps.c (_dbus_string_save_to_file): fix some
2231         memleaks
2232
2233         * dbus/dbus-keyring.c (add_new_key): fix a memleak, and
2234         on realloc be sure to update the pointer in the keyring
2235
2236         * dbus/dbus-string.c (_dbus_string_zero): compensate for align
2237         offset to avoid writing to unallocated memory
2238
2239         * dbus/dbus-auth.c (process_rejected): return FALSE if we fail to
2240         try the next mechanism, so we properly handle OOM
2241
2242         * dbus/dbus-keyring.c (_dbus_keyring_new_homedir): fix double-free
2243         on OOM.
2244         (_dbus_keyring_new): fix OOM bug
2245         (_dbus_keyring_new_homedir): always set error; impose a maximum
2246         number of keys we'll load from the file, mostly to speed up the
2247         test suite and make its OOM checks more useful, but also for
2248         general sanity.
2249
2250         * dbus/dbus-auth.c (process_error_server): reject authentication
2251         if we get an error from the client
2252         (process_cancel): on cancel, send REJECTED, per the spec
2253         (process_error_client): send CANCEL if we get an error from the
2254         server.
2255
2256 2003-04-18  Havoc Pennington  <hp@pobox.com>
2257
2258         * dbus/dbus-mainloop.c (_dbus_loop_iterate): fix UMR in verbose
2259         debug spew
2260
2261         * dbus/dbus-auth.c (handle_client_data_cookie_sha1_mech): fix OOM
2262         handling problem
2263
2264         * dbus/dbus-keyring.c (_dbus_keyring_new_homedir): only whine
2265         about DBUS_TEST_HOMEDIR once
2266
2267         * bus/Makefile.am (TESTS_ENVIRONMENT): put DBUS_TEST_HOMEDIR in
2268         the environment
2269
2270         * bus/dispatch.c (bus_dispatch_sha1_test): actually load sha1
2271         config file so we test the right thing
2272
2273         Throughout: assorted docs improvements
2274
2275 2003-04-18  Havoc Pennington  <hp@pobox.com>
2276
2277         * glib/dbus-gmain.c: adapt to watch changes
2278
2279         * bus/bus.c, bus/activation.c, etc.: adjust to watch changes
2280
2281         * dbus/dbus-server.h: remove dbus_server_handle_watch
2282
2283         * dbus/dbus-connection.h: remove dbus_connection_handle_watch
2284
2285         * dbus/dbus-watch.c (dbus_watch_handle): change DBusWatch to work
2286         like DBusTimeout, so we don't need dbus_connection_handle_watch
2287         etc.
2288
2289 2003-04-17  Havoc Pennington  <hp@redhat.com>
2290
2291         * dbus/dbus-userdb.c, dbus/dbus-sysdeps.c: redo all the passwd
2292         database usage so it all goes via the DBusUserDatabase cache.
2293
2294 2003-04-17  Havoc Pennington  <hp@redhat.com>
2295
2296         * dbus/dbus-mainloop.c (_dbus_loop_iterate): fix logic so that if
2297         there was an OOM watch we skipped, we always return TRUE so we
2298         iterate again to have a look at it again. Fixes test suite hang.
2299         Code rearrangement also lets us lose some memset and only iterate
2300         over callbacks once.
2301
2302         * bus/driver.c (bus_driver_handle_message): sense of test for
2303         reply was backward
2304
2305 2003-04-16  Havoc Pennington  <hp@pobox.com>
2306
2307         * doc/dbus-specification.sgml: make spec say serials are unsigned
2308
2309         * dbus/dbus-message.h: change message serials to unsigned
2310
2311         * dbus/dbus-connection.c: adapt to message serials being unsigned
2312
2313 2003-04-15  Havoc Pennington  <hp@pobox.com>
2314
2315         * bus/bus.c: create and keep around a shared DBusUserDatabase
2316         object.
2317
2318         * bus/connection.c (bus_connection_get_groups): don't cache
2319         groups for user in the connection object, since user database
2320         object now does that.
2321
2322 2003-04-16  Havoc Pennington  <hp@redhat.com>
2323
2324         * dbus/dbus-message.c (_dbus_message_add_size_counter): keep a
2325         list of size counters
2326         (_dbus_message_loader_putback_message_link): put back a popped link
2327
2328         * dbus/dbus-connection.c
2329         (dbus_connection_set_max_live_messages_size): rename
2330         max_received_size
2331         (dbus_connection_get_outgoing_size): get size of outgoing
2332         queue
2333         (_dbus_connection_set_connection_counter): remove this cruft
2334
2335 2003-04-14  Havoc Pennington  <hp@redhat.com>
2336
2337         * dbus/dbus-userdb.c: user database abstraction, mostly to get
2338         caching, but at some point we might want to be able to use a
2339         different database.
2340
2341         * bus/dispatch.c (bus_dispatch_sha1_test): add a test that uses
2342         SHA1 conf file to test the sha1 auth mechanism, since the regular
2343         test always uses EXTERNAL when available.
2344
2345         * configure.in,
2346         test/data/valid-config-files/debug-allow-all-sha1.conf.in:
2347         add conf file that requires use of sha1 auth
2348
2349 2003-04-13  Havoc Pennington  <hp@pobox.com>
2350
2351         * tools/dbus-send.c, tools/dbus-monitor.c: two utility programs
2352         from Philip Blundell to send messages and monitor them.
2353
2354 2003-04-13  Havoc Pennington  <hp@pobox.com>
2355
2356         * dbus/dbus-mainloop.c: fix some reentrancy issues by refcounting
2357         callbacks
2358
2359         * test/data/valid-config-files/debug-allow-all.conf.in: allow all
2360         users
2361
2362         * dbus/dbus-transport.c (_dbus_transport_get_dispatch_status):
2363         fix to only recover unused bytes if we're already authenticated
2364         (_dbus_transport_get_is_authenticated): fix to still mark us
2365         authenticated if there are unused bytes.
2366
2367         * bus/dispatch.c: implement security policy checking
2368
2369         * bus/connection.c (bus_transaction_send_from_driver): new
2370
2371         * bus/bus.c (bus_context_check_security_policy): new
2372
2373         * bus/dispatch.c (send_service_nonexistent_error): delete this,
2374         now we just set the DBusError and it gets converted to an error
2375         reply.
2376
2377         * bus/connection.c (allow_user_function): enable code using actual
2378         data from the config file
2379
2380         * bus/policy.c (list_allows_user): handle wildcard rules for
2381         user/group connection perms
2382
2383 2003-04-13  Havoc Pennington  <hp@pobox.com>
2384
2385         * bus/config-parser.c: Load up the BusPolicy and BusPolicyRules
2386
2387         * dbus/dbus-sysdeps.c (_dbus_get_user_id): new function
2388
2389         * bus/policy.c (bus_policy_append_mandatory_rule)
2390         (bus_policy_append_default_rule, bus_policy_append_user_rule)
2391         (bus_policy_append_group_rule): new functions
2392
2393 2003-04-12  Havoc Pennington  <hp@pobox.com>
2394
2395         * bus/config-parser.c (bus_config_parser_new): fix a memleak
2396
2397         * dbus/dbus-sysdeps.c: change DBusCredentials to use longs for
2398         the pid/gid/uid, just for paranoia.
2399
2400         * test/break-loader.c (randomly_do_n_things): find a byte
2401         containing a type code, and randomly change it to a different
2402         type code.
2403
2404 2003-04-12  Havoc Pennington  <hp@pobox.com>
2405
2406         * bus/policy.h: change BusPolicy to be the thing from the config
2407         file, and rename old BusPolicy to BusClientPolicy
2408
2409         * bus/bus.c, bus/connection.c, bus/config-parser.c: change to
2410         match change in how policy works
2411
2412         * dbus/dbus-internals.h: mark assert_not_reached as
2413         __attribute((noreturn))__
2414
2415 2003-04-11  Havoc Pennington  <hp@redhat.com>
2416
2417         * doc/dbus-specification.sgml: fix a spot with the wrong name for
2418         the broadcast service. Use boolean return for ServiceExists.
2419
2420 2003-04-11  Havoc Pennington  <hp@redhat.com>
2421
2422         * configure.in: add another directory to look for qt in.
2423
2424 2003-04-11  Havoc Pennington  <hp@redhat.com>
2425
2426         * AUTHORS: add Colin Walters
2427
2428 2003-04-11  Havoc Pennington  <hp@redhat.com>
2429
2430         * NEWS: update
2431
2432         * configure.in: 0.9
2433
2434 2003-04-11  Havoc Pennington  <hp@redhat.com>
2435
2436         * bus/messagebus.in: remove pid file when stopping the
2437         message bus, since the bus won't have privileges to remove it
2438         itself.
2439
2440 2003-04-11  Havoc Pennington  <hp@redhat.com>
2441
2442         * bus/bus.c (bus_context_new): move credentials change after
2443         creating pidfile
2444
2445 2003-04-11  Havoc Pennington  <hp@pobox.com>
2446
2447         * test/decode-gcov.c: add "below average functions" to the
2448         coverage report, and change how some of the code works.
2449
2450         * bus/test-main.c: bracket some stuff in DBUS_BUILD_TESTS so it's
2451         not in the coverage stats.
2452
2453         * test/test-service.c (main): use _dbus_verbose not fprintf in a
2454         couple places so running the test suite doesn't result in megaspam.
2455
2456 2003-04-11  Havoc Pennington  <hp@pobox.com>
2457
2458         * bus/dispatch.c (check_existent_service_activation): accept a no
2459         memory error in a place we didn't before
2460
2461         * bus/test.c (bus_test_run_everything): remove hacky "do it twice
2462         in case the first one failed," since the test suite is less
2463         broken now.
2464
2465 2003-04-10  Havoc Pennington  <hp@pobox.com>
2466
2467         * bus/dispatch.c (check_segfault_service_activation): add test
2468         for launching an executable that just crashes.
2469
2470         * test/test-segfault.c (main): try setting coredumpsize to 0 so we
2471         don't leave a million cores. We'll see how portable this is.
2472
2473 2003-04-10  Havoc Pennington  <hp@pobox.com>
2474
2475         * dbus/dbus-spawn.c (_dbus_spawn_async_with_babysitter): move all
2476         the possible parent failures before we fork, so that we don't
2477         fail to create a babysitter after creating the child.
2478
2479         * bus/activation.c (bus_activation_activate_service): kill child
2480         if we don't successfully complete the activation.
2481
2482 2003-04-10  Havoc Pennington  <hp@redhat.com>
2483
2484         * dbus/dbus-connection.c (dbus_connection_flush): don't spin on
2485         the connection if it's disconnected
2486
2487         * bus/activation.c (bus_activation_service_created): use new
2488         transaction features to roll back removal of pending activation if
2489         we don't successfully create the service after all. Don't remove
2490         pending activation if the function fails.
2491
2492         * dbus/dbus-list.c (_dbus_list_insert_before_link)
2493         (_dbus_list_insert_after_link): new code to facilitate
2494         services.c fixes
2495
2496         * dbus/dbus-hash.c (_dbus_hash_table_insert_string_preallocated):
2497         new functionality, so we can preallocate the ability to insert
2498         into a hash table.
2499
2500         * bus/connection.c (bus_transaction_add_cancel_hook): new function
2501         allowing us to put custom hooks in a transaction to be used for
2502         cancelling said transaction
2503
2504         * doc/dbus-specification.sgml: add some discussion of secondary
2505         service owners, and disallow zero-length service names
2506
2507         * bus/services.c (bus_registry_acquire_service): new function,
2508         splits out part of bus_driver_handle_acquire_service() and fixes
2509         a bug where we didn't remove the service doing the acquiring
2510         from the secondary queue if we failed to remove the current owner
2511         from the front of the queue.
2512
2513 2003-04-10  Alexander Larsson  <alexl@redhat.com>
2514
2515         * doc/dbus-specification.sgml:
2516         s/org.freedesktop.Broadcast/org.freedesktop.DBus.Broadcast/
2517
2518 2003-04-10  Alexander Larsson  <alexl@redhat.com>
2519
2520         * bus/.cvsignore:
2521         * glib/.cvsignore:
2522         * test/.cvsignore:
2523         Added files to cvsignore
2524
2525         * dbus/dbus-message.h:
2526         * dbus/dbus-message.c: (dbus_message_iter_get_named):
2527         Make get_named() take two out argument and return a boolean.
2528         (dbus_message_iter_get_args_valist):
2529         Update usage of get_named().
2530         (dbus_message_iter_append_byte):
2531         Fix typo
2532         (dbus_message_iter_append_named)
2533         Fix typo
2534         (message_iter_test), (check_message_handling_type), (_dbus_message_test):
2535         More tests.
2536
2537 2003-04-10  Alexander Larsson  <alexl@redhat.com>
2538
2539         * dbus/dbus-marshal.[ch]:
2540         Add array_type_pos argument to _dbus_marshal_validate_arg.
2541         Let you pass a NULL end_pos to _dbus_marshal_validate_type.
2542
2543         * dbus/dbus-message.[ch]:
2544         Multi-dimensional arrays have full type specification in the
2545         outermost array. Iter code re-arranged to handle this.
2546         Added some more iter tests.
2547
2548         * doc/dbus-specification.sgml:
2549         Add me to authors.
2550         Remove old FIXME.
2551         Update new array encoding description.
2552         Correct DBUS_SERVICE_FLAGS_REPLACE_EXISTING description.
2553
2554         * test/data/invalid-messages/array-with-mixed-types.message:
2555         * test/data/valid-messages/array-of-array-of-uint32.message:
2556         Change to the new array format.
2557
2558         * test/data/invalid-messages/too-short-dict.message:
2559         Fix bug in test.
2560
2561         * test/data/valid-messages/recursive-types.message:
2562         Fix up and extend test.
2563
2564 2003-04-10  Havoc Pennington  <hp@pobox.com>
2565
2566         * bus/dispatch.c: lots of fixes
2567
2568         * dbus/dbus-mainloop.c (_dbus_loop_dispatch): export
2569         (_dbus_loop_iterate): remove old "quit if no callbacks" code,
2570         that was crack, broke the test service.
2571
2572         * dbus/dbus-transport.c (_dbus_transport_open): fix error
2573         handling to avoid piling up errors if we get a failure on the
2574         first address.
2575
2576         * dbus/dbus-internals.c (_dbus_real_assert_not_reached): include
2577         pid in assertion failures.
2578
2579         * dbus/dbus-mainloop.c (_dbus_loop_iterate): use static arrays up
2580         to some fixed size of file descriptor array. Don't return TRUE
2581         anytime a timeout exists, that led to lots of busy loop silliness
2582         in the tests.
2583
2584 2003-04-09  Havoc Pennington  <hp@redhat.com>
2585
2586         * dbus/dbus-mainloop.c (check_timeout): fix timeouts, I thought
2587         I'd checked this in earlier but hadn't.
2588
2589 2003-04-09  Havoc Pennington  <hp@redhat.com>
2590
2591         * bus/dispatch.c (bus_dispatch_test): get a bit further through
2592         the activation test (man this is getting old!)
2593
2594 2003-04-09  Havoc Pennington  <hp@redhat.com>
2595
2596         * test/test-utils.c: use dispatch status function to fix this up
2597
2598         * bus/connection.c (connection_watch_callback): don't dispatch
2599         from here
2600         (connection_timeout_callback): don't dispatch from here
2601         (bus_connections_setup_connection): set the dispatch status function
2602         (bus_connection_disconnected): unset it
2603
2604         * dbus/dbus-mainloop.c (_dbus_loop_queue_dispatch): new function
2605         used to add a connection to be dispatched
2606         (_dbus_loop_iterate): do the dispatching at the end of each
2607         iteration
2608
2609         * dbus/dbus-connection.c
2610         (dbus_connection_set_dispatch_status_function): new function
2611         allowing us to fix up main loop usage
2612         (_dbus_connection_last_unref): free all the various function
2613         user data
2614         (dbus_connection_dispatch): call the DispatchStatusFunction
2615         whenever this function returns
2616         (dbus_connection_handle_watch): call DispatchStatusFunction
2617         (dbus_connection_send_with_reply_and_block): call DispatchStatusFunction
2618         (reply_handler_timeout): call DispatchStatusFunction
2619         (dbus_connection_flush): call DispatchStatusFunction
2620
2621 2003-04-09  Havoc Pennington  <hp@redhat.com>
2622
2623         * dbus/dbus-bus.c (dbus_bus_register): fix up error handling and
2624         a memory leak
2625
2626         * bus/dispatch.c (check_service_activated): fix bug in test
2627
2628         * dbus/dbus-mainloop.c (check_timeout): fix this up
2629
2630         * dbus/dbus-internals.c (_dbus_verbose_real): include PID in
2631         verbose output so we can sort out output from different processes,
2632         e.g. in the activation case.
2633
2634 2003-04-08  Colin Walters  <walters@gnu.org>
2635
2636         * bus/bus.c (struct BusContext) [pidfile]: New member, to store
2637         the pid file.
2638         (bus_context_new): Set it.
2639         (bus_context_unref): Use it to delete the pid file.
2640
2641 2003-04-08  Havoc Pennington  <hp@redhat.com>
2642
2643         * test/data/invalid-messages/array-with-mixed-types.message:
2644         regression test that fails for the moment
2645
2646         * dbus/dbus-test.c (dbus_internal_do_not_use_run_tests): reorder
2647         tests for convenience
2648
2649         * dbus/dbus-marshal.c (_dbus_marshal_validate_arg): don't allow
2650         array of nil, it broke things.
2651
2652         * test/data/invalid-messages/array-of-nil.message: regression test
2653
2654         * test/data/valid-messages/array-of-array-of-uint32.message:
2655         happened to write this so added it to suite
2656
2657 2003-04-08  Havoc Pennington  <hp@redhat.com>
2658
2659         * bus/driver.c (bus_driver_handle_acquire_service): init
2660         retval/reply before checking name
2661
2662         * dbus/dbus-marshal.c (_dbus_marshal_validate_arg): add a
2663         recursion depth argument
2664
2665         * dbus/dbus-message.h (struct DBusMessageIter): put some padding
2666         in the public struct for future extension
2667
2668         * dbus/dbus-message-builder.c (_dbus_message_data_load): fix
2669         typo
2670
2671         * dbus/dbus-marshal.c (_dbus_marshal_validate_arg): fix a verbose
2672         message
2673
2674         * doc/dbus-specification.sgml: fix typo
2675
2676 2003-04-08  Alexander Larsson  <alexl@redhat.com>
2677
2678         Implemented recursive types, named types and new-style iters
2679
2680         * bus/driver.c:
2681         * glib/test-thread-client.c: (thread_func):
2682         * glib/test-thread-server.c: (handle_test_message):
2683         * test/test-service.c: (handle_echo):
2684         Update to new api
2685
2686         * dbus/Makefile.am:
2687         * dbus/dbus-dict.c:
2688         * dbus/dbus-dict.h:
2689         * dbus/dbus.h
2690         Remove DBusDict
2691
2692         * dbus/dbus-internals.c: (_dbus_type_to_string):
2693         Update for new types.
2694
2695         * dbus/dbus-marshal.[ch]:
2696         Implement recursive types and the new marshalling format.
2697         Remove hardcoded dict marshalling.
2698         Marshal named types.
2699
2700         * dbus/dbus-message-builder.c:
2701         Add BYTE_ARRAY.
2702         Remove references to old types
2703
2704         * dbus/dbus-message.[ch]:
2705         New non-refcounted iter API that supports recursive iters.
2706         Use iters for appending, including support for recursive
2707         iters.
2708         Add byte and named type support.
2709         Update everything to new marshalling formats.
2710         Add tests for new API.
2711
2712         * dbus/dbus-protocol.h:
2713         Remove old array types.
2714         Add types: BYTE, ARRAY, DICT, NAMED
2715
2716         * dbus/dbus-string.c:
2717         * dbus/dbus-sysdeps.c:
2718         Make parse_double locale safe.
2719
2720         * dbus/dbus-test-main.c:
2721         Call setlocale.
2722
2723         * dbus/dbus-test.c:
2724         Kill dict test
2725
2726         * doc/dbus-specification.sgml:
2727         Update spec
2728
2729         * test/data/incomplete-messages/missing-body.message:
2730         * test/data/invalid-messages/bad-boolean.message:
2731         * test/data/invalid-messages/bad-boolean-array.message:
2732         * test/data/invalid-messages/boolean-array-length-too-long.message-raw:
2733         * test/data/invalid-messages/boolean-has-no-value.message-raw:
2734         * test/data/invalid-messages/too-short-dict.message:
2735         * test/data/valid-messages/dict-simple.message:
2736         * test/data/valid-messages/dict.message:
2737         * test/data/valid-messages/emptiness.message:
2738         * test/data/valid-messages/lots-of-arguments.message:
2739         * test/data/valid-messages/no-padding.message:
2740         * test/data/valid-messages/recursive-types.message:
2741         Add missing NAME fields
2742         Fix up dicts & arrays
2743
2744         * test/data/invalid-messages/dict-with-nil-value.message:
2745         Removed, this is not invalid anymore.
2746
2747         * test/data/valid-messages/recursive-types.message:
2748         Add new test for deeply recursive types.
2749
2750 2003-04-07  Havoc Pennington  <hp@pobox.com>
2751
2752         * bus/driver.c (bus_driver_handle_acquire_service): return an
2753         error if you try to acquire a service that starts with ':'
2754
2755 2003-04-07  Havoc Pennington  <hp@redhat.com>
2756
2757         * doc/dbus-specification.sgml: require that base service names
2758         start with ':' and that the base service is created/deleted
2759         as first and last things a connection does on the bus
2760
2761         * bus/dispatch.c (check_existent_service_activation): lots more
2762         work on the activation test; it doesn't fully pass yet...
2763
2764         * test/test-service.c (main): fix so we don't memleak the
2765         connection to the message bus
2766         (filter_func): accept a message asking us to exit
2767
2768 2003-04-06  Havoc Pennington  <hp@pobox.com>
2769
2770         * qt/Makefile.am (dbusinclude_HEADERS): install dbus-qt.h,
2771         from Colin Walters
2772
2773         * configure.in: fixes to Qt detection from Colin Walters
2774
2775         * doc/Makefile.am: Only remove generated docbook dirs if they
2776         exist, from Colin Walters
2777
2778         * dbus/dbus-bus.c: change how we set well-known connections to
2779         NULL, so that it works if a single connection is stored in
2780         two well-known array slots.
2781
2782         * test/Makefile.am: remove a lot of stuff that isn't immediately
2783         useful, it's in CVS history if we want it.
2784
2785         * test/test-service.c: use dbus-mainloop instead of that
2786         watch.[hc] crack
2787
2788 2003-04-06  Havoc Pennington  <hp@pobox.com>
2789
2790         * dbus/Makefile.am: split lists of sources into stuff that goes in
2791         the library, util functions that go in the lib and are also used
2792         elsewhere, and util functions that are used in tests/daemon but
2793         don't go in the lib.
2794
2795         * dbus/dbus-mainloop.h, dbus/dbus-mainloop.c: move bus/loop.[hc]
2796         here so it can be used in test binaries also
2797
2798 2003-04-06  Havoc Pennington  <hp@pobox.com>
2799
2800         * dbus/dbus-sysdeps.c (_dbus_become_daemon): write the pidfile
2801         here in the parent process, so we can return an error if it
2802         fails. Also, move some of the code into the child so the parent
2803         is less hosed if we fail midway through.
2804
2805         * bus/bus.c (bus_context_new): move pidfile detection further up
2806         in the function, before we start overwriting sockets and such.
2807
2808         * bus/messagebus.in: adjust this a bit, not sure if it will work.
2809
2810         * configure.in: add --with-system-pid-file and --with-system-socket
2811
2812 2003-04-06  Colin Walters  <walters@verbum.org>
2813
2814         * configure.in (DBUS_SYSTEM_PID_FILE): New variable.
2815
2816         * bus/system.conf.in: Declare a pidfile.
2817
2818         * bus/bus.c (bus_context_new): Test for an existing pid file, and
2819         create one (if appropriate).
2820
2821         * bus/config-parser.c (enum ElementType) [ELEMENT_PIDFILE]: New.
2822         (struct BusConfigParser) [pidfile]: New.
2823         (element_type_to_name, merge_included, start_busconfig_child)
2824         (bus_config_parser_end_element, bus_config_parser_content): Handle it.
2825         (bus_config_parser_unref): Free it.
2826         (bus_config_parser_get_pidfile): New function.
2827
2828         * bus/config-parser.h (_dbus_write_pid_file): Prototype.
2829
2830         * dbus/dbus-errors.h (DBUS_ERROR_PIDFILE_EXISTS): New error.
2831
2832         * dbus/dbus-sysdeps.c (_dbus_write_pid_file): New function.
2833
2834         * dbus/dbus-sysdeps.h: Prototype it.
2835
2836 2003-04-06  Havoc Pennington  <hp@pobox.com>
2837
2838         * bus/bus.c (bus_context_new): print the address in here, rather
2839         than in main(), because we need to do it before forking the daemon
2840
2841         * bus/dispatch.c (send_service_nonexistent_error): set the sender
2842         on the service nonexistent error
2843
2844         * bus/driver.c (bus_driver_handle_acquire_service): set the
2845         sender on the AcquireService reply
2846
2847         * test/data/valid-config-files/debug-allow-all.conf.in: Make test
2848         server also listen on a UNIX socket so services can connect to it.
2849
2850 2003-04-06  Havoc Pennington  <hp@pobox.com>
2851
2852         * dbus/dbus-threads.c: Redo how the fake debug mutexes are done
2853         so it detects deadlocks and also we actually init threads when
2854         debugging.
2855
2856 2003-04-06  Havoc Pennington  <hp@pobox.com>
2857
2858         * dbus/dbus-server-unix.c (_dbus_server_new_for_domain_socket):
2859         save the domain socket name, and unlink it when we disconnect the
2860         server. Means that at least when we exit normally, we won't leave
2861         a bunch of junk in /tmp
2862
2863         * dbus/dbus-transport-unix.c
2864         (_dbus_transport_new_for_domain_socket): code cleanup (nicer
2865         memory management). (I was making a real change here but then
2866         didn't)
2867
2868 2003-04-06  Havoc Pennington  <hp@pobox.com>
2869
2870         * bus/bus.c (bus_context_new): fix wrong handling of
2871         server_data_slot_unref() in the error case.
2872
2873         * dbus/dbus-internals.h (_dbus_assert): change so it passes
2874         "(condition) != 0" to _dbus_real_assert so that
2875         "_dbus_assert (pointer)" doesn't cause a warning
2876
2877         * bus/main.c (main): accept --print-address option to print out
2878         the message bus address
2879
2880         * dbus/dbus-sysdeps.c (_dbus_generate_random_ascii): export this
2881
2882         * dbus/dbus-transport.c (_dbus_transport_open): special error for
2883         "tmpdir" option to unix: address on client side
2884
2885         * dbus/dbus-server.c (dbus_server_listen): handle "tmpdir" option
2886         to unix: address
2887
2888         * configure.in (TEST_SOCKET_DIR): locate a temporary directory
2889         we can use to create sockets in the test suite.
2890
2891         * bus/main.c (signal_handler): on SIGTERM, exit the daemon
2892         cleanly. To be used for testing.
2893
2894         * dbus/dbus-spawn.c (babysit): use _dbus_set_signal_handler()
2895
2896         * dbus/dbus-sysdeps.c (_dbus_set_signal_handler): new
2897
2898         * dbus/dbus-server-debug-pipe.c (_dbus_transport_debug_pipe_new):
2899         handle trying to call this when there's no servers active
2900
2901 2003-04-05  Havoc Pennington  <hp@pobox.com>
2902
2903         * NEWS: update
2904
2905         * configure.in: 0.8
2906
2907 2003-04-05  Havoc Pennington  <hp@pobox.com>
2908
2909         * bus/bus.c (setup_server): fix this so dbus-daemon-1 doesn't
2910         crash on startup. Need to get "try starting the daemon"
2911         in the test suite I guess. ;-)
2912
2913         * dbus/dbus-server.h, dbus/dbus-server.c: remove the stuff that
2914         tracked the number of open connections; it's better done in
2915         application-specific code as you want it to span all servers etc.
2916
2917 2003-04-05  Havoc Pennington  <hp@pobox.com>
2918
2919         * bus/Makefile.am (install-data-hook): add missing DESTDIR,
2920         patch from Colin Walters
2921
2922 2003-04-05  Havoc Pennington  <hp@pobox.com>
2923
2924         * doc/config-file.txt (Elements): fix docs of <auth> to reflect
2925         reality; in fact multiple mechanisms are allowed.
2926
2927         * dbus/dbus-internals.c (_dbus_real_assert)
2928         (_dbus_real_assert_not_reached): move guts of _dbus_assert() and
2929         _dbus_assert_not_reached() into functions, so that they don't show
2930         up in basic block counts for test coverage, and don't use up as
2931         much disk space. Does mean slower execution speed though, so
2932         assumes --disable-asserts is the normal production case.
2933
2934 2003-04-05  Havoc Pennington  <hp@pobox.com>
2935
2936         * test/Makefile.am (dist-hook): also dist *.in files
2937
2938         * NEWS: update
2939
2940         * configure.in: 0.7
2941
2942 2003-04-05  Havoc Pennington  <hp@pobox.com>
2943
2944         * dbus/dbus-string.c: docs warning
2945
2946         * dbus/dbus-spawn.c: missing docs
2947
2948         * dbus/dbus-memory.c (struct ShutdownClosure): missing docs
2949
2950 2003-04-05  Havoc Pennington  <hp@pobox.com>
2951
2952         * bus/loop.c (bus_loop_iterate): fix the timeout code, using
2953         magic from GLib
2954
2955         * dbus/dbus-spawn.c (_dbus_babysitter_unref): set sitter_pid
2956         to -1 once we've reaped the babysitter
2957         (_dbus_babysitter_handle_watch): do as much work as we can, not
2958         just one go of it
2959
2960         * bus/activation.c: add code using DBusBabysitter so that we
2961         handle it when a service fails to start up properly.
2962         (bus_activation_service_created): don't remove the activation
2963         entries as we go, just let them get removed when we free the pending
2964         activation. Unref reply messages after sending them.
2965
2966 2003-04-05  Havoc Pennington  <hp@pobox.com>
2967
2968         * test/decode-gcov.c (main): print per-directory stats in the report
2969
2970         * Makefile.am (coverage-report.txt): don't include test/* in gcov stats
2971
2972 2003-04-05  Havoc Pennington  <hp@pobox.com>
2973
2974         * Makefile.am (coverage-report.txt): add target "coverage-report.txt"
2975
2976         * test/decode-gcov.c: hack up a little program to suck data
2977         out of gcov files. Yes this is sort of silly.
2978
2979         * configure.in: define something in config.h and do an
2980         AM_CONDITIONAL when gcov is enabled
2981
2982 2003-04-04  Havoc Pennington  <hp@redhat.com>
2983
2984         * dbus/dbus-spawn.c, dbus/dbus-spawn.h: Change dbus_spawn to
2985         return a "babysitter" object that is used to monitor the status of
2986         the spawned process and reap it when required.
2987
2988         * test/test-segfault.c, test/test-exit.c,
2989         test/test-sleep-forever.c: binaries that do various lame things,
2990         used in the test suite.
2991
2992         * dbus/dbus-sysdeps.c: kill _dbus_errno_to_string()
2993
2994 2003-04-03  Havoc Pennington  <hp@pobox.com>
2995
2996         * dbus/dbus-spawn.c: Move dbus-spawn into a separate file
2997         in preparation for modifying it, dbus-sysdeps is getting
2998         a bit unmanageable.
2999
3000 2003-04-03  Havoc Pennington  <hp@redhat.com>
3001
3002         * bus/loop.h, bus/loop.c: make the mainloop an object so we can
3003         have multiple ones
3004
3005         * bus/*.[hc]: adapt to mainloop change
3006
3007 2003-04-03  Havoc Pennington  <hp@redhat.com>
3008
3009         * bus/activation.c (load_directory): fix up memleaks
3010         (bus_activation_entry_free): free the entry
3011
3012         * dbus/dbus-bus.c (dbus_bus_acquire_service): return an error if
3013         we get one from the message bus; fix memleaks.
3014
3015         * dbus/dbus-message.c (dbus_set_error_from_message): new function
3016
3017 2003-04-03  Havoc Pennington  <hp@pobox.com>
3018
3019         * bus/config-parser.c (bus_config_parser_unref): free
3020         list of mechanisms, bug discovered by test suite enhancements
3021         (putting system.conf and session.conf into suite)
3022
3023         * test/Makefile.am, test/test-service.c: add placeholder for a
3024         test service that we'll activate as part of test suite. Doesn't
3025         do anything yet.
3026
3027         * dbus/dbus-sysdeps.c (_dbus_setenv): support unsetenv by
3028         setting NULL value, and use system malloc not dbus_malloc()
3029         when we have unavoidable memleakage.
3030
3031         * dbus/dbus-bus.c (dbus_bus_get): fix bug where bus type of 0
3032         didn't work, and support DBUS_BUS_ACTIVATION.
3033
3034         * bus/activation.c (child_setup): pass our well-known bus type to
3035         the child
3036
3037         * bus/config-parser.c: support <type> to specify well-known type
3038
3039         * doc/dbus-specification.sgml: document the env variables to
3040         locate well-known buses and find service activator
3041
3042 2003-04-02  Havoc Pennington  <hp@redhat.com>
3043
3044         * test/Makefile.am (all-local): add a rule to copy tests to
3045         builddir, so we can have generated tests. Use this to remove the
3046         silly hack for testing system.conf and session.conf. Will use this
3047         shortly to generate .service files pointing to test binaries.
3048
3049 2003-04-02  Havoc Pennington  <hp@redhat.com>
3050
3051         * dbus/dbus-string.c (set_length): fix a bug - we allocated max of
3052         current alloc and needed new length, not max of the doubled
3053         allocation and needed new length. Also, when building tests,
3054         don't do the double-allocation stuff, just realloc every time.
3055
3056 2003-04-02  Havoc Pennington  <hp@redhat.com>
3057
3058         * dbus/dbus-sysdeps.c (_dbus_file_get_contents): include filenames
3059         in error messages
3060         (_dbus_string_get_dirname): new
3061         (_dbus_sysdeps_test): new
3062         (_dbus_directory_open): include dirnames in error messages
3063
3064         * bus/config-parser.c: interpret <include> and <includedir> and
3065         <servicedir> relative to config file location if the given
3066         filename is not absolute.
3067
3068         * dbus/dbus-string.c (_dbus_string_find_byte_backward): new
3069
3070 2003-04-02  Havoc Pennington  <hp@redhat.com>
3071
3072         * bus/connection.c (bus_transaction_send_error_reply): set sender
3073         service for the error, and unref the reply on success
3074
3075         * bus/activation.c: convert to use BusTransaction so OOM can be
3076         handled correctly
3077         (bus_activation_service_created): set sender of the message
3078
3079 2003-04-01  Havoc Pennington  <hp@redhat.com>
3080
3081         * bus/config-parser.c, bus/bus.c: implement <servicedir> and
3082         <includedir> (at least mostly)
3083
3084         * dbus/dbus-sysdeps.c (_dbus_change_identity): set the group ID
3085         first, then the user ID
3086
3087 2003-04-01  Havoc Pennington  <hp@pobox.com>
3088
3089         * dbus/dbus-server.c (dbus_server_set_auth_mechanisms): new
3090         function
3091
3092         * dbus/dbus-auth.c (_dbus_auth_set_mechanisms): new
3093
3094         * dbus/dbus-internals.c (_dbus_dup_string_array): new function
3095
3096         * dbus/dbus-sysdeps.c (_dbus_listen_unix_socket): chmod the
3097         socket 0777, and unlink any existing socket.
3098
3099         * bus/bus.c (bus_context_new): change our UID/GID and fork if
3100         the configuration file so specifies; set up auth mechanism
3101         restrictions
3102
3103         * bus/config-parser.c (bus_config_parser_content): add support
3104         for <fork> option and fill in code for <auth>
3105
3106         * bus/system.conf.in: add <fork/> to default configuration,
3107         and limit auth mechanisms to EXTERNAL
3108
3109         * doc/config-file.txt (Elements): add <fork>
3110
3111         * dbus/dbus-sysdeps.c (_dbus_become_daemon): new function
3112         (_dbus_change_identity): new function
3113
3114 2003-03-31  Havoc Pennington  <hp@redhat.com>
3115
3116         * dbus/dbus-sysdeps.c (_dbus_connect_unix_socket)
3117         (_dbus_listen_unix_socket): fix off-by-one error in null
3118         termination spotted by Nalin
3119
3120 2003-03-31  Havoc Pennington  <hp@redhat.com>
3121
3122         * dbus/dbus-keyring.c (_dbus_keyring_new_homedir): allow setting
3123         DBUS_TEST_HOMEDIR when tests are enabled, so we can test without
3124         having a real home directory available.
3125
3126 2003-03-31  Havoc Pennington  <hp@redhat.com>
3127
3128         * bus/Makefile.am (install-data-hook): create /var/run/dbus
3129
3130         * bus/messagebus.in: add init script for Red Hat /etc/init.d
3131
3132         * configure.in: add support for specifying a style of init script
3133         to install
3134
3135 2003-03-31  Havoc Pennington  <hp@redhat.com>
3136
3137         Fix some annoying DBusString API and fix all affected code.
3138
3139         * dbus/dbus-string.c (_dbus_string_init): get rid of annoying
3140         max_length argument
3141         (_dbus_string_get_data): change to return string instead of using
3142         an out param
3143         (_dbus_string_get_const_data): ditto
3144         (_dbus_string_get_data_len): ditto
3145         (_dbus_string_get_const_data_len): ditto
3146
3147 2003-03-31  Havoc Pennington  <hp@redhat.com>
3148
3149         * bus/main.c (main): fix up the command line arguments to be nicer
3150
3151 2003-03-31  Havoc Pennington  <hp@redhat.com>
3152
3153         * dbus/Makefile.am (INCLUDES): use EXPANDED_LOCALSTATEDIR to
3154         define DBUS_SYSTEM_BUS_PATH as we want to compile in the same
3155         final location that lands in the config file
3156
3157         * bus/config-loader-expat.c (bus_config_load): fix type of
3158         XML_Parser variable
3159
3160         * doc/TODO: remove TODO item for dbus_bus_get()
3161
3162         * dbus/dbus-bus.c (bus_data_free): add missing lock/unlock
3163
3164 2003-03-31  Havoc Pennington  <hp@pobox.com>
3165
3166         * dbus/dbus-transport-unix.c (_dbus_transport_new_for_domain_socket)
3167         (_dbus_transport_new_for_tcp_socket): these didn't need the "server"
3168         argument since they are always client side
3169
3170         * dbus/dbus-server.c (dbus_server_get_address): new function
3171
3172         * bus/main.c (main): take the configuration file as an argument.
3173
3174         * test/data/valid-config-files/debug-allow-all.conf: new file to
3175         use with dispatch.c tests for example
3176
3177         * bus/test-main.c (main): require test data dir
3178
3179         * bus/bus.c (bus_context_new): change this to take a
3180         configuration file name as argument
3181
3182         * doc/config-file.txt (Elements): add <servicedir>
3183
3184         * bus/system.conf, bus/session.conf: new files
3185
3186         * dbus/dbus-bus.c (dbus_bus_get): look for system bus on
3187         well-known socket if none set
3188
3189         * configure.in: create system.conf and session.conf
3190
3191 2003-03-30  Havoc Pennington  <hp@pobox.com>
3192
3193         * bus/config-parser.c: hacking
3194
3195         * dbus/dbus-memory.c: don't use DBusList for the list of stuff
3196         to shut down, since it could cause weirdness with the DBusList
3197         lock
3198
3199         * dbus/dbus-list.c (_dbus_list_test): add tests for the
3200         link-oriented stack routines
3201         (alloc_link): free the mempool if the first alloc from it fails
3202
3203         * dbus/dbus-mempool.c (struct DBusMemBlock): fix alignment issue
3204
3205         * dbus/dbus-string.c (UNICODE_VALID): sync new version of this
3206         from GLib
3207         (_dbus_string_skip_white): new
3208
3209         * doc/config-file.txt (Elements): add <includedir>
3210
3211 2003-03-28  Havoc Pennington  <hp@pobox.com>
3212
3213         * dbus/dbus-string.c (_dbus_string_copy_data_len)
3214         (_dbus_string_copy_data): new functions
3215
3216 2003-03-28  Anders Carlsson  <andersca@codefactory.se>
3217
3218         * dbus/dbus-bus.c: (bus_data_free), (dbus_bus_get):
3219         * dbus/dbus-bus.h:
3220         Add dbus_bus_get.
3221
3222         * dbus/dbus-memory.c:
3223         Fix a doc comment.
3224
3225 2003-03-28  Havoc Pennington  <hp@pobox.com>
3226
3227         * bus/test.c (bus_test_flush_bus): remove the sleep from here,
3228         I think it may have just been superstition. Not sure.
3229
3230         * dbus/dbus-string.c (_dbus_string_base64_decode): catch some OOM
3231         failures that were not being handled.
3232
3233         * dbus/dbus-auth.c (process_auth): fix a memleak in OOM handling
3234
3235         * dbus/dbus-memory.c: add ability to set number of mallocs in a
3236         row that will fail on out-of-memory.
3237
3238         * dbus/dbus-internals.c (_dbus_test_oom_handling): convenience
3239         function for testing out-of-memory handling.
3240
3241         * bus/config-loader-expat.c (memsuite): don't wrap the dbus
3242         allocation functions, they do map exactly to the expat ones.
3243
3244 2003-03-27  Havoc Pennington  <hp@redhat.com>
3245
3246         * bus/config-loader-libxml.c (bus_config_load): add another error
3247         check
3248
3249 2003-03-26  Anders Carlsson  <andersca@codefactory.se>
3250
3251         * doc/TODO:
3252         Add note about automatic service activation.
3253
3254         * doc/dbus-specification.sgml:
3255         Rename the specification and clarify a few things.
3256
3257 2003-03-26  Anders Carlsson  <andersca@codefactory.se>
3258
3259         * Doxyfile.in:
3260         * dbus/dbus-address.c:
3261         * dbus/dbus-dict.c:
3262         * dbus/dbus-marshal.c:
3263         * dbus/dbus-server-debug-pipe.c:
3264         * dbus/dbus-transport-unix.c:
3265         Fix documentation warnings.
3266
3267 2003-03-26  Havoc Pennington  <hp@pobox.com>
3268
3269         * bus/test-main.c, dbus/dbus-test.c (main): check memleaks
3270         after every test so it's quick and easy to see which leaked, and
3271         so we test multiple dbus_shutdown() calls
3272
3273         * configure.in: change configure.in XML stuff to also support
3274         expat
3275
3276         * config-loader-libxml.c: some hacking
3277
3278         * config-loader-expat.c: some hacking
3279
3280         * config-parser.c: some hacking, plus tests
3281
3282 2003-03-25  Havoc Pennington  <hp@redhat.com>
3283
3284         * throughout - add more _DBUS_ASSERT_ERROR_IS_CLEAR
3285
3286         * configure.in: add --with-xml option to specify XML library,
3287         right now only libxml is supported.
3288
3289         * bus/config-loader-libxml.c, config-parser.c: sync some minor
3290         nonworking code between home and work, still just stubs
3291
3292 2003-03-24  Havoc Pennington  <hp@redhat.com>
3293
3294         * dbus/dbus-sysdeps.c (_dbus_set_fd_nonblocking): move to this
3295         file
3296
3297         * dbus/dbus-errors.c (dbus_set_error, dbus_set_error_const): allow
3298         NULL argument for "message" if the error is a well-known one,
3299         fill in a generic message in this case.
3300
3301         * dbus/dbus-errors.h (DBusResultCode): Kill DBusResultCode in
3302         favor of DBusError
3303
3304         * bus/test.c (bus_test_flush_bus): add
3305
3306         * bus/policy.c (bus_policy_test): test code stub
3307
3308 2003-03-24  Havoc Pennington  <hp@pobox.com>
3309
3310         * bus/connection.c (bus_connections_setup_connection): set up
3311         the "can this user connect" function, but it always returns
3312         TRUE until we have a config file parser so we can have a config
3313         file that allows connections.
3314
3315 2003-03-23  Havoc Pennington  <hp@pobox.com>
3316
3317         * dbus/dbus-threads.c (dbus_mutex_new, dbus_condvar_new): with
3318         DBUS_BUILD_TESTS, actually alloc/free a block of memory for
3319         the mutex, so we can check for proper memory management
3320         and OOM handling.
3321
3322         * dbus/dbus-dataslot.c: remove the mutex from
3323         DBusDataSlotAllocator and lock it manually when using it,
3324         to simplify fitting it into the global slots framework.
3325
3326         * dbus/dbus-threads.c (init_static_locks): rework how we're
3327         handling global locks so they are easily shut down.
3328
3329         * bus/policy.c (bus_policy_append_rule): fix
3330
3331         * bus/test-main.c (main): check for memleaks
3332
3333         * dbus/dbus-test.c (dbus_internal_do_not_use_run_tests): make
3334         test suite check for memleaks
3335
3336         * dbus/dbus-memory.c: add support in test mode for tracking
3337         number of outstanding blocks
3338
3339 2003-03-23  Havoc Pennington  <hp@pobox.com>
3340
3341         * bus/policy.c, bus/bus.c, bus/connection.c: implement allow/deny
3342         policies code
3343
3344         * dbus/dbus-hash.h: add ULONG hash keys
3345
3346         * dbus/dbus-sysdeps.c (_dbus_get_groups): new
3347         (_dbus_get_group_id): new function
3348
3349 2003-03-20  Havoc Pennington  <hp@redhat.com>
3350
3351         * dbus/dbus-connection.c (dbus_connection_set_unix_user_function):
3352         new function
3353         (dbus_connection_get_unix_user): new function
3354
3355 2003-03-20  Havoc Pennington  <hp@pobox.com>
3356
3357         * bus/connection.c (bus_connection_send_oom_error): assert that
3358         message has a sender
3359         (connection_execute_transaction): ditto
3360         (bus_connection_preallocate_oom_error): fix to set the sender, and
3361         set recipient to the destination service, not the bus driver
3362
3363         * bus/policy.c: hacking
3364
3365         * dbus/dbus-message.c (dbus_message_service_is): new function
3366         (dbus_message_sender_is): new
3367
3368 2003-03-19  Havoc Pennington  <hp@redhat.com>
3369
3370         * bus/policy.c: start sketching code for policy restrictions on
3371         what connections can do.
3372
3373 2003-03-18  Havoc Pennington  <hp@redhat.com>
3374
3375         * doc/TODO: some notes on high-level todo items. Little nitpick
3376         stuff is all in @todo, so no need to add it here.
3377
3378         * doc/config-file.txt: some notes on how config file might look
3379
3380 2003-03-18  Anders Carlsson  <andersca@codefactory.se>
3381
3382         * configure.in: 0.6
3383
3384         * NEWS: Update.
3385
3386 2003-03-17  Havoc Pennington  <hp@redhat.com>
3387
3388         * dbus/dbus-internals.h: add gcc attributes so that
3389         our printf-style functions warn on bad arguments to
3390         format
3391
3392         * dbus/dbus-sysdeps.c (_dbus_connect_tcp_socket): fix printf
3393         format bug
3394
3395         * dbus/dbus-message.c (_dbus_message_loader_queue_messages): fix
3396         printf format bug
3397
3398 2003-03-17  Havoc Pennington  <hp@redhat.com>
3399
3400         * bus/test-main.c (main): make it print something as it runs
3401         so make check doesn't look stuck
3402
3403         * doc/negotiation.txt, doc/dbus-sasl-profile.txt: remove
3404         from CVS, now obsolete
3405
3406 2003-03-17  Anders Carlsson  <andersca@codefactory.se>
3407
3408         * bus/dispatch.c: (bus_dispatch):
3409         Refetch the service name since it may have been reallocated
3410         when dbus_message_set_sender was called.
3411
3412         * dbus/dbus-sysdeps.c: (_dbus_accept):
3413         Add address and address length variables and use them to stop
3414         valgrind from complaining.
3415
3416 2003-03-17  Havoc Pennington  <hp@pobox.com>
3417
3418         All tests pass, no memleaks, no valgrind complaints.
3419
3420         * bus/test.c: refcount handler_slot
3421
3422         * bus/connection.c (bus_connections_new): refcount
3423         connection_data_slot
3424
3425         * dbus/dbus-auth-script.c (_dbus_auth_script_run): delete unused
3426         bytes so that auth scripts pass.
3427
3428         * bus/dispatch.c: init message_handler_slot so it gets allocated
3429         properly
3430
3431         * bus/dispatch.c (message_handler_slot_ref): fix memleak
3432
3433         * dbus/dbus-server-debug-pipe.c (_dbus_server_debug_pipe_new):
3434         dealloc server_pipe_hash when no longer used for benefit of
3435         leak checking
3436
3437         * dbus/dbus-auth.c (process_command): memleak fix
3438
3439         * bus/dispatch.c (check_hello_message): memleak fix
3440
3441 2003-03-16  Havoc Pennington  <hp@pobox.com>
3442
3443         * dbus/dbus-bus.c (ensure_bus_data): fix double-unref of the data slot
3444
3445 2003-03-17  Anders Carlsson  <andersca@codefactory.se>
3446
3447         * bus/activation.c (bus_activation_activate_service): Append
3448         the pending activation entry to the list of pending activations.
3449
3450 2003-03-16  Havoc Pennington  <hp@pobox.com>
3451
3452         * bus/dispatch.c (bus_dispatch_test): remove double-unrefs of
3453         connections
3454
3455         * dbus/dbus-address.c (create_entry): fix OOM handling when
3456         failing to alloc entry->method
3457
3458 2003-03-16  Havoc Pennington  <hp@pobox.com>
3459
3460         * dbus/dbus-watch.c (_dbus_watch_new): handle failure to malloc
3461         the watch
3462
3463         * dbus/dbus-server-debug-pipe.c (_dbus_transport_debug_pipe_new):
3464         add some missing dbus_set_result
3465
3466         * bus/dispatch.c (bus_dispatch_add_connection): handle failure to
3467         alloc the DBusMessageHandler
3468
3469         * dbus/dbus-transport.c (_dbus_transport_disconnect): don't ref
3470         the transport here, since we call this from the finalizer; it
3471         resulted in a double-finalize.
3472
3473         * dbus/dbus-transport.c (_dbus_transport_disconnect): fix a bug
3474         where we tried to use transport->connection that was NULL,
3475         happened when transport was disconnected early on due to OOM
3476
3477         * bus/*.c: adapt to handle OOM for watches/timeouts
3478
3479         * dbus/dbus-transport-unix.c: port to handle OOM during
3480         watch handling
3481
3482         * dbus/dbus-auth.c (_dbus_auth_get_unused_bytes): return a
3483         reference to unused bytes instead of a copy
3484
3485         * dbus/dbus-server.c (dbus_server_handle_watch): return FALSE for
3486         out of memory
3487
3488         * dbus/dbus-connection.c (dbus_connection_handle_watch): return
3489         FALSE on OOM
3490
3491         * dbus/dbus-timeout.c (dbus_timeout_handle): return FALSE for out
3492         of memory
3493
3494 2003-03-16  Anders Carlsson  <andersca@codefactory.se>
3495
3496         * doc/dbus-specification.sgml:
3497         Document reply message for ActivateService.
3498
3499 2003-03-16  Anders Carlsson  <andersca@codefactory.se>
3500
3501         * bus/activation.c: (bus_pending_activation_entry_free),
3502         (bus_pending_activation_free), (bus_activation_new),
3503         (bus_activation_unref), (bus_activation_service_created),
3504         (bus_activation_activate_service):
3505         * bus/activation.h:
3506         * bus/bus.c: (bus_context_new):
3507         * bus/desktop-file.c: (new_section):
3508         * bus/driver.c: (bus_driver_send_service_deleted),
3509         (bus_driver_handle_activate_service):
3510         * bus/services.c: (bus_registry_new), (bus_registry_ensure):
3511         * bus/services.h:
3512         * dbus/dbus-connection.c:
3513         (dbus_connection_send_with_reply_and_block):
3514         * dbus/dbus-message.c: (dbus_message_append_args_valist):
3515         * dbus/dbus-protocol.h:
3516         Make activation work better. Now pending activations will be queued
3517         and the daemon won't try to activate services that are already registered.
3518
3519 2003-03-16  Havoc Pennington  <hp@pobox.com>
3520
3521         * dbus/dbus-bus.c (ensure_bus_data): handle failure to set
3522         connection data
3523
3524         * dbus/dbus-memory.c (_dbus_initialize_malloc_debug): support
3525         DBUS_MALLOC_BACKTRACES to print trace when failing an alloc
3526
3527 2003-03-16  Havoc Pennington  <hp@pobox.com>
3528
3529         * dbus/dbus-string.c (_dbus_string_validate_utf8): oops, unbreak
3530         this. always run the test suite before commit...
3531
3532         * bus/*: adapt to DBusConnection API changes
3533
3534         * glib/dbus-gmain.c: adapt to DBusConnection API changes,
3535         requires renaming stuff to avoid dbus_connection_dispatch name
3536         conflict.
3537
3538         * dbus/dbus-transport.c (_dbus_transport_queue_messages): new
3539         function
3540
3541         * dbus/dbus-message.c (_dbus_message_loader_queue_messages):
3542         separate from _dbus_message_loader_return_buffer()
3543
3544         * dbus/dbus-connection.c (dbus_connection_get_n_messages): remove
3545         this, because it's now always broken to use; the number of
3546         messages in queue vs. the number still buffered by the message
3547         loader is undefined/meaningless. Should use
3548         dbus_connection_get_dispatch_state().
3549         (dbus_connection_dispatch): rename from
3550         dbus_connection_dispatch_message
3551
3552 2003-03-16  Havoc Pennington  <hp@pobox.com>
3553
3554         * dbus/dbus-string.c (_dbus_string_validate_utf8): copy in a real
3555         implementation
3556
3557 2003-03-16  Anders Carlsson  <andersca@codefactory.se>
3558
3559         * dbus/dbus-connection.c:
3560         (dbus_connection_send_with_reply_and_block):
3561         Decrease connection->n_incoming when removing an entry
3562         from the list.
3563         * dbus/dbus-dict.c: (dbus_dict_entry_free),
3564         (dbus_dict_set_boolean_array), (dbus_dict_set_int32_array),
3565         (dbus_dict_set_uint32_array), (dbus_dict_set_double_array),
3566         (dbus_dict_set_byte_array), (dbus_dict_set_string_array),
3567         (dbus_dict_get_boolean_array), (dbus_dict_get_double_array),
3568         (dbus_dict_get_byte_array):
3569         Handle NULL arrays and strings. Also add support for byte arrays.
3570
3571         * dbus/dbus-marshal.c: (_dbus_marshal_byte_array),
3572         (_dbus_marshal_dict), (_dbus_demarshal_byte_array),
3573         (_dbus_demarshal_int32_array), (_dbus_demarshal_uint32_array),
3574         (_dbus_demarshal_double_array), (_dbus_demarshal_string_array),
3575         (_dbus_demarshal_dict), (demarshal_and_validate_len),
3576         (_dbus_marshal_validate_arg), (_dbus_marshal_test):
3577         * dbus/dbus-marshal.h:
3578         Add support for marshalling and demarshalling empty arrays and strings.
3579
3580         * dbus/dbus-message.c: (dbus_message_append_args_valist),
3581         (dbus_message_append_string_array),
3582         (dbus_message_iter_get_boolean),
3583         (dbus_message_iter_get_boolean_array),
3584         (dbus_message_iter_get_int32_array),
3585         (dbus_message_iter_get_uint32_array),
3586         (dbus_message_iter_get_double_array),
3587         (dbus_message_iter_get_byte_array),
3588         (dbus_message_iter_get_string_array), (dbus_message_iter_get_dict),
3589         (check_message_handling):
3590         Add support for getting empty arrays and dicts.
3591
3592         * dbus/dbus-string.c: (_dbus_string_validate_utf8):
3593         Don't do any validation at all for now, that's better than just checking
3594         for ASCII.
3595
3596         * test/data/valid-messages/emptiness.message:
3597         New test message with lots of empty arrays.
3598
3599 2003-03-16  Havoc Pennington  <hp@pobox.com>
3600
3601         * dbus/dbus-connection.c
3602         (_dbus_connection_queue_received_message_link): new function that
3603         can't fail due to OOM
3604
3605         * dbus/dbus-message.c (_dbus_message_loader_pop_message_link):
3606         new function pops a message together with a list link
3607         containing it.
3608
3609         * dbus/dbus-transport-unix.c (queue_messages): use new link-based
3610         message queuing functions to avoid needing to alloc memory
3611
3612 2003-03-16  Havoc Pennington  <hp@pobox.com>
3613
3614         Oops - test code was only testing failure of around 30 of the
3615         mallocs in the test path, but it turns out there are 500+
3616         mallocs. I believe this was due to misguided linking setup such
3617         that there was one copy of dbus_malloc etc. in the daemon and one
3618         in the shared lib, and only daemon mallocs were tested. In any
3619         case, the test case now tests all 500+ mallocs, and doesn't pass
3620         yet, though there are lots of fixes in this patch.
3621
3622         * dbus/dbus-connection.c (dbus_connection_dispatch_message): fix
3623         this so that it doesn't need to allocate memory, since it
3624         has no way of indicating failure due to OOM (and would be
3625         annoying if it did).
3626
3627         * dbus/dbus-list.c (_dbus_list_pop_first_link): new function
3628
3629         * bus/Makefile.am: rearrange to create two self-contained
3630         libraries, to avoid having libraries with overlapping symbols.
3631         that was resulting in weirdness, e.g. I'm pretty sure there
3632         were two copies of global static variables.
3633
3634         * dbus/dbus-internals.c: move the malloc debug stuff to
3635         dbus-memory.c
3636
3637         * dbus/dbus-list.c (free_link): free list mempool if it becomes
3638         empty.
3639
3640         * dbus/dbus-memory.c (_dbus_disable_mem_pools): new function
3641
3642         * dbus/dbus-address.c (dbus_parse_address): free list nodes
3643         on failure.
3644
3645         * bus/dispatch.c (bus_dispatch_add_connection): free
3646         message_handler_slot when no longer using it, so
3647         memory leak checkers are happy for the test suite.
3648
3649         * dbus/dbus-server-debug-pipe.c (debug_finalize): free server name
3650
3651         * bus/bus.c (new_connection_callback): disconnect in here if
3652         bus_connections_setup_connection fails.
3653
3654         * bus/connection.c (bus_connections_unref): fix to free the
3655         connections
3656         (bus_connections_setup_connection): if this fails, don't
3657         disconnect the connection, just be sure there are no side
3658         effects.
3659
3660         * dbus/dbus-string.c (undo_alignment): unbreak this
3661
3662         * dbus/dbus-auth.c (_dbus_auth_unref): free some stuff we were
3663         leaking
3664         (_dbus_auth_new): fix the order in which we free strings
3665         on OOM failure
3666
3667         * bus/connection.c (bus_connection_disconnected): fix to
3668         not send ServiceDeleted multiple times in case of memory
3669         allocation failure
3670
3671         * dbus/dbus-bus.c (dbus_bus_get_base_service): new function to
3672         get the base service name
3673         (dbus_bus_register_client): don't return base service name,
3674         instead store it on the DBusConnection and have an accessor
3675         function for it.
3676         (dbus_bus_register_client): rename dbus_bus_register()
3677
3678         * bus/dispatch.c (check_hello_message): verify that other
3679         connections on the bus also got the correct results, not
3680         just the one sending hello
3681
3682 2003-03-15  Havoc Pennington  <hp@pobox.com>
3683
3684         Make it pass the Hello handling test including all OOM codepaths.
3685         Now to do other messages...
3686
3687         * bus/services.c (bus_service_remove_owner): fix crash when
3688         removing owner from an empty list of owners
3689         (bus_registry_ensure): don't leave service in the list of
3690         a connection's owned services if we fail to put the service
3691         in the hash table.
3692
3693         * bus/connection.c (bus_connection_preallocate_oom_error): set
3694         error flag on the OOM error.
3695
3696         * dbus/dbus-connection.c (_dbus_connection_new_for_transport):
3697         handle _dbus_transport_set_connection failure
3698
3699         * dbus/dbus-transport-unix.c (_dbus_transport_new_for_fd): modify
3700         to create watches up front and simply enable/disable them as
3701         needed.
3702         (unix_connection_set): this can now fail on OOM
3703
3704         * dbus/dbus-timeout.c, dbus/dbus-watch.c: add concept
3705         of enabling/disabling a watch or timeout.
3706
3707         * bus/loop.c (bus_loop_iterate): don't touch disabled
3708         watches/timeouts
3709
3710         * glib/dbus-gmain.c: adapt to enable/disable watches and timeouts
3711
3712 2003-03-15  Havoc Pennington  <hp@pobox.com>
3713
3714         * bus/dispatch.c (bus_dispatch_test): OK, now finally actually
3715         write useful test code, after all that futzing around ;-)
3716
3717         Test does not yet pass because we can't handle OOM in
3718         _dbus_transport_messages_pending (basically,
3719         dbus_connection_preallocate_send() does not prealloc the write
3720         watch). To fix this, I think we need to add new stuff to
3721         set_watch_functions, namely a SetEnabled function so we can alloc
3722         the watch earlier, then enable it later.
3723
3724         * dbus/Makefile.am (libdbus_convenience_la_SOURCES): move
3725         dbus-memory.c to the convenience lib
3726
3727         * bus/test.c: rename some static functions to keep them clearly
3728         distinct from stuff in connection.c. Handle client disconnection.
3729
3730 2003-03-14  Havoc Pennington  <hp@pobox.com>
3731
3732         * bus/dispatch.c (bus_dispatch_test): do test using debug-pipe
3733         transport, tests more of the real codepath. Set up clients
3734         with bus_setup_debug_client.
3735
3736         * bus/test.c (bus_setup_debug_client): function to set up debug
3737         "clients" on the main loop
3738
3739         * dbus/dbus-transport.c (_dbus_transport_open): add debug-pipe
3740         support
3741
3742         * dbus/dbus-server.c (dbus_server_listen): add debug-pipe
3743         server type
3744
3745         * dbus/dbus-server-debug.c: support a debug server based on pipes
3746
3747         * dbus/dbus-sysdeps.c (_dbus_full_duplex_pipe): new function
3748         (_dbus_close): new function
3749
3750         * configure.in: check for socketpair
3751
3752 2003-03-14  Havoc Pennington  <hp@redhat.com>
3753
3754         * dbus/dbus-memory.c: add a "detect buffer overwrites on free"
3755         cheesy hack
3756
3757         * dbus/dbus-transport-debug.c: rework this a good bit to be
3758         less complicated. hopefully still works.
3759
3760         * dbus/dbus-server-debug.c (handle_new_client): remove timeout
3761         manually
3762
3763         * glib/dbus-gmain.c (timeout_handler): don't remove timeout
3764         after running it
3765
3766         * dbus/dbus-message.c (dbus_message_copy): rename from
3767         dbus_message_new_from_message, fix it up to copy
3768         all the message fields, add test case
3769
3770         * bus/dispatch.c (bus_dispatch_test): add some more test code,
3771         not quite passing yet
3772
3773 2003-03-14  Havoc Pennington  <hp@pobox.com>
3774
3775         * bus/loop.c (bus_loop_iterate): add this so we can "run loop
3776         until no work remains" in test code. (the large diff here
3777         is just code movement, no actual changes)
3778
3779         * dbus/dbus-server-debug.c (DEFAULT_INTERVAL): change interval to
3780         1, no point waiting around for test code.
3781         (_dbus_server_debug_accept_transport): unref the timeout
3782         after adding it (right?)
3783
3784         * dbus/dbus-transport-debug.c (DEFAULT_INTERVAL): ditto
3785
3786 2003-03-13  Havoc Pennington  <hp@redhat.com>
3787
3788         * dbus/dbus-timeout.c (_dbus_timeout_list_set_functions): handle
3789         out of memory
3790
3791         * dbus/dbus-watch.c (_dbus_watch_list_set_functions): handle out
3792         of memory
3793
3794         * dbus/dbus-connection.h: Make AddWatchFunction and
3795         AddTimeoutFunction return a bool so they can fail on out-of-memory
3796
3797         * bus/bus.c (bus_context_new): set up timeout handlers
3798
3799         * bus/connection.c (bus_connections_setup_connection): set up
3800         timeout handlers
3801
3802         * glib/dbus-gmain.c: adapt to the fact that set_functions stuff
3803         can fail
3804
3805         * bus/bus.c (bus_context_new): adapt to changes
3806
3807         * bus/connection.c: adapt to changes
3808
3809         * test/watch.c: adapt to DBusWatch changes
3810
3811         * bus/dispatch.c (bus_dispatch_test): started adding this but
3812         didn't finish
3813
3814 2003-03-14  Anders Carlsson  <andersca@codefactory.se>
3815
3816         * bus/dispatch.c (send_service_nonexistent_error): Fix typo.
3817
3818 2003-03-13  Havoc Pennington  <hp@pobox.com>
3819
3820         * bus/test.c, bus/test.h, bus/Makefile.am, bus/test-main.c:
3821         set up a test framework as for the library
3822
3823 2003-03-12  Havoc Pennington  <hp@pobox.com>
3824
3825         Throughout: purge global variables, introduce BusActivation,
3826         BusConnections, BusRegistry, etc. objects instead.
3827
3828         * bus/bus.h, bus/bus.c: introduce BusContext as a global
3829         message bus object
3830
3831         * test/Makefile.am (TEST_BINARIES): disable bus-test for now,
3832         going to redo this a bit differently I think
3833
3834 2003-03-12  Havoc Pennington  <hp@redhat.com>
3835
3836         Mega-patch that gets the message bus daemon initially handling
3837         out-of-memory. Work still needed. Also lots of random
3838         moving stuff to DBusError instead of ResultCode.
3839
3840         * dbus/dbus-list.c (_dbus_list_length_is_one): new function
3841
3842         * dbus/dbus-connection.c
3843         (dbus_connection_send_with_reply_and_block): use DBusError
3844
3845         * dbus/dbus-bus.c: adapt to API changes, make it use DBusError not
3846         DBusResultCode
3847
3848         * dbus/dbus-connection.c (dbus_connection_send): drop the result
3849         code here, as the only failure possible is OOM.
3850
3851         * bus/connection.c (bus_connection_disconnect):
3852         rename bus_connection_disconnected as it's a notification only
3853
3854         * bus/driver.c (bus_driver_handle_acquire_service): don't free
3855         "name" on get_args failure, should be done by get_args;
3856         don't disconnect client for bad args, just return an error.
3857         (bus_driver_handle_service_exists): ditto
3858
3859         * bus/services.c (bus_services_list): NULL-terminate returned array
3860
3861         * bus/driver.c (bus_driver_send_service_lost)
3862         (bus_driver_send_service_acquired): send messages from driver to a
3863         specific client to the client's unique name, not to the broadcast
3864         service.
3865
3866         * dbus/dbus-message.c (decode_header_data): reject messages that
3867         contain no name field
3868         (_dbus_message_get_client_serial): rename to
3869         dbus_message_get_serial and make public
3870         (_dbus_message_set_serial): rename from set_client_serial
3871         (_dbus_message_set_reply_serial): make public
3872         (_dbus_message_get_reply_serial): make public
3873
3874         * bus/connection.c (bus_connection_foreach): allow stopping
3875         iteration by returning FALSE from foreach function.
3876
3877         * dbus/dbus-connection.c (dbus_connection_send_preallocated)
3878         (dbus_connection_free_preallocated_send)
3879         (dbus_connection_preallocate_send): new API for sending a message
3880         without possibility of malloc failure.
3881         (dbus_connection_send_message): rename to just
3882         dbus_connection_send (and same for whole function family)
3883
3884         * dbus/dbus-errors.c (dbus_error_free): make this reinit the error
3885
3886         * dbus/dbus-sysdeps.c (_dbus_exit): new function
3887
3888         * bus/activation.c: handle/return errors
3889
3890         * dbus/dbus-errors.h: add more DBUS_ERROR #define
3891
3892         * dbus/dbus-sysdeps.c (_dbus_directory_open) (_dbus_file_get_contents)
3893         (_dbus_directory_get_next_file): use DBusError instead of DBusResultCode
3894         (_dbus_result_from_errno): move to this file
3895
3896 2003-03-10  Anders Carlsson  <andersca@codefactory.se>
3897
3898         * dbus/dbus-marshal.c:
3899         (_dbus_marshal_set_string):
3900         Take a length argument so we can marshal the correct string
3901         length.
3902
3903         (_dbus_marshal_dict), (_dbus_demarshal_dict),
3904         (_dbus_marshal_get_arg_end_pos), (_dbus_marshal_validate_arg),
3905         (_dbus_marshal_test):
3906         * dbus/dbus-marshal.h:
3907         Add support for marshalling and demarshalling dicts.
3908
3909         * dbus/dbus-message-builder.c: (_dbus_message_data_load):
3910         Add support for TYPE DICT.
3911
3912         * dbus/dbus-message.c: (set_string_field):
3913         Adjust header padding.
3914
3915         (dbus_message_append_args_valist), (dbus_message_append_dict),
3916         (dbus_message_get_args_valist), (dbus_message_iter_get_arg_type),
3917         (dbus_message_iter_get_dict), (_dbus_message_loader_return_buffer),
3918         (check_message_handling), (check_have_valid_message):
3919         * dbus/dbus-message.h:
3920         Add functions for setting and getting dicts.
3921
3922         * dbus/dbus-protocol.h:
3923         Add DBUS_TYPE_DICT.
3924
3925         * dbus/dbus.h:
3926         Add dbus-dict.h
3927
3928         * doc/dbus-specification.sgml:
3929         Add information about how dicts are marshalled.
3930
3931         * test/data/invalid-messages/dict-with-nil-value.message:
3932         * test/data/invalid-messages/too-short-dict.message:
3933         * test/data/valid-messages/dict-simple.message:
3934         * test/data/valid-messages/dict.message:
3935         Add sample messages containing dicts.
3936
3937 2003-03-08  Anders Carlsson  <andersca@codefactory.se>
3938
3939         * dbus/dbus-dict.h: Add DBUS_END_DECLS.
3940
3941 2003-03-07  Anders Carlsson  <andersca@codefactory.se>
3942
3943         * dbus/Makefile.am:
3944         * dbus/dbus-dict.c: (dbus_dict_entry_free), (dbus_dict_new),
3945         (dbus_dict_get_keys), (insert_entry), (dbus_dict_set_boolean),
3946         (dbus_dict_set_int32), (dbus_dict_set_uint32),
3947         (dbus_dict_set_double), (dbus_dict_set_string),
3948         (dbus_dict_set_boolean_array), (dbus_dict_set_int32_array),
3949         (dbus_dict_set_uint32_array), (dbus_dict_set_double_array),
3950         (dbus_dict_set_string_array), (_dbus_dict_test):
3951         * dbus/dbus-dict.h:
3952         Fix according to comments from Havoc.
3953
3954 2003-03-06  Michael Meeks  <michael@server.home>
3955
3956         * configure.in: if we don't have kde-config, disable have_qt.
3957
3958 2003-03-07  Anders Carlsson  <andersca@codefactory.se>
3959
3960         * dbus/Makefile.am:
3961         Add dbus-dict.[ch]
3962
3963         * dbus/dbus-dict.c: (dbus_dict_entry_free), (dbus_dict_new),
3964         (dbus_dict_ref), (dbus_dict_unref), (dbus_dict_contains),
3965         (dbus_dict_remove), (dbus_dict_get_value_type),
3966         (dbus_dict_get_keys), (dbus_dict_put_boolean),
3967         (dbus_dict_put_int32), (dbus_dict_put_uint32),
3968         (dbus_dict_put_double), (dbus_dict_put_string),
3969         (dbus_dict_put_boolean_array), (dbus_dict_put_int32_array),
3970         (dbus_dict_put_uint32_array), (dbus_dict_put_double_array),
3971         (dbus_dict_put_string_array), (dbus_dict_get_boolean),
3972         (dbus_dict_get_int32), (dbus_dict_get_uint32),
3973         (dbus_dict_get_double), (dbus_dict_get_string),
3974         (dbus_dict_get_boolean_array), (dbus_dict_get_int32_array),
3975         (dbus_dict_get_uint32_array), (dbus_dict_get_double_array),
3976         (dbus_dict_get_string_array), (_dbus_dict_test):
3977         * dbus/dbus-dict.h:
3978         Add DBusDict implementation
3979
3980         * dbus/dbus-test.c: (dbus_internal_do_not_use_run_tests):
3981         * dbus/dbus-test.h:
3982         Add _dbus_dict_test
3983
3984 2003-03-04  Havoc Pennington  <hp@pobox.com>
3985
3986         * test/data/auth/*: adapt to changes
3987
3988         * dbus/dbus-auth-script.c (_dbus_auth_script_run): add
3989         USERID_BASE64 and change USERNAME_BASE64 to put in username not
3990         userid
3991
3992         * dbus/dbus-keyring.c (_dbus_keyring_validate_context): prevent
3993         more stuff from being in a context name, to make the protocol
3994         simpler to deal with
3995
3996         * dbus/dbus-errors.c (dbus_error_has_name): new function
3997         (dbus_error_is_set): new function
3998
3999         * dbus/dbus-auth.c: replace DBUS_STUPID_TEST_MECH auth
4000         with DBUS_COOKIE_SHA1, implement DBUS_COOKIE_SHA1
4001
4002         * dbus/dbus-connection.c (dbus_connection_flush): also read
4003         messages during a flush operation
4004
4005         * dbus/Makefile.am: remove dbus-md5 since it isn't currently used.
4006
4007 2003-03-05  Anders Carlsson  <andersca@codefactory.se>
4008
4009         * configure.in: Check for gethostbyname on Solaris.
4010
4011         * dbus/dbus-transport.c: (_dbus_transport_open):
4012         Remove duplicate "tcp" entry.
4013
4014         * doc/dbus-specification.sgml:
4015         Clarify some things.
4016
4017 2003-03-05  Anders Carlsson  <andersca@codefactory.se>
4018
4019         * dbus/dbus-auth.c: (send_rejected), (process_test_subdir):
4020         * dbus/dbus-keyring.c: (_dbus_keyring_new_homedir),
4021         (_dbus_keyring_test):
4022         * dbus/dbus-md5.c: (_dbus_md5_compute):
4023         * dbus/dbus-sha.c: (_dbus_sha_compute):
4024         Plug memory leaks.
4025
4026 2003-03-05  Anders Carlsson  <andersca@codefactory.se>
4027
4028         * README: Add some things.
4029
4030 2003-03-04  Anders Carlsson  <andersca@codefactory.se>
4031
4032         * dbus/dbus-message.c (dbus_message_append_args_valist): Add a break;
4033         after case DBUS_TYPE_BOOELAN.
4034
4035 2003-03-02  Havoc Pennington  <hp@pobox.com>
4036
4037         * test/break-loader.c (randomly_set_extreme_ints): add test that
4038         sets really huge and small integers
4039
4040         * dbus/dbus-marshal.c (_dbus_marshal_validate_arg): add check
4041         that length of boolean array fits in the string, and that
4042         string has room for boolean value in single-bool case.
4043
4044         * dbus/dbus-message-builder.c (_dbus_message_data_load): add
4045         optional value to "ALIGN" command which is what to fill the
4046         alignment with.
4047
4048         * test/data/valid-messages/no-padding.message: add regression
4049         test for the message padding problem
4050
4051 2003-03-02  Havoc Pennington  <hp@pobox.com>
4052
4053         * dbus/dbus-message.c (decode_header_data): fix to always init
4054         message_padding, from Benjamin Dauvergne
4055
4056 2003-03-02  Havoc Pennington  <hp@pobox.com>
4057
4058         * configure.in: 0.5
4059
4060         * NEWS: Update.
4061
4062 2003-03-01  Joe Shaw  <joe@assbarn.com>
4063
4064         * configure.in: Check for "struct cmsgcred" and try to access its
4065         members for BSD-like unices.
4066
4067         * dbus/dbus-sysdeps.c (read_credentials_byte): Fold this back into
4068         _dbus_read_credentials_unix_socket().
4069         (_dbus_read_credentials_unix_socket): Use recvmsg() instead of
4070         read() for reading the credential byte off the unix socket.  Use
4071         struct cmsgcred on systems that support it.
4072
4073 2003-02-27  Alexander Larsson  <alexl@redhat.com>
4074
4075         * glib/Makefile.am:
4076         * configure.in:
4077         Make gthreads-2.0 dependency optional. Don't build thread test if
4078         its not found.
4079
4080 2003-02-27  Havoc Pennington  <hp@pobox.com>
4081
4082         * dbus/dbus-connection.c
4083         (dbus_connection_send_message_with_reply_and_block): fix doh!
4084         doh! doh! bug that resulted in never removing a reply from the
4085         queue, no wonder we called get_reply_serial so much ;-)
4086
4087         * dbus/dbus-message.c (struct DBusMessage): cache reply serial
4088         and client serial instead of demarshaling them every time
4089
4090 2003-02-27  Havoc Pennington  <hp@pobox.com>
4091
4092         * dbus/dbus-marshal.c (_dbus_demarshal_int32): rewrite to be much
4093         more inlined, using dbus-string-private.h, speeds things up
4094         substantially
4095
4096         * dbus/dbus-string.c (_dbus_string_free): apply align offset
4097         when freeing the string
4098         (_dbus_string_steal_data): fix for align offset
4099         (undo_alignment): new function
4100
4101 2003-02-26  Havoc Pennington  <hp@redhat.com>
4102
4103         All kinds of audit fixes from Owen, plus initial attempt to
4104         handle unaligned memory returned from malloc.
4105
4106         * dbus/dbus-string.c (_dbus_string_init): clamp max length to
4107         leave room for align_offset and nul byte
4108         (fixup_alignment): function to track an align_offset and
4109         ensure real->str is aligned
4110         (DBUS_GENERIC_STRING_PREAMBLE): len must be less than allocated,
4111         to allow a nul byte plus align offset
4112         (_dbus_string_lock): fix overflow issue
4113         (_dbus_string_init_const_len): add assertions on sanity of len,
4114         assign allocated to be ALLOCATION_PADDING larger than len
4115         (set_length): fixup the overflow handling
4116         (_dbus_string_get_data_len): fix overflow in assertion
4117         (open_gap): detect overflow in size of gap to be opened
4118         (_dbus_string_lengthen): add overflow check
4119         (_dbus_string_align_length): fix overflow with _DBUS_ALIGN_VALUE
4120         (_dbus_string_append): add overflow check
4121         (_dbus_string_append_unichar): overflow
4122         (_dbus_string_delete): fix overflow in assertion
4123         (_dbus_string_copy_len): overflow in assertion
4124         (_dbus_string_replace_len): overflows in assertions
4125         (_dbus_string_find): change to implement in terms of
4126         _dbus_string_find_to
4127         (_dbus_string_find_to): assorted fixage
4128         (_dbus_string_equal_c_str): assert c_str != NULL,
4129         fix logic so the function works
4130         (_dbus_string_ends_with_c_str): fix overflow thingy
4131         (_dbus_string_base64_encode): overflow fix
4132         (_dbus_string_validate_ascii): overflow
4133         (_dbus_string_validate_nul): overflow
4134
4135 2003-02-26  Havoc Pennington  <hp@redhat.com>
4136
4137         * dbus/dbus-marshal.c (_dbus_marshal_test): fix to work with DISABLE_ASSERTS
4138
4139 2003-02-26  Alexander Larsson  <alexl@redhat.com>
4140
4141         * configure.in:
4142         Set DBUS_GLIB_THREADS_LIBS for apps using gthread-2.0
4143
4144         * dbus/dbus-connection.c:
4145         * dbus/dbus-connection.h:
4146         Fix _dbus_connection_acquire_io_path and _dbus_connection_acquire_dispatch.
4147         Add dbus_connection_set_wakeup_main_function and use it when queueing
4148         incoming and outgoing messages.
4149
4150
4151         * dbus/dbus-dataslot.c:
4152         Threadsafe usage of DBusDataSlotAllocator
4153
4154         * dbus/dbus-message.c: (dbus_message_get_args_iter):
4155         dbus_new can fail.
4156
4157         * dbus/dbus-server-unix.c:
4158         Add todo comment
4159
4160         * glib/dbus-gmain.c:
4161         Implement the new wakeup functions for glib.
4162
4163         * glib/Makefile.am:
4164         * glib/test-thread-client.c:
4165         * glib/test-thread-server.c:
4166         * glib/test-thread.h:
4167         Initial cut at some thread test code. Not really done yet.
4168
4169 2003-02-26  Havoc Pennington  <hp@pobox.com>
4170
4171         * dbus/dbus-connection.c
4172         (dbus_connection_send_message_with_reply_and_block): fix crash
4173         where we ref'd the outgoing message instead of the returned reply
4174
4175         * dbus/dbus-transport-unix.c (do_authentication): check read watch
4176         at the end of this function, so if we didn't need to read for
4177         authentication, we reinstall it for receiving messages
4178
4179         * dbus/dbus-message.c (dbus_message_new_reply): allow replies to
4180         a NULL sender for peer-to-peer case
4181
4182         * dbus/dbus-transport-unix.c (check_read_watch): handle
4183         !authenticated case correctly
4184
4185         * glib/dbus-gmain.c: add support for DBusServer
4186
4187         * dbus/dbus-server.c: add data slot support
4188
4189         * glib/dbus-gmain.c (dbus_connection_setup_with_g_main): check
4190         return values and handle errors
4191
4192         * dbus/dbus-dataslot.c: factor out the data slot stuff from
4193         DBusConnection
4194
4195         * Doxyfile.in (INPUT): add glib subdir
4196
4197         * glib/dbus-gmain.c (dbus_connection_setup_with_g_main): rename
4198         setup_with_g_main instead of hookup_with_g_main; write docs
4199
4200 2003-02-24  Anders Carlsson  <andersca@codefactory.se>
4201
4202         * dbus/dbus-marshal.c: (_dbus_marshal_validate_arg):
4203         * dbus/dbus-message-builder.c: (_dbus_message_data_load):
4204         * dbus/dbus-message.c: (dbus_message_append_boolean),
4205         (dbus_message_append_boolean_array),
4206         (dbus_message_get_args_valist), (_dbus_message_test):
4207         * dbus/dbus-message.h:
4208         * doc/dbus-specification.sgml:
4209         Various fixes as pointed out by Havoc.
4210
4211         * test/data/invalid-messages/bad-boolean-array.message:
4212         * test/data/invalid-messages/bad-boolean.message:
4213         Add invalid boolean value test cases.
4214
4215 2003-02-24  Anders Carlsson  <andersca@codefactory.se>
4216
4217         * dbus/dbus-internals.c: (_dbus_type_to_string):
4218         * dbus/dbus-marshal.c: (_dbus_marshal_get_arg_end_pos),
4219         (_dbus_marshal_validate_arg):
4220         * dbus/dbus-message-builder.c: (_dbus_message_data_load):
4221         * dbus/dbus-message.c: (dbus_message_append_args_valist),
4222         (dbus_message_append_boolean), (dbus_message_append_boolean_array),
4223         (dbus_message_get_args_valist), (dbus_message_iter_get_boolean),
4224         (dbus_message_iter_get_int32), (dbus_message_iter_get_uint32),
4225         (dbus_message_iter_get_double),
4226         (dbus_message_iter_get_boolean_array), (message_iter_test):
4227         * dbus/dbus-message.h:
4228         * dbus/dbus-protocol.h:
4229         * doc/dbus-specification.sgml:
4230         * test/data/valid-messages/lots-of-arguments.message:
4231         Add support for boolean and boolean array types.
4232
4233 2003-02-23  Havoc Pennington  <hp@pobox.com>
4234
4235         * dbus/dbus-keyring.c: finish most of this implementation and
4236         simple unit test
4237
4238         * dbus/dbus-errors.c (dbus_set_error_const, dbus_set_error): make
4239         these barf if the error isn't cleared to NULL
4240
4241         * dbus/dbus-sysdeps.c (_dbus_delete_file): set error on failure
4242         (_dbus_create_directory): new function
4243
4244         * dbus/dbus-errors.c (dbus_set_error): fix warning
4245
4246         * dbus/dbus-string.c (_dbus_string_hex_encode): new function
4247         (_dbus_string_hex_decode): new function
4248         (test_hex_roundtrip): test code
4249
4250         * dbus/dbus-sha.c (_dbus_sha_compute): use dbus_string_hex_encode
4251
4252         * dbus/dbus-md5.c (_dbus_md5_compute): use dbus_string_hex_encode
4253
4254         * dbus/dbus-sysdeps.c (_dbus_string_save_to_file): make this use
4255         the save-to-temp/rename trick to atomically write the new file
4256         (_dbus_string_parse_uint): new function
4257
4258 2003-02-22  Havoc Pennington  <hp@pobox.com>
4259
4260         * test/Makefile.am (dist-hook): fix dist for test/data/sha-1
4261
4262 2003-02-22  Havoc Pennington  <hp@pobox.com>
4263
4264         * dbus/dbus-message.c (dbus_message_iter_get_string_array):
4265         (dbus_message_iter_get_byte_array): Fix up doxygen warnings
4266
4267         * dbus/dbus-sha.c: add implementation of SHA-1 algorithm
4268
4269         * dbus/test/data/sha-1: add US government test suite for SHA-1
4270
4271 2003-02-21  Anders Carlsson  <andersca@codefactory.se>
4272
4273         * dbus/dbus-marshal.c: (_dbus_demarshal_string_array):
4274         Make string arrays NULL-terminated.
4275
4276         * dbus/dbus-memory.c: (dbus_free_string_array):
4277         * dbus/dbus-memory.h:
4278         New function for freeing NULL-terminated string arrays.
4279
4280         * dbus/dbus-message-builder.c: (append_quoted_string),
4281         (_dbus_message_data_load):
4282         Add support for array types.
4283
4284         * dbus/dbus-message.c: (check_message_handling):
4285         Add more types as test cases.
4286
4287         * dbus/dbus-sysdeps.c: (_dbus_string_parse_int),
4288         (_dbus_string_parse_double):
4289         Add the start offset to the end offset.
4290
4291         * test/data/valid-messages/lots-of-arguments.message:
4292         New test message with lots of arguments.
4293
4294 2003-02-21  Anders Carlsson  <andersca@codefactory.se>
4295
4296         * dbus/dbus-message.c: (dbus_message_append_nil),
4297         (dbus_message_append_int32), (dbus_message_append_uint32),
4298         (dbus_message_append_double), (dbus_message_append_string),
4299         (dbus_message_append_int32_array),
4300         (dbus_message_append_uint32_array),
4301         (dbus_message_append_double_array),
4302         (dbus_message_append_byte_array),
4303         (dbus_message_append_string_array):
4304         Fix all out-of-memory handling in these functions.
4305
4306 2003-02-21  Anders Carlsson  <andersca@codefactory.se>
4307
4308         * dbus/dbus-message.c: (dbus_message_append_nil):
4309         Fix a silly.
4310
4311 2003-02-21  Anders Carlsson  <andersca@codefactory.se>
4312
4313         * dbus/dbus-message.c: (dbus_message_append_args_valist),
4314         (dbus_message_append_nil), (dbus_message_append_int32_array),
4315         (dbus_message_append_uint32_array),
4316         (dbus_message_append_double_array),
4317         (dbus_message_append_byte_array),
4318         (dbus_message_append_string_array), (dbus_message_get_args_valist),
4319         (dbus_message_iter_get_int32_array),
4320         (dbus_message_iter_get_uint32_array),
4321         (dbus_message_iter_get_double_array),
4322         (dbus_message_iter_get_byte_array),
4323         (dbus_message_iter_get_string_array):
4324
4325         * dbus/dbus-message.h:
4326         Add functions for appending and getting arrays.
4327
4328 2003-02-21  Anders Carlsson  <andersca@codefactory.se>
4329
4330         * dbus/dbus-mempool.c (_dbus_mem_pool_new): Make the
4331         element size at least 8 bytes, fixes mempool tests on
4332         64-bit machines.
4333
4334 2003-02-20  Alexander Larsson  <alexl@redhat.com>
4335
4336         * dbus/dbus-transport-unix.c (unix_do_iteration):
4337         Unlock the connection mutex during a blocking select call.
4338         Add todo about how we need a way to wake up the select.
4339
4340         * dbus/dbus-connection-internal.h:
4341         * dbus/dbus-connection.c:
4342         Add _dbus_connection_lock and _dbus_connection_unlock.
4343
4344 2003-02-19  Havoc Pennington  <hp@pobox.com>
4345
4346         * Doxyfile.in (PREDEFINED): put DOXYGEN_SHOULD_SKIP_THIS in
4347         Doxyfile.in, not Doxyfile
4348
4349         * dbus/dbus-keyring.c: do some hacking on this
4350
4351         * dbus/dbus-sysdeps.c (_dbus_delete_file): new
4352
4353         * dbus/dbus-errors.c (dbus_set_error_const): do not call
4354         dbus_error_init
4355         (dbus_set_error): remove dbus_error_init, check for message ==
4356         NULL *before* we sprintf into it, and add @todo about including
4357         system headers in this file
4358
4359         * dbus/dbus-sysdeps.c (_dbus_create_file_exclusively): new
4360
4361         * dbus/dbus-errors.h (DBUS_ERROR_FAILED): add
4362
4363         * dbus/dbus-sysdeps.c (get_user_info): break this function out to
4364         get various bits of user information based on either username
4365         or user ID
4366         (_dbus_homedir_from_username): new function
4367
4368 2003-02-19  Anders Carlsson  <andersca@codefactory.se>
4369
4370         * configure.in:
4371         Add check for nonposix getpwnam_r
4372
4373         * dbus/dbus-mempool.c: (_dbus_mem_pool_new):
4374         Align the pool element size to a sizeof (void *) boundary.
4375
4376         * dbus/dbus-sysdeps.c: (_dbus_setenv), (_dbus_connect_unix_socket),
4377         (_dbus_listen_unix_socket), (_dbus_credentials_from_username):
4378         General Solaris fixes.
4379
4380         * test/data/valid-messages/simplest-manual.message:
4381         Explicitly state that we want little-endian packing.
4382
4383 2003-02-19  Mikael Hallendal  <micke@codefactory.se>
4384
4385         * dbus/dbus-server.c (dbus_server_listen): Support tcp: addresses.
4386
4387         * dbus/dbus-transport-unix.c (_dbus_transport_new_for_tcp_socket):
4388         Added to create a transport connecting using a tcp/ip socket.
4389
4390         * dbus/dbus-sysdeps.c (_dbus_connect_tcp_socket): Added to connect
4391         to a tcp socket at given host and port.
4392         (_dbus_listen_tcp_socket): added to listen on tcp socket for given
4393         hostname and port.
4394
4395         * dbus/dbus-server.c (dbus_server_listen): Support tcp: addresses.
4396
4397         * dbus/dbus-server-unix.c (_dbus_server_new_for_tcp_socket):
4398         Added to create a server listening on a TCP/IP socket.
4399
4400 2003-02-19  Havoc Pennington  <hp@pobox.com>
4401
4402         Throughout: mop up all the Doxygen warnings and undocumented
4403         stuff.
4404
4405         * dbus/dbus-sysdeps.c (do_exec): do not use execvp, we don't want
4406         to search any paths.
4407
4408         * dbus/dbus-threads.c: move global mutex initializers to
4409         dbus-internals.h, multiple prototypes was confusing doxygen
4410         besides being kind of ugly
4411
4412         * Doxyfile (PREDEFINED): have Doxygen define
4413         DOXYGEN_SHOULD_SKIP_THIS so we can exclude things from
4414         docs with #ifndef DOXYGEN_SHOULD_SKIP_THIS
4415         (do not abuse the feature! it's for stuff like the autogenerated
4416         macros in dbus-md5.c, not just for things you don't feel like
4417         documenting...)
4418
4419 2003-02-18  Havoc Pennington  <hp@pobox.com>
4420
4421         * dbus/dbus-string.c (_dbus_string_zero): new function
4422
4423         * dbus/dbus-md5.c: include MD5 implementation by L. Peter Deutsch,
4424         wrap it in some dbus-friendly API
4425
4426         * dbus/dbus-types.h: add 16-bit types
4427
4428 2003-02-18  Joe Shaw  <joe@assbarn.com>
4429
4430         * dbus/dbus-auth.c (handle_server_data_stupid_test_mech): Just get
4431         credentials from our currently running process.
4432         (get_word): Fix a buglet where we were copying the entire length
4433         instead of relative to our position.
4434
4435         * dbus/dbus-hash.c (_dbus_hash_test): Don't try to allocate the
4436         keys on the stack... it's 640k of data.
4437
4438         * dbus/dbus-sysdeps.c (_dbus_read_credentials_unix_socket): Always
4439         read the credentials byte off the socket, even if we don't have
4440         SO_PEERCRED.
4441         (_dbus_poll): Implement poll() using select() for systems which
4442         don't have it.
4443
4444         * glib/test-dbus-glib.c (main): Print out an error if no
4445         parameters are given.
4446
4447         * test/data/auth/fallback.auth-script: Added.  Tests that a client
4448         can fallback to a secondary auth mechanism if the first fails.
4449
4450 2003-02-18  Havoc Pennington  <hp@pobox.com>
4451
4452         * AUTHORS: add Alex
4453
4454 2003-02-17  Havoc Pennington  <hp@pobox.com>
4455
4456         * doc/dbus-specification.sgml: lots of cosmetic
4457         cleanups/rearrangement, add assorted FIXME, change DBUS_ADDRESS
4458         env variable to DBUS_BUS_ADDRESS, s/client/application/,
4459         s/server/bus/ (except in authentication section). Add a section
4460         "Message Bus Message Routing"
4461
4462 2003-02-17  Anders Carlsson  <andersca@codefactory.se.>
4463
4464         Release 0.4
4465
4466         * NEWS: Update
4467
4468 2003-02-17  Anders Carlsson  <andersca@codefactory.se>
4469
4470         * doc/dbus-specification.sgml:
4471         Specification updates.
4472
4473 2003-02-17  Anders Carlsson  <andersca@codefactory.se>
4474
4475         * bus/activation.c: (bus_activation_init), (child_setup),
4476         (bus_activation_activate_service):
4477         * bus/activation.h:
4478         * bus/main.c: (main):
4479         Set DBUS_ADDRESS environment variable.
4480
4481         * dbus/dbus-errors.c: (dbus_set_error):
4482         Don't use va_copy since that's a C99 feature.
4483
4484         * dbus/dbus-sysdeps.c: (_dbus_setenv), (do_exec),
4485         (_dbus_spawn_async):
4486         * dbus/dbus-sysdeps.h:
4487         Add child_setup_func to _dbus_spawn_async.
4488
4489         * doc/dbus-specification.sgml:
4490         Update specification.
4491
4492         * test/spawn-test.c: (setup_func), (main):
4493         Fix test.
4494
4495 2003-02-17  Alexander Larsson  <alexl@redhat.com>
4496
4497         * dbus/dbus-connection.c (_dbus_connection_handler_destroyed_locked):
4498         Added todo.
4499
4500 2003-02-17  Anders Carlsson  <andersca@codefactory.se>
4501
4502         * doc/.cvsignore:
4503         * doc/Makefile.am:
4504         * doc/dbus-test-plan.sgml:
4505         Add test plan document.
4506
4507         * test/Makefile.am:
4508         Fix distcheck.
4509
4510 2003-02-17  Anders Carlsson  <andersca@codefactory.se>
4511
4512         * dbus/dbus-message.c: (decode_header_data),
4513         (_dbus_message_loader_return_buffer):
4514         Set the header padding amount when loading a message.
4515
4516 2003-02-16  Anders Carlsson  <andersca@codefactory.se>
4517
4518         * bus/dispatch.c: (send_one_message):
4519         Only send broadcast messages to registered connections.
4520
4521         * dbus/dbus-message.c: (dbus_message_name_is):
4522         * dbus/dbus-message.h:
4523         New convenience function.
4524
4525         * dbus/dbus-transport-debug.c: (do_reading):
4526         Only dispatch one message per run.
4527
4528         * test/Makefile.am:
4529         * test/bus-test.c: (new_connection_callback), (die),
4530         (test_hello_client1_handler), (test_hello_client2_handler),
4531         (test_hello_replies), (main):
4532
4533         * test/bus-test-loop.[ch]:
4534         Add these.
4535
4536 2003-02-16  Havoc Pennington  <hp@pobox.com>
4537
4538         * dbus/dbus-connection.c (dbus_connection_dispatch_message): fix
4539         backward conditional
4540
4541 2003-02-16  Alexander Larsson  <alexl@redhat.com>
4542
4543         * dbus/dbus-connection.c:
4544         Implement sent_message_with_reply. (with_reply_and block is still
4545         busted).
4546         Made dispatch_message not lose message if OOM.
4547
4548         * dbus/dbus-errors.h:
4549         Add NoReply error (for reply timeouts).
4550
4551 2003-02-16  Alexander Larsson  <alexl@redhat.com>
4552
4553         * dbus/dbus-hash.c (_dbus_hash_table_unref):
4554         Actually free keys and values when destroying hashtable.
4555
4556 2003-02-16  Anders Carlsson  <andersca@codefactory.se>
4557
4558         * dbus/dbus-auth.c: (client_try_next_mechanism):
4559         Plug a leak.
4560
4561         * dbus/dbus-threads.c: (dbus_condvar_wait_timeout):
4562         Return TRUE if there's no thread implementation around.
4563
4564         * glib/dbus-gmain.c: (free_source),
4565         (dbus_connection_hookup_with_g_main):
4566         Make sure to remove the GSource when the connection is finalized.
4567
4568 2003-02-16  Anders Carlsson  <andersca@codefactory.se>
4569
4570         * bus/dispatch.c: (bus_dispatch_message_handler):
4571         * dbus/dbus-errors.h:
4572         Return an error if someone tries to send a message to a service
4573         that doesn't exist.
4574
4575 2003-02-16  Anders Carlsson  <andersca@codefactory.se>
4576
4577         * bus/activation.c: (load_directory), (bus_activation_init),
4578         (bus_activation_activate_service):
4579         * bus/activation.h:
4580         * bus/driver.c:
4581         (bus_driver_handle_activate_service), (bus_driver_handle_message):
4582         More work on the activation handling.
4583
4584         * dbus/dbus-errors.h:
4585         Add some error messages
4586
4587         * dbus/dbus-message.c: (dbus_message_new_error_reply):
4588         * dbus/dbus-message.h:
4589         New function that creates an error message.
4590
4591         * dbus/dbus-protocol.h:
4592         Add ACTIVATE_SERVER message.
4593
4594         * dbus/dbus-server-unix.c: (unix_handle_watch),
4595         (_dbus_server_new_for_domain_socket):
4596         Call _dbus_fd_set_close_on_exec.
4597
4598         * dbus/dbus-sysdeps.c: (make_pipe), (do_exec),
4599         (_dbus_spawn_async), (_dbus_disable_sigpipe),
4600         (_dbus_fd_set_close_on_exec):
4601         * dbus/dbus-sysdeps.h:
4602         Add _dbus_fd_set_close_on exec function. Also add function that checks
4603         that all open fds are set to close-on-exec and warns otherwise.
4604
4605         * dbus/dbus-transport-unix.c:
4606         (_dbus_transport_new_for_domain_socket):
4607         Call _dbus_fd_set_close_on_exec.
4608
4609 2003-02-16  Havoc Pennington  <hp@pobox.com>
4610
4611         * dbus/dbus-connection.c (dbus_connection_set_change_sigpipe):
4612         allow people to avoid setting SIGPIPE to SIG_IGN
4613         (_dbus_connection_new_for_transport): disable SIGPIPE unless
4614         we've been asked not to
4615
4616 2003-02-15  Anders Carlsson  <andersca@codefactory.se>
4617
4618         * dbus/dbus-list.c: (_dbus_list_append_link),
4619         (_dbus_list_prepend_link):
4620         * dbus/dbus-memory.c: (dbus_malloc), (dbus_malloc0),
4621         (dbus_realloc):
4622         Warning fixes.
4623
4624 2003-02-15  Anders Carlsson  <andersca@codefactory.se>
4625
4626         * bus/Makefile.am:
4627         * bus/activation.c: (bus_activation_entry_free),
4628         (add_desktop_file_entry), (load_directory), (bus_activation_init):
4629         * bus/activation.h:
4630         * bus/main.c: (main):
4631         Add simple activation support, doesn't work yet though.
4632
4633 2003-02-15   Zack Rusin  <zack@kde.org>
4634
4635         * qt/dbus-qthread.cpp:  small casting fix
4636
4637 2003-02-15  Anders Carlsson  <andersca@codefactory.se>
4638
4639         * dbus/dbus-errors.c: (dbus_set_error):
4640         * dbus/dbus-errors.h:
4641         Add a few errors and make dbus_set_error void.
4642
4643         * dbus/dbus-sysdeps.c:
4644         (_dbus_errno_to_string), (close_and_invalidate), (make_pipe),
4645         (write_err_and_exit), (read_ints), (do_exec), (_dbus_spawn_async):
4646         * dbus/dbus-sysdeps.h:
4647         Add _dbus_spawn_async.
4648
4649         * test/spawn-test.c: (main):
4650         Test for _dbus_spawn_async.
4651
4652 2003-02-15  Anders Carlsson  <andersca@codefactory.se>
4653
4654         * dbus/dbus-internals.h:
4655         Fix build without tests.
4656
4657         * dbus/dbus-list.c: (alloc_link):
4658         Fix a segfault when a malloc fails.
4659
4660         * dbus/dbus-memory.c: (initialize_malloc_debug), (dbus_malloc),
4661         (dbus_malloc0), (dbus_realloc):
4662         Add support for malloc debugging.
4663
4664 2003-02-15  Alexander Larsson  <alexl@redhat.com>
4665
4666         * dbus/dbus-threads.c:
4667         * dbus/dbus-threads.h:
4668         Add condvars. Remove static mutext from API.
4669         Implement static mutexes by initializing them from threads_init.
4670
4671         * glib/dbus-gthread.c:
4672         * qt/dbus-qthread.cpp:
4673         Update with the thread api changes.
4674
4675
4676         * dbus/dbus-list.c:
4677         * dbus/dbus-list.h:
4678         Turn StaticMutex into normal mutex + init function.
4679         Export new functions _dbus_list_alloc_link, _dbus_list_free_link,
4680         _dbus_list_append_link, _dbus_list_prepend_link
4681
4682
4683         * dbus/dbus-sysdeps.c:
4684         * dbus/dbus-sysdeps.h:
4685         New type dbus_atomic_t, and new functions _dbus_atomic_inc,
4686         _dbus_atomic_dec. Only slow fallback implementation at the moment.
4687
4688         * dbus/dbus-protocol.h:
4689         Add DBUS_MESSAGE_LOCAL_DISCONNECT define
4690
4691         * dbus/dbus-message.c:
4692         Make ref/unref atomic.
4693         Fix some docs.
4694
4695         * dbus/dbus-connection-internal.h:
4696         * dbus/dbus-connection.c:
4697         * dbus/dbus-connection.h:
4698         Make threadsafe.
4699         Change _peek to _borrow,_return & _steal_borrowed.
4700         Change disconnect callback to event.
4701         Make dbus_connection_dispatch_messages reentrant.
4702
4703         * dbus/dbus-transport.c:
4704         Don't ref the connection on calls to the transport
4705         implementation.
4706
4707         * dbus/dbus-message-handler.c:
4708         Make threadsafe.
4709
4710         * glib/dbus-gmain.c:
4711         Don't use peek_message anymore
4712
4713         * test/Makefile.am:
4714         * test/debug-thread.c:
4715         * test/debug-thread.h:
4716         Simple thread implementation that asserts() on deadlocks in
4717         single-threaded code.
4718
4719         * test/bus-test.c:
4720         (main) Call debug_threads_init.
4721
4722         * test/watch.c:
4723         Use disconnect message instead of disconnect callback.
4724
4725         * bus/connection.c:
4726         * bus/connection.h:
4727         Don't call dbus_connection_set_disconnect_function. Instead export
4728         bus_connection_disconnect.
4729
4730         * bus/dispatch.c:
4731         Call bus_connection_disconnect when we get a disconnected message.
4732
4733 2003-02-15  Havoc Pennington  <hp@pobox.com>
4734
4735         * dbus/dbus-message.c (dbus_message_new): fool around with the
4736         docs
4737
4738 2003-02-14  Havoc Pennington  <hp@pobox.com>
4739
4740         * dbus/dbus-mempool.c: fail if the debug functions so indicate
4741
4742         * dbus/dbus-memory.c: fail if the debug functions indicate we
4743         should
4744
4745         * dbus/dbus-internals.c (_dbus_set_fail_alloc_counter)
4746         (_dbus_decrement_fail_alloc_counter): debug functions to
4747         simulate memory allocation failures
4748
4749 2003-02-14  Havoc Pennington  <hp@pobox.com>
4750
4751         * dbus/dbus-errors.h (struct DBusError): add a word of padding
4752         to DBusError
4753
4754 2003-02-13  Anders Carlsson  <andersca@codefactory.se>
4755
4756         * bus/driver.c: (bus_driver_handle_hello):
4757         * bus/driver.h:
4758         * bus/services.c: (bus_service_lookup):
4759         Reorder message sending so we get a more sane order.
4760
4761         * test/bus-test.c: (message_handler):
4762         Fix tyop.
4763
4764 2003-02-13  Anders Carlsson  <andersca@codefactory.se>
4765
4766         * bus/driver.c: (bus_driver_send_service_deleted),
4767         (bus_driver_send_service_created), (bus_driver_send_service_lost),
4768         (bus_driver_send_service_acquired), (bus_driver_handle_hello),
4769         (bus_driver_send_welcome_message),
4770         (bus_driver_handle_list_services),
4771         (bus_driver_handle_acquire_service),
4772         (bus_driver_handle_service_exists):
4773         * dbus/dbus-bus.c: (dbus_bus_register_client),
4774         (dbus_bus_acquire_service), (dbus_bus_service_exists):
4775         * dbus/dbus-errors.c: (dbus_result_to_string):
4776         * dbus/dbus-errors.h:
4777         * dbus/dbus-message.c: (dbus_message_append_args),
4778         (dbus_message_append_args_valist), (dbus_message_get_args),
4779         (dbus_message_get_args_valist), (dbus_message_get_args_iter),
4780         (dbus_message_iter_get_arg_type), (dbus_message_iter_get_string),
4781         (dbus_message_iter_get_byte_array),
4782         (dbus_message_iter_get_string_array), (message_iter_test),
4783         (check_message_handling), (_dbus_message_test):
4784         * dbus/dbus-message.h:
4785         * test/bus-test.c: (main):
4786         Change fields to arguments in messages, so that they won't be
4787         confused with header fields.
4788
4789         * glib/test-dbus-glib.c: (main):
4790         Remove append_fields from hello message.
4791
4792 2003-02-13  Anders Carlsson  <andersca@codefactory.se>
4793
4794         * dbus/dbus-errors.c:
4795         * dbus/dbus-message.c:
4796         * dbus/dbus-string.c:
4797         Documentation fixes.
4798
4799 2003-02-13  Anders Carlsson  <andersca@codefactory.se>
4800
4801         * glib/dbus-gmain.c: (timeout_handler), (add_timeout),
4802         (remove_timeout):
4803         Implement support for timeouts in dbus-glib.
4804
4805 2003-02-13  Anders Carlsson  <andersca@codefactory.se>
4806
4807         * dbus/dbus-message-builder.c: (_dbus_message_data_load):
4808         * dbus/dbus-message.c: (process_test_subdir):
4809         * test/break-loader.c: (find_breaks_based_on):
4810         Plug some memory leaks.
4811
4812 2003-02-13  Richard Hult  <rhult@codefactory.se>
4813
4814         * bus/main.c: Fix build.
4815
4816         * dbus/dbus-errors.h:
4817         * dbus/dbus-errors.c: Fix copyright for Anders.
4818
4819 2003-02-13  Anders Carlsson  <andersca@codefactory.se>
4820
4821         * bus/Makefile.am:
4822         Add utils.[ch]
4823
4824         * bus/connection.c: (bus_connection_foreach):
4825         Fix a warning.
4826
4827         * bus/desktop-file.c: (grow_lines_in_section), (grow_sections),
4828         (unescape_string), (new_section), (parse_section_start),
4829         (parse_key_value), (report_error), (bus_desktop_file_load),
4830         (bus_desktop_file_get_string):
4831         * bus/desktop-file.h:
4832         Use DBusError for error reporting.
4833
4834         * bus/dispatch.c: (send_one_message),
4835         (bus_dispatch_message_handler):
4836         * bus/driver.c: (bus_driver_send_service_deleted),
4837         (bus_driver_send_service_created), (bus_driver_send_service_lost),
4838         (bus_driver_send_service_acquired), (bus_driver_handle_hello),
4839         (bus_driver_send_welcome_message),
4840         (bus_driver_handle_list_services),
4841         (bus_driver_handle_acquire_service),
4842         (bus_driver_handle_service_exists):
4843         * bus/loop.c: (bus_loop_run):
4844         * bus/main.c:
4845         Use BUS_HANDLE_OOM instead of _DBUS_HANDLE_OOM.
4846
4847         * bus/utils.c: (bus_wait_for_memory):
4848         * bus/utils.h:
4849         New files with general utility functions.
4850
4851         * dbus/dbus-internals.h:
4852         Remove _DBUS_HANDLE_OOM.
4853
4854 2003-02-13  Anders Carlsson  <andersca@codefactory.se>
4855
4856         * dbus/dbus-errors.c: (dbus_result_to_string), (dbus_error_init),
4857         (dbus_error_free), (dbus_set_error_const), (dbus_set_error):
4858         * dbus/dbus-errors.h:
4859         Add DBusError structure.
4860
4861 2003-02-13  Anders Carlsson  <andersca@codefactory.se>
4862
4863         * test/data/valid-messages/standard-acquire-service.message:
4864         * test/data/valid-messages/standard-hello.message:
4865         * test/data/valid-messages/standard-list-services.message:
4866         * test/data/valid-messages/standard-service-exists.message:
4867         Add some standard messages.
4868
4869 2003-02-13  Anders Carlsson  <andersca@codefactory.se>
4870
4871         * bus/driver.c: (bus_driver_send_welcome_message),
4872         (bus_driver_handle_list_services),
4873         (bus_driver_handle_acquire_service),
4874         (bus_driver_handle_service_exists), (bus_driver_handle_message):
4875         Update for API changes in libdbus.
4876
4877         * dbus/dbus-message.c: (dbus_message_new_reply):
4878         * dbus/dbus-message.h:
4879         Remove the name argument. The spec states that replies shouldn't
4880         have a name.
4881
4882 2003-02-13  Anders Carlsson  <andersca@codefactory.se>
4883
4884         * bus/desktop-file.c: (parse_section_start), (parse_key_value),
4885         (report_error), (bus_desktop_file_load), (lookup_section),
4886         (lookup_line), (bus_desktop_file_get_raw),
4887         (bus_desktop_file_get_string):
4888         * bus/desktop-file.h:
4889         Some fixes, and new functions for getting a key value from a section.
4890
4891 2003-02-13  Havoc Pennington  <hp@pobox.com>
4892
4893         * test/data/auth/fail-after-n-attempts.auth-script: new test
4894
4895         * dbus/dbus-auth.c (send_rejected): shutdown_mech() when we
4896         reject the client.
4897
4898 2003-02-13  Havoc Pennington  <hp@pobox.com>
4899
4900         * dbus/dbus-auth.c (handle_server_data_external_mech): args to
4901         dbus_credentials_match were backward
4902
4903         * dbus/dbus-auth-script.c (_dbus_auth_script_run): support
4904         NO_CREDENTIALS and ROOT_CREDENTIALS
4905
4906         * dbus/dbus-auth.c (_dbus_auth_do_work): move get_state() routine
4907         into here. Never process more commands after we've reached an
4908         end state; store further data as unused bytes.
4909
4910         * test/data/auth/*: add more auth tests
4911
4912         * dbus/dbus-auth-script.c (_dbus_auth_script_run): support EXPECT
4913         command to match exact string and EXPECT_UNUSED to match unused
4914         bytes
4915
4916         * test/Makefile.am (dist-hook): fix to dist all the test stuff
4917
4918 2003-02-12  Havoc Pennington  <hp@pobox.com>
4919
4920         * dbus/dbus-string.c (_dbus_string_pop_line): fix to also strip
4921         \r off of popped lines
4922
4923         * dbus/dbus-auth.c (_dbus_auth_test): write code to run auth
4924         scripts
4925
4926         * dbus/dbus-auth-script.c (_dbus_auth_script_run): when doing a
4927         SEND, append \r\n
4928
4929 2003-02-12  Havoc Pennington  <hp@pobox.com>
4930
4931         * dbus/Makefile.am: remove break-loader from the build, since it
4932         moved.
4933
4934         * configure.in: add --enable-gcov to turn on coverage profiling
4935         flags and disable optimization
4936
4937 2003-02-10  Havoc Pennington  <hp@pobox.com>
4938
4939         * dbus/dbus-auth-script.c, dbus/dbus-auth-script.h: sync
4940         initial cut at test framework for DBusAuth from laptop.
4941         Doesn't quite work yet but it compiles and I need to get
4942         it off the 266mhz laptop. ;-)
4943
4944         * dbus/dbus-server-debug.c (_dbus_server_debug_accept_transport):
4945         fix a memleak in error case
4946
4947 2003-02-12  Anders Carlsson  <andersca@codefactory.se>
4948
4949         * bus/Makefile.am:
4950         * bus/desktop-file.c:
4951         * bus/desktop-file.h:
4952         Add a desktop file parser.
4953
4954 2003-02-11  Zack Rusin  <zack@kde.org>
4955
4956         * qt/message.[h|cpp]: sample implementation
4957         of the KDE wrapper for DBusMessage
4958
4959 2003-02-09  Zack Rusin  <zack@kde.org>
4960
4961         * test/bus-test.c: make_it_compile
4962         * doc/dbus-specification.sgml: minimal semantic fix
4963
4964 2003-02-06  Anders Carlsson  <andersca@codefactory.se>
4965
4966         Release 0.3
4967
4968         * NEWS: Update
4969
4970 2003-02-06  Anders Carlsson  <andersca@codefactory.se>
4971
4972         * dbus/Makefile.am:
4973         * dbus/dbus-break-loader.c:
4974         * test/Makefile.am:
4975         * test/break-loader.c:
4976         Move dbus-break-loader to test/ and rename it to break-loader.
4977
4978 2003-02-02  Havoc Pennington  <hp@pobox.com>
4979
4980         * dbus/dbus-keyring.c, dbus/dbus-keyring.h: template files
4981         for code to manage cookies in your home directory
4982
4983         * dbus/dbus-sysdeps.c (_dbus_generate_random_bytes): new function
4984
4985         * dbus/dbus-auth.c (get_state): impose a maximum number of tries
4986         to authenticate, then disconnect the client.
4987
4988 2003-02-03  Alexander Larsson  <alexl@redhat.com>
4989
4990         * dbus/dbus-message.c (dbus_message_append_fields):
4991         Correct docs.
4992
4993 2003-02-02  Anders Carlsson  <andersca@codefactory.se>
4994
4995         * doc/dbus-specification.sgml:
4996         Update address format section.
4997
4998 2003-02-02  Anders Carlsson  <andersca@codefactory.se>
4999
5000         * test/Makefile.am:
5001         * test/bus-test.c: (get_time), (add_timeout), (remove_timeout),
5002         (message_handler), (new_connection_callback), (loop_quit),
5003         (loop_run), (main):
5004         Add bus test.
5005
5006 2003-02-02  Anders Carlsson  <andersca@codefactory.se>
5007
5008         * bus/driver.c: (bus_driver_handle_service_exists):
5009         Simplify the code a bit.
5010
5011         * dbus/dbus-bus.c: (dbus_bus_service_exists):
5012         Fix a silly.
5013
5014 2003-02-02  Anders Carlsson  <andersca@codefactory.se>
5015
5016         * bus/Makefile.am:
5017         Add libdbus-daemon.la and link to it.
5018
5019 2003-02-01  James Willcox  <jwillcox@gnome.org>
5020
5021         * bus/driver.c: (bus_driver_handle_own_service):
5022         Actually include the service reply code in the message.
5023
5024 2003-02-02  Anders Carlsson  <andersca@codefactory.se>
5025
5026         * bus/driver.c: (bus_driver_handle_service_exists):
5027         Don't unref the incoming message.
5028
5029 2003-02-02  Anders Carlsson  <andersca@codefactory.se>
5030
5031         * dbus/dbus.h: Add dbus-address.h and dbus-bus.h
5032
5033 2003-02-02  Anders Carlsson  <andersca@codefactory.se>
5034
5035         * dbus/dbus-server.c: (dbus_server_listen):
5036         * dbus/dbus-transport.c: (_dbus_transport_open):
5037         ifdef out the calls to the debug transport and server.
5038
5039 2003-02-02  Alexander Larsson  <alexl@redhat.com>
5040
5041         * dbus/dbus-watch.c (dbus_watch_get_flags):
5042         Add note in the docs that ERROR or HANGUP won't be returned
5043         and are assumed always on.
5044
5045         * glib/dbus-gmain.c (add_watch):
5046         Always add IO_ERR | IO_HUP
5047
5048         * dbus/dbus-message.h:
5049         Add semicolon after dbus_message_iter_get_string_array().
5050         Makes qt code build again
5051
5052 2003-02-01  Anders Carlsson  <andersca@codefactory.se>
5053
5054         * bus/driver.c: (create_unique_client_name),
5055         (bus_driver_handle_hello):
5056         Don't take a name, just use a numeric id to identify
5057         each client.
5058
5059         * dbus/Makefile.am:
5060         * dbus/dbus-bus.c: (dbus_bus_register_client),
5061         (dbus_bus_acquire_service), (dbus_bus_service_exists):
5062         * dbus/dbus-bus.h:
5063         Add new convenience functions for communicating with the bus.
5064
5065         * dbus/dbus-message.h:
5066
5067         * dbus/dbus-protocol.h:
5068         Fix a typo.
5069
5070 2003-02-01  Alexander Larsson  <alexl@redhat.com>
5071
5072         * dbus/dbus-message.c (dbus_message_append_fields):
5073         Add some more doc comments.
5074
5075 2003-02-01  Havoc Pennington  <hp@pobox.com>
5076
5077         * dbus/dbus-break-loader.c (randomly_modify_length): change
5078         a 4-byte value in the message as if it were a length
5079
5080         * dbus/dbus-sysdeps.c (_dbus_string_save_to_file): don't set
5081         execute bit on saved files
5082
5083 2003-02-01  Havoc Pennington  <hp@pobox.com>
5084
5085         * dbus/dbus-break-loader.c (main): new program to find messages
5086         that break the loader.
5087
5088         * dbus/dbus-sysdeps.c (_dbus_string_append_uint): new function
5089         * dbus/dbus-sysdeps.c (_dbus_string_save_to_file): new function
5090
5091         * dbus/dbus-string.c (_dbus_string_set_byte): new
5092
5093 2003-01-31  Havoc Pennington  <hp@pobox.com>
5094
5095         * dbus/dbus-message.c: refactor the test code to be more general,
5096         in preparation for writing a "randomly permute test cases to
5097         try to break the loader" program.
5098
5099 2003-01-31  Havoc Pennington  <hp@pobox.com>
5100
5101         * doc/dbus-specification.sgml: work on the specification
5102
5103         * dbus/dbus-message.c (_dbus_message_loader_return_buffer): check
5104         the protocol version of the message.
5105
5106         * dbus/dbus-protocol.h: drop special _REPLY names, the spec
5107         no longer specifies that.
5108         (DBUS_SERVICE_REPLY_SERVICE_EXISTS): fix flags (1/2/4/8 not
5109         1/2/3/4)
5110
5111         * dbus/dbus-marshal.c (_dbus_marshal_get_arg_end_pos): add missing
5112         "break" for DBUS_TYPE_NIL, remove @todo
5113
5114 2003-01-31  Havoc Pennington  <hp@pobox.com>
5115
5116         * dbus/dbus-message.c (dbus_message_set_is_error_reply): rename
5117         just set_is_error/get_is_error as this is a commonly-used
5118         function, and write docs.
5119
5120 2003-01-31  Anders Carlsson  <andersca@codefactory.se>
5121
5122         * dbus/dbus-address.c: (dbus_address_entry_free):
5123         Free key and value lists.
5124
5125         * dbus/dbus-internals.c: (_dbus_type_to_string):
5126         Add the types we didn't have.
5127
5128         * dbus/dbus-marshal.c: (_dbus_marshal_get_arg_end_pos),
5129         (_dbus_marshal_validate_arg):
5130         Add NIL types.
5131
5132         * dbus/dbus-message.c: (dbus_message_set_sender):
5133         Remove todo about being able to set sender to NULL.
5134
5135         (dbus_message_set_is_error_reply),
5136         (dbus_message_get_is_error_reply):
5137         * dbus/dbus-message.h:
5138         New functions.
5139
5140         * dbus/dbus-protocol.h:
5141         Add error reply flag.
5142
5143         * test/data/valid-messages/opposite-endian.message:
5144         Add NIL type to test.
5145
5146 2003-01-31  Havoc Pennington  <hp@pobox.com>
5147
5148         * doc/dbus-specification.sgml: fully specify the header.  Add
5149         flags and major protocol version, and change header/body len to
5150         unsigned.
5151
5152         * dbus/dbus-message-builder.c (append_saved_length): append length
5153         as uint32
5154
5155         * dbus/dbus-message.c (dbus_message_create_header): change header
5156         length and body length to unsigned. Add the new fields from the
5157         spec
5158         (_dbus_message_loader_return_buffer): unsigned header/body len
5159
5160 2003-01-30  Havoc Pennington  <hp@pobox.com>
5161
5162         * dbus/dbus-auth.c: rework to use only REJECTED, no
5163         MECHANISMS
5164
5165         * doc/dbus-sasl-profile.txt: drop MECHANISMS and just
5166         use REJECTED, suggested by Mark McLoughlin
5167
5168 2003-01-30  Havoc Pennington  <hp@pobox.com>
5169
5170         * dbus/dbus-server.c (dbus_server_listen): @todo about how we need
5171         a better way to report errors here. e.g.  "unix address lacks
5172         path" or something. also "no such file" when the path doesn't
5173         exist, etc.
5174
5175         * dbus/dbus-address.c (dbus_address_entries_free): add @todo about
5176         leaking list nodes
5177         (dbus_parse_address): add @todo about documenting address format,
5178         and allowing , and ; to be escaped
5179
5180 2003-01-30  Anders Carlsson  <andersca@codefactory.se>
5181
5182         * dbus/Makefile.am:
5183         Add dbus-address.[ch]
5184
5185         * dbus/dbus-address.c: (dbus_address_entry_free),
5186         (dbus_address_entries_free), (create_entry),
5187         (dbus_address_entry_get_method), (dbus_address_entry_get_value),
5188         (dbus_parse_address), (_dbus_address_test):
5189         * dbus/dbus-address.h:
5190         New files for dealing with address parsing.
5191
5192         * dbus/dbus-connection.c:
5193         Document timeout functions.
5194
5195         * dbus/dbus-message.c:
5196         Document dbus_message_new_from_message.
5197
5198         * dbus/dbus-server-debug.c:
5199         Document.
5200
5201         * dbus/dbus-server.c: (dbus_server_listen):
5202         Parse address and use correct server implementation.
5203
5204         * dbus/dbus-string.c: (_dbus_string_find_to), (_dbus_string_test):
5205         * dbus/dbus-string.h:
5206         New function with test.
5207
5208         * dbus/dbus-test.c: (dbus_internal_symbol_do_not_use_run_tests):
5209         * dbus/dbus-test.h:
5210         Add address tests.
5211
5212         * dbus/dbus-transport-debug.c:
5213         Document.
5214
5215         * dbus/dbus-transport.c: (_dbus_transport_open):
5216         Parse address and use correct transport implementation.
5217
5218 2003-01-30  Havoc Pennington  <hp@pobox.com>
5219
5220         * dbus/dbus-message.c: use message->byte_order instead of
5221         DBUS_COMPILER_BYTE_ORDER throughout.
5222         (dbus_message_create_header): pad header to align the
5223         start of the body of the message to 8-byte boundary
5224
5225         * dbus/dbus-marshal.h: make all the demarshalers take const
5226         DBusString arguments.
5227
5228         * dbus/dbus-message.c (_dbus_message_loader_return_buffer):
5229         validate message args here, so we don't have to do slow validation
5230         later, and so we catch bad messages as they are incoming. Also add
5231         better checks on header_len and body_len. Also fill in
5232         message->byte_order
5233
5234         * dbus/dbus-string.c (_dbus_string_validate_utf8): new (not
5235         implemented properly)
5236         (_dbus_string_validate_nul): new function to check all-nul
5237
5238         * dbus/dbus-marshal.c (_dbus_marshal_get_field_end_pos): rename
5239         get_arg_end_pos and remove all validation
5240         (_dbus_marshal_validate_arg): actually do validation here.
5241
5242 2003-01-29  Havoc Pennington  <hp@pobox.com>
5243
5244         * dbus/dbus-message.c (check_message_handling): fix assertion
5245         failure on set_client_serial
5246
5247 2003-01-28  Havoc Pennington  <hp@pobox.com>
5248
5249         * dbus/dbus-server-debug.c: Add doc section comments
5250
5251         * dbus/dbus-transport-debug.c: add doc section comments
5252
5253 2003-01-28  Havoc Pennington  <hp@redhat.com>
5254
5255         * dbus/dbus-string.c (_dbus_string_base64_decode): append bytes in
5256         the reverse order from how I had it
5257         (_dbus_string_base64_encode): reverse encoding order. I was
5258         basically byteswapping everything during encoding.
5259
5260 2003-01-28  Anders Carlsson  <andersca@codefactory.se>
5261
5262         * dbus/dbus-connection-internal.h:
5263         * dbus/dbus-connection.c: (_dbus_connection_add_timeout),
5264         (_dbus_connection_remove_timeout):
5265         Add functions for adding and removing timeouts.
5266
5267         * dbus/dbus-message.c: (dbus_message_new_from_message):
5268         Add new function that takes a message and creates an exact
5269         copy of it, but with the refcount set to 1.
5270         (check_message_handling):
5271         Fix build error.
5272
5273         * dbus/dbus-server-protected.h:
5274         * dbus/dbus-server.c: (_dbus_server_init_base),
5275         (_dbus_server_finalize_base), (_dbus_server_add_timeout),
5276         (dbus_server_set_timeout_functions):
5277         (_dbus_server_remove_timeout):
5278         New functions so that a server can add and remove timeouts.
5279
5280         (dbus_server_listen):
5281         Add commented out call to dbus_server_debug_new.
5282
5283         * dbus/dbus-timeout.c: (_dbus_timeout_new):
5284         Actually set the handler, doh.
5285
5286         * dbus/dbus-transport.c: (_dbus_transport_open):
5287         Add commented out call to dbus_transport_debug_client_new.
5288
5289         * dbus/Makefile.am:
5290         Add dbus-transport-debug.[ch] and dbus-server-debug.[ch]
5291
5292 2003-01-28  Havoc Pennington  <hp@pobox.com>
5293
5294         * dbus/dbus-message.c (check_message_handling): function to check
5295         on the loaded message, iterates over it etc.
5296
5297 2003-01-28  Havoc Pennington  <hp@pobox.com>
5298
5299         * test/Makefile.am (dist-hook): fix make distdir
5300
5301         * dbus/Makefile.am (TESTS_ENVIRONMENT): fix make check
5302
5303 2003-01-27  Havoc Pennington  <hp@pobox.com>
5304
5305         * dbus/dbus-mempool.c (time_for_size): replace printf with
5306         _dbus_verbose
5307
5308         * dbus/dbus-message-builder.c (_dbus_message_data_load): allow
5309         empty lines; fix the SAVE_LENGTH stuff to be
5310         START_LENGTH/END_LENGTH so it actually works; couple other
5311         bugfixes
5312
5313         * test/Makefile.am (dist-hook): add dist-hook for .message files
5314
5315         * dbus/dbus-string.c (DBUS_STRING_COPY_PREAMBLE): source of a copy
5316         can be constant or locked.
5317         (_dbus_string_free): allow freeing a const string as
5318         documented/intended
5319
5320         * dbus/dbus-sysdeps.c (_dbus_concat_dir_and_file): utility
5321
5322         * dbus/dbus-test-main.c (main): take an argument which is the
5323         directory containing test data
5324
5325         * dbus/dbus-message.c (_dbus_message_test): pass a test_data_dir
5326         argument to this and load all the messages in test/data/
5327         checking that they can be loaded or not loaded as appropriate.
5328
5329 2003-01-27  Anders Carlsson  <andersca@codefactory.se>
5330
5331         * bus/dispatch.c: (bus_dispatch_message_handler):
5332         Dispatch messages sent to services.
5333
5334         * bus/driver.c: (bus_driver_send_service_deleted),
5335         (bus_driver_send_service_created), (bus_driver_send_service_lost),
5336         (bus_driver_send_service_acquired):
5337         Add helper functions for sending service related messages.
5338
5339         (bus_driver_send_welcome_message):
5340         Send HELLO_REPLY instead of WELCOME.
5341
5342         (bus_driver_handle_list_services):
5343         Send LIST_SERVICES_REPLY instead of SERVICES.
5344
5345         (bus_driver_handle_own_service),
5346         (bus_driver_handle_service_exists):
5347         New message handlers.
5348
5349         (bus_driver_handle_message):
5350         Invoke new message handlers.
5351
5352         (bus_driver_remove_connection):
5353         Don't remove any services here since that's done automatically
5354         by bus_service_remove_owner now.
5355
5356         * bus/driver.h:
5357         New function signatures.
5358
5359         * bus/services.c: (bus_service_add_owner):
5360         Send ServiceAcquired message if we're the only primary owner.
5361
5362         (bus_service_remove_owner):
5363         Send ServiceAcquired/ServiceLost messages.
5364
5365         (bus_service_set_prohibit_replacement),
5366         (bus_service_get_prohibit_replacement):
5367         Functions for setting prohibit replacement.
5368
5369         (bus_service_has_owner):
5370         New function that checks if a connection is in the owner queue of
5371         a certain service.
5372
5373         * bus/services.h:
5374         Add new function signatures.
5375
5376         * dbus/dbus-list.c: (_dbus_list_test):
5377         Add tests for _dbus_list_remove_last and traversing the list backwards.
5378
5379         * dbus/dbus-list.h:
5380         Fix a typo in _dbus_list_get_prev_link, if we're at the first element we can't
5381         go any further, so return NULL then.
5382
5383         * dbus/dbus-protocol.h:
5384         Add new messages, service flags and service replies.
5385
5386 2003-01-26  Havoc Pennington  <hp@pobox.com>
5387
5388         * dbus/dbus-message-builder.c: implement, completely untested.
5389
5390         * test/data/*: add data to be used in testing.
5391         ".message" files are our simple loadable text format.
5392         ".message-raw" will be binary dumps of messages.
5393
5394         * dbus/dbus-string.c (_dbus_string_starts_with_c_str): new
5395
5396 2003-01-26  Havoc Pennington  <hp@pobox.com>
5397
5398         * dbus/dbus-sysdeps.c (_dbus_file_get_contents): new function
5399
5400         * dbus/dbus-errors.c (dbus_result_to_string): add
5401         file errors
5402
5403         * dbus/dbus-message-builder.c: new file, will contain code to load
5404         up messages from files. Not implemented yet.
5405
5406 2003-01-26  Havoc Pennington  <hp@pobox.com>
5407
5408         * dbus/dbus-message.c (dbus_message_set_sender): support deleting
5409         the sender by setting to NULL
5410
5411 2003-01-26  Havoc Pennington  <hp@pobox.com>
5412
5413         The unit tests pass, but otherwise untested.  If it breaks, the
5414         tests should have been better. ;-)
5415
5416         * bus/driver.c (bus_driver_handle_hello): return if we disconnect
5417         the connection.
5418
5419         * dbus/dbus-message.c: redo everything so we maintain
5420         message->header as the only copy of the various fields.
5421         This avoids the possibility of out-of-memory in some cases,
5422         for example dbus_message_lock() can't run out of memory anymore,
5423         and avoids extra copying. Figured I may as well go ahead and do
5424         this since it was busted for dbus_message_lock to not return
5425         failure on OOM, and dbus_message_write_header was totally
5426         unchecked for OOM. Also fixed some random other bugs.
5427
5428         * dbus/dbus-marshal.c (_dbus_marshal_get_field_end_pos): verify
5429         that strings are nul-terminated. Also, end_pos can be equal
5430         to string length just not greater than, I think.
5431         (_dbus_marshal_set_int32): new function
5432         (_dbus_marshal_set_uint32): new function
5433         (_dbus_marshal_set_string): new function
5434
5435         * dbus/dbus-connection.c (_dbus_connection_new_for_transport): fix
5436         a warning, init timeout_list to NULL
5437         (dbus_connection_send_message): don't use uninitialized variable
5438         "serial"
5439
5440         * dbus/dbus-string.c (_dbus_string_replace_len): new function
5441
5442 2003-01-26  Anders Carlsson  <andersca@codefactory.se>
5443
5444         * bus/driver.c: (bus_driver_handle_hello),
5445         (bus_driver_send_welcome_message):
5446         Plug leaks
5447
5448 2003-01-26  Anders Carlsson  <andersca@codefactory.se>
5449
5450         * dbus/dbus-auth.c: (process_auth), (_dbus_auth_unref):
5451         * dbus/dbus-connection.c: (_dbus_connection_new_for_transport),
5452         (dbus_connection_unref):
5453         * dbus/dbus-marshal.c: (_dbus_marshal_test):
5454         * dbus/dbus-message.c: (dbus_message_unref),
5455         Plug memory leaks.
5456
5457         (dbus_message_get_fields):
5458         Remove debugging printout.
5459
5460         (_dbus_message_loader_return_buffer):
5461         Don't store the header string.
5462
5463         (_dbus_message_test):
5464         Plug leaks.
5465
5466 2003-01-26  Richard Hult  <rhult@codefactory.se>
5467
5468         * glib/dbus-gmain.c (dbus_connection_dispatch): Traverse a copy of
5469         the file descriptor list, since it can change under us.
5470
5471 2003-01-25  Anders Carlsson  <andersca@codefactory.se>
5472
5473         * glib/dbus-gmain.c: (dbus_connection_prepare),
5474         (dbus_connection_check), (dbus_connection_dispatch), (add_watch),
5475         (remove_watch), (dbus_connection_hookup_with_g_main):
5476         Rewrite the glib handling to use its own GSource instead of a
5477         GIOChannel so we can catch messages put in the queue while waiting
5478         for a reply.
5479
5480 2003-01-25  Anders Carlsson  <andersca@codefactory.se>
5481
5482         * bus/Makefile.am:
5483         * bus/connection.c: (connection_disconnect_handler),
5484         (connection_watch_callback), (bus_connection_setup):
5485         * bus/dispatch.c: (send_one_message),
5486         (bus_dispatch_broadcast_message), (bus_dispatch_message_handler),
5487         (bus_dispatch_add_connection), (bus_dispatch_remove_connection):
5488         * bus/dispatch.h:
5489         * bus/driver.c: (bus_driver_send_service_deleted),
5490         (bus_driver_send_service_created), (bus_driver_handle_hello),
5491         (bus_driver_send_welcome_message),
5492         (bus_driver_handle_list_services), (bus_driver_remove_connection),
5493         (bus_driver_handle_message):
5494         * bus/driver.h:
5495         Refactor code, put the message dispatching in its own file. Use
5496         _DBUS_HANDLE_OOM. Also send ServiceDeleted messages when a client
5497         is disconnected.
5498
5499 2003-01-25  Anders Carlsson  <andersca@codefactory.se>
5500
5501         * dbus/dbus-internals.h:
5502         Add _DBUS_HANDLE_OOM macro, it doesn't do anything currently.
5503
5504         * dbus/dbus-message.c: (dbus_message_get_sender):
5505         * dbus/dbus-message.h:
5506         Implement dbus_message_get_sender.
5507
5508         * dbus/dbus-protocol.h:
5509         Add message and service defines.
5510
5511 2003-01-25  Anders Carlsson  <andersca@codefactory.se>
5512
5513         * dbus/dbus-connection.c: (dbus_connection_send_message):
5514         * dbus/dbus-message-internal.h:
5515         * dbus/dbus-message.c: (_dbus_message_get_client_serial),
5516         (dbus_message_write_header):
5517         Remove _dbus_messag_unlock and don't set the client serial on a
5518         message if one already exists.
5519
5520 2003-01-24  Havoc Pennington  <hp@pobox.com>
5521
5522         * dbus/dbus-list.c (alloc_link): put a thread lock on the global
5523         list_pool
5524
5525         * bus/driver.c (bus_driver_handle_list_services): fix a leak
5526         on OOM
5527
5528 2003-01-25  Anders Carlsson  <andersca@codefactory.se>
5529
5530         * dbus/dbus-list.c: (alloc_link), (free_link):
5531         Use a memory pool for the links.
5532
5533 2003-01-25  Anders Carlsson  <andersca@codefactory.se>
5534
5535         * bus/connection.c: (bus_connection_foreach):
5536         * bus/connection.h:
5537         Add new bus_connection_foreach function.
5538
5539         * bus/driver.c: (send_one_message), (bus_driver_broadcast_message):
5540         Add function that broadcasts a message to all clients.
5541
5542         (bus_driver_send_service_created), (bus_driver_handle_hello),
5543         (bus_driver_send_welcome_message),
5544         (bus_driver_handle_list_services), (bus_driver_message_handler):
5545         Implement functions that take care of listing services, and notifying
5546         clients when new services are created.
5547
5548         * bus/services.c: (bus_services_list):
5549         * bus/services.h:
5550         Add new function that returns an array of strings with the currently
5551         registered services.
5552
5553         * glib/dbus-glib.h:
5554         * glib/dbus-gmain.c:
5555         Update copyright year.
5556
5557 2003-01-25  Anders Carlsson  <andersca@codefactory.se>
5558
5559         * dbus/dbus-connection.c: (dbus_connection_send_message):
5560         Unlock the message in case it was sent earlier.
5561
5562         (dbus_connection_send_message_with_reply_and_block):
5563         Remove the reply message from the list.
5564
5565         * dbus/dbus-marshal.c: (_dbus_demarshal_string_array):
5566         Set array_len and new_pos correctly.
5567
5568         (_dbus_marshal_test):
5569         Remove debug output.
5570
5571         * dbus/dbus-message-internal.h:
5572         * dbus/dbus-message.c: (_dbus_message_get_reply_serial):
5573         New function that returns the reply serial.
5574
5575         (_dbus_message_unlock):
5576         New function that unlocks a message and resets its header.
5577
5578         (dbus_message_append_string_array),
5579         (dbus_message_get_fields_valist),
5580         (dbus_message_iter_get_field_type),
5581         (dbus_message_iter_get_string_array),
5582         (dbus_message_get_fields),
5583         (dbus_message_append_fields_valist):
5584         Handle string arrays.
5585
5586         (dbus_message_set_sender):
5587         Make this function public since the bus daemon needs it.
5588
5589         (decode_header_data):
5590         Set the reply serial to -1 initially.
5591
5592         * dbus/dbus-message.h:
5593         Add dbus_message_set_sender.
5594
5595 2003-01-24  Havoc Pennington  <hp@pobox.com>
5596
5597         * doc/dbus-specification.sgml: add some stuff
5598
5599 2003-01-22  Havoc Pennington  <hp@pobox.com>
5600
5601         * doc/dbus-specification.sgml: Start to document the protocol.
5602
5603 2003-01-22  Havoc Pennington  <hp@pobox.com>
5604
5605         * dbus/dbus-connection.c
5606         (dbus_connection_send_message_with_reply_and_block): add some @todo
5607
5608         * bus/driver.c (bus_driver_add_connection): add a FIXME about memleak
5609
5610 2003-01-21  Havoc Pennington  <hp@pobox.com>
5611
5612         (patch untested because can't compile)
5613
5614         * bus/driver.c (create_unique_client_name): make this function
5615         never recycle client names. Also, caller should initialize
5616         the DBusString.
5617
5618         * dbus/dbus-sysdeps.c (_dbus_get_current_time): new function
5619
5620 2003-01-21  Anders Carlsson  <andersca@codefactory.se>
5621
5622         * dbus/dbus-marshal.c: (_dbus_marshal_double),
5623         (_dbus_marshal_int32), (_dbus_marshal_uint32),
5624         (_dbus_marshal_int32_array), (_dbus_marshal_uint32_array),
5625         (_dbus_marshal_double_array), (_dbus_marshal_string_array),
5626         (_dbus_demarshal_int32_array), (_dbus_demarshal_uint32_array),
5627         (_dbus_demarshal_double_array), (_dbus_demarshal_string_array),
5628         (_dbus_marshal_get_field_end_pos), (_dbus_marshal_test):
5629         * dbus/dbus-marshal.h:
5630         * dbus/dbus-protocol.h:
5631         Add support for marshalling and demarshalling integer, double
5632         and string arrays.
5633
5634 2003-01-21  Anders Carlsson  <andersca@codefactory.se>
5635
5636         * bus/Makefile.am:
5637         Add driver.[ch]
5638
5639         * bus/connection.c: (connection_disconnect_handler):
5640         Remove the connection from the bus driver's list.
5641
5642         (connection_watch_callback): Dispatch messages.
5643
5644         (free_connection_data): Free connection name.
5645
5646         (bus_connection_setup): Add connection to the bus driver's list.
5647         (bus_connection_remove_owned_service):
5648         (bus_connection_set_name), (bus_connection_get_name):
5649         Add functions for setting and getting the connection's name.
5650
5651         * bus/connection.h:
5652         Add function headers.
5653
5654         * bus/driver.c: (create_unique_client_name),
5655         (bus_driver_handle_hello_message),
5656         (bus_driver_send_welcome_message), (bus_driver_message_handler),
5657         (bus_driver_add_connection), (bus_driver_remove_connection):
5658         * bus/driver.h:
5659         * bus/main.c:
5660         * bus/services.c: (bus_service_free):
5661         * bus/services.h:
5662         New file that handles communication and registreation with the bus
5663         itself.
5664
5665 2003-01-21  Anders Carlsson  <andersca@codefactory.se>
5666
5667         * dbus/dbus-connection.c: (dbus_connection_send_message):
5668         Add a new client_serial parameter.
5669
5670         (dbus_connection_send_message_with_reply):
5671         Remove a @todo since we've implemented the blocking function.
5672
5673         (dbus_connection_send_message_with_reply_and_block):
5674         New function that sends a message and waits for a reply and
5675         then returns the reply.
5676
5677         * dbus/dbus-connection.h:
5678         Add new functions.
5679
5680         * dbus/dbus-errors.c: (dbus_result_to_string):
5681         * dbus/dbus-errors.h:
5682         Add new DBUS_RESULT.
5683
5684         * dbus/dbus-message-internal.h:
5685         * dbus/dbus-message.c: (_dbus_message_get_reply_serial),
5686         (_dbus_message_set_sender), (dbus_message_write_header),
5687         (dbus_message_new_reply), (decode_header_data),
5688         (_dbus_message_loader_return_buffer), (_dbus_message_test):
5689         * dbus/dbus-message.h:
5690         Add new functions that set the reply serial and sender.
5691         Also marshal and demarshal them correctly and add test.
5692
5693         * dbus/dbus-protocol.h:
5694         Add new DBUS_MESSAGE_TYPE_SENDER.
5695
5696         * glib/dbus-glib.h:
5697         * glib/dbus-gmain.c: (watch_callback), (free_callback_data),
5698         (add_watch), (remove_watch), (add_timeout), (remove_timeout),
5699         (dbus_connection_hookup_with_g_main):
5700         * glib/test-dbus-glib.c: (main):
5701         Rewrite to use GIOChannel and remove the GSource crack.
5702
5703         * test/echo-client.c: (main):
5704         * test/watch.c: (check_messages):
5705         Update for changed APIs
5706
5707 2003-01-19  Anders Carlsson  <andersca@codefactory.se>
5708
5709         * dbus/Makefile.am: Add dbus-timeout.[cħ]
5710
5711         * dbus/dbus-connection.c: (_dbus_connection_new_for_transport):
5712         Create a DBusTimeoutList.
5713         (dbus_connection_set_timeout_functions): Add new function to
5714         set timeout callbacks
5715
5716         * dbus/dbus-connection.h: Add public DBusTimeout API.
5717
5718         * dbus/dbus-message.c: (dbus_message_get_service):
5719         * dbus/dbus-message.h:  New function.
5720
5721         * dbus/dbus-server.c: Fix small doc typo.
5722
5723         * dbus/dbus-timeout.[ch]: New files for mainloop timeouts.
5724
5725 2003-01-19  Anders Carlsson  <andersca@codefactory.se>
5726
5727         * dbus/dbus-string.c (_dbus_string_move_len): Don't delete all
5728         of the string, just as long as specified.
5729
5730 2003-01-19  Havoc Pennington  <hp@pobox.com>
5731
5732         * dbus/dbus-connection.c (dbus_connection_get_is_authenticated):
5733         new function
5734
5735         * dbus/dbus-server.c (dbus_server_set_max_connections)
5736         (dbus_server_get_max_connections, dbus_server_get_n_connections):
5737         keep track of current number of connections, and add API for
5738         setting a max (but haven't implemented enforcing the max yet)
5739
5740 2003-01-18  Havoc Pennington  <hp@pobox.com>
5741
5742         * dbus/dbus-transport-unix.c (unix_do_iteration): only do the
5743         reading/writing if read_watch != NULL or write_watch != NULL.
5744
5745         * dbus/dbus-message.c (_dbus_message_loader_return_buffer): fix
5746         the message loader code to actually load message->header and
5747         message->body into the newly-created message.
5748
5749         * dbus/dbus-transport-unix.c (check_write_watch): fix a mem leak
5750         in OOM case
5751
5752         * dbus/dbus-connection.c (dbus_connection_set_max_message_size)
5753         (dbus_connection_get_max_message_size)
5754         (dbus_connection_set_max_live_messages_size)
5755         (dbus_connection_get_max_live_messages_size): implement some
5756         resource limitation functions
5757
5758         * dbus/dbus-resources.c: new file implementing some of the
5759         resource limits stuff
5760
5761         * dbus/dbus-message.c (dbus_message_iter_get_byte_array): add
5762         missing docs, add @todo to handle OOM etc.
5763
5764         * dbus/dbus-marshal.c (_dbus_demarshal_byte_array): add missing
5765         docs
5766
5767 2003-01-18  Havoc Pennington  <hp@pobox.com>
5768
5769         * dbus/dbus-connection.c (dbus_connection_unref): disconnect the
5770         connection if it hasn't been already.
5771
5772         * dbus/dbus-connection.h: kill off the idea of an ErrorFunction,
5773         replace with DisconnectFunction.
5774
5775 2003-01-18  Havoc Pennington  <hp@pobox.com>
5776
5777         Building --disable-verbose-mode --disable-asserts --disable-tests
5778         cuts the library from 112K to 45K or so
5779
5780         * configure.in: check for varargs macro support,
5781         add --enable-verbose-mode, --enable-asserts.
5782
5783         * dbus/dbus-internals.h (_dbus_assert): support
5784         DBUS_DISABLE_ASSERT
5785         (_dbus_verbose): support DBUS_ENABLE_VERBOSE_MODE
5786
5787 2003-01-18  Havoc Pennington  <hp@pobox.com>
5788
5789         * dbus/dbus-test.c: include config.h so that tests actually run
5790
5791         * dbus/dbus-string.c: add assertions that stuff is 8-byte aligned,
5792         so the failure mode when that assumption fails will be plenty
5793         obvious.
5794
5795 2003-01-18  Havoc Pennington  <hp@pobox.com>
5796
5797         * configure.in: default --enable-tests to $USE_MAINTAINER_MODE
5798
5799         * dbus/Makefile.am: fix it up so dubs-test-main.c is included in
5800         the distribution
5801
5802         * test/Makefile.am: don't use special variable "TESTS" for echo-*
5803         since we don't want to use those in make check
5804
5805 2003-01-15  Havoc Pennington  <hp@redhat.com>
5806
5807         Release 0.2
5808
5809         * NEWS: update
5810
5811 2003-01-15  Havoc Pennington  <hp@redhat.com>
5812
5813         * test/Makefile.am: fix so that test source code ends up in the
5814         distribution on make distcheck
5815
5816 2003-01-15  Havoc Pennington  <hp@redhat.com>
5817
5818         Release 0.1.
5819
5820         * NEWS: update
5821
5822 2003-01-15  Havoc Pennington  <hp@redhat.com>
5823
5824         * dbus/dbus-test.c (dbus_internal_symbol_do_not_use_run_tests):
5825         fix build when --disable-tests
5826
5827         * Makefile.am (EXTRA_DIST): put HACKING in here
5828
5829         * HACKING: document procedure for making a tarball release.
5830
5831 2003-01-14  Anders Carlsson  <andersca@codefactory.se>
5832
5833         * bus/connection.c: (connection_error_handler),
5834         (bus_connection_setup):
5835         * bus/main.c: (main):
5836         Make sure that the DBusConnectionData struct is NULLed
5837         out to prevent a segfault.
5838
5839         * dbus/dbus-errors.c: (dbus_result_to_string):
5840         * dbus/dbus-errors.h:
5841         * dbus/dbus-message.c: (dbus_message_get_fields),
5842         (dbus_message_get_fields_valist), (_dbus_message_test):
5843         * dbus/dbus-message.h:
5844         Make dbus_message_get_fields return a result code so we can
5845         track invalid fields as well as oom.
5846
5847 2003-01-11  Havoc Pennington  <hp@pobox.com>
5848
5849         * configure.in: change --enable-test/--enable-ansi action-if-given
5850         to enable_foo=$enableval instead of enable_foo=yes
5851
5852 2003-01-08  Havoc Pennington  <hp@pobox.com>
5853
5854         * dbus/dbus-string.c (_dbus_string_align_length): new function
5855
5856         * dbus/dbus-test-main.c: move main() for test app here
5857         * dbus/dbus-test.c
5858         (dbus_internal_symbol_do_not_use_run_tests): we have to export a
5859         symbol to run tests, because dbus-test isn't in the main
5860         library
5861
5862         Code review nitpicks.
5863
5864         * dbus/dbus-message.c (dbus_message_write_header): add newlines
5865         for people with narrow emacs ;-). Assert client_serial was filled
5866         in. Assert message->name != NULL.
5867         (dbus_message_append_fields): have "first_field_type" arg separate
5868         from va list, needed for C++ binding that also uses varargs IIRC
5869         and helps with type safety
5870         (dbus_message_new): add @todo about using DBusString to store
5871         service/name internally
5872         (dbus_message_new): don't leak ->service and ->name on OOM later
5873         in the function
5874         (dbus_message_unref): free the service name
5875         (dbus_message_get_fields): same change to varargs
5876         i.e. first_field_type
5877         (_dbus_message_loader_return_buffer): assert that the message data
5878         is aligned (if not it's a bug in our code). Put in verbose griping
5879         about why we set corrupted = TRUE.
5880         (decode_header_data): add FIXME that char* is evil.  Was going to
5881         add FIXME about evil locale-specific string.h strncmp, but just
5882         switched to wacky string-as-uint32 optimization. Move check for
5883         "no room for field name" above get_const_data_len() to avoid
5884         assertion failure in get_const_data_len if we have trailing 2
5885         bytes or the like. Check for service and name fields being
5886         provided twice. Don't leak service/name on error. Require field
5887         names to be aligned to 4 bytes.
5888
5889         * dbus/dbus-marshal.c: move byte swap stuff to header
5890         (_dbus_pack_int32): uscore-prefix
5891         (_dbus_unpack_int32): uscore-prefix
5892         (_dbus_unpack_uint32): export
5893         (_dbus_demarshal_string): add @todo complaining about use of
5894         memcpy()
5895         (_dbus_marshal_get_field_end_pos): add @todo about bad error
5896         handling allowing corrupt data to go unchecked
5897
5898 2003-01-08  Havoc Pennington  <hp@redhat.com>
5899
5900         * dbus/dbus-transport-unix.c (unix_do_iteration): add read/write
5901         to the select() as needed for authentication. (should be using
5902         _dbus_poll() not select, but for another day)
5903
5904         * dbus/dbus.h: include dbus/dbus-protocol.h
5905
5906 2003-01-08  Anders Carlsson  <andersca@codefactory.se>
5907
5908         * dbus/Makefile.am (dbusinclude_HEADERS): Install
5909         dbus-connection.h
5910
5911 2003-01-08  Anders Carlsson  <andersca@codefactory.se>
5912
5913         * dbus/dbus-internals.c: (_dbus_type_to_string):
5914         New function that returns a string describing a type.
5915
5916         * dbus/dbus-marshal.c: (_dbus_demarshal_byte_array):
5917         * dbus/dbus-marshal.h:
5918         * dbus/dbus-message.c: (dbus_message_get_fields_valist),
5919         (dbus_message_iter_get_field_type), (dbus_message_iter_get_double),
5920         (dbus_message_iter_get_byte_array):
5921         * dbus/dbus-message.h:
5922         Add new convenience functions for appending and getting message fields.
5923         Also add demarshalling routines for byte arrays.
5924
5925 2003-01-07  Anders Carlsson  <andersca@codefactory.se>
5926
5927         * dbus/dbus-connection-internal.h:
5928         * dbus/dbus-connection.c: (_dbus_connection_new_for_transport),
5929         (_dbus_connection_get_next_client_serial),
5930         (dbus_connection_send_message):
5931         * dbus/dbus-internals.h:
5932         * dbus/dbus-marshal.c: (unpack_uint32), (dbus_unpack_int32),
5933         (dbus_pack_int32), (_dbus_marshal_double), (_dbus_marshal_int32),
5934         (_dbus_marshal_uint32), (_dbus_demarshal_double),
5935         (_dbus_demarshal_int32), (_dbus_demarshal_uint32),
5936         (_dbus_demarshal_string), (_dbus_marshal_get_field_end_pos),
5937         (_dbus_verbose_bytes), (_dbus_marshal_test):
5938         * dbus/dbus-marshal.h:
5939         * dbus/dbus-message-internal.h:
5940         * dbus/dbus-message.c: (_dbus_message_set_client_serial),
5941         (dbus_message_write_header), (_dbus_message_lock),
5942         (dbus_message_new), (dbus_message_ref), (dbus_message_unref),
5943         (dbus_message_get_name), (dbus_message_append_int32),
5944         (dbus_message_append_uint32), (dbus_message_append_double),
5945         (dbus_message_append_string), (dbus_message_append_byte_array),
5946         (dbus_message_get_fields_iter), (dbus_message_iter_ref),
5947         (dbus_message_iter_unref), (dbus_message_iter_has_next),
5948         (dbus_message_iter_next), (dbus_message_iter_get_field_type),
5949         (dbus_message_iter_get_string), (dbus_message_iter_get_int32),
5950         (dbus_message_iter_get_uint32), (dbus_message_iter_get_double),
5951         (decode_header_data), (_dbus_message_loader_return_buffer),
5952         (message_iter_test), (_dbus_message_test):
5953         * dbus/dbus-message.h:
5954         * dbus/dbus-protocol.h:
5955         * dbus/dbus-test.c: (main):
5956         * dbus/dbus-test.h:
5957         * glib/test-dbus-glib.c: (message_handler), (main):
5958         * test/echo-client.c: (main):
5959         * test/watch.c: (check_messages):
5960         Make messages sendable and receivable for real.
5961
5962 2003-01-07  Anders Carlsson  <andersca@codefactory.se>
5963
5964         * dbus/dbus-marshal.c: (_dbus_marshal_double),
5965         (_dbus_marshal_string), (_dbus_marshal_byte_array):
5966         * dbus/dbus-message.c: (dbus_message_append_int32),
5967         (dbus_message_append_uint32), (dbus_message_append_double),
5968         (dbus_message_append_string), (dbus_message_append_byte_array):
5969         Handle OOM restoration.
5970
5971 2003-01-07  Anders Carlsson  <andersca@codefactory.se>
5972
5973         * dbus/dbus-marshal.c: (_dbus_marshal_string),
5974         (_dbus_demarshal_string), (_dbus_marshal_test):
5975         * dbus/dbus-marshal.h:
5976         * dbus/dbus-message.c: (dbus_message_get_name),
5977         Document these functions.
5978
5979         (dbus_message_append_int32), (dbus_message_append_uint32),
5980         (dbus_message_append_double), (dbus_message_append_string),
5981         (dbus_message_append_byte_array):
5982         * dbus/dbus-message.h:
5983         Add functions for adding message fields of different types.
5984
5985         * dbus/dbus-protocol.h:
5986         Add the different types.
5987
5988 2003-01-05  Havoc Pennington  <hp@pobox.com>
5989
5990         * bus/connection.c: implement routines for handling connections,
5991         first thing is keeping a list of owned services on each connection
5992         and setting up watches etc.
5993
5994         * bus/services.c: implement a mapping from service names to lists
5995         of connections
5996
5997         * dbus/dbus-hash.c: add DBUS_HASH_POINTER
5998
5999         * dbus/dbus-threads.c (dbus_static_mutex_lock): add functions
6000         to use static mutexes for global data
6001
6002         * dbus/dbus-connection.c (dbus_connection_set_data): add new
6003         collection of functions to set/get application-specific data
6004         on the DBusConnection.
6005
6006 2003-01-04  Havoc Pennington  <hp@pobox.com>
6007
6008         * dbus/dbus-sysdeps.c (_dbus_sleep_milliseconds): new function
6009         (_dbus_poll): new function
6010
6011         * dbus/dbus-internals.h (_DBUS_STRUCT_OFFSET): new macro
6012         copied from GLib
6013
6014         * bus/loop.c: initial code for the daemon main loop
6015
6016 2003-01-04  Havoc Pennington  <hp@pobox.com>
6017
6018         * test/watch.c (error_handler): make it safe if the error handler
6019         is called multiple times (if we s/error handler/disconnect
6020         handler/ we should just guarantee it's called only once)
6021
6022         * dbus/dbus-transport.c (_dbus_transport_disconnect): call the
6023         error handler on disconnect (it's quite possible we should
6024         just change the error handler to a "disconnect handler," I'm
6025         not sure we have any other meaningful errors)
6026
6027         * configure.in: check for getpwnam_r
6028
6029         * dbus/dbus-transport.c, dbus/dbus-transport-unix.c,
6030         dbus/dbus-auth.c: add credentials support, add EXTERNAL auth
6031         mechanism as in SASL spec, using socket credentials
6032
6033         * dbus/dbus-sysdeps.c (_dbus_read_credentials_unix_socket): new function
6034         (_dbus_send_credentials_unix_socket): new function
6035
6036         * dbus/dbus-sysdeps.c (_dbus_accept_unix_socket): rename just
6037         dbus_accept()
6038         (_dbus_write): only check errno if <0 returned
6039         (_dbus_write_two): ditto
6040
6041 2003-01-02  Anders Carlsson  <andersca@codefactory.se>
6042
6043         * dbus/dbus-marshal.c: (_dbus_marshal_utf8_string),
6044         (_dbus_marshal_byte_array), (_dbus_demarshal_utf8_string),
6045         (_dbus_marshal_test):
6046         * dbus/dbus-marshal.h:
6047         Add _dbus_marshal_byte_array and rename _dbus_marshal_string
6048         to _dbus_marshal_utf8_string. Also fix some tests.
6049
6050 2002-12-28  Harri Porten  <porten@kde.org>
6051
6052         * configure.in: added check for C++ compiler and a very cheesy
6053         check for the Qt integration
6054
6055         * Makefile.am (SUBDIRS): compile qt subdir if support is enabled
6056
6057         * qt/Makefile.am: added
6058
6059         * qt/.cvsignore: added
6060
6061         * qt/dbus-qthread.cc, qt/dbus-qthread.cpp: renamed former to
6062         latter, added #ifdef QT_THREAD_SUPPORT guard.
6063
6064         * dbus/Makefile.am: added missing headers for make dist
6065
6066 2002-12-28  Kristian Rietveld  <kris@gtk.org>
6067
6068         * dbus/Makefile.am: fixup export-symbols-regex.
6069
6070 2002-12-27  Anders Carlsson  <andersca@codefactory.se>
6071
6072         * acinclude.m4: Add this file and put the
6073         PKG_CHECK_MODULE macro in it.
6074
6075 2002-12-27  Anders Carlsson  <andersca@codefactory.se>
6076
6077         * dbus/dbus-marshal.c: (_dbus_marshal_string),
6078         (_dbus_demarshal_double), (_dbus_demarshal_int32),
6079         (_dbus_demarshal_uint32), (_dbus_demarshal_string),
6080         (_dbus_marshal_test):
6081         Make the demarshalling routines align the pos argument.
6082         Add string marshalling tests and fix the obvious bugs
6083         discovered.
6084
6085 2002-12-26  Havoc Pennington  <hp@pobox.com>
6086
6087         * dbus/dbus-auth.c: fixes fixes fixes
6088
6089         * dbus/dbus-transport-unix.c: wire up support for
6090         encoding/decoding data on the wire
6091
6092         * dbus/dbus-auth.c (_dbus_auth_encode_data)
6093         (_dbus_auth_decode_data): append to target string
6094         instead of nuking it.
6095
6096 2002-12-26  Havoc Pennington  <hp@pobox.com>
6097
6098         * dbus/dbus-marshal.h (DBUS_COMPILER_BYTE_ORDER): #ifdef
6099         WORDS_BIGENDIAN then compiler byte order is DBUS_BIG_ENDIAN,
6100         doh
6101
6102         * dbus/dbus-marshal.c: Add macros to do int swapping in-place and
6103         avoid swap_bytes() overhead (ignoring possible assembly stuff for
6104         now). Main point is because I wanted unpack_uint32 to implement
6105         _dbus_verbose_bytes
6106         (_dbus_verbose_bytes): new function
6107
6108         * dbus/dbus-string.c (_dbus_string_validate_ascii): new function
6109
6110         * dbus/dbus-message.c (_dbus_message_loader_get_is_corrupted): add
6111         mechanism to handle a corrupt message stream
6112         (_dbus_message_loader_new): fix preallocation to only prealloc,
6113         not prelengthen
6114
6115         * dbus/dbus-string.c (_dbus_string_skip_blank): fix this function
6116         (_dbus_string_test): enhance tests for copy/move and fix the
6117         functions
6118
6119         * dbus/dbus-transport-unix.c: Hold references in more places to
6120         avoid reentrancy problems
6121
6122         * dbus/dbus-transport.c: ditto
6123
6124         * dbus/dbus-connection.c (dbus_connection_dispatch_message): don't
6125         leak reference count in no-message case
6126
6127         * test/watch.c (do_mainloop): handle adding/removing watches
6128         during iteration over the watches. Also, ref the connection/server
6129         stored on a watch, so we don't try to mangle a destroyed one.
6130
6131         * dbus/dbus-transport-unix.c (do_authentication): perform
6132         authentication
6133
6134         * dbus/dbus-auth.c (get_state): add a state
6135         AUTHENTICATED_WITH_UNUSED_BYTES and return it if required
6136         (_dbus_auth_get_unused_bytes): append the unused bytes
6137         to the passed in string, rather than prepend
6138
6139         * dbus/dbus-transport.c (_dbus_transport_init_base): create
6140         the auth conversation DBusAuth
6141
6142         * dbus/dbus-transport-unix.c (_dbus_transport_new_for_fd)
6143         (_dbus_transport_new_for_domain_socket): when creating a
6144         transport, pass in whether it's a client-side or server-side
6145         transport so we know which DBusAuth to create
6146
6147 2002-12-03  Havoc Pennington  <hp@pobox.com>
6148
6149         * dbus/dbus-transport-unix.c (unix_finalize): finalize base
6150         _after_ finalizing the derived members
6151         (unix_connection_set): unref watch if we fail to add it
6152
6153         * dbus/dbus-connection.c (dbus_connection_unref): delete the
6154         transport first, so that the connection owned by the
6155         transport will be valid as the transport finalizes.
6156
6157         * dbus/dbus-transport-unix.c (unix_finalize): free the write_watch
6158         if necessary, and remove watches from the connection.
6159
6160         * dbus/dbus-watch.c (_dbus_watch_list_free): improve a comment
6161
6162 2002-12-26  Anders Carlsson  <andersca@codefactory.se>
6163
6164         * dbus/dbus-marshal.c: (_dbus_marshal_string),
6165         (_dbus_demarshal_double), (_dbus_demarshal_int32),
6166         (_dbus_demarshal_uint32), (_dbus_demarshal_string),
6167         (_dbus_marshal_test):
6168         * dbus/dbus-marshal.h:
6169         Add string marshal functions and have the demarshal functions
6170         return the new position.
6171
6172 2002-12-25  Havoc Pennington  <hp@pobox.com>
6173
6174         * doc/dbus-sasl-profile.txt: docs on the authentication protocol,
6175         it is a simple protocol that just maps directly to SASL.
6176
6177         * dbus/dbus-auth.h, dbus/dbus-auth.c: authentication protocol
6178         initial implementation, not actually used yet.
6179
6180         * dbus/dbus-string.c (_dbus_string_find): new function
6181         (_dbus_string_equal): new function
6182         (_dbus_string_base64_encode): new function
6183         (_dbus_string_base64_decode): new function
6184
6185 2002-12-25  Anders Carlsson  <andersca@codefactory.se>
6186
6187         * dbus/Makefile.am:
6188         * dbus/dbus-marshal.c: (swap_bytes), (_dbus_marshal_double),
6189         (_dbus_marshal_int32), (_dbus_marshal_uint32),
6190         (_dbus_demarshal_double), (_dbus_demarshal_int32),
6191         (_dbus_demarshal_uint32), (_dbus_marshal_test):
6192         * dbus/dbus-marshal.h:
6193         * dbus/dbus-protocol.h:
6194         * dbus/dbus-test.c: (main):
6195         * dbus/dbus-test.h:
6196         Add un-optimized marshalling/demarshalling routines.
6197
6198 2002-12-25  Harri Porten  <porten@kde.org>
6199
6200         * qt/dbus-qt.h: adjusted ctor and getter to KDE/Qt conventions
6201
6202 2002-12-24  Zack Rusin  <zack@kde.org>
6203
6204         * qt/dbus-qthread.cc: adding - integrates QMutex into Dbus
6205         * qt/dbus-qt.h: skeleton with two sample implemenatation of the
6206         main loop stuff
6207
6208 2002-12-24  Havoc Pennington  <hp@pobox.com>
6209
6210         * glib/dbus-gthread.c: fix include
6211
6212         * glib/dbus-glib.h: rename DBusMessageHandler for now.
6213         I think glib API needs to change, though, as you don't
6214         want to use DBusMessageFunction, you want to use the
6215         DBusMessageHandler object. Probably
6216         dbus_connection_open_with_g_main_loop()
6217         and dbus_connection_setup_g_main_loop() or something like that
6218         (but think of better names...) that just create a connection
6219         that has watch/timeout functions etc. already set up.
6220
6221         * dbus/dbus-connection.c
6222         (dbus_connection_send_message_with_reply): new function just to
6223         show how the message handler helps us deal with replies.
6224
6225         * dbus/dbus-list.c (_dbus_list_remove_last): new function
6226
6227         * dbus/dbus-string.c (_dbus_string_test): free a string that
6228         wasn't
6229
6230         * dbus/dbus-hash.c: use memory pools for the hash entries
6231         (rebuild_table): be more paranoid about overflow, and
6232         shrink table when we can
6233         (_dbus_hash_test): reduce number of sprintfs and write
6234         valid C89. Add tests for case where we grow and then
6235         shrink the hash table.
6236
6237         * dbus/dbus-mempool.h, dbus/dbus-mempool.c: memory pools
6238
6239         * dbus/dbus-connection.c (dbus_connection_register_handler)
6240         (dbus_connection_unregister_handler): new functions
6241
6242         * dbus/dbus-message.c (dbus_message_get_name): new
6243
6244         * dbus/dbus-list.c: fix docs typo
6245
6246         * dbus/dbus-message-handler.h, dbus/dbus-message-handler.c:
6247         an object representing a handler for messages.
6248
6249 2002-12-16  Anders Carlsson  <andersca@codefactory.se>
6250
6251         * glib/dbus-glib.h:
6252         * glib/dbus-gthread.c: (dbus_gthread_init):
6253         Don't use the gdbus prefix for public functions.
6254
6255 2002-12-16  Anders Carlsson  <andersca@codefactory.se>
6256
6257         * Makefile.am:
6258         * configure.in:
6259         Add GLib checks and fixup .pc files
6260
6261         * glib/Makefile.am:
6262         * glib/dbus-glib.h:
6263         * glib/dbus-gmain.c: (gdbus_connection_prepare),
6264         (gdbus_connection_check), (gdbus_connection_dispatch),
6265         (gdbus_add_connection_watch), (gdbus_remove_connection_watch),
6266         (dbus_connection_gsource_new):
6267         * glib/dbus-gthread.c: (dbus_gmutex_new), (dbus_gmutex_free),
6268         (dbus_gmutex_lock), (dbus_gmutex_unlock), (dbus_gthread_init):
6269         * glib/test-dbus-glib.c: (message_handler), (main):
6270         Add GLib support.
6271
6272 2002-12-15  Harri Porten  <porten@kde.org>
6273
6274         * autogen.sh: check for libtoolize before attempting to use it
6275
6276         * dbus/dbus-transport-unix.c: include <sys/time.h> for timeval
6277         struct.
6278
6279         * .cvsignore: ignore more stamp files
6280
6281         * dbus/dbus-watch.c (_dbus_watch_list_new): fixed doc error
6282
6283         * test/Makefile.am: added -I$(top_srcdir) to be able to compile
6284         without make install.
6285
6286 2002-12-15  Havoc Pennington  <hp@pobox.com>
6287
6288         * dbus/dbus-threads.c: add thread stubs that a higher library
6289         layer can fill in. e.g. the GLib wrapper might fill them in with
6290         GThread stuff. We still need to use this thread API to
6291         thread-safe-ize the library.
6292
6293 2002-12-12  Havoc Pennington  <hp@pobox.com>
6294
6295         * dbus/dbus-transport-unix.c, dbus/dbus-server-unix.c: use the
6296         below new interfaces and include fewer system headers.
6297
6298         * dbus/dbus-sysdeps.c (_dbus_read): new function
6299         (_dbus_write): new function
6300         (_dbus_write_two): new function
6301         (_dbus_connect_unix_socket): new function
6302         (_dbus_listen_unix_socket): new function
6303
6304         * dbus/dbus-message-internal.h: change interfaces to use
6305         DBusString
6306
6307 2002-12-11  Havoc Pennington  <hp@pobox.com>
6308
6309         * dbus/dbus-types.h: add dbus_unichar
6310
6311         * dbus/dbus-internals.c (_dbus_verbose): use _dbus_getenv
6312
6313         * dbus/dbus-connection.c (dbus_connection_send_message): return
6314         TRUE on success
6315
6316         * dbus/dbus-transport.c: include dbus-watch.h
6317
6318         * dbus/dbus-connection.c: include dbus-message-internal.h
6319
6320         * HACKING: add file with coding guidelines stuff.
6321
6322         * dbus/dbus-string.h, dbus/dbus-string.c: Encapsulate all string
6323         handling here, for security purposes (as in vsftpd). Not actually
6324         using this class yet.
6325
6326         * dbus/dbus-sysdeps.h, dbus/dbus-sysdeps.c: Encapsulate all
6327         system/libc usage here, as in vsftpd, for ease of auditing (and
6328         should also simplify portability). Haven't actually moved all the
6329         system/libc usage into here yet.
6330
6331 2002-11-25  Havoc Pennington  <hp@pobox.com>
6332
6333         * dbus/dbus-internals.c (_dbus_verbose): fix to not
6334         always print the first verbose message.
6335
6336 2002-11-24  Havoc Pennington  <hp@pobox.com>
6337
6338         * test/echo-client.c, test/echo-server.c: cheesy test
6339         clients.
6340
6341         * configure.in (AC_CHECK_FUNCS): check for writev
6342
6343         * dbus/dbus-message.c (_dbus_message_get_network_data): new
6344         function
6345
6346         * dbus/dbus-list.c (_dbus_list_foreach): new function
6347
6348         * dbus/dbus-internals.c (_dbus_verbose): new function
6349
6350         * dbus/dbus-server.c, dbus/dbus-server.h: public object
6351         representing a server that listens for connections.
6352
6353         * dbus/.cvsignore: create
6354
6355         * dbus/dbus-errors.h, dbus/dbus-errors.c:
6356         public API for reporting errors
6357
6358         * dbus/dbus-connection.h, dbus/dbus-connection.c:
6359         public object representing a connection that
6360         sends/receives messages. (Same object used for
6361         both client and server.)
6362
6363         * dbus/dbus-transport.h, dbus/dbus-transport.c:
6364         Basic abstraction for different kinds of stream
6365         that we might read/write messages from.
6366
6367 2002-11-23  Havoc Pennington  <hp@pobox.com>
6368
6369         * dbus/dbus-internals.h (_DBUS_INT_MAX): add _DBUS_INT_MIN
6370         _DBUS_INT_MAX
6371
6372         * dbus/dbus-test.c (main): add list test, and include
6373         dbus-test.h as intended
6374
6375         * dbus/dbus-hash.c (_dbus_hash_table_remove_string)
6376         (_dbus_hash_table_remove_int): return value indicates
6377         whether the entry existed to remove
6378
6379         * dbus/dbus-list.c: add linked list utility class,
6380         with docs and tests
6381
6382         * dbus/dbus-hash.c: add TODO item about shrinking the hash bucket
6383         array sometimes.
6384
6385 2002-11-23  Havoc Pennington  <hp@pobox.com>
6386
6387         * Doxyfile.in (INCLUDE_FILE_PATTERNS): expand DBUS_BEGIN_DECLS/
6388         DBUS_END_DECLS to nothing, that should fix this once and for all
6389
6390         * Doxyfile.in (JAVADOC_AUTOBRIEF): set to YES
6391
6392         * dbus/dbus-message.c, dbus/dbus-hash.c:
6393         add some missing @brief
6394
6395 2002-11-23  Havoc Pennington  <hp@pobox.com>
6396
6397         * dbus/dbus-message.h: put semicolons after DEBUG_BEGIN_DECLS
6398         to avoid confusing Doxygen
6399
6400         * dbus/dbus-hash.c: @} not }@
6401
6402         * dbus/dbus-message.c (struct DBusMessage): split out
6403         internals docs
6404
6405 2002-11-23  Havoc Pennington  <hp@pobox.com>
6406
6407         * configure.in: pile on more warning flags if using gcc
6408
6409         * Doxyfile.in (EXTRACT_STATIC): set to NO, so we don't have
6410         to document static functions
6411
6412         * configure.in: add summary to end of configure so it
6413         looks nice and attractive
6414
6415         * dbus/dbus-hash.c: finish implementation and write unit
6416         tests and docs
6417
6418         * configure.in: add --enable-tests to enable unit tests
6419
6420         * dbus/dbus-test.c: test program to run unit tests
6421         for all files in dbus/*, initially runs a test for
6422         dbus-hash.c
6423
6424         * dbus/dbus-internals.h: file to hold some internal utility stuff
6425
6426 2002-11-22  Havoc Pennington  <hp@redhat.com>
6427
6428         * dbus/dbus-hash.c: copy in Tcl hash table, not yet
6429         "ported" away from Tcl
6430
6431         * dbus/dbus-types.h: header for types such as dbus_bool_t
6432
6433 2002-11-22  Havoc Pennington  <hp@redhat.com>
6434
6435         * dbus/dbus.h: fixups for doc warnings
6436
6437         * Doxyfile.in (FILE_PATTERNS): we need to scan .h to pick up
6438         macros
6439         (QUIET): make it quiet so we can see warnings
6440
6441         * dbus/dbus-memory.c: teach D-BUS to allocate and free memory
6442
6443 2002-11-22  Havoc Pennington  <hp@redhat.com>
6444
6445         * Makefile.am: include "Doxyfile" target in all-local
6446
6447         * configure.in: generate the Doxyfile
6448
6449         * Doxyfile.in: move Doxyfile here, so we can use
6450         configure to generate a Doxyfile with the right
6451         version number etc.
6452
6453 2002-11-22  Havoc Pennington  <hp@redhat.com>
6454
6455         * dbus/dbus-message.c: move inline docs into .c file
6456
6457         * Doxyfile (OUTPUT_DIRECTORY): move output to doc/api
6458         so all docs are under doc/
6459         (MAN_EXTENSION): generate man pages. Use extension
6460         ".3dbus" which matches ".3qt" on my system,
6461         I guess this is OK, I don't know really.
6462         (FILE_PATTERNS): look for .c files not .h, makes sense
6463         for plain C I think
6464
6465 2002-11-22  Havoc Pennington  <hp@pobox.com>
6466
6467         * Makefile.am (SUBDIRS): rename subdir "server" to "bus"
6468         because any app can be a server, and any app can be a client,
6469         the bus is a special kind of server.
6470
6471 Thu Nov 21 23:35:31 2002  Zack Rusin  <zack@kde.org>
6472
6473         * Doxyfile : adding. Still needs Makefile rules to be generated
6474         automatically (just run "doxygen" in the toplevel dir for now to
6475         generate docs)
6476
6477         * dbus/dbus-message.h : Adding sample docs (javadoc since
6478         resembles gtk-doc a little more)
6479
6480         * dbus/dbus.h : Adding sample docs
6481
6482 2002-11-21  Havoc Pennington  <hp@redhat.com>
6483
6484         * dbus/Makefile.am (INCLUDES): define DBUS_COMPILATION
6485         so we can allow ourselves to include files directly,
6486         instead of having to use dbus.h
6487
6488         * dbus/dbus.h: fill in
6489
6490         * dbus/dbus-message.h: sketch out a sample header file.
6491         Include griping if you include it directly instead of
6492         via dbus.h
6493
6494         * dbus/dbus-macros.h: new file with macros for extern "C",
6495         TRUE/FALSE, NULL, etc.
6496
6497         * doc/file-boilerplate.c: put include guards in here
6498
6499 2002-11-21  Havoc Pennington  <hp@redhat.com>
6500
6501         * doc/file-boilerplate.c: include both AFL and GPL boilerplate.
6502
6503         * COPYING: include the GPL as well, and license code
6504         under both AFL and GPL.
6505
6506 2002-11-21  Havoc Pennington  <hp@redhat.com>
6507
6508         * acconfig.h: get rid of this
6509
6510         * autogen.sh (run_configure): add --no-configure option
6511
6512         * configure.in: remove AC_ARG_PROGRAM to make
6513         autoconf complain less. add AC_PREREQ.
6514         add AC_DEFINE third arg.
6515
6516 2002-11-21  Anders Carlsson  <andersca@codefactory.se>
6517
6518         * doc/Makefile.am:
6519         Fix references so we can distcheck.
6520
6521 2002-11-21  Havoc Pennington  <hp@redhat.com>
6522
6523         * Initial module creation
6524