summaryrefslogtreecommitdiff
path: root/protocol/ivi-application.xml
blob: aeeeba2267ecb549a43b6a2b4517b257cd66885e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
<?xml version="1.0" encoding="UTF-8"?>
<protocol name="ivi_application">

    <copyright>
    Copyright (C) 2013 DENSO CORPORATION
    Copyright (c) 2013 BMW Car IT GmbH

    Permission is hereby granted, free of charge, to any person obtaining a copy
    of this software and associated documentation files (the "Software"), to deal
    in the Software without restriction, including without limitation the rights
    to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
    copies of the Software, and to permit persons to whom the Software is
    furnished to do so, subject to the following conditions:

    The above copyright notice and this permission notice shall be included in
    all copies or substantial portions of the Software.

    THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
    IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
    FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
    AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
    LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
    OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
    THE SOFTWARE.
    </copyright>

    <interface name="ivi_surface" version="1">
        <description summary="application interface to surface in ivi compositor"/>

        <request name="destroy" type="destructor">
            <description summary="destroy ivi_surface"/>
        </request>

        <event name="visibility">
            <description summary="visibility of surface in ivi compositor has changed">
                The new visibility state is provided in argument visibility.
                If visibility is 0, the surface has become invisible.
                If visibility is not 0, the surface has become visible.
            </description>
            <arg name="visibility" type="int"/>
        </event>

    </interface>

    <interface name="ivi_application" version="1">
        <description summary="interface for ivi applications to use ivi compositor features"/>

        <request name="surface_create">
            <description summary="create surface in ivi compositor">
                surface_create will create a new surface with surface_id in ivi compositor,
                if it does not yet exists. If the surface with surface_id already exists in
                ivi compositor, the application content provided in argument surface will
                be used as surface content. If an other ivi application already registered
                content for surface with surface_id, an error event will indicate the problem.
            </description>
            <arg name="id_surface" type="uint"/>
            <arg name="surface" type="object" interface="wl_surface"/>
            <arg name="id" type="new_id" interface="ivi_surface"/>
        </request>

        <enum name="error_code">
            <description summary="possible error codes returned by ivi compositor">
                These error codes define all possible error codes returned by ivi compositor
                on server-side errors.
            </description>
            <entry name="unknown_error"   value="1" summary="unknown error encountered"/>
            <entry name="resource_in_use" value="2" summary="resource is in use and can not be shared"/>
        </enum>

        <event name="error">
            <description summary="server-side error detected">
                The ivi compositor encountered error while processing a request by this
                application. The error is defined by argument error_code and optional
                error_text.
                If the application requires to associate this error event to a request,
                it can
                    1. send request
                    2. force display roundtrip
                    3. check, if error event was received
                 but this restricts the application to have only one open request at a time.
            </description>
            <arg name="error_code" type="int"/>
            <arg name="error_text" type="string" allow-null="true"/>
        </event>

    </interface>

</protocol>