Making Internet Explorer, Multiviews, and application/xhtml+xml agree (Edit x2)

Being a tinkerer and technophile, or more appropriately, a "simplicity/cleanliness in implementation/interface"-ophile, I've been trying to get a trivial portion of my site to serve as application/xhtml+xml to the proper browsers, while allowing me to use URLs without file-type extensions (which I think are a little ugly anyways). I ran into plenty of trouble finding a solution which IE agrees with, so I'm happy to share it to those who are interested. There are loads of purported solutions on-line, such as writing the HTTP Content-type header with php or python, or using Apache's mod-rewrite to redirect to the proper page based on the browser's Accept header. For me, the scripting solutions are out, as I'm interested in doing a bit more than just serving the same XHTML 1.0 in different ways. For instance, I'm using XHTML 1.1 now, and plan to use XHTML 2.0 in the future (when IE probably still won't support application/xhtml+xml). I don't want to just have the page interpreted differently, I want to use the new language to make my markup more simple and semantic. This leaves the option of maintaining two copies of the files in question and having the server determine which to serve when a request for an extension-less file such "index" is sent. There are two options here. The first is mod-rewrite, which unfortunately I couldn't get to work, and without access to my friend's "apache.conf", I can't debug. The other way is called "Multiviews", it's used primarily to serve different translations of a given page based on the browser or user-agent's language preference. This works unambiguously because basically every browser gets the Accept-Language header right. Unfortunately the Accept header is more problematic. The problem here, as usual lies in the most recent version of IE, which doesn't list much of anything in it's Accept header. For example, rather than list text/html as the preferred document type along with others IE accepts, it includes the blanket */*. This will of course match with any and all MIME types and therefore give no information about what IE "likes". So the trivial solution, which involves giving the browser what it asks for, is out. Time for a Hack. If one just does as he expects he needs to do in this situation, and puts the two files up as normal, turns on multiviews and trys to access the page in Firefox and then in IE, they'll find that the application/xhtml+xml is preferred in both. Unfortunately since IE won't interpret the page, users of IE (who really aren't bad people) get a download dialog box. This won't do, so I did some tinkering and I finally found a solution which actually works. I present to you my awesomely bad hack: Append white-space to the end of the smaller file, such that they are equal in size. The same XHTML is about 5-10% smaller, keeping in mind the need for IE-specific stylesheets and alerts. Lacking other reasons, Apache is providing the XHTML to (the seemingly indifferent) IE due to the smaller file size. The Multiviews algorithm spells this out. Seemingly there should be work-arounds, using .var and quality-of-source values, but I was unable to get this to work. The white-space has been the only workable solution I've come up with so far is . This results in the following behavior:
application/xhtml+xml
  • Firefox 1.5
  • Opera 8.5
text/html
  • IE 6.0
  • Safari 2.0
Once I script the white-space addition, serving both will be a simple process. If you have a better solution, or problems with the one above, feel free to comment or contact me.

Edit: Level to the Rescue

So here we have open-source web-serving. Someone has provided me a much better solution in the comments below, which I'll discuss now, lest we all do things without understanding them. The approach is to use the Apache level designator to force IE to prefer HTML over XHTML. One can see how this works in the Apache documentation for the Content Negotiation algoritm. I'd done some experimenting with the qs factor, but it had affected multiple browsers, rather than just one. Referring to the algorithm documentation, all quality-of-source values being equal, any browser which advertises that it prefers application/xhtml+xml over text/html in its HTTP accept-header will have the algorithm settled in step 1 of the algoritm. This covers Firefox and Opera. The others, IE & Safari, give both text/html and * a quality factor of 1, and so continue on down the steps. They had been finishing at step 8, which decides based on content-length. The much nicer solution is to stop them at step 4 in the algorithm, this time on the level parameter. A big thanks to Chris for the tip.

Edit 2: Not so fast

Alright so level isn't working for me... IE still tries to load the application/xhtml+xml files if they're of smaller file size. Tried level in both the .htaccess and through type-maps to no avail. If anyone has this working or another alternative, I'd be happy to hear it...

Blogging in Style...

My blog is too beautiful for words now that it's all dressed up. I stumbled upon this theme contest, and lo, I did find something that was passably suitable.

Close Seconds:

  • Zen Minimalist
  • Yaaarr! Tis me blog!

A case for SVG

An interesting things about the implementation of the theme: The "boxes", left and right are not simply block-level objects with red backgrounds and white borders. There's a single container div with a repeated backgrount image which includes the background color and borders. Also, the deeper red that the content sits on is not simply a background-color css rule, it's composed of a single vertically-stretched, horizontally-tiled (I think) image. I'd have preferred the former, but this wouldn't have given the nice left-to-right gradient on the page, and top-to-bottom gradient on the background. It'd be interesting to do this with a few lines of SVG. Why? Well the short answer is, I don't know how to use the visual graphics programs to make a pretty gradient, and nor do I think I should have to. If you take a look at how simple these graphics are, they can be described simply and easily by people without art training, so it would be nice if they were creatable by people such as myself as well. Unfortunately, the support isn't there, yet. It is, however, in the latest version of Firefox, which you should use for plenty of other reasons.

The Temporary Dangers of Omniscience

One of many questions I face these days is: "How public a life do I want to live?". Does recording political sentiments or actions put me at risk of some harm?

Could I see discrimination from potential employer? Do otherwise harmless acts, which would normally have gone unnoticed, once recorded bring on the chance of financial consequences? For instance, there were some small, inconsequential instances of fire at a recent party at my coop. Could something like this put us at risk of higher insurance costs, and how far could such a thing go?

As we collect and index more and more information, and move toward that ideal state of omniscience, shouldn't we take these instances less seriously, as we would have had they never been divulged and discovered? I believe that we often should, though we may not be able to count on that now. Should I put myself out on that edge, divulging my secrets, risking harms now, in the interest of creating the society I would like to see?

Clearly, in this case, I've already made a choice. You can see the pictures above.

I U+2764 Unicode

As always, I've been working on a random side-project, and lately, I've been learning to appreciate Unicode. Specifically, the rude awakening of having to deal with various character encodings rather than plain ASCII text. Of course, now I can say something silly like Oh '0x92', this must be good ol' 1252. But having to carry this sort of arbitrary knowledge around is a bit silly now, and will be all the more silly as people interact more across languages and cultures.

For now, it's a fact of life, and I know we can all learn to deal with it. But I'll be working toward the day when, we'[ll] take Unicode for granted and cheerfully accept things like perl variables called $¶, the URI http://alþing.is/þjóð/, and people named Zoë.

Until then, you can wear shirts like this one. Now, I'd like to point out here that the so-called Mac version is more correct. The diamond with inset question mark is actually a unicode character for "replacement character" (U+FFFD). Both Windows and (Gnome) Linux get this wrong (for now).

Words can hurt, or help...

Those of us who aren't particularly fond of either Republicans or Democrats will sometimes refer to both of them, as a group, as "Republicrats". Suggesting that, though their adherants will claim differently, the two are equally bad. Tonight, I heard a similar term, in a much different sense. The word is "Repubocrat". That's re-pub-O-crat, rather than re-pub-LI-crat, above. The difference is, the person doesn't mean anything by it except that she agrees with neither and both. This was her way of saying that she was fiscally conservative and socially liberal, a line libertarian folks have been pulling a long time to explain their position to "outsiders", with limited success. Unfortunately for libertarians, for many reasons, the little contact the public has with libertarians in a political context is sometimes not very good, and is almost never compelling. There are plenty of explanations for this, but the important issue here is that important ideas and positions are not being considered in part for communication problems. Looking back at the history of how political ideas gain traction, one that has appeared several times over the past hundered years, is to change the dynamics of the conversation by changing the language. An example is the word "Liberal" in America. In most of the world, "Liberals" are those arguing against greater state power and for greater freedom, whereas here the name is used by those who elsewhere would be called "Socialists" or, since that name has been sullied, "Social Democrats". In fact the name Liberal here used to have the same popular meaning, before it was coopted by people sympathetic to socialist movements abroad and in the U.S. So Enlightenment thinkers, or "Classical Liberals" as they are sometimes now called, coopted the word "Libertarian" from the Anarchists! So I suggest that sensible libertarians start looking for a new banner to march under, and I think Repubocrat is a reasonable first consideration. The appeal is that it carries the essential meaning that we hold some views in common with each party, that we agree with both and neither. Also, the name will seem familiar and friendly to those who have settled into our supposed "two-party" system. One, hidden bonus, I think, is that extreme libertarians will be loathe to call themselves Repubocrats, because the close association it draws to the existing parties. Some would say that's the most important bonus. Perhaps if we could only shake them, we'd be just fine.

Midlake - Some of them Were Superstitious

I went looking for the lyrics to the Midlake song, "Some of them were Superstitious", hoping to make a point to a friend. I couldn't find them anywhere, so I transcribed the whole thing. I later decided it was too abstract for my audience, but rather than delete it, I provide it here, for you, whoever happens to come across it.

Some of them were superstitious sitting with their backs facing the orchard, all of them with mittens on their hands and feet were waiting there for the winter. Thousands on the freeze-rail I could never join them there. But then we dare not bother, but couldn't help but holler "Yeah".

There's no use in hiding the joy from the bright new sun. I could wait for winter, better if it never comes.

Some of them were superstitious watching them parade around the town square, some of them appraising monacled and simply 'cause they don't know better. Someone to protect them someone to keep track of them. Though I don't believe them, I would rather holler "Yeah".

There's no use in hiding the joy from the bright new sun. Now you say you're leaving but leaving will just bring you down.

Can you operate machines like that, miles a day on tough terrain and grass?

I'm not sure if we will meet again. I guess it depends on which company you're in.

And when you're gone, you're gone. So soon, so soon, so long. But life, it works for someone, and you're someone.

Much too busy

Wow I've been really busy... a lot going on the past few weeks, everything from my car getting totaled, to another great trip to California. Maybe sometime I'll take the time to write some of this down...

A networked world

One night in Cali, Stephanie and I were out to see a show, when we noticed something strange. I won't go into details but we saw something that didn't seem right, and my first instinct was to call the non-emergency police services number. It took a lot of trying, but I pretty quickly got on the phone with a dispatcher and rattled off the details of what we'd seen. While I was still on the line, still answering questions about specifics, two cop cars zipped around the corner, speeding off in the direction we'd just come from. In a matter of minutes I got a call back from the dispatcher thanking us for calling it in. I'm guessing there was in fact a crime in progress, and thanks to the accessible communication afforded by cell phones, we were able to get the word to the right people in a very short time. It's my hope that we saved someone from frustration and violation felt by someone who suffers a crime without finding the perpetrator.

On an even more serious note, It's this kind of thing which encourages me not to worry about the prospect of governmental missuse of technology. As lines of communication are shortened, the people's power to associate, work together and aggregate information increases at a level comparable to the convenience afforded the government, perhaps in some cases more so, as the people are not so easily tied down by governmental bureacracy. This convenience helps keep the balance of power somewhat level, and guards against minor tyrannies.

Californians

By far the best part of my time in Cali was the people I met there.

First there was Robert, who is an Apple intern this summer, and all of his intern friend, including his 3 room-mates.Those 3 guys, Robert's room-mates are some of the best guys I've met, good people all around. We hung around the city and they were very cool about letting me stay with them. I don't know what more to say other than, there's were guys I could hang out with. It's hard to say what would change were the circumstances any different, but I can say I wish them well.

On the other hand, there's Stephanie, who let me stay in her place within ten minutes of meeting her, then kept asking me if I thought that was weird. I honestly didn't, perhaps only because I have a slightly skewed, open-minded (ala hippy) view of the whole thing. She too was great, her boyfriend and best friend and room-mates were also nice.

Gosh I guess nothing much of substance, just missing California already. Maybe I could get back there...

ahhh!! Public Transportation...

So I've been in San Fran for 3 days now... and I'm having a great time.

WWDC has been excellent, the big news (Apple & Intel) was interesting, but makes sense, in my view. If you're questioning my logic, consider these facts: the iMac G5 is underclocked in the guise of power management, the PowerMac G5 is water cooled and has come up 35% in speed in 24 months, and the PowerBook G5 is non-existant and may never be seen. Clearly there is a power issue, and Intel, while I don't like them a bit (Pentium 4 designed for marketing, anyone?), is a reasonable supplier for reasonably powerful low power chips. I've no doubt that, with the power problem not so serious, Apple's designers will be free to come up with something even better than what we're seeing now (which is Apple's best yet, IMO).

Anyway, back to the matter at hand... I've been in California a few days, and the Public transpo has been hell! Learning curve I guess, but I've missed like 3 trains! Once, I barely missed a train. Rather than wait an hour, I caught a cab to a stop farther down. 20 minutes later, I was at a farther stop. A full hour after then, the train "moseys" into the station. What the hell! Anyway, so many exclamation points can't be good for me.

On the other hand. Something good did come out of the Caltrain. I met a girl named Stefanie. She's a teacher from Arizona who, of course has the summer off and was vacationing in San Francisco. After she was nearly hit by a train, I was complaining to her about how long it took to get from San Jose to San Fran (90 minutes!) when she offered me a place to stay in San Fran. I'm not one to turn down such an offer, and she had an air to her that I liked, so I accepted. Very interesting girl, lives on Haight street. I'm only sorry I only will have a week to know her.