[PATCH wayland-protocols] Add governance document
Simon Ser
contact at emersion.fr
Fri Nov 15 00:10:58 UTC 2019
The idea of a better-defined governance model for wayland-protocols has
been discussed for quite a while [1].
A new GOVERNANCE document describes how changes to the wayland-protocols
repository are accepted. A set of members representing projects can vote
on merge requests sent via GitLab. The initial list of members is
available in the MEMBERS file.
[1]: https://lists.freedesktop.org/archives/wayland-devel/2019-February/040076.html
Signed-off-by: Drew DeVault <sir at cmpwn.com>
Signed-off-by: Simon Ser <contact at emersion.fr>
Acked-by: Daniel Stone <daniels at collabora.com>
Acked-by: Pekka Paalanen <pekka.paalanen at collabora.com>
Acked-by: Johan Helsing <johan.helsing at qt.io>
Acked-by: Roman Gilg <subdiff at gmail.com>
Cc: Mike Blumenkrantz <michael.blumenkrantz at gmail.com>
Cc: Jonas Ådahl <jadahl at gmail.com>
Cc: Carlos Garnacho <carlosg at gnome.org>
Cc: David Edmundson <david at davidedmundson.co.uk>
Cc: Christopher James Halse Rogers <raof at ubuntu.com>
Cc: Alan Griffiths <alan.griffiths at canonical.com>
---
GOVERNANCE | 149 +++++++++++++++++++++++++++++++++++++++++++++++++++++
MEMBERS | 11 ++++
2 files changed, 160 insertions(+)
create mode 100644 GOVERNANCE
create mode 100644 MEMBERS
diff --git a/GOVERNANCE b/GOVERNANCE
new file mode 100644
index 000000000000..912ae5bb8808
--- /dev/null
+++ b/GOVERNANCE
@@ -0,0 +1,149 @@
+ wayland-protocols governance
+
+This document governs the maintenance of wayland-protocols and serves to outline
+the broader process for standardization of protocol extensions in the Wayland
+ecosystem.
+
+ 1. Membership
+
+Membership in wayland-protocols is offered to stakeholders in the Wayland
+ecosystem who have an interest in participating in protocol extension
+standardization.
+
+ 1.1. Membership requirements
+
+a. Membership is extended to projects, rather than individuals.
+b. Members represent general-purpose projects with a stake in multiple Wayland
+ protocols (e.g. compositors, GUI toolkits, etc), rather than special-purpose
+ applications with a stake in only one or two.
+c. Each project must provide one or two named individuals as points-of-contact
+ for that project who can be reached to discuss protocol-related matters.
+d. During a vote, if two points-of-contact for the same member disagree, the
+ member's vote is considered blank.
+
+ 1.2. Becoming a member
+
+a. New members who meet the criteria outlined in 1.1 are established by
+ invitation from an existing member. Projects hoping to join should reach out
+ to an existing member asking for this invitation.
+b. New members shall write to the wayland-devel mailing list stating their
+ intention of joining and their sponsor.
+c. The sponsor shall respond acknowledging their sponsorship of the membership.
+d. A 14 day discussion period for comments from wayland-protocols members will
+ be held.
+e. At the conclusion of the discussion period, the new membership is established
+ unless their application was NACKed by a 1/2 majority of all existing members.
+
+ 1.3. Ceasing membership
+
+a. A member may step down by writing their intention to do so to the
+ wayland-devel mailing list.
+b. A removal vote may be called for by an existing member by posting to the
+ wayland-devel mailing list. This begins a 14 day voting & discussion
+ period.
+c. At the conclusion of the voting period, the member is removed if the votes
+ total 2/3rds of all current members.
+d. Removed members are not eligible to apply for membership again for a period
+ of 1 year.
+e. Following a failed vote, the member who called for the vote cannot
+ call for a re-vote or propose any other removal for 90 days.
+
+ 2. Protocols
+
+ 2.1. Protocol namespaces
+
+a. Namespaces are implemented in practice by prefixing each interface name in a
+ protocol definition (XML) with the namespace name, and an underscore (e.g.
+ "xdg_wm_base").
+b. Protocols in a namespace may optionally use the namespace followed by a dash
+ in the name (e.g. "xdg-shell").
+c. The "xdg" namespace is established for protocols letting clients
+ configure its surfaces as "windows", allowing clients to affect how they
+ are managed.
+d. The "wp" namespace is established for protocols generally useful to Wayland
+ implementations (i.e. "plumbing" protocols).
+e. The "ext" namespace is established as a general catch-all for protocols that
+ fit into no other namespace.
+
+ 2.2. Protocol inclusion requirements
+
+a. All protocols found in the "xdg" and "wp" namespaces at the time of writing
+ are grandfathered into their respective namespace without further discussion.
+b. Protocols in the "xdg" and "wp" namespace are eligible for inclusion only if
+ ACKed by at least 3 members.
+c. Protocols in the "xdg" and "wp" namespace are ineligible for inclusion if
+ if NACKed by any member.
+d. Protocols in the "xdg" and "wp" namespaces must have at least 3 open-source
+ implementations (either 1 client + 2 servers, or 2 clients + 1 server) to be
+ eligible for inclusion.
+e. Protocols in the "ext" namespace are eligible for inclusion only if ACKed by
+ at least one other member.
+f. Protocols in the "ext" namespace must have at least one open-source client &
+ one open-source server implementation to be eligible for inclusion.
+g. "Open-source" is defined as distributed with an Open Source Initiative
+ approved license.
+
+ 2.3. Introducing new protocols
+
+a. A new protocol may be proposed by submitting a merge request to the
+ wayland-protocols Gitlab repository.
+b. Protocol proposal posts must include justification for their inclusion in
+ their namespace per the requirements outlined in section 2.2.
+c. An indefinite discussion period for comments from wayland-protocols members
+ will be held, with a minimum duration of 30 days. Protocols which require a
+ certain level of implementation status, ACKs from members, and so on, should
+ use this time to acquire them.
+d. When the proposed protocol meets all requirements for inclusion per section
+ 2.2, and the minimum discussion period has elapsed, the sponsoring member may
+ merge their changes in the wayland-protocol repository.
+e. Amendments to existing protocols may be proposed by the same process, with
+ no minimum discussion period.
+f. Declaring a protocol stable may be proposed by the same process, with the
+ regular 30 day minimum discussion period.
+
+ 3. Protocol adoption documentation
+
+ 3.1. Adoption website
+
+a. This section is informational.
+b. A website will be made available for interested parties to browse the
+ implementation status of protocols included in wayland-protocols.
+c. A statement from each member of wayland-protocols will be included on the
+ site.
+d. Each protocol will be listed along with its approval status from each member.
+e. The approval statuses are:
+ 1. NACK, or "negative acknowledgement", meaning that the member is opposed to
+ the protocol in principle.
+ 2. NOPP, or "no opposition", meaning that the member is not opposed to the
+ protocol in principle, but does not provide an implementation.
+ 3. ACK, or "acknowledged", meaning that the member supports the protocol in
+ principle, but does not provide an implementation.
+ 4. IMPL, or "implemented", meaning that the member supports the protocol and
+ provides an implementation.
+f. Each member may write a short statement expanding on the rationale for their
+ approval status, which will be included on the site.
+g. A supplementary list of implementations will also be provided on the site,
+ which may include implementations supported by non-members.
+
+ 3.2. Changes to the adoption website
+
+a. This section is informational.
+b. A new protocol is added to the website by the sponsoring member at the
+ conclusion of the discussion period (section 2.3.c).
+c. During the discussion period (section 2.3.c), interested parties may express
+ their approval status on the Gitlab merge request. The default approval
+ status for members who do not participate in the discussion is "NOPP".
+d. Members may change their acknowledgement status or support statement at any
+ time after the discussion period (section 2.3.c) has closed by simply merging
+ their update in the wayland-protocols repository.
+
+ 4. Amending this document
+
+a. An amendment to this document may be proposed any member by
+ submitting a merge request on Gitlab.
+b. A 30 day discussion period for comments from wayland-protocols members will
+ be held.
+c. At the conclusion of the discussion period, an amendment will become
+ effective if it's ACKed by at least 2/3rds of all wayland-protocols members,
+ and NACKed by none. The sponsoring member may merge their change to the
+ wayland-protocols repository at this point.
diff --git a/MEMBERS b/MEMBERS
new file mode 100644
index 000000000000..9f8ace57b4ba
--- /dev/null
+++ b/MEMBERS
@@ -0,0 +1,11 @@
+- EFL/Enlightenment: Mike Blumenkrantz <michael.blumenkrantz at gmail.com>
+- GTK/Mutter: Jonas Ådahl <jadahl at gmail.com>,
+ Carlos Garnacho <carlosg at gnome.org>
+- KWin: Roman Gilg <subdiff at gmail.com>,
+ David Edmundson <david at davidedmundson.co.uk>
+- Mir: Christopher James Halse Rogers <raof at ubuntu.com>,
+ Alan Griffiths <alan.griffiths at canonical.com>
+- Qt: Johan Helsing <johan.helsing at qt.io>
+- Weston: Pekka Paalanen <pekka.paalanen at collabora.com>,
+ Daniel Stone <daniel at fooishbar.org>
+- wlroots/Sway: Drew DeVault <sir at cmpwn.com>, Simon Ser <contact at emersion.fr>
--
2.24.0
More information about the wayland-devel
mailing list