[PATCH wayland] protocol: Add a surface_has_existing_role error
Pekka Paalanen
ppaalanen at gmail.com
Mon Sep 22 01:10:14 PDT 2014
On Mon, 25 Aug 2014 08:59:51 +0300
Pekka Paalanen <ppaalanen at gmail.com> wrote:
> On Fri, 22 Aug 2014 10:48:02 -0700
> Jason Ekstrand <jason at jlekstrand.net> wrote:
>
> > As I mentioned on IRC, I don't really like adding and using an enum value
> > without bumping protocol version. However, the only time we ever use it is
> > to kill the client so the worst thing that can happen is that the client
> > doesn't report the error correctly. I think I'm ok with it.
>
> Yeah, I don't see a problem in adding values to an error enum.
>
> However, I do wonder if this is logical.
>
> Let's say xdg_shell used this. A client issues request
> xdg_shell at 33.get_xdg_surface(wl_surface at 20). There are quite likely
> several other requests on wl_surface at 20, and since I assume
> get_xdg_surface will be raising a protocol error, there will also be an
> earlier request on some other interface already giving a role to
> wl_surface at 20. And all these requests can be in the same burst.
>
> Using the below enum value, the compositor would send the error on
> wl_surface at 20, but you don't know which interface call caused it.
>
> Using an error enum value in xdg_shell, the compositor would be sending
> the error on xdg_shell at 33, but you don't know for which surface.
>
> One solution to both "don't know"s is to add the missing information to
> the error message for humans to see.
>
> Both ways could work in practice, but this would be the first (legal)
> case of sending the error on a different object than whose request
> caused it to trigger.
>
> It may make sense in this one case, but if we do it here, we generally
> allow it everywhere, which I believe can bring confusion on what errors
> can be raised where. It will no longer be true, that the possible
> errors are the ones defined in the interface containing the request,
> plus wl_display errors. You will be also adding all errors on all
> argument objects to the set, per request.
>
> That is why I am hesitant to commit this. I'm sure someone will find
> a case where this would make something like writing language bindings
> more difficult for him, even if it seems obscure or even silly to us.
>
> It's not like we share e.g. pixel format enums between, say, wl_shm and
> wl_drm, even though they are the same AFAIK, and there is a
> considerable amount of duplication. (Yes, that is a bit different case,
> because there we would be breaking also the namespacing.)
>
>
> Thanks,
> pq
>
> > On Fri, Aug 22, 2014 at 10:37 AM, Jasper St. Pierre <jstpierre at mecheye.net>
> > wrote:
> >
> > > This will be used by implementations to send out errors if clients try
> > > to set roles on surfaces that already have roles.
> > > ---
> > > protocol/wayland.xml | 1 +
> > > 1 file changed, 1 insertion(+)
> > >
> > > diff --git a/protocol/wayland.xml b/protocol/wayland.xml
> > > index bb457bc..f6eb54d 100644
> > > --- a/protocol/wayland.xml
> > > +++ b/protocol/wayland.xml
> > > @@ -983,6 +983,7 @@
> > > </description>
> > > <entry name="invalid_scale" value="0" summary="buffer scale value
> > > is invalid"/>
> > > <entry name="invalid_transform" value="1" summary="buffer transform
> > > value is invalid"/>
> > > + <entry name="surface_has_existing_role" value="2" summary="the
> > > surface passed already has a role"/>
> > > </enum>
Hi,
does anyone still want to defend this patch, or should we add "existing
role" error definitions to all interfaces assigning roles instead?
Thanks,
pq
More information about the wayland-devel
mailing list