A Certain Rocking Vuntz

So, I just plowed through a few hundred emails in my gnome-panel bugzilla.gnome.org folder. In one
sense it was incredibly boring, because I don’t think I actually
interacted with a single bug report, but in another sense its was just
incredibly awesome. The folder appears to be just full of bugs which
Vincent Untz has already
closed. Rocking!

I didn’t know Vincent had a blog, interesting. I’ll need to
polish my French a bit to understand it, though. About all I could
understand was "J'adore vim". I guess its a good thing he
uses vim, really. If he used emacs he’d put us all to even more
shame fixing even more bugs.

SSH, X Forwarding and Xauth

Discovered something interesting yesterday while trying to figure out
why Sabayon wasn’t
working for jdennis over SSH:

  • With ssh -Y, the SSH server creates a proxy X server to
    your local display which is just like any other SSH tunnel. Then
    it points $DISPLAY at the tunnel,
    e.g. DISPLAY=:10
  • In order for you to have permission to access the local display,
    though, it also needs to add an xauth cookie your ~/.Xauthority on
    the remote host.
  • The interesting part is that it doesn’t do what you might assume
    and just forward your xauth cookie for the local display to the
    remote host. Instead it creates another cookie, sends that to the
    remote host and its that cookie which gets merged to your
    ~/.Xauthority. When you try and connect from the remote host to the
    local display over the tunnel, the SSH client compares the cookie
    in the first protocol message and if it matches the one it
    generated for the tunnel, it swaps that cookie with the original
    cookie and allows the connection to complete.

At first that might just seem like misguided paranoid delusional
crackrock, but it does actually make sense. With this cool trick, if
you SSH to a compromised machine (i.e. a machine where an attacker can
access you ~/.Xauthority), then your display is only vulnerable while
you remain logged in. Once you log out again, the compromised cookie
is useless.

Old Bugs

Luis commented on old
bugs recently. It certainly feels good to close old bugs. Like this four year old
bug
.

People will be glad to know that with very latest glibc (it’ll be in
glibc 2.3.4), you’ll be able to change the timezone and the clock
applet will actually notice. Yay for us! 🙂

Aching All Over

Spent the weekend surfing with five friends on the wild and windy west
coast. Having never surfed before, I’m now so sore I can barely
move. If I had to leave the house to do my job, I’d be taking the day
off I reckon.

Six of the lads going away for the weekend used to be a Very Dangerous
Thing. But this weekend we managed to stay out of trouble. Are we
getting old or were we just too tired after the surfing? I wonder …

Never in my life have I never heard so many bad chat-up lines, though:

Boy standing in pub porch smoking. Girl runs in out of the rain and
stops. Boy, “How’s it going?”. Girl looks up, sees the inane drunken
grin, dismisses Boy immediately, looks back down at her phone and
starts typing a text message. Boy, “Ah, we’ve only just met and you’re
texting me already?”. Girl runs.

Panel Upgrade Brokeness

Tom
you’ll be delighted to know that if turn back time and decide to wait
until FC 3 to switch from RHL 9, the panel won’t forget your nicely
configured 10 launchers and 10 applets …

I can’t help with the turning back the time part, though 🙂

Notification Icons vs. Applets

It saddens me to see people writing applets as notification icons
because I’ve been there myself and spent a good deal of time trying to
get traction on the problem but ended up dropping the ball.

The Network Monitor started out as a notification icon. But I was
unhappy
with that for a number of reasons:

  1. No consensus on what the notification area should be used for. Until
    we have that, I’m worried about serious notification area bloat.
  2. No reasonable way of starting standalone notification icons short of
    “start gnome-netstatus and save your session”
  3. Other less fundamental problems – no keynav, no decent notification
    icon widget, can’t re-arrange icons, problems expanding icons to the
    full panel width …

I think we got tantalizingly close
to consensus
on the first problem, and EggStatusIcon is
an okay start on a widget, but in the end I ran out of time and turned
the Network Monitor into an applet.

Granted, I didn’t care whether or not the Network Monitor worked in
KDE. Cross-desktop applets isn’t an intractable problem, but just
lumping everything into the notification area is no way to approach
it.

Anyway, what I really wanted to mention was that I don’t think problem
(2) above is a session manager
problem
. The notification area itself should manage these icons,
not the session manager … if the panel isn’t running or the
notification area isn’t on the panel, these icons shouldn’t be running,
right?

At some point we discussed the idea that each notification icon should
install a .desktop file describing the icon. In the preferences dialog
you could enable/disable each icon. If the icon is standalone (like
the Network Monitor) it would have an Exec field and the
notification area would spawn it if enabled. If the icon is part of an
application (e.g. the epiphany download icon) the notification area
would only allow the icon to be displayed if its enabled.

All this reminded me that I actually had a good argument
against every application developer’s favourite feature – “Minimise to
Notification Area”. Don’t argue with a butler analogy!

Fixing the Session Manager

There’s lots of talk at the moment about “fixing the session manager”,
a sentiment I agree with, but I worry that if we don’t step back and
look at the big picture a bit we’ll screw things up even more.

To me, “Session Management” is all about providing the ability to take
a snapshot of what you’re doing right now, log out and be able to come
back later, log in and continue where you left off. So if I saved
the state of my session I’d expect following to be remembered:

  • the applications which are running, and the windows belong to
    those applications which are open
  • the size and position of all those windows
  • which documents I have open, the position within those
    documents etc.

Alternatively, people seem to set things up just how they’d like it
when they log in every morning and take a snaphot of the session at
that point.

This is the kind of functionality which XSMP was designed for but it
hasn’t yet worked out very well because most applications don’t do a
good job of implementing it and there’s not a lot of clarity on how
session state differs from application state (e.g. when you close your
browser, should it remember the last position of the window or should
it only remember that when you save your session?)

Anyway, lets forget about this feature for the moment. We do our best
to hide it in GNOME because we know its broken and my impression is
that most people don’t bother with it because of its brokeness. I’m
not too concerned about fixing it right now.

There’s this whole other thing the session manager does, though. It
starts what we think of as the “desktop shell” – the window manager,
panel, nautilus, screensaver daemon, settings daemon etc. etc. I think
most user’s mental model of the desktop would be that all these
components make up a single entity in which different applications
run. Whether the panel is running isn’t a part of transient session
state in the same way as whether the browser is running, its a fixed
part of the desktop.

Making this distinction gives us the ability to treat the session
shell and transient session state differently. But to what end? Well,
there’s a number of thing we can do differently if we treat the
management of the session shell as a different problem:

  1. We stop forcing users to understand that in order to have certain
    desktop services started at login they must run them and then
    save the session.
  2. We consolidate all the hard-coded hacks for starting desktop
    services into a single mechanism whereby desktop services can
    register themselves with the session manager and asked to be
    started up based on a user preference.
  3. We remove the possibility of “losing” important parts of the
    desktop from your session
  4. We can start the session in two stages – the desktop shell
    followed by the applications, perhaps hiding the entire screen
    until the desktop has started
  5. We can remove obtuse terms like “Metacity Window Manager”, “The
    Panel”, “Nautilus” from the splash screen and just have “Starting
    GNOME”.
  6. Since we won’t have to worry about managing legacy applications,
    we can think about dumping XSMP and coming up with a solution
    specifically designed for starting the desktop itself

Here’s another way to look at it – if you save your session while
you’re running GNOME, wouldn’t it make sense that when you log in to
KDE the same applications are running? If the answer to that is yes, I
think it shows that the question of activating desktop shell
components is orthogonal to the question of restoring session state on
login.

This is Home

Lashing rain. Blustering wind. Troubled skies. A soft day, to be
sure.

Driving back to Dublin after a weekend in Waterford. Its a narrow,
twisting road. Countryside punctuated regularily by small country
towns. You wouldn’t guess its the main road between two cities in a
first world country.

County Kilkenny makes up a good chunk of the journey. And Its a
special day for Kilkenny. In about thirty minutes we’ll know just how
special. Every town and village is deserted. The county colours,
black and amber, are everywhere.

Switch on the radio and Micheal O’Muircheartaigh, with his legendary
commentary in a guttural Kerry accent, brings life to this dull
scene. You suddenly realise that every living room and pub you pass is
crammed with excitement. All eyes are on Croke Park as Kilkenny battle
with Cork in the All Ireland Hurling Final.

“Henry Shefflin looks toward the goal. Only two in the goal. Shefflin
hits it hard … drives it hard … away way down the field … drives
it over the bar”

By the time I make it to Dublin, this battle will have finished. As I
pass by Croke Park the streets will be thronged with some very wet
people. Half of them won’t care, half of them will be utterly
miserable. Maybe I should just switch off the radio and guess from the
crowds who came out on top.

“8 points to Cork, 8 points to Kilkenny. Twenty Eight All Irelands a
piece … Its a hard game from start to finish.”

Nah, I may barely know the first thing about hurling, but I can’t miss
this.

In the end,
Cork came out well on top. Cork 0-17 Kilkenny 0-9.