unofficial mirror of guile-user@gnu.org 
 help / color / mirror / Atom feed
From: mark@markwitmer.com
To: guile-user@gnu.org
Subject: Guile XCB
Date: Mon, 17 Jun 2013 20:25:43 -0700	[thread overview]
Message-ID: <8738sgje14.fsf@mark-desktop.PK5001Z> (raw)


Hi everyone,

I'm pleased to announce that Guile XCB is, at last, a real thing! I had
to take a couple months off of working on it, but finally had time
recently to go back and get it in pretty good shape.

You can find it at https://github.com/mwitmer/guile-xcb.

In the end I was able to write the whole thing without any C, so maybe
this is a good candidate to include in the Guildhall. I've written a few
simple programs in it but haven't really pushed it too hard. Sometime in
the near-ish future I'd like to write some kind of window manager using
it and I'm sure there will be many bugs found and squashed in the
process!

I also had an interesting time coming up with the necessary autotools
magic to properly compile xml files to go files using the compiler I
wrote and then install them. I'm still not sure if I'm doing it the
right way -- adding new languages is really neat feature of Guile that's
still a little tricky to automate.

Here's the README:

1 Overview
==========

  Guile XCB is an X11 client library written entirely in Guile
  Scheme. It makes use of the Guile compiler and virtual machine to turn
  XML descriptions of the X protocol provided by the XCB project into
  Guile object code files.

  Support is included for the core X protocol and twenty-seven
  extensions. Guile XCB also includes some simple code for running
  asynchronous event loops.


2 Samples and Documentation
===========================

  Samples using Guile XCB can be found in the xcb/xml/samples
  directory. They include:

  - tinywm.scm: A Guile XCB implementation of tinywm 
  - win.scm: A simple demonstration of creating a window and receiving
     events 
  - randr.scm: A subset of the xrandr command line tool's functionality

  More detailed documentation resides in the texinfo manual included in
  this distribution.


3 Installation and Prerequisites
================================

  You can use the typical ./configure, make, make install chain to build
  Guile XCB.

  Guile XCB requires the latest release of Guile (2.0.9).


4 Project Status and Caveats
============================

  - The full XCB stack is implemented; however, many of the extensions
    haven't been extensively tested.

  - Extensions that send large requests are probably going to be too
    slow for practical use. In a future release, void and byte lists
    should be represented as bytevectors, not regular vectors.

  - Guile XCB includes a stripped-down Scheme implementation of Xauth
    that only supports UNIX sockets for now; it doesn't pick the "best"
    authentication method available, just the first.

  - XPRINT is excluded because it's deprecated and its XML file has just
    enough special cases in it that it wasn't worth including. Some
    other deprecated extensions are included simply because there was no
    reason not to.


-- 
Mark Witmer



             reply	other threads:[~2013-06-18  3:25 UTC|newest]

Thread overview: 5+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2013-06-18  3:25 mark [this message]
2013-06-18 12:50 ` Guile XCB Ludovic Courtès
2013-06-18 16:49   ` mark.d.witmer
2013-06-18 15:43 ` Stefan Israelsson Tampe
2013-06-18 16:54   ` mark.d.witmer

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

  List information: https://www.gnu.org/software/guile/

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=8738sgje14.fsf@mark-desktop.PK5001Z \
    --to=mark@markwitmer.com \
    --cc=guile-user@gnu.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).