memory freeing necessary?
Matthew Johnson
dbus at matthew.ath.cx
Tue Jul 25 13:29:49 PDT 2006
On Tue, 25 Jul 2006, Havoc Pennington wrote:
>> and other services do the same? Should the file extension be ".xml". Or
>> do we want a dbus specific one, e.g. ".dbus-introspection-data"? What's
>> the MIME type going to be (for example what about
>> "application/dbus-introspection-data" or do we not need one?
>
> I don't know here, what do other apps do?
A fairly even split, I think. We aren't really pushing this as a Format
(cf open document, xsl, etc) and nothing needs it as a separate
mime-type, so .xml is fine imo
>> - Should we require or just encourage apps to drop files there? Some
>> apps are not really are introspectable (hal just gained this in CVS
>> HEAD a month or two ago, NM still don't IIRC) and some never will,
>> so suggest to not require it.
>
> I think encourage.
I think _all_ apps should be introspectable. It's a condition of the
bindings that they provide this, I think a c-api dbus program which
doesn't should be considered a bug.
> I think I actually said "exceptions are part of the defined semantics of a
> method, even though they aren't in the type signature, and you have to
> specify non-compiler-checked semantics in an ABI anyway and exceptions would
> fall under that spec"
>
> IOW exceptions can't be added if they break the semantics, so your previous
> bullet point applies ;-)
So can we please have annotations that list them? If it's part of the
API/ABI it should be in the introspection data.
>> - can you add IN parameters to methods / signals? In the C ABI you can
>> do this
>
> This would break source compatibility.
>
> We may want to change dbus_message_get_args() (and corresponding routines in
> the glib, etc. bindings) to throw an error if there are extra args so people
> don't do this... one for the TODO
>
>> - can you add OUT parameters? In the C ABI you make a function
>> returning "void" return something provided, of course, you don't
>> need the caller to free it
>
> Seems like a similar case of may break source compat though it doesn't break
> wire compat.
The Java bindings enforce this anyway; the method is looked up via an
(object,interface,method,args) tuple, which allows overloading; return
types are all strongly typed so you will get a runtime error if the
wrong type is returned.
Matt
--
Matthew Johnson
http://www.matthew.ath.cx/
More information about the hal
mailing list