From mboxrd@z Thu Jan 1 00:00:00 1970 Path: news.gmane.org!not-for-mail From: joakim@verona.se Newsgroups: gmane.emacs.tangents Subject: The xwidget branch origin story Date: Sat, 14 Nov 2015 21:13:25 +0100 Message-ID: NNTP-Posting-Host: plane.gmane.org Mime-Version: 1.0 Content-Type: text/plain X-Trace: ger.gmane.org 1447652281 10246 80.91.229.3 (16 Nov 2015 05:38:01 GMT) X-Complaints-To: usenet@ger.gmane.org NNTP-Posting-Date: Mon, 16 Nov 2015 05:38:01 +0000 (UTC) To: emacs-tangents@gnu.org Original-X-From: emacs-tangents-bounces+get-emacs-tangents=m.gmane.org@gnu.org Mon Nov 16 06:37:50 2015 Return-path: Envelope-to: get-emacs-tangents@m.gmane.org Original-Received: from lists.gnu.org ([208.118.235.17]) by plane.gmane.org with esmtp (Exim 4.69) (envelope-from ) id 1ZyCU9-00062B-7V for get-emacs-tangents@m.gmane.org; Mon, 16 Nov 2015 06:37:49 +0100 Original-Received: from localhost ([::1]:45610 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1ZyCU8-0006iX-J6 for get-emacs-tangents@m.gmane.org; Mon, 16 Nov 2015 00:37:48 -0500 Original-Received: from eggs.gnu.org ([2001:4830:134:3::10]:45859) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1ZxhCq-0004K1-Ax for emacs-tangents@gnu.org; Sat, 14 Nov 2015 15:13:53 -0500 Original-Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1ZxhCm-0000P1-90 for emacs-tangents@gnu.org; Sat, 14 Nov 2015 15:13:52 -0500 Original-Received: from mx6.bahnhof.se ([213.80.101.16]:47213) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1ZxhCl-0000L5-VU for emacs-tangents@gnu.org; Sat, 14 Nov 2015 15:13:48 -0500 Original-Received: from localhost (mf.bahnhof.se [213.80.101.20]) by mx6-reinject (Postfix) with ESMTP id 94B0341A03 for ; Sat, 14 Nov 2015 21:13:44 +0100 (CET) X-Virus-Scanned: by amavisd-new using ClamAV at bahnhof.se (MF2) Original-Received: from mf2.bahnhof.se ([127.0.0.1]) by localhost (mf2.bahnhof.se [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id jNto8KCzKPtw for ; Sat, 14 Nov 2015 21:13:36 +0100 (CET) Original-Received: from mta.verona.se (h-235-62.a149.priv.bahnhof.se [85.24.235.62]) by mf2.bahnhof.se (Postfix) with ESMTP id 5466E940157 for ; Sat, 14 Nov 2015 21:13:35 +0100 (CET) Original-Received: from localhost (unknown [127.0.0.1]) by mta.verona.se (Postfix) with ESMTP id C521A4EE9DC for ; Sat, 14 Nov 2015 20:13:35 +0000 (UTC) X-Virus-Scanned: amavisd-new at verona.se Original-Received: from mta.verona.se ([127.0.0.1]) by localhost (exodia.verona.se [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id vG-tIvy0tSto for ; Sat, 14 Nov 2015 21:13:25 +0100 (CET) Original-Received: from exodia.verona.se (www.verona.se [192.168.200.15]) by mta.verona.se (Postfix) with ESMTP id 96CDE4EE9DB for ; Sat, 14 Nov 2015 21:13:25 +0100 (CET) User-Agent: Gnus/5.13 (Gnus v5.13) Emacs/25.0.50 (gnu/linux) X-detected-operating-system: by eggs.gnu.org: GNU/Linux 2.2.x-3.x [generic] X-Received-From: 213.80.101.16 X-BeenThere: emacs-tangents@gnu.org X-Mailman-Version: 2.1.14 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: emacs-tangents-bounces+get-emacs-tangents=m.gmane.org@gnu.org Original-Sender: emacs-tangents-bounces+get-emacs-tangents=m.gmane.org@gnu.org Xref: news.gmane.org gmane.emacs.tangents:15 Archived-At: There are some misconceptions about the xwidget branch, and some people are just scratching their heads wondering what the branch is for. For me it is easier to answer these questions by regaling you with the very interesting origin story of the xwidget branch! I like making music and art in my spare time. I particularly like the particular electronic music genre called Live Coding. In this genre you code music live, and as the code changes, the music changes. It is a very interesting style for me, but there are some challenges of course. You don't have much time to think about your code, and you need to have fast feedback from your programming environment. There are several Lisp based environments for live coding, and I like the Overtone one, which is based on the Clojure lisp and the Supercollider sound engine. Mere's a tiny fragment from my project called Sylt. (def d (industrial2)) (ctl d :wobble 1) (ctl d :wobble-vol 1) (ctl d :kick-vol 1) (ctl d :note 40) (ctl d :bpm 250) The industrial2 function starts an algorithmic sequencer. You can change the wobble aspect of the sound by (ctl d :wobble 1), just by evaluating the code in Emacs with c-x e, just as you do with Lisp. You can change the numerical constants with Emacs macrology and the like, and directly affect the sound. But wouldn't it be nice if you could have a slider controller right in your Emacs window, directly below the code? Emacs could parse the forms, with the Emacs parser infrastructure Semantic, and provide the slider just by parsing the code, or a comment. That would be really useful. At the time I had recently provided the Imagemagic patch to Emacs. How hard could it be to make a slider? It should work more or less like an image object. It turned out to be more complex than I thought at the outset, but it did work in the end. It was nice, because I could get a tighter loop between creativity and results. Given that the infrastructure needed to have a slider component in Emacs would be more or less the same as any graphical component, how hard could it be to have a browser widget? The browser widget turned out to be very useful for me when working with things like animations in svg and html within Emacs. And that's the origin story of the xwidget branch. The basic idea is to have a tighter feedback loop, similar to what the REPL gives you when developing. The xwidget_mvp branch, is a stripped down version of the xwidget branch that only provides the browser widget. The idea was to merge this branch to master first, and then resume work on the xwidget branch that has some further useful features. The xwidget_mvp branch should be understood as a stepping stone on the road to a larger goal. I hope this also clears up the question of why you can't use a window manager hack instead of xwidget objects. The functionality in the xwidget branch provides a much deeper integration between the component and Emacs than you get with a window manager hack. You can access the components internals from Emacs. The xwidget branch for instance contains a (at the moment limited) interface between Emacs and the Gnome introspection model. As the interface matures, you would be able to call component methods directly from Lisp without writing C code. Another thing that gets asked a lot is the xwidget name. I just combined 'x' meaning any, and widget, thus xwidget. I needed a prefix in the code. In retrospect the name wasn't very descriptive, because people believe that the branch is only meant for X windows, which it isn't, even if I only have tested it there. Anyway, I hope this clears things up a bit. -- Joakim Verona