diff --git a/.github/LICENSE b/.github/LICENSE
new file mode 100644
index 0000000..cc3e245
--- /dev/null
+++ b/.github/LICENSE
@@ -0,0 +1,427 @@
+Attribution-ShareAlike 4.0 International
+
+=======================================================================
+
+Creative Commons Corporation ("Creative Commons") is not a law firm and
+does not provide legal services or legal advice. Distribution of
+Creative Commons public licenses does not create a lawyer-client or
+other relationship. Creative Commons makes its licenses and related
+information available on an "as-is" basis. Creative Commons gives no
+warranties regarding its licenses, any material licensed under their
+terms and conditions, or any related information. Creative Commons
+disclaims all liability for damages resulting from their use to the
+fullest extent possible.
+
+Using Creative Commons Public Licenses
+
+Creative Commons public licenses provide a standard set of terms and
+conditions that creators and other rights holders may use to share
+original works of authorship and other material subject to copyright
+and certain other rights specified in the public license below. The
+following considerations are for informational purposes only, are not
+exhaustive, and do not form part of our licenses.
+
+ Considerations for licensors: Our public licenses are
+ intended for use by those authorized to give the public
+ permission to use material in ways otherwise restricted by
+ copyright and certain other rights. Our licenses are
+ irrevocable. Licensors should read and understand the terms
+ and conditions of the license they choose before applying it.
+ Licensors should also secure all rights necessary before
+ applying our licenses so that the public can reuse the
+ material as expected. Licensors should clearly mark any
+ material not subject to the license. This includes other CC-
+ licensed material, or material used under an exception or
+ limitation to copyright. More considerations for licensors:
+ wiki.creativecommons.org/Considerations_for_licensors
+
+ Considerations for the public: By using one of our public
+ licenses, a licensor grants the public permission to use the
+ licensed material under specified terms and conditions. If
+ the licensor's permission is not necessary for any reason--for
+ example, because of any applicable exception or limitation to
+ copyright--then that use is not regulated by the license. Our
+ licenses grant only permissions under copyright and certain
+ other rights that a licensor has authority to grant. Use of
+ the licensed material may still be restricted for other
+ reasons, including because others have copyright or other
+ rights in the material. A licensor may make special requests,
+ such as asking that all changes be marked or described.
+ Although not required by our licenses, you are encouraged to
+ respect those requests where reasonable. More considerations
+ for the public:
+ wiki.creativecommons.org/Considerations_for_licensees
+
+=======================================================================
+
+Creative Commons Attribution-ShareAlike 4.0 International Public
+License
+
+By exercising the Licensed Rights (defined below), You accept and agree
+to be bound by the terms and conditions of this Creative Commons
+Attribution-ShareAlike 4.0 International Public License ("Public
+License"). To the extent this Public License may be interpreted as a
+contract, You are granted the Licensed Rights in consideration of Your
+acceptance of these terms and conditions, and the Licensor grants You
+such rights in consideration of benefits the Licensor receives from
+making the Licensed Material available under these terms and
+conditions.
+
+
+Section 1 -- Definitions.
+
+ a. Adapted Material means material subject to Copyright and Similar
+ Rights that is derived from or based upon the Licensed Material
+ and in which the Licensed Material is translated, altered,
+ arranged, transformed, or otherwise modified in a manner requiring
+ permission under the Copyright and Similar Rights held by the
+ Licensor. For purposes of this Public License, where the Licensed
+ Material is a musical work, performance, or sound recording,
+ Adapted Material is always produced where the Licensed Material is
+ synched in timed relation with a moving image.
+
+ b. Adapter's License means the license You apply to Your Copyright
+ and Similar Rights in Your contributions to Adapted Material in
+ accordance with the terms and conditions of this Public License.
+
+ c. BY-SA Compatible License means a license listed at
+ creativecommons.org/compatiblelicenses, approved by Creative
+ Commons as essentially the equivalent of this Public License.
+
+ d. Copyright and Similar Rights means copyright and/or similar rights
+ closely related to copyright including, without limitation,
+ performance, broadcast, sound recording, and Sui Generis Database
+ Rights, without regard to how the rights are labeled or
+ categorized. For purposes of this Public License, the rights
+ specified in Section 2(b)(1)-(2) are not Copyright and Similar
+ Rights.
+
+ e. Effective Technological Measures means those measures that, in the
+ absence of proper authority, may not be circumvented under laws
+ fulfilling obligations under Article 11 of the WIPO Copyright
+ Treaty adopted on December 20, 1996, and/or similar international
+ agreements.
+
+ f. Exceptions and Limitations means fair use, fair dealing, and/or
+ any other exception or limitation to Copyright and Similar Rights
+ that applies to Your use of the Licensed Material.
+
+ g. License Elements means the license attributes listed in the name
+ of a Creative Commons Public License. The License Elements of this
+ Public License are Attribution and ShareAlike.
+
+ h. Licensed Material means the artistic or literary work, database,
+ or other material to which the Licensor applied this Public
+ License.
+
+ i. Licensed Rights means the rights granted to You subject to the
+ terms and conditions of this Public License, which are limited to
+ all Copyright and Similar Rights that apply to Your use of the
+ Licensed Material and that the Licensor has authority to license.
+
+ j. Licensor means the individual(s) or entity(ies) granting rights
+ under this Public License.
+
+ k. Share means to provide material to the public by any means or
+ process that requires permission under the Licensed Rights, such
+ as reproduction, public display, public performance, distribution,
+ dissemination, communication, or importation, and to make material
+ available to the public including in ways that members of the
+ public may access the material from a place and at a time
+ individually chosen by them.
+
+ l. Sui Generis Database Rights means rights other than copyright
+ resulting from Directive 96/9/EC of the European Parliament and of
+ the Council of 11 March 1996 on the legal protection of databases,
+ as amended and/or succeeded, as well as other essentially
+ equivalent rights anywhere in the world.
+
+ m. You means the individual or entity exercising the Licensed Rights
+ under this Public License. Your has a corresponding meaning.
+
+
+Section 2 -- Scope.
+
+ a. License grant.
+
+ 1. Subject to the terms and conditions of this Public License,
+ the Licensor hereby grants You a worldwide, royalty-free,
+ non-sublicensable, non-exclusive, irrevocable license to
+ exercise the Licensed Rights in the Licensed Material to:
+
+ a. reproduce and Share the Licensed Material, in whole or
+ in part; and
+
+ b. produce, reproduce, and Share Adapted Material.
+
+ 2. Exceptions and Limitations. For the avoidance of doubt, where
+ Exceptions and Limitations apply to Your use, this Public
+ License does not apply, and You do not need to comply with
+ its terms and conditions.
+
+ 3. Term. The term of this Public License is specified in Section
+ 6(a).
+
+ 4. Media and formats; technical modifications allowed. The
+ Licensor authorizes You to exercise the Licensed Rights in
+ all media and formats whether now known or hereafter created,
+ and to make technical modifications necessary to do so. The
+ Licensor waives and/or agrees not to assert any right or
+ authority to forbid You from making technical modifications
+ necessary to exercise the Licensed Rights, including
+ technical modifications necessary to circumvent Effective
+ Technological Measures. For purposes of this Public License,
+ simply making modifications authorized by this Section 2(a)
+ (4) never produces Adapted Material.
+
+ 5. Downstream recipients.
+
+ a. Offer from the Licensor -- Licensed Material. Every
+ recipient of the Licensed Material automatically
+ receives an offer from the Licensor to exercise the
+ Licensed Rights under the terms and conditions of this
+ Public License.
+
+ b. Additional offer from the Licensor -- Adapted Material.
+ Every recipient of Adapted Material from You
+ automatically receives an offer from the Licensor to
+ exercise the Licensed Rights in the Adapted Material
+ under the conditions of the Adapter's License You apply.
+
+ c. No downstream restrictions. You may not offer or impose
+ any additional or different terms or conditions on, or
+ apply any Effective Technological Measures to, the
+ Licensed Material if doing so restricts exercise of the
+ Licensed Rights by any recipient of the Licensed
+ Material.
+
+ 6. No endorsement. Nothing in this Public License constitutes or
+ may be construed as permission to assert or imply that You
+ are, or that Your use of the Licensed Material is, connected
+ with, or sponsored, endorsed, or granted official status by,
+ the Licensor or others designated to receive attribution as
+ provided in Section 3(a)(1)(A)(i).
+
+ b. Other rights.
+
+ 1. Moral rights, such as the right of integrity, are not
+ licensed under this Public License, nor are publicity,
+ privacy, and/or other similar personality rights; however, to
+ the extent possible, the Licensor waives and/or agrees not to
+ assert any such rights held by the Licensor to the limited
+ extent necessary to allow You to exercise the Licensed
+ Rights, but not otherwise.
+
+ 2. Patent and trademark rights are not licensed under this
+ Public License.
+
+ 3. To the extent possible, the Licensor waives any right to
+ collect royalties from You for the exercise of the Licensed
+ Rights, whether directly or through a collecting society
+ under any voluntary or waivable statutory or compulsory
+ licensing scheme. In all other cases the Licensor expressly
+ reserves any right to collect such royalties.
+
+
+Section 3 -- License Conditions.
+
+Your exercise of the Licensed Rights is expressly made subject to the
+following conditions.
+
+ a. Attribution.
+
+ 1. If You Share the Licensed Material (including in modified
+ form), You must:
+
+ a. retain the following if it is supplied by the Licensor
+ with the Licensed Material:
+
+ i. identification of the creator(s) of the Licensed
+ Material and any others designated to receive
+ attribution, in any reasonable manner requested by
+ the Licensor (including by pseudonym if
+ designated);
+
+ ii. a copyright notice;
+
+ iii. a notice that refers to this Public License;
+
+ iv. a notice that refers to the disclaimer of
+ warranties;
+
+ v. a URI or hyperlink to the Licensed Material to the
+ extent reasonably practicable;
+
+ b. indicate if You modified the Licensed Material and
+ retain an indication of any previous modifications; and
+
+ c. indicate the Licensed Material is licensed under this
+ Public License, and include the text of, or the URI or
+ hyperlink to, this Public License.
+
+ 2. You may satisfy the conditions in Section 3(a)(1) in any
+ reasonable manner based on the medium, means, and context in
+ which You Share the Licensed Material. For example, it may be
+ reasonable to satisfy the conditions by providing a URI or
+ hyperlink to a resource that includes the required
+ information.
+
+ 3. If requested by the Licensor, You must remove any of the
+ information required by Section 3(a)(1)(A) to the extent
+ reasonably practicable.
+
+ b. ShareAlike.
+
+ In addition to the conditions in Section 3(a), if You Share
+ Adapted Material You produce, the following conditions also apply.
+
+ 1. The Adapter's License You apply must be a Creative Commons
+ license with the same License Elements, this version or
+ later, or a BY-SA Compatible License.
+
+ 2. You must include the text of, or the URI or hyperlink to, the
+ Adapter's License You apply. You may satisfy this condition
+ in any reasonable manner based on the medium, means, and
+ context in which You Share Adapted Material.
+
+ 3. You may not offer or impose any additional or different terms
+ or conditions on, or apply any Effective Technological
+ Measures to, Adapted Material that restrict exercise of the
+ rights granted under the Adapter's License You apply.
+
+
+Section 4 -- Sui Generis Database Rights.
+
+Where the Licensed Rights include Sui Generis Database Rights that
+apply to Your use of the Licensed Material:
+
+ a. for the avoidance of doubt, Section 2(a)(1) grants You the right
+ to extract, reuse, reproduce, and Share all or a substantial
+ portion of the contents of the database;
+
+ b. if You include all or a substantial portion of the database
+ contents in a database in which You have Sui Generis Database
+ Rights, then the database in which You have Sui Generis Database
+ Rights (but not its individual contents) is Adapted Material,
+
+ including for purposes of Section 3(b); and
+ c. You must comply with the conditions in Section 3(a) if You Share
+ all or a substantial portion of the contents of the database.
+
+For the avoidance of doubt, this Section 4 supplements and does not
+replace Your obligations under this Public License where the Licensed
+Rights include other Copyright and Similar Rights.
+
+
+Section 5 -- Disclaimer of Warranties and Limitation of Liability.
+
+ a. UNLESS OTHERWISE SEPARATELY UNDERTAKEN BY THE LICENSOR, TO THE
+ EXTENT POSSIBLE, THE LICENSOR OFFERS THE LICENSED MATERIAL AS-IS
+ AND AS-AVAILABLE, AND MAKES NO REPRESENTATIONS OR WARRANTIES OF
+ ANY KIND CONCERNING THE LICENSED MATERIAL, WHETHER EXPRESS,
+ IMPLIED, STATUTORY, OR OTHER. THIS INCLUDES, WITHOUT LIMITATION,
+ WARRANTIES OF TITLE, MERCHANTABILITY, FITNESS FOR A PARTICULAR
+ PURPOSE, NON-INFRINGEMENT, ABSENCE OF LATENT OR OTHER DEFECTS,
+ ACCURACY, OR THE PRESENCE OR ABSENCE OF ERRORS, WHETHER OR NOT
+ KNOWN OR DISCOVERABLE. WHERE DISCLAIMERS OF WARRANTIES ARE NOT
+ ALLOWED IN FULL OR IN PART, THIS DISCLAIMER MAY NOT APPLY TO YOU.
+
+ b. TO THE EXTENT POSSIBLE, IN NO EVENT WILL THE LICENSOR BE LIABLE
+ TO YOU ON ANY LEGAL THEORY (INCLUDING, WITHOUT LIMITATION,
+ NEGLIGENCE) OR OTHERWISE FOR ANY DIRECT, SPECIAL, INDIRECT,
+ INCIDENTAL, CONSEQUENTIAL, PUNITIVE, EXEMPLARY, OR OTHER LOSSES,
+ COSTS, EXPENSES, OR DAMAGES ARISING OUT OF THIS PUBLIC LICENSE OR
+ USE OF THE LICENSED MATERIAL, EVEN IF THE LICENSOR HAS BEEN
+ ADVISED OF THE POSSIBILITY OF SUCH LOSSES, COSTS, EXPENSES, OR
+ DAMAGES. WHERE A LIMITATION OF LIABILITY IS NOT ALLOWED IN FULL OR
+ IN PART, THIS LIMITATION MAY NOT APPLY TO YOU.
+
+ c. The disclaimer of warranties and limitation of liability provided
+ above shall be interpreted in a manner that, to the extent
+ possible, most closely approximates an absolute disclaimer and
+ waiver of all liability.
+
+
+Section 6 -- Term and Termination.
+
+ a. This Public License applies for the term of the Copyright and
+ Similar Rights licensed here. However, if You fail to comply with
+ this Public License, then Your rights under this Public License
+ terminate automatically.
+
+ b. Where Your right to use the Licensed Material has terminated under
+ Section 6(a), it reinstates:
+
+ 1. automatically as of the date the violation is cured, provided
+ it is cured within 30 days of Your discovery of the
+ violation; or
+
+ 2. upon express reinstatement by the Licensor.
+
+ For the avoidance of doubt, this Section 6(b) does not affect any
+ right the Licensor may have to seek remedies for Your violations
+ of this Public License.
+
+ c. For the avoidance of doubt, the Licensor may also offer the
+ Licensed Material under separate terms or conditions or stop
+ distributing the Licensed Material at any time; however, doing so
+ will not terminate this Public License.
+
+ d. Sections 1, 5, 6, 7, and 8 survive termination of this Public
+ License.
+
+
+Section 7 -- Other Terms and Conditions.
+
+ a. The Licensor shall not be bound by any additional or different
+ terms or conditions communicated by You unless expressly agreed.
+
+ b. Any arrangements, understandings, or agreements regarding the
+ Licensed Material not stated herein are separate from and
+ independent of the terms and conditions of this Public License.
+
+
+Section 8 -- Interpretation.
+
+ a. For the avoidance of doubt, this Public License does not, and
+ shall not be interpreted to, reduce, limit, restrict, or impose
+ conditions on any use of the Licensed Material that could lawfully
+ be made without permission under this Public License.
+
+ b. To the extent possible, if any provision of this Public License is
+ deemed unenforceable, it shall be automatically reformed to the
+ minimum extent necessary to make it enforceable. If the provision
+ cannot be reformed, it shall be severed from this Public License
+ without affecting the enforceability of the remaining terms and
+ conditions.
+
+ c. No term or condition of this Public License will be waived and no
+ failure to comply consented to unless expressly agreed to by the
+ Licensor.
+
+ d. Nothing in this Public License constitutes or may be interpreted
+ as a limitation upon, or waiver of, any privileges and immunities
+ that apply to the Licensor or You, including from the legal
+ processes of any jurisdiction or authority.
+
+
+=======================================================================
+
+Creative Commons is not a party to its public
+licenses. Notwithstanding, Creative Commons may elect to apply one of
+its public licenses to material it publishes and in those instances
+will be considered the “Licensor.” The text of the Creative Commons
+public licenses is dedicated to the public domain under the CC0 Public
+Domain Dedication. Except for the limited purpose of indicating that
+material is shared under a Creative Commons public license or as
+otherwise permitted by the Creative Commons policies published at
+creativecommons.org/policies, Creative Commons does not authorize the
+use of the trademark "Creative Commons" or any other trademark or logo
+of Creative Commons without its prior written consent including,
+without limitation, in connection with any unauthorized modifications
+to any of its public licenses or any other arrangements,
+understandings, or agreements concerning use of licensed material. For
+the avoidance of doubt, this paragraph does not form part of the
+public licenses.
+
+Creative Commons may be contacted at creativecommons.org.
diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml
new file mode 100644
index 0000000..1d8f58e
--- /dev/null
+++ b/.github/workflows/main.yml
@@ -0,0 +1,46 @@
+---
+name: Generate PDF using Pandoc
+
+# Controls when the workflow will run
+on:
+ # Triggers the workflow on push or pull request events but only for the master branch
+ push:
+ branches: [ master ]
+
+ # Allows you to run this workflow manually from the Actions tab
+ workflow_dispatch:
+
+# A workflow run is made up of one or more jobs that can run sequentially or in parallel
+jobs:
+ # This workflow contains a single job called "create_pdf"
+ create_pdf:
+ # The type of runner that the job will run on
+ runs-on: ubuntu-latest
+
+ # Pandoc Docker image v3.1.1.0
+ container:
+ image: pandoc/latex:3.1.1.0
+
+ # Steps represent a sequence of tasks that will be executed as part of the job
+ steps:
+ # Checks-out your repository under $GITHUB_WORKSPACE, so your job can access it
+ - uses: actions/checkout@v4
+
+ # Run the PDF creation script in the container
+ - uses: docker://pandoc/latex:3.1.1.0
+ with:
+ entrypoint: './pandoc-docker.sh'
+
+ # Create an output with the shortened version of the commit SHA
+ - id: short_sha
+ env:
+ GITHUB_SHA: ${{ github.sha }}
+ run: echo "{short_sha}={$(echo ${GITHUB_SHA::7})}" >> $GITHUB_OUTPUT
+
+ # Create a release with the PDFs as assets and the shortened SHA as the tag name
+ - uses: softprops/action-gh-release@v2
+ with:
+ tag_name: v${{ steps.short_sha.outputs.short_sha }}
+ draft: false
+ files: |
+ *.pdf
diff --git a/.gitignore b/.gitignore
index 7585238..478c1b1 100644
--- a/.gitignore
+++ b/.gitignore
@@ -1 +1,2 @@
+*.pdf
book
diff --git a/README.md b/README.md
new file mode 100644
index 0000000..f712598
--- /dev/null
+++ b/README.md
@@ -0,0 +1,35 @@
+# WAYLAND BOOK
+
+This repository is a clone of the repository for [Wayland Book](https://wayland-book.com/), located at
+[~sircmpwn/wayland-book](https://git.sr.ht/~sircmpwn/wayland-book).
+
+The original author of this work is [Drew DeVault](https://github.com/ddevault).
+
+## GENERATING A PDF
+
+Every commit or push to the master branch will generate a PDF that can then be
+downloaded under the Releases tab. There are two local scripts available if
+that is preferred as well.
+
+The PDF can also be generated on a local client by cloning this repository and
+running `pandoc.sh` in a shell, assuming the dependencies below are installed
+locally and accessible.
+
+The `pandoc-docker.sh` script can be used with the [pandoc/latex Docker images](https://hub.docker.com/r/pandoc/latex)
+to similarly generate the same output PDF as the one in the Releases tab.
+
+## DEPENDENCIES
+
+The local execution of the script depends on two packages being installed:
+
+- pandoc
+- tex
+
+Check with your distribution for how to install those packages.
+
+## CONTRIBUTING
+
+All issues to report or contributions to be made should be done upstream at the
+source content repository linked above. This repository will then be rebased so
+that a new PDF can be generated with the changes. The only exception would be
+the case where something specific to the PDF generation should be addressed.
diff --git a/deeplists.tex b/deeplists.tex
new file mode 100644
index 0000000..a35480a
--- /dev/null
+++ b/deeplists.tex
@@ -0,0 +1,24 @@
+ \usepackage{enumitem}
+ \setlistdepth{9}
+
+ \setlist[itemize,1]{label=$\bullet$}
+ \setlist[itemize,2]{label=$\bullet$}
+ \setlist[itemize,3]{label=$\bullet$}
+ \setlist[itemize,4]{label=$\bullet$}
+ \setlist[itemize,5]{label=$\bullet$}
+ \setlist[itemize,6]{label=$\bullet$}
+ \setlist[itemize,7]{label=$\bullet$}
+ \setlist[itemize,8]{label=$\bullet$}
+ \setlist[itemize,9]{label=$\bullet$}
+ \renewlist{itemize}{itemize}{9}
+
+ \setlist[enumerate,1]{label=$\arabic*.$}
+ \setlist[enumerate,2]{label=$\alph*.$}
+ \setlist[enumerate,3]{label=$\roman*.$}
+ \setlist[enumerate,4]{label=$\arabic*.$}
+ \setlist[enumerate,5]{label=$\alpha*$}
+ \setlist[enumerate,6]{label=$\roman*.$}
+ \setlist[enumerate,7]{label=$\arabic*.$}
+ \setlist[enumerate,8]{label=$\alph*.$}
+ \setlist[enumerate,9]{label=$\roman*.$}
+ \renewlist{enumerate}{enumerate}{9}
diff --git a/pandoc-docker.sh b/pandoc-docker.sh
new file mode 100755
index 0000000..e3ba44e
--- /dev/null
+++ b/pandoc-docker.sh
@@ -0,0 +1,15 @@
+#! /bin/sh
+
+# Install dependencies for successful PDF generations
+tlmgr install ctex enumitem float koma-script titling
+
+# Generate PDFs using pandoc
+for filename in pandoc-*yaml; do
+ # Create variable for language based on filename
+ language=`echo $filename | cut -d'.' -f1 | cut -d'-' -f2-3`
+
+ # Attempt to create the PDF
+ echo "Generating ${language} PDF..."
+ pandoc -d ${filename}
+ [[ $? -eq 0 ]] && echo "Success! The ${language} PDF has been successfully created!"
+done
diff --git a/pandoc-en-US.yaml b/pandoc-en-US.yaml
new file mode 100644
index 0000000..0b1403b
--- /dev/null
+++ b/pandoc-en-US.yaml
@@ -0,0 +1,97 @@
+---
+metadata:
+ title: The Wayland Protocol
+ author: Drew DeVault
+ category: "License: Creative Commons Attribution 4.0 International License"
+ keywords:
+ - "display server"
+ - "wayland"
+ - "xorg"
+ - "xwayland"
+standalone: true
+variables:
+ documentclass: scrbook
+ header-includes:
+ - \usepackage{graphicx}
+ - \usepackage{titling}
+ - \newcommand{\titlesc}[1]{\textsc{#1}}
+ - \pretitle{\begin{center}\includegraphics[width=2in]{wayland-logo.png}\\\LARGE\titlesc}
+ - \posttitle{\end{center}}
+ lang: en-US
+ links-as-notes: true
+ lot: false
+ lof: false
+ margin-top: 1.27cm
+ margin-left: .635cm
+ margin-right: .635cm
+ margin-bottom: 1.27cm
+ numbersections: true
+table-of-contents: true
+toc-depth: 2
+include-in-header: deeplists.tex
+verbosity: ERROR
+pdf-engine: xelatex
+input-files:
+ - ./src/introduction.md
+ - ./src/introduction/high-level-design.md
+ - ./src/introduction/goals.md
+ - ./src/introduction/package.md
+ - ./src/protocol-design.md
+ - ./src/protocol-design/wire-protocol.md
+ - ./src/protocol-design/interfaces-reqs-events.md
+ - ./src/protocol-design/high-level.md
+ - ./src/protocol-design/design-patterns.md
+ - ./src/libwayland.md
+ - ./src/libwayland/util.md
+ - ./src/libwayland/wayland-scanner.md
+ - ./src/libwayland/proxies.md
+ - ./src/libwayland/interfaces.md
+# - ./src/libwayland/event-loop.md
+# - ./src/libwayland/fds.md
+ - ./src/wayland-display.md
+ - ./src/wayland-display/creation.md
+ - ./src/wayland-display/event-loop.md
+ - ./src/registry.md
+ - ./src/registry/binding.md
+ - ./src/registry/server-side.md
+ - ./src/surfaces.md
+ - ./src/surfaces/compositor.md
+ - ./src/surfaces/shared-memory.md
+ - ./src/surfaces/dmabuf.md
+ - ./src/surfaces/roles.md
+# - ./src/surfaces/surface-roles.md
+ - ./src/xdg-shell-basics.md
+ - ./src/xdg-shell-basics/xdg-surface.md
+ - ./src/xdg-shell-basics/xdg-toplevel.md
+ - ./src/xdg-shell-basics/example-code.md
+ - ./src/surfaces-in-depth.md
+ - ./src/surfaces-in-depth/lifecycle.md
+ - ./src/surfaces-in-depth/frame-callbacks.md
+ - ./src/surfaces-in-depth/damaging-surfaces.md
+ - ./src/surfaces-in-depth/surface-regions.md
+ - ./src/surfaces-in-depth/subsurfaces.md
+ - ./src/surfaces-in-depth/hidpi.md
+ - ./src/seat.md
+ - ./src/seat/pointer.md
+ - ./src/seat/xkb.md
+ - ./src/seat/keyboard.md
+ - ./src/seat/touch.md
+ - ./src/seat/example.md
+ - ./src/xdg-shell-in-depth.md
+ - ./src/xdg-shell-in-depth/configuration.md
+ - ./src/xdg-shell-in-depth/popups.md
+ - ./src/xdg-shell-in-depth/interactive.md
+ - ./src/xdg-shell-in-depth/positioners.md
+# - ./src/clipboard.md
+# - ./src/clipboard/data-offers.md
+# - ./src/clipboard/dnd.md
+# - ./src/protocol-extensions.md
+# - ./src/protocol-extensions/timing.md
+# - ./src/protocol-extensions/pointer-constraints.md
+# - ./src/protocol-extensions/clipboard.md
+# - ./src/protocol-extensions/desktop-shell.md
+# - ./src/protocol-extensions/misc.md
+# - ./src/protocol-extensions/writing.md
+# - ./src/acknowledgements.md
+output-file: wayland-book.pdf
+...
diff --git a/pandoc.sh b/pandoc.sh
new file mode 100755
index 0000000..c699ae2
--- /dev/null
+++ b/pandoc.sh
@@ -0,0 +1,31 @@
+#! /bin/bash
+
+# Generate PDFs using pandoc
+generate_pdfs() {
+ for filename in pandoc-*yaml; do
+ # Create variable for language based on filename
+ IFS=- read _ language <<< "${filename}"
+ language=${language/.yaml/}
+
+ # Attempt to create the PDF
+ echo "Generating ${language} PDF..."
+ pandoc -d "${filename}"
+ [[ $? -eq 0 ]] && echo "Success! The ${language} PDF has been successfully created!"
+ done
+}
+
+# Check if dependencies exist
+check_dependencies () {
+ for dependency in "${dependencies[@]}"
+ do
+ if ! [ -x "$(command -v ${dependency})" ]; then
+ echo "Error: $dependency is not installed." >&2
+ exit 1
+ fi
+ done
+}
+
+dependencies=("pandoc" "tex")
+
+check_dependencies
+generate_pdfs
diff --git a/src/clipboard/data-offers.md b/src/clipboard/data-offers.md
index 9205374..b2aab8b 100644
--- a/src/clipboard/data-offers.md
+++ b/src/clipboard/data-offers.md
@@ -1 +1 @@
-# Data offers
+## Data offers
diff --git a/src/clipboard/dnd.md b/src/clipboard/dnd.md
index 4436a74..f3d45f1 100644
--- a/src/clipboard/dnd.md
+++ b/src/clipboard/dnd.md
@@ -1 +1 @@
-# Drag & drop
+## Drag & drop
diff --git a/src/introduction.md b/src/introduction.md
index 36a65aa..2668205 100644
--- a/src/introduction.md
+++ b/src/introduction.md
@@ -26,7 +26,7 @@ be updated later. Chapters 11 forward in large part remain to be written.
- Add example code for interactive move, to demonstrate the use of serials
- Prepare PDFs and EPUBs
-## About the book
+### About the book
This work is licensed under a Creative Commons
@@ -37,7 +37,7 @@ Attribution-ShareAlike 4.0 International License. The source code is
[source]: https://git.sr.ht/~sircmpwn/wayland-book
-## About the author
+### About the author
In the words of Preston Carpenter, a close collaborator of Drew's:
diff --git a/src/introduction/goals.md b/src/introduction/goals.md
index 497336b..890db26 100644
--- a/src/introduction/goals.md
+++ b/src/introduction/goals.md
@@ -1,4 +1,4 @@
-# Goals & target audience
+## Goals & target audience
Our goal is for you to come away from this book with an understanding of the
Wayland protocol and its high-level usage. You should have a solid understanding
diff --git a/src/introduction/high-level-design.md b/src/introduction/high-level-design.md
index 48e35aa..dae9587 100644
--- a/src/introduction/high-level-design.md
+++ b/src/introduction/high-level-design.md
@@ -1,4 +1,4 @@
-# High-level design
+## High-level design
Your computer has *input* and *output* devices, which respectively are
responsible for receiving information from you and displaying information to
@@ -18,7 +18,7 @@ their appropriate place on your outputs. The process of bringing together all of
your application windows for display on an output is called *compositing*
— and thus we call the software which does this the *compositor*.
-## In practice
+### In practice
There are many distinct software components in desktop ecosystem. There are
tools like Mesa for rendering (and each of its drivers), the Linux KMS/DRM
@@ -31,7 +31,7 @@ run most applications without implicating any of this software. That being said,
a surface-level understanding of what these pieces are and how they work is
useful. Let's start from the bottom and work our way up.
-## The hardware
+### The hardware
A typical computer is equipped with a few important pieces of hardware. Outside
of the box, we have your displays, keyboard, mouse, perhaps some speakers and a
@@ -55,7 +55,7 @@ on your system. The hardware provides an interface with which it can be
commanded to perform work, and does what it's told — regardless of who
tells it so. For this reason, only one component is allowed to talk to it...
-## The kernel
+### The kernel
This responsibility falls onto the kernel. The kernel is a complex beast, so
we'll focus on only the parts which are relevant to Wayland. Linux's job is to
@@ -74,12 +74,12 @@ modesetting, and a render node (e.g. `renderD128`), for unprivileged operations
like rendering or video decoding. For evdev, the "device nodes" are
`/dev/input/event*`.
-## Userspace
+### Userspace
Now, we enter userspace. Here, applications are isolated from the hardware and
must work via the device nodes provided by the kernel.
-### libdrm
+#### libdrm
Most Linux interfaces have a userspace counterpart which provides a
pleasant(ish) C API for working with these device nodes. One such library is
@@ -87,7 +87,7 @@ libdrm, which is the userspace portion of the DRM subsystem. libdrm is used by
Wayland compositors to do modesetting and other DRM operations, but is generally
not used by Wayland clients directly.
-### Mesa
+#### Mesa
Mesa is one of the most important parts of the Linux graphics stack. It
provides, among other things, vendor-optimized implementations of OpenGL (and
@@ -96,7 +96,7 @@ abstraction on top of libdrm for allocating buffers on the GPU. Most Wayland
compositors will use both GBM and OpenGL via Mesa, and most Wayland clients will
use at least its OpenGL or Vulkan implementations.
-### libinput
+#### libinput
Like libdrm abstracts the DRM subsystem, libinput provides the userspace end of
evdev. It's responsible for receiving input events from the kernel from your
@@ -105,7 +105,7 @@ the Wayland compositor. The Wayland compositor requires special permissions to
use the evdev files, forcing Wayland clients to go through the compositor to
receive input events — which, for example, prevents keylogging.
-### (e)udev
+#### (e)udev
Dealing with the appearance of new devices from the kernel, configuring
permissions for the resulting device nodes in `/dev`, and sending word of these
@@ -114,7 +114,7 @@ onto userspace. Most systems use udev (or eudev, a fork) for this purpose. Your
Wayland compositor uses udev to enumerate input devices and GPUs, and to receive
notifications when new ones appear or old ones are unplugged.
-### xkbcommon
+#### xkbcommon
XKB, short for X keyboard, is the original keyboard handling subsystem of the
Xorg server. Several years ago, it was extracted from the Xorg tree and made
@@ -126,13 +126,13 @@ these scan codes into meaningful and generic key "symbols" — for example,
converting `65` to `XKB_KEY_Space`. It also contains a state machine which knows
that pressing "1" while shift is held emits "!".
-### pixman
+#### pixman
A simple library used by clients and compositors alike for efficiently
manipulating pixel buffers, doing math with intersecting rectangles, and
performing other similar **pix**el **man**ipulation tasks.
-### libwayland
+#### libwayland
libwayland the most commonly used implementation of the Wayland protocol,
is written in C, and handles much of the low-level wire protocol. It also
@@ -140,7 +140,7 @@ provides a tool which generates high-level code from Wayland protocol
definitions (which are XML files). We will be discussing libwayland in detail in
chapter 1.3, and throughout this book.
-### ...and all the rest.
+#### ...and all the rest.
Each of the pieces mentioned so far are consistently found throughout the Linux
desktop ecosystem. Beyond this, more components exist. Many graphical
diff --git a/src/introduction/package.md b/src/introduction/package.md
index 4560031..6147338 100644
--- a/src/introduction/package.md
+++ b/src/introduction/package.md
@@ -1,4 +1,4 @@
-# What's in the Wayland package
+## What's in the Wayland package
When you install "wayland" in your Linux distribution, you'll most likely end up
with the freedesktop.org distribution of libwayland-client, libwayland-server,
@@ -8,7 +8,7 @@ represents the most popular *implementation* of the Wayland protocol, but it is
not the only one. Chapter 3 covers this implementation of Wayland in detail; the
rest of the book is equally applicable to any implementation.
-## wayland.xml
+### wayland.xml
Wayland protocols are defined by XML files. If you locate and open "wayland.xml"
in your favorite text editor, you will find the XML specification for the "core"
@@ -16,7 +16,7 @@ Wayland protocol. This is a high-level protocol — built on top of the wire
protocol that we'll discuss in the next chapter. Most of this book is devoted to
explaining this file.
-## wayland-scanner
+### wayland-scanner
The "wayland-scanner" tool is used to process these XML files and generate code
from them. The most common implementation is the one you're examining now, and
@@ -24,7 +24,7 @@ it can be used to generate C headers & glue code from XML files like
wayland.xml. Other scanners exist for other programming languages, notably
wayland-rs (Rust), waymonad-scanner (Haskell), and more.
-## libwayland
+### libwayland
The two libraries, libwayland-client and libwayland-server, include an
implementation of the wire protocol for each end of the connection. Some common
diff --git a/src/libwayland/event-loop.md b/src/libwayland/event-loop.md
index 01428a3..c3d9de5 100644
--- a/src/libwayland/event-loop.md
+++ b/src/libwayland/event-loop.md
@@ -1 +1 @@
-# The event loop
+## The event loop
diff --git a/src/libwayland/fds.md b/src/libwayland/fds.md
index dd20d77..da4878c 100644
--- a/src/libwayland/fds.md
+++ b/src/libwayland/fds.md
@@ -1 +1 @@
-# File descriptor passing
+## File descriptor passing
diff --git a/src/libwayland/interfaces.md b/src/libwayland/interfaces.md
index 2365acb..a0206d5 100644
--- a/src/libwayland/interfaces.md
+++ b/src/libwayland/interfaces.md
@@ -1,4 +1,4 @@
-# Interfaces & listeners
+## Interfaces & listeners
Finally, we reach the summit of libwayland's abstractions: interfaces and
listeners. The ideas discussed in previous chapters — `wl_proxy` and
diff --git a/src/libwayland/proxies.md b/src/libwayland/proxies.md
index 51231df..647a4d9 100644
--- a/src/libwayland/proxies.md
+++ b/src/libwayland/proxies.md
@@ -1,4 +1,4 @@
-# Proxies & resources
+## Proxies & resources
An *object* is an entity known to both the client and server that has some
state, changes to which are negotiated over the wire. On the client side,
diff --git a/src/libwayland/util.md b/src/libwayland/util.md
index 596e2b3..59aa281 100644
--- a/src/libwayland/util.md
+++ b/src/libwayland/util.md
@@ -1,4 +1,4 @@
-# wayland-util primitives
+## wayland-util primitives
Common to both the client and server libraries is `wayland-util.h`, which
defines a number of structs, utility functions, and macros that establish a
diff --git a/src/libwayland/wayland-scanner.md b/src/libwayland/wayland-scanner.md
index abe2799..4cedea0 100644
--- a/src/libwayland/wayland-scanner.md
+++ b/src/libwayland/wayland-scanner.md
@@ -1,4 +1,4 @@
-# wayland-scanner
+## wayland-scanner
The Wayland package comes with one binary: `wayland-scanner`. This tool is used
to generate C headers & glue code from the Wayland protocol XML files discussed
diff --git a/src/protocol-design/design-patterns.md b/src/protocol-design/design-patterns.md
index 276aeb8..6371f1a 100644
--- a/src/protocol-design/design-patterns.md
+++ b/src/protocol-design/design-patterns.md
@@ -1,4 +1,4 @@
-# Protocol design patterns
+## Protocol design patterns
There are some key concepts which have been applied in the design of most
Wayland protocols that we should briefly cover here. These patterns are found
@@ -6,7 +6,7 @@ throughout the high-level Wayland protocol and protocol extensions (well, in the
Wayland protocol, at least[^1]). If you find yourself writing your own
protocol extensions, you'd be wise to apply these patterns yourself.
-## Atomicity
+### Atomicity
The most important of the Wayland protocol design patterns is *atomicity*. A
stated goal of Wayland is "every frame is perfect". To this end, most interfaces
@@ -29,7 +29,7 @@ few other key design decisions, this allows Wayland compositors to render
everything perfectly in every frame — no tearing or partially updated
windows, just every pixel in its place and every place in its pixel.
-## Resource lifetimes
+### Resource lifetimes
Another important design pattern is avoiding a situation where the server or
client is sending events or requests that pertain to an invalid object. For this
@@ -48,7 +48,7 @@ queued up some requests for an object before destroying it, it would have had to
send these requests in the correct order so that the object is no longer used
after the client agreed it had been destroyed.
-## Versioning
+### Versioning
There are two versioning models in use in Wayland protocols: unstable and
stable. Both models only allow for backwards-compatible changes, but when a
diff --git a/src/protocol-design/high-level.md b/src/protocol-design/high-level.md
index f9808e8..d6dd52b 100644
--- a/src/protocol-design/high-level.md
+++ b/src/protocol-design/high-level.md
@@ -1,4 +1,4 @@
-# The high-level protocol
+## The high-level protocol
In chapter 1.3, I mentioned that `wayland.xml` is probably installed with the
Wayland package on your system. Find and pull up that file now in your favorite
diff --git a/src/protocol-design/interfaces-reqs-events.md b/src/protocol-design/interfaces-reqs-events.md
index 3bb7899..aa3c067 100644
--- a/src/protocol-design/interfaces-reqs-events.md
+++ b/src/protocol-design/interfaces-reqs-events.md
@@ -1,11 +1,11 @@
-# Interfaces, requests, and events
+## Interfaces, requests, and events
The Wayland protocol works by issuing *requests* and *events* that act on
*objects*. Each object has an *interface* which defines what requests and events
are possible, and the *signature* of each. Let's consider an example interface:
`wl_surface`.
-## Requests
+### Requests
A surface is a box of pixels that can be displayed on-screen. It's one of the
primitives we build things like application windows out of. One of its
@@ -28,7 +28,7 @@ it looks up the signature for the request with opcode 2. It then knows to expect
four integers as the arguments, and it can decode the message and dispatch it
for processing internally.
-## Events
+### Events
The server can also send messages back to the client — events. One event
that the server can send regarding a `wl_surface` is "enter", which it sends
@@ -47,7 +47,7 @@ tune as the server did. It looks up object 10, associates it with the
opcode 0. It decodes the rest of the message accordingly, looking up the
`wl_output` with ID 5 as well, then dispatches it for processing internally.
-## Interfaces
+### Interfaces
The interfaces which define the list of requests and events, the opcodes
associated with each, and the signatures with which you can decode the messages,
diff --git a/src/protocol-design/wire-protocol.md b/src/protocol-design/wire-protocol.md
index e02ad10..e216331 100644
--- a/src/protocol-design/wire-protocol.md
+++ b/src/protocol-design/wire-protocol.md
@@ -1,4 +1,4 @@
-# Wire protocol basics
+## Wire protocol basics
**Note**: If you're just going to use libwayland, this chapter is optional -
feel free to skip to chapter 2.2.
@@ -35,7 +35,7 @@ the other end using the ancillary data in the Unix domain socket message
**enum**: A single value (or bitmap) from an enumeration of known constants,
encoded into a 32-bit integer.
-## Messages
+### Messages
The wire protocol is a stream of messages built with these primitives. Every
message is an event (in the case of server to client messages) or request
@@ -55,7 +55,7 @@ and can be used to bootstrap other objects. We'll discuss this in chapter 4. The
next chapter goes over what an interface is, and how requests and events work,
assuming you've already negotiated an object ID. Speaking of which...
-## Object IDs
+### Object IDs
When a message comes in with a `new_id` argument, the sender allocates an object
ID for it — the interface used for this object is established through
@@ -69,7 +69,7 @@ new object allocation.
An object ID of 0 represents a null object; that is, a non-existent object or
the explicit lack of an object.
-## Transports
+### Transports
To date all known Wayland implementations work over a Unix domain socket. This
is used for one reason in particular: file descriptor messages. Unix sockets are
diff --git a/src/protocol-extensions/clipboard.md b/src/protocol-extensions/clipboard.md
index a1c34c2..cdce0e6 100644
--- a/src/protocol-extensions/clipboard.md
+++ b/src/protocol-extensions/clipboard.md
@@ -1 +1 @@
-# Extended clipboard
+## Extended clipboard
diff --git a/src/protocol-extensions/desktop-shell.md b/src/protocol-extensions/desktop-shell.md
index 6874e4e..dd4fc51 100644
--- a/src/protocol-extensions/desktop-shell.md
+++ b/src/protocol-extensions/desktop-shell.md
@@ -1 +1 @@
-# Desktop shell components
+## Desktop shell components
diff --git a/src/protocol-extensions/misc.md b/src/protocol-extensions/misc.md
index cafdd1a..ad5f745 100644
--- a/src/protocol-extensions/misc.md
+++ b/src/protocol-extensions/misc.md
@@ -1 +1 @@
-# Miscellaneous extensions
+## Miscellaneous extensions
diff --git a/src/protocol-extensions/pointer-constraints.md b/src/protocol-extensions/pointer-constraints.md
index 74e169f..93ff976 100644
--- a/src/protocol-extensions/pointer-constraints.md
+++ b/src/protocol-extensions/pointer-constraints.md
@@ -1 +1 @@
-# Pointer constraints
+## Pointer constraints
diff --git a/src/protocol-extensions/timing.md b/src/protocol-extensions/timing.md
index 0fb1545..d620e4e 100644
--- a/src/protocol-extensions/timing.md
+++ b/src/protocol-extensions/timing.md
@@ -1 +1 @@
-# Accurate timing
+## Accurate timing
diff --git a/src/protocol-extensions/writing.md b/src/protocol-extensions/writing.md
index 0a30b32..a8b6da5 100644
--- a/src/protocol-extensions/writing.md
+++ b/src/protocol-extensions/writing.md
@@ -1 +1 @@
-# Writing protocol extensions
+## Writing protocol extensions
diff --git a/src/registry/binding.md b/src/registry/binding.md
index 185bc93..2f21e93 100644
--- a/src/registry/binding.md
+++ b/src/registry/binding.md
@@ -1,4 +1,4 @@
-# Binding to globals
+## Binding to globals
Upon creating a registry object, the server will emit the `global` event for
each global available on the server. You can then bind to the globals you
diff --git a/src/registry/server-side.md b/src/registry/server-side.md
index e2d9a32..112edce 100644
--- a/src/registry/server-side.md
+++ b/src/registry/server-side.md
@@ -1,4 +1,4 @@
-# Registering globals
+## Registering globals
Registering globals with libwayland-server is done somewhat differently. When
you generate "server-code" with wayland-scanner, it creates interfaces
diff --git a/src/seat.md b/src/seat.md
index 50164fd..3d6579a 100644
--- a/src/seat.md
+++ b/src/seat.md
@@ -67,7 +67,7 @@ chapters.
Before we get to those, let's cover some common semantics.
-## Event serials
+### Event serials
Some actions that a Wayland client may perform require a trivial form of
authentication in the form of input event serials. For example, a client which
@@ -92,7 +92,7 @@ the desired action.
We'll discuss these in more detail in later chapters, when we start covering
the specific requests which require input event serials to validate them.
-## Input frames
+### Input frames
A single input event from an input device may be broken up into several Wayland
events for practical reasons. For example, a `wl_pointer` will emit an `axis`
@@ -114,7 +114,7 @@ If this sounds too complicated, don't sweat it. Many applications don't have to
worry about input frames. It's only when you start doing more complex input
event handling that you'll want to concern yourself with this.
-## Releasing devices
+### Releasing devices
When you're done using a device, each interface has a `release` request you can
use to clean it up. It'll look something like this:
diff --git a/src/seat/example.md b/src/seat/example.md
index fa1fe5d..73a7f6f 100644
--- a/src/seat/example.md
+++ b/src/seat/example.md
@@ -1,4 +1,4 @@
-# Expanding our example code
+## Expanding our example code
In previous chapters, we built a simple client which can present its surfaces on
the display. Let's expand this code a bit to build a client which can receive
@@ -8,7 +8,7 @@ events to stderr.
This is going to require a lot more code than we've worked with so far, so get
strapped in. The first thing we need to do is set up the seat.
-## Setting up the seat
+### Setting up the seat
The first thing we'll need is a reference to a seat. We'll add it to our
`client_state` struct, and add keyboard, pointer, and touch objects for later
@@ -73,7 +73,7 @@ also rig up that listener:
If you compile (`cc -o client client.c xdg-shell-protocol.c`) and run this now,
you should seat the name of the seat printed to stderr.
-## Rigging up pointer events
+### Rigging up pointer events
Let's get to pointer events. If you recall, pointer events from the Wayland
server are to be accumulated into a single logical event. For this reason, we'll
@@ -356,7 +356,7 @@ confusing, though. All we're doing here is pretty-printing the accumulated state
for this frame to stderr. If you compile and run this again now, you should be
able to wiggle your mouse over the window and see input events printed out!
-## Rigging up keyboard events
+### Rigging up keyboard events
Let's update our `client_state` struct with some fields to store XKB state.
@@ -557,7 +557,7 @@ you to decide.
If you compile this again, you should be able to start typing into the window
and see your input printed into the log. Huzzah!
-## Rigging up touch events
+### Rigging up touch events
Finally, we'll add support for touch-capable devices. Like pointers, a "frame"
event exists for touch devices. However, they're further complicated by the
@@ -837,7 +837,7 @@ Compile and run this again, and you'll be able to see touch events printed to
stderr as you interact with your touch device (assuming you have such a device
to test with). And now our client supports input!
-## What's next?
+### What's next?
There are a lot of different kinds of input devices, so extending our code to
support them was a fair bit of work — our code has grown by 2.5× in
diff --git a/src/seat/keyboard.md b/src/seat/keyboard.md
index 83df82b..1e27fc9 100644
--- a/src/seat/keyboard.md
+++ b/src/seat/keyboard.md
@@ -1,4 +1,4 @@
-# Keyboard input
+## Keyboard input
Equipped with an understanding of how to use XKB, let's extend our Wayland code
to provide us with key events to feed into it. Similarly to how we obtained a
@@ -17,7 +17,7 @@ keyboard.
But how do you actually use it? Let's start with the basics.
-## Key maps
+### Key maps
When you bind to `wl_keyboard`, the first event that the server is likely to
send is `keymap`.
@@ -69,7 +69,7 @@ Once we have a keymap, we can interpret future keypress events for this
`wl_keyboard`. Note that the server can send a new keymap at any time, and all
future key events should be interpreted in that light.
-## Keyboard focus
+### Keyboard focus
```
@@ -94,7 +94,7 @@ The "enter" event also includes an array of currently pressed keys. This is an
array of 32-bit unsigned integers, each representing the scancode of a pressed
key.
-## Input events
+### Input events
Once the keyboard has entered your surface, you can expect to start receiving
input events.
@@ -152,7 +152,7 @@ static void wl_keyboard_modifiers(void *data, struct wl_keyboard *wl_keyboard,
}
```
-## Key repeat
+### Key repeat
The last event to consider is the "repeat_info" event:
diff --git a/src/seat/pointer.md b/src/seat/pointer.md
index 172a73d..fe398ad 100644
--- a/src/seat/pointer.md
+++ b/src/seat/pointer.md
@@ -1,4 +1,4 @@
-# Pointer input
+## Pointer input
Using the `wl_seat.get_pointer` request, clients may obtain a `wl_pointer`
object. The server will send events to it whenever the user moves their pointer,
@@ -75,7 +75,7 @@ After the cursor has entered your surface and you have attached an appropriate
cursor, you're ready to start processing input events. There are motion, button,
and axis events.
-## Pointer frames
+### Pointer frames
A single frame of input processing on the server could carry information about
lots of changes — for example, polling the mouse once could return, in a
@@ -91,7 +91,7 @@ Clients should accumulate all `wl_pointer` events as they're received, then
process pending inputs as a single pointer event once the "frame" event is
received.
-## Motion events
+### Motion events
Motion events are specified in the same coordinate space as the `enter` event
uses, and are straightforward enough:
@@ -108,7 +108,7 @@ Like all input events which include a timestamp, the `time` value is a
monotonically increasing millisecond-precision timestamp associated with this
input event.
-## Button events
+### Button events
Button events are mostly self-explanatory:
@@ -133,7 +133,7 @@ the most useful ones will probably be represented by the constants `BTN_LEFT`,
`BTN_RIGHT`, and `BTN_MIDDLE`. There are more, I'll leave you to peruse the
header at your leisure.
-## Axis events
+### Axis events
The axis event is used for scrolling actions, such as rotating your scroll wheel
or rocking it from left to right. The most basic form looks like this:
diff --git a/src/seat/touch.md b/src/seat/touch.md
index c8ce269..de7c626 100644
--- a/src/seat/touch.md
+++ b/src/seat/touch.md
@@ -1,4 +1,4 @@
-# Touch input
+## Touch input
On the surface, touchscreen input is fairly simple, and your implementation can
be simple as well. However, the protocol offers you a lot of depth, which
@@ -15,7 +15,7 @@ Similarly to other input devices, you may obtain a `wl_touch` resource with
`wl_seat.get_touch`, and you should send a "release" request when you're
finished with it.
-## Touch frames
+### Touch frames
Like pointers, a single frame of touch processing on the server might carry
information about many changes, but the server sends these as discrete Wayland
@@ -29,7 +29,7 @@ Clients should accumulate all `wl_touch` events as they're received, then
process pending inputs as a single touch event when the "frame" event is
received.
-## Touch and release
+### Touch and release
The first events we'll look at are "down" and "up", which are respectively
raised when you press your finger against the device, and remove your finger
@@ -58,7 +58,7 @@ argument. The time is a monotonically increasing timestamp with an arbitrary
epoch, in milliseconds.[^2] Note also the inclusion of a serial, which can be
included in future requests to associate them with this input event.
-## Motion
+### Motion
After you receive a "down" event with a specific touch ID, you will begin to
receive motion events which describe the movement of that touch point across the
@@ -76,7 +76,7 @@ device.
The "x" and "y" coordinates here are in the relative coordinate space of the
surface which the "enter" event was sent for.
-## Gesture cancellation
+### Gesture cancellation
Touch events often have to meet some threshold before they're recognized as a
gesture. For example, swiping across the screen from left to right could be used
@@ -96,7 +96,7 @@ taking over.
When you receive this event, all active touch points are cancelled.
-## Shape and orientation
+### Shape and orientation
Some high-end touch hardware is capable of determining more information about
the way the user is interacting with it. For users of suitable hardware and
diff --git a/src/seat/xkb.md b/src/seat/xkb.md
index b439146..815e292 100644
--- a/src/seat/xkb.md
+++ b/src/seat/xkb.md
@@ -1,4 +1,4 @@
-# XKB, briefly
+## XKB, briefly
The next input device on our list is keyboards, but we need to stop and give you
some additional context before we discuss them. Keymaps are an essential detail
@@ -27,7 +27,7 @@ primitives for dealing with all of these cases, and maintains a state machine
which tracks what your keyboard is doing and figures out exactly which *Unicode
codepoints* the user is trying to type.
-## Using XKB
+### Using XKB
So how is xkbcommon actually used? Well, the first step is to link to it and
grab the header, `xkbcommon/xkbcommon.h`.[^1] Most programs which utilize
diff --git a/src/surfaces-in-depth/damaging-surfaces.md b/src/surfaces-in-depth/damaging-surfaces.md
index 0c1aaa8..4e1f716 100644
--- a/src/surfaces-in-depth/damaging-surfaces.md
+++ b/src/surfaces-in-depth/damaging-surfaces.md
@@ -1,4 +1,4 @@
-# Damaging surfaces
+## Damaging surfaces
You may have noticed in the last example that we added this line of code when we
committed a new frame for the surface:
diff --git a/src/surfaces-in-depth/frame-callbacks.md b/src/surfaces-in-depth/frame-callbacks.md
index 1e5f030..f3c1850 100644
--- a/src/surfaces-in-depth/frame-callbacks.md
+++ b/src/surfaces-in-depth/frame-callbacks.md
@@ -1,4 +1,4 @@
-# Frame callbacks
+## Frame callbacks
The simplest way to update your surface is to simply render and attach new
frames when it needs to change. This approach works well, for example, with
diff --git a/src/surfaces-in-depth/hidpi.md b/src/surfaces-in-depth/hidpi.md
index 70afbde..bea94e4 100644
--- a/src/surfaces-in-depth/hidpi.md
+++ b/src/surfaces-in-depth/hidpi.md
@@ -1,4 +1,4 @@
-# High density surfaces (HiDPI)
+## High density surfaces (HiDPI)
In the past several years, a huge leap in pixel density in high-end displays has
been seen, new displays packing twice as many pixels into the same physical area
diff --git a/src/surfaces-in-depth/lifecycle.md b/src/surfaces-in-depth/lifecycle.md
index cfead55..8007731 100644
--- a/src/surfaces-in-depth/lifecycle.md
+++ b/src/surfaces-in-depth/lifecycle.md
@@ -1,4 +1,4 @@
-# Surface lifecycle
+## Surface lifecycle
We mentioned earlier that Wayland is designed to update everything atomically,
such that no frame is ever presented in an invalid or intermediate state. Of the
diff --git a/src/surfaces-in-depth/subsurfaces.md b/src/surfaces-in-depth/subsurfaces.md
index 575594b..87400b6 100644
--- a/src/surfaces-in-depth/subsurfaces.md
+++ b/src/surfaces-in-depth/subsurfaces.md
@@ -1,4 +1,4 @@
-# Subsurfaces
+## Subsurfaces
There's only one[^1] surface role defined in the core Wayland protocol,
`wayland.xml`: subsurfaces. They have an X, Y position relative to the parent
diff --git a/src/surfaces-in-depth/surface-regions.md b/src/surfaces-in-depth/surface-regions.md
index fd4b8f3..df876d0 100644
--- a/src/surfaces-in-depth/surface-regions.md
+++ b/src/surfaces-in-depth/surface-regions.md
@@ -1,4 +1,4 @@
-# Surface regions
+## Surface regions
We've already used the `wl_compositor` interface to create `wl_surfaces` via
`wl_compositor.create_surface`. Note, however, that it has a second request:
diff --git a/src/surfaces/compositor.md b/src/surfaces/compositor.md
index 0e57d28..9ab8e7f 100644
--- a/src/surfaces/compositor.md
+++ b/src/surfaces/compositor.md
@@ -1,4 +1,4 @@
-# Using wl_compositor
+## Using wl_compositor
They say naming things is one of the most difficult problems in computer
science, and here we are, with evidence in hand. The `wl_compositor` global is
diff --git a/src/surfaces/dmabuf.md b/src/surfaces/dmabuf.md
index dd68677..c162c4d 100644
--- a/src/surfaces/dmabuf.md
+++ b/src/surfaces/dmabuf.md
@@ -1,4 +1,4 @@
-# Linux dmabuf
+## Linux dmabuf
@@ -33,7 +33,7 @@ particular. However, we can provide a short summary of its use.
Should you need to change the size of the `wl_egl_window` later, use
`wl_egl_window_resize`.
-## But I really want to know about the internals
+### But I really want to know about the internals
Some Wayland programmers who don't use libwayland complain that this approach
ties Mesa and libwayland tightly together, which is true. However, untangling
@@ -43,7 +43,7 @@ for details on the protocol, and Mesa's implementation at
`src/egl/drivers/dri2/platform_wayland.c` (at the time of writing). Good luck
and godspeed.
-## For the server
+### For the server
Unfortunately, the details for the compositor are both complicated and
out-of-scope for this book. I can point you in the right direction, however:
diff --git a/src/surfaces/roles.md b/src/surfaces/roles.md
index 1e76209..9114026 100644
--- a/src/surfaces/roles.md
+++ b/src/surfaces/roles.md
@@ -1,4 +1,4 @@
-# Surface roles
+## Surface roles
We have created a pixel buffer, sent it to the server, and attached it to a
surface through which we can allegedly present it to the user. However, one
diff --git a/src/surfaces/shared-memory.md b/src/surfaces/shared-memory.md
index 0484676..96a52d0 100644
--- a/src/surfaces/shared-memory.md
+++ b/src/surfaces/shared-memory.md
@@ -1,4 +1,4 @@
-# Shared memory buffers
+## Shared memory buffers
The simplest means of getting pixels from client to compositor, and the only one
enshrined in `wayland.xml`, is `wl_shm` — shared memory. Simply put, it
@@ -7,7 +7,7 @@ allows you to transfer a file descriptor for the compositor to mmap with
synchronization primitives to keep everyone from fighting over each buffer, and
you have a workable — and portable — solution.
-## Binding to wl_shm
+### Binding to wl_shm
The registry global listener explained in chapter 5.1 will advertise the
`wl_shm` global when it's available. Binding to it is fairly straightforward.
@@ -47,7 +47,7 @@ full list of possible pixel formats is given in `wayland.xml`. Two formats are
required to be supported: `ARGB8888`, and `XRGB8888`, which are 24-bit color,
with and without an alpha channel respectively.
-## Allocating a shared memory pool
+### Allocating a shared memory pool
A combination of POSIX `shm_open` and random file names can be utilized to
create a file suitable for this purpose, and `ftruncate` can be utilized to
@@ -131,7 +131,7 @@ struct wl_shm *shm = ...; // Bound from registry
struct wl_shm_pool *pool = wl_shm_create_pool(shm, fd, shm_pool_size);
```
-## Creating buffers from a pool
+### Creating buffers from a pool
Once word of this gets to the compositor, it will `mmap` this file descriptor as
well. Wayland is asynchronous, though, so we can start allocating buffers from
@@ -185,7 +185,7 @@ role.
[^1]: "Damaged" meaning "this area needs to be redrawn"
-## wl_shm on the server
+### wl_shm on the server
Before we get there, however, the server-side part of this deserves note.
libwayland provides some helpers to make using `wl_shm` easier. To configure it
diff --git a/src/surfaces/surface-roles.md b/src/surfaces/surface-roles.md
index b52b9f0..9db3a96 100644
--- a/src/surfaces/surface-roles.md
+++ b/src/surfaces/surface-roles.md
@@ -1 +1 @@
-# Surface roles
+## Surface roles
diff --git a/src/wayland-display/creation.md b/src/wayland-display/creation.md
index c731fcc..213ec64 100644
--- a/src/wayland-display/creation.md
+++ b/src/wayland-display/creation.md
@@ -1,8 +1,8 @@
-# Creating a display
+## Creating a display
Fire up your text editor — it's time to write our first lines of code.
-## For Wayland clients
+### For Wayland clients
Connecting to a Wayland server and creating a `wl_display` to manage the
connection's state is quite easy:
@@ -69,7 +69,7 @@ You can also obtain the file descriptor that the `wl_display` is using via
int wl_display_get_fd(struct wl_display *display);
```
-## For Wayland servers
+### For Wayland servers
The process is fairly simple for servers as well. The creation of the display
and binding to a socket are separate, to give you time to configure the display
diff --git a/src/wayland-display/event-loop.md b/src/wayland-display/event-loop.md
index 5f45d44..ff914fe 100644
--- a/src/wayland-display/event-loop.md
+++ b/src/wayland-display/event-loop.md
@@ -1,11 +1,11 @@
-# Incorporating an event loop
+## Incorporating an event loop
libwayland provides its own event loop implementation for Wayland servers to
take advantage of, but the maintainers have acknowledged this as a design
overstep. For clients, there is no such equivalent. Regardless, the Wayland
server event loop is useful enough, even if it's out-of-scope.
-## Wayland server event loop
+### Wayland server event loop
Each `wl_display` created by libwayland-server has a corresponding
`wl_event_loop`, which you may obtain a reference to with
@@ -35,7 +35,7 @@ occurs on that file descriptor. You will also need to call
[poll]: https://pubs.opengroup.org/onlinepubs/009695399/functions/poll.html
-## Wayland client event loop
+### Wayland client event loop
libwayland-client, on the other hand, does not have its own event loop. However,
since there is only generally one file descriptor, it's easier to manage
@@ -54,7 +54,7 @@ descriptor with `wl_display_get_fd`. Upon `POLLIN` events, call
`wl_display_dispatch` to process incoming events. To flush outgoing requests,
call `wl_display_flush`.
-## Almost there!
+### Almost there!
At this point you have all of the context you need to set up a Wayland
display and process events and requests. The only remaining step is to allocate
diff --git a/src/xdg-shell-basics.md b/src/xdg-shell-basics.md
index dea94e8..8b87471 100644
--- a/src/xdg-shell-basics.md
+++ b/src/xdg-shell-basics.md
@@ -15,7 +15,7 @@ you'll find it in the `wayland-protocols` package. It's probably installed at a
path somewhat like `/usr/share/wayland-protocols/stable/xdg-shell/xdg-shell.xml`
on your system.
-## xdg_wm_base
+### xdg_wm_base
`xdg_wm_base` is the only global defined by the specification, and it provides
requests for creating each of the other objects you need. The most basic
diff --git a/src/xdg-shell-basics/example-code.md b/src/xdg-shell-basics/example-code.md
index e2c3313..a08160c 100644
--- a/src/xdg-shell-basics/example-code.md
+++ b/src/xdg-shell-basics/example-code.md
@@ -1,4 +1,4 @@
-# Extended example code
+## Extended example code
Using the sum of what we've learned so far, we can now write a Wayland client
which displays something on the screen. The following code is a complete Wayland
diff --git a/src/xdg-shell-basics/xdg-surface.md b/src/xdg-shell-basics/xdg-surface.md
index 259ae12..754197c 100644
--- a/src/xdg-shell-basics/xdg-surface.md
+++ b/src/xdg-shell-basics/xdg-surface.md
@@ -1,4 +1,4 @@
-# XDG surfaces
+## XDG surfaces
Surfaces in the domain of xdg-shell are referred to as `xdg_surfaces`, and this
interface brings with it a small amount of functionality common to both kinds of
diff --git a/src/xdg-shell-basics/xdg-toplevel.md b/src/xdg-shell-basics/xdg-toplevel.md
index 2f18d06..ad1679a 100644
--- a/src/xdg-shell-basics/xdg-toplevel.md
+++ b/src/xdg-shell-basics/xdg-toplevel.md
@@ -1,4 +1,4 @@
-# Application windows
+## Application windows
We have shaved many yaks to get here, but it's time: XDG toplevel is the
interface which we will finally use to display an application window. The XDG
diff --git a/src/xdg-shell-in-depth/configuration.md b/src/xdg-shell-in-depth/configuration.md
index d38cbd9..4b79fa3 100644
--- a/src/xdg-shell-in-depth/configuration.md
+++ b/src/xdg-shell-in-depth/configuration.md
@@ -1,4 +1,4 @@
-# Configuration & lifecycle
+## Configuration & lifecycle
Previously, we created a window at a fixed size of our choosing: 640x480.
However, the compositor will often have an opinion about what size our window
@@ -34,7 +34,7 @@ assumed a state consistent with these suggestions, it sends an `ack_configure`
request with the same serial to indicate this. Upon the next commit to the
associated `wl_surface`, the compositor will consider the state consistent.
-## XDG top-level lifecycle
+### XDG top-level lifecycle
Our example code from chapter 7 works, but it's not the best citizen of the
desktop right now. It does not assume the compositor's recommended size, and if
@@ -162,7 +162,7 @@ diff --git a/client.c b/client.c
If you compile and run this client again, you'll notice that it's a lot more
well-behaved than before.
-## Requesting state changes
+### Requesting state changes
The client can also request that the compositor put the client into one of these
states, or place constraints on the size of the window.
diff --git a/src/xdg-shell-in-depth/interactive.md b/src/xdg-shell-in-depth/interactive.md
index 7f9bc23..b19cb60 100644
--- a/src/xdg-shell-in-depth/interactive.md
+++ b/src/xdg-shell-in-depth/interactive.md
@@ -1,4 +1,4 @@
-# Interactive move and resize
+## Interactive move and resize
Many application windows have interactive UI elements the user can use to drag
around or resize windows. Many Wayland clients, by default, expect to be
@@ -78,7 +78,7 @@ client-driven interactions with compositor-driven meta operations like
minimizing windows. If your client uses client-side decorations, you may use
this request for this purpose.
-## xdg-decoration
+### xdg-decoration
The last detail which bears mentioning when discussing the behavior of
client-side decorations is the protocol which governs the negotiation of their
diff --git a/src/xdg-shell-in-depth/popups.md b/src/xdg-shell-in-depth/popups.md
index 980824d..3312bca 100644
--- a/src/xdg-shell-in-depth/popups.md
+++ b/src/xdg-shell-in-depth/popups.md
@@ -1,4 +1,4 @@
-# Popups
+## Popups
When designing software which utilizes application windows, there are many cases
where smaller secondary surfaces are used for various purposes. Some examples
@@ -48,7 +48,7 @@ Then we can render and attach buffers to our popup surface with the same
lifecyle discussed earlier. We also have access to a few other popup-specific
features.
-## Configuration
+### Configuration
Like the XDG toplevel configure event, the compositor has an event which it may
use to suggest the size for your popup to assume. Unlike toplevels, however,
@@ -69,7 +69,7 @@ position of the popup relative to its parent surface.
The client can influence these values with the XDG positioner, to be discussed
in chapter 10.4.
-## Popup grabs
+### Popup grabs
Popup surfaces will often want to "grab" all input, for example to allow the
user to use the arrow keys to select different menu items. This is facilitated
@@ -88,7 +88,7 @@ request. These semantics are covered in detail in chapter 9. The compositor can
cancel this grab later, for example if the user presses escape or clicks outside
of your popup.
-## Dismissal
+### Dismissal
In these cases where the compositor dismisses your popup, such as when the
escape key is pressed, the following event is sent:
@@ -101,7 +101,7 @@ To avoid race conditions, the compositor keeps the popup structures in memory
and services requests for them even after their dismissal. For more detail about
object lifetimes and race conditions, see chapter 2.4.
-## Destroying popups
+### Destroying popups
Client-initiated destruction of a popup is fairly straightforward:
diff --git a/src/xdg-shell-in-depth/positioners.md b/src/xdg-shell-in-depth/positioners.md
index bac2330..bc592e2 100644
--- a/src/xdg-shell-in-depth/positioners.md
+++ b/src/xdg-shell-in-depth/positioners.md
@@ -1,4 +1,4 @@
-# Positioners
+## Positioners
When we introduced pop-ups a few pages ago, we noted that you had to provide a
positioner object when creating the pop-up. We asked you not to worry about it
@@ -15,7 +15,7 @@ client specify certain constraints in how the pop-up can be moved or resized,
and then the compositor, being in full possession of the facts, can make the
final call on how to accommodate.
-# The Basics
+### The Basics
```xml
@@ -36,7 +36,7 @@ The set_size request is used to set the size of the pop-up window being created.
All clients which use a positioner will use these two requests. Now, let's get
to the interesting ones.
-# Anchoring
+### Anchoring
```xml
```
diff --git a/wayland-logo.png b/wayland-logo.png
new file mode 100644
index 0000000..76aca75
Binary files /dev/null and b/wayland-logo.png differ