Some days when I am debugging, I run across a bug in gdb and think, “I wish someone would fix that already”.
Then I remember that I’m working on gdb now.
Some days when I am debugging, I run across a bug in gdb and think, “I wish someone would fix that already”.
Then I remember that I’m working on gdb now.
Years ago I read Vacuum Flowers and loved it — it was, and remains, one of my favorite cyberpunk novels. I remember believing at the time that Swanwick was a mysterious author; I heard a rumor about a sequel to Flowers but nothing else.
The other day I ran across The Dog Said Bow Wow in the library, and now I suspect that, as usual, I simply did not pay any attention to developments in the SF publishing world, but instead just believed I would somehow know. Most likely (continuing my tradition: I didn’t look), Swanwick has had a robust and verbose career.
Anyway, Bow Wow is a series of delightful short stories. I read it in one sitting. You probably will too.
We checked out Three Bags Full from the library on a whim — Elyn grabbed it off the shelf to show to me, and I immediately thought of somehow using it to poke fun at a friend of ours who likes cat mysteries. A mystery solved by a flock of sheep sounds like the next logical step!
This turns out to be a great book. I was hooked from the first page, titled “Dramatis Oves”, and I got a lot of pleasure from reading the rest of it. It is at turns hilarious, scary, existential, sad, and moving. It is consistently creative and a great comfort read.
While we were watching a ball in a TV adaptation of Northanger Abbey last night, Elyn hit upon a genius idea: DDR Georgian Edition. Just the thing for those Austen revival parties!
Despite my lackluster performance at a talk last month (about Emacs, what else?) the Boulder LUG let me attend another meeting. Thanks!
This past Thursday’s topic was PostgreSQL, presented by Kevin Kempter. I’d say about 40 people attended, which for BLUG translates to standing room only. Databases are a hot topic.
I was fascinated by this talk — I know little about databases and enjoy hearing about them. Although it ranged strangely between the very generic (high-level comparison of MySQL and PostgreSQL) and the incredibly specific (rundown of command line options to psql), Kevin’s depth of knowledge and cool stories made this well worth attending.
Postgres is a good product. My impression, overall, is that while it is missing some gloss that Oracle has, it is basically “enterprise-ready”. Kevin has a project now that gets one terabyte of new data per day, and Postgres handles that fine. Refreshingly, Kevin did not spend much time defending the choice of an open source product over a proprietary one. I guess at a LUG that would seem unnecessary — I thought so, too, until somebody asked why bother.
A database is a big programming environment in its own right. One take away for me was: learn something before starting. Kevin said he’s run across projects that did not vacuum regularly and were running with a lot of bloat — basic stuff. Based on his talk and the questions, some of which I did not understand at all, I would say that if I were running a company I would just hire a DBA and move on.
Kevin is a fan of Slony-I for replication. This came up over and over through the talk, as did table partitioning (which I had never heard of before).
One goal I have for integrating Python scripting into gdb is to be able to fully control gdb from Python. I’ve made a few steps toward this recently. Today I can do:
#! /home/tromey/gnu/python-gdb/build/gdb/gdb --python import sys, gdb from hack import inferior child = inferior(sys.argv) if not child.run(): gdb.execute("bt 5") gdb.cli()
This is a short script that is marked executable. With this, I can invoke “stop-if-broken my-program arguments
“. This will run the program; if it dies for some reason, it will print a stack trace and bring up the gdb command line. Otherwise, it exits.
I like to think you can already see the future of gdb here, though. And although this is pretty young, you can easily extend it a bit — for instance, you could add breakpoints between creating the inferior and starting it. Still, don’t be totally fooled; this is still a toy and there is a lot to do on the gdb side.
The “hack
” stuff is because I have no clue about intelligently managing Python packages. I’m looking for a good guide here. What I really want to do, I think, is have classes like Inferior
, Breakpoint
, etc, directly in the gdb namespace, but I don’t want everything in one huge file. Or is this javathink? Writing “import gdb.inferior.Inferior
” feels weird. (If you’re going to give me advice — which I really want — there is an added wrinkle, which is that the gdb
module is created directly in the C code in gdb.)
Yesterday I set up a new blog aggregator for Elyn. It is called “All About Psychotherapy and Counseling“, and aggregates blogs from various therapists, including her.
Setting this stuff up is pretty easy — I used WordPress, because the hosting service makes it very, very easy to install, and because Elyn already knows how to use it. Then she found a WordPress theme she liked; I installed that and tweaked it a bit with some newfound PHP knowledge. And finally, I installed the excellent FeedWordPress plugin to handle the actual aggregation. There were a couple tricky bits — I had to use a trick to get the author attribution to work properly (I don’t know yet if this is a FeedWordPress problem or a blogspot problem) — but nothing too extreme.
I’m a fan of WordPress.
Go read the new planet.
This weekend our wireless router went on the fritz, so I replaced it. Naturally, this turned into a multi-day, hair-pulling ordeal.
First, the new wireless box did not play well with the DSL router. For some reason, it was apparently programmed with an extra error check, so I couldn’t get its built-in DHCP server to hand out addresses on the same network as the DSL server, even though I configured them to handle different ranges. The old wireless handled this just fine… grrr.
So, I subnetted, using 192.168.0.0/7. Great! Everything is working. Except…
Elyn couldn’t print any more. Looking in the logs I saw the dreaded client-error-not-found
. My searches yielded nothing worthwhile — am I unusually bad at searching, or is there just little information out there?
First, I changed the machine attached to the printer to have a (local) static IP. It’s been a long time since I did this kind of thing (I switched to NetworkManager as early as possible), and so this took a while. (I didn’t find a man page describing the ifcfg files — is there one?) A static IP let me hard-code the IP address on Elyn’s Mac without worrying that a reboot would invalidate her configuration.
Oh, BTW — setting up a new printer is a great example of a place where the Mac’s vaunted GUI is not so hot. For one thing, as far as I can tell, you can’t edit an existing printer — you have to delete it and start over. I got really good at typing “192.168.0.50”.
It turns out that having a default printer configured in CUPS was not enough to let the Mac print properly. I don’t know whether this is a bug on the Mac or a bug in the CUPS in F8 — I saw requests in the log for “ipp://192.168.0.50:631/
“, but then CUPS would return the not-found error, and the print job would fail.
In the end I hit upon telling the Mac that the printer queue name was “printers/Name” (“Name” being the name of the printer), and this worked… I think this is amazingly obscure.
Due to my recent hacking on gdb, I’ve been thinking recently about patch review. Mostly, I seem to be interested the social aspects of review; though there’s also a lot to discuss concerning the mechanics, and that would probably be a useful area for a tutorial of some kind.
Here are a few guidelines I came up with, based on what I think I do when I review a patch:
You may have heard that I’ve moved to the Frysk project for a while. In case you’re curious, my incremental compiler project is on hold while I do this. (I’ve lamely not blogged about the gcc summit or other things that have happened lately… I’m trying to catch up on this stuff, I hope when I do you won’t mind a bit of old news.)
Anyway, we’ve started the process of changing frysk’s direction. You can read about what we’re planning in this post on the frysk list; feel free to respond — we want your input. Essentially, we’re looking at changing some aspects of the implementation, and more explicitly making it be a debugger.