<?xml version="1.0" encoding="UTF-8"?>
<?xml-stylesheet type="text/xsl" media="screen" href="/~d/styles/atom10full.xsl"?><?xml-stylesheet type="text/css" media="screen" href="http://feeds.hypsometry.com/~d/styles/itemcontent.css"?><feed xmlns="http://www.w3.org/2005/Atom" xmlns:feedburner="http://rssnamespace.org/feedburner/ext/1.0" xml:lang="en-us">
  <updated>2010-07-30T14:19:08-07:00</updated>
  
  <title>The Hypsometry Blog.</title>
  <id>tag:blog.hypsometry.com,2009-11-07:/</id>
  
  <author>
    <name>Christopher Boone</name>
  </author>
  <rights type="text">Copyright 2009 Christopher Boone.</rights>

  
  <link rel="alternate" type="text/html" href="http://blog.hypsometry.com/" title="The Hypsometry Blog." />
  
  
  <atom10:link xmlns:atom10="http://www.w3.org/2005/Atom" rel="self" type="application/atom+xml" href="http://feeds.hypsometry.com/hypsometry/blog/articles" /><feedburner:info uri="hypsometry/blog/articles" /><atom10:link xmlns:atom10="http://www.w3.org/2005/Atom" rel="hub" href="http://pubsubhubbub.appspot.com/" /><feedburner:emailServiceId>hypsometry/blog/articles</feedburner:emailServiceId><feedburner:feedburnerHostname>http://feedburner.google.com</feedburner:feedburnerHostname><feedburner:feedFlare href="http://add.my.yahoo.com/rss?url=http%3A%2F%2Ffeeds.hypsometry.com%2Fhypsometry%2Fblog%2Farticles" src="http://us.i1.yimg.com/us.yimg.com/i/us/my/addtomyyahoo4.gif">Subscribe with My Yahoo!</feedburner:feedFlare><feedburner:feedFlare href="http://www.newsgator.com/ngs/subscriber/subext.aspx?url=http%3A%2F%2Ffeeds.hypsometry.com%2Fhypsometry%2Fblog%2Farticles" src="http://www.newsgator.com/images/ngsub1.gif">Subscribe with NewsGator</feedburner:feedFlare><feedburner:feedFlare href="http://feeds.my.aol.com/add.jsp?url=http%3A%2F%2Ffeeds.hypsometry.com%2Fhypsometry%2Fblog%2Farticles" src="http://o.aolcdn.com/favorites.my.aol.com/webmaster/ffclient/webroot/locale/en-US/images/myAOLButtonSmall.gif">Subscribe with My AOL</feedburner:feedFlare><feedburner:feedFlare href="http://www.bloglines.com/sub/http://feeds.hypsometry.com/hypsometry/blog/articles" src="http://www.bloglines.com/images/sub_modern11.gif">Subscribe with Bloglines</feedburner:feedFlare><feedburner:feedFlare href="http://www.netvibes.com/subscribe.php?url=http%3A%2F%2Ffeeds.hypsometry.com%2Fhypsometry%2Fblog%2Farticles" src="http://www.netvibes.com/img/add2netvibes.gif">Subscribe with Netvibes</feedburner:feedFlare><feedburner:feedFlare href="http://fusion.google.com/add?feedurl=http%3A%2F%2Ffeeds.hypsometry.com%2Fhypsometry%2Fblog%2Farticles" src="http://buttons.googlesyndication.com/fusion/add.gif">Subscribe with Google</feedburner:feedFlare><feedburner:feedFlare href="http://www.pageflakes.com/subscribe.aspx?url=http%3A%2F%2Ffeeds.hypsometry.com%2Fhypsometry%2Fblog%2Farticles" src="http://www.pageflakes.com/ImageFile.ashx?instanceId=Static_4&amp;fileName=ATP_blu_91x17.gif">Subscribe with Pageflakes</feedburner:feedFlare><entry>
    <published>2010-07-22T10:26:00-07:00</published>
    <updated>2010-07-22T10:26:00-07:00</updated>
  
    <title>XI.</title>
    <id>tag:blog.hypsometry.com,2010-07-22:/articles/rubyist-static-site-generators/</id>
  
    <author>
      <name>Christopher Boone</name>
    </author>
    <rights type="text">Copyright 2009 Christopher Boone.</rights>
  
    <link rel="alternate" type="text/html" href="http://blog.hypsometry.com/articles/rubyist-static-site-generators/" />
  
    <summary type="html">
      &lt;p&gt;Last fall, after years of creating highly dynamic websites and web applications, I reversed directions. Now I aim for as much static HTML as possible. It&amp;#8217;s simpler, faster, cleaner, more elegant, easier to read, and for most projects it&amp;#8217;s all you need.&lt;/p&gt;

&lt;p&gt;&lt;a href='http://hypsography.com/'&gt;Hypsography&lt;/a&gt; and &lt;a href='http://hypsometry.com/'&gt;Hypsometry&lt;/a&gt;, for example, are both entirely static. Hand written HTML, CSS, and Javascript, served up simple and fast.&lt;/p&gt;

&lt;p&gt;This site, &lt;a href='http://blog.hypsometry.com/'&gt;the Hypsometry Blog&lt;/a&gt;, is built with &lt;a href='http://github.com/mojombo/jekyll'&gt;Jekyll&lt;/a&gt;, &lt;a href='http://tom.preston-werner.com/'&gt;Tom Preston-Werner&amp;#8217;s&lt;/a&gt; elegant little Ruby hacker blogging tool. Jekyll takes &lt;a href='http://www.liquidmarkup.org/'&gt;Liquid templates&lt;/a&gt; and fills them with marked-up text, sprinkling a little &lt;a href='http://www.yaml.org/'&gt;YAML&lt;/a&gt; data over the top, and outputs HTML ready for your server. That works well.&lt;/p&gt;

&lt;p&gt;Hypsography, however, is getting to the point where I don&amp;#8217;t want to be maintaining all the code by hand (albeit with heavy help from &lt;a href='http://macromates.com/'&gt;Textmate&lt;/a&gt;), but I also don&amp;#8217;t want to lose the simplicity and speed of serving static files. There&amp;#8217;s no need to migrate to a full-bore content management system, with all the configuration and maintenance hassles that inevitably entails. Jekyll&amp;#8217;s wonderful, but it&amp;#8217;s not usable on sites that aren&amp;#8217;t simple blogs.&lt;/p&gt;

&lt;p&gt;Since Jekyll was released, a slew of static site generators written in Ruby have come along (and some have gone right along too). They all have a basic philosophy similar to &lt;a href='http://tom.preston-werner.com/2008/11/17/blogging-like-a-hacker.html'&gt;that originally outlined by Tom Preston-Werner:&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;They all take templates and content and merge them together, creating static HTML sites ready for deployment. They tend to use YAML for configuration. Most accept multiple markup formats as input. They all can watch your directory for changes in order to rebuild the site dynamically as you work on it.&lt;/p&gt;

&lt;p&gt;Their differences are smaller, but important. Each has a slightly different approach to the same problem, and thus each meets a slightly different need.&lt;/p&gt;

&lt;p&gt;Having spent the past couple days (for the second time in six months) going through the options and evaluating them, I thought I&amp;#8217;d summarize what I&amp;#8217;ve found. Let me point out that all the programs discussed below seem excellent and worth investigation. There are other programs out there which seem less excellent, and I&amp;#8217;ve ignored those here. Please let me know if I&amp;#8217;ve missed anything, of course.&lt;/p&gt;

&lt;p&gt;(There is one other useful approach to all this: Writing your own generator using &lt;a href='http://en.wikipedia.org/wiki/Rake_(software)'&gt;Rake&lt;/a&gt;, YAML, and &lt;a href='http://github.com/defunkt/mustache'&gt;Mustache&lt;/a&gt;. This is quite appealing, but not what I&amp;#8217;m in the market for today. &lt;a href='http://ozmm.org/posts/static_sites_with_mustache.html'&gt;Chris Wanstrath wrote about his approach last year&lt;/a&gt;, if you&amp;#8217;re interested.)&lt;/p&gt;

&lt;p&gt;Here follows my one-sentence summaries of all the Rubyist static site generators that I&amp;#8217;ve looked at recently:&lt;/p&gt;

&lt;h2 id='bonsai'&gt;&lt;a href='http://tinytree.info/'&gt;Bonsai.&lt;/a&gt;&lt;/h2&gt;

&lt;p&gt;Beautiful, simple, flexible (uses &lt;a href='http://github.com/rtomayko/tilt'&gt;Tilt&lt;/a&gt; for template handling), progressive (HTML5 by default), but the current version doesn&amp;#8217;t work out of the box and it&amp;#8217;s intended primarily for portfolio sites. (&lt;a href='http://tinytree.info/'&gt;Project site&lt;/a&gt;, &lt;a href='http://github.com/benschwarz/bonsai'&gt;Github&lt;/a&gt;.)&lt;/p&gt;

&lt;h2 id='middleman'&gt;&lt;a href='http://wiki.github.com/tdreyno/middleman/'&gt;Middleman.&lt;/a&gt;&lt;/h2&gt;

&lt;p&gt;Rails-like (in ways both good and bad), highly configurable and flexible, and includes automatic minification of CSS and Javascript, as well as other useful optimizations. (&lt;a href='http://awardwinningfjords.com/2009/10/22/middleman.html'&gt;Introductory post&lt;/a&gt;, &lt;a href='http://wiki.github.com/tdreyno/middleman/'&gt;Github&lt;/a&gt;.)&lt;/p&gt;

&lt;h2 id='nanoc'&gt;&lt;a href='http://nanoc.stoneship.org/'&gt;Nanoc.&lt;/a&gt;&lt;/h2&gt;

&lt;p&gt;Extremely powerful and extensible, perhaps too much so, and prefers configuration to convention. (&lt;a href='http://nanoc.stoneship.org/'&gt;Project site&lt;/a&gt;, &lt;a href='http://github.com/ddfreyne/nanoc'&gt;Github&lt;/a&gt;.)&lt;/p&gt;

&lt;h2 id='staticmatic'&gt;&lt;a href='http://staticmatic.rubyforge.org/'&gt;Staticmatic.&lt;/a&gt;&lt;/h2&gt;

&lt;p&gt;Simple, clean, but strangely &lt;a href='http://haml-lang.com/'&gt;Haml&lt;/a&gt;-dependent. (&lt;a href='http://staticmatic.rubyforge.org/'&gt;Ruby Forge&lt;/a&gt;, &lt;a href='http://github.com/staticmatic/staticmatic'&gt;Github&lt;/a&gt;.)&lt;/p&gt;

&lt;h2 id='webby'&gt;&lt;a href='http://webby.rubyforge.org/'&gt;Webby.&lt;/a&gt;&lt;/h2&gt;

&lt;p&gt;Simple, flexible, quite Jekyllish. (&lt;a href='http://webby.rubyforge.org/'&gt;Ruby Forge&lt;/a&gt;, &lt;a href='http://github.com/TwP/webby'&gt;Github&lt;/a&gt;.)&lt;/p&gt;

&lt;h2 id='webgen'&gt;&lt;a href='http://webgen.rubyforge.org/'&gt;Webgen.&lt;/a&gt;&lt;/h2&gt;

&lt;p&gt;Powerful, extensible, slightly rigid in operation. (&lt;a href='http://webgen.rubyforge.org/'&gt;Ruby Forge&lt;/a&gt;, &lt;a href='http://github.com/gettalong/webgen'&gt;Github&lt;/a&gt;.)&lt;/p&gt;

&lt;h2 id='not_quite_a_conclusion'&gt;Not quite a conclusion.&lt;/h2&gt;

&lt;p&gt;That&amp;#8217;s the list, and those are my notes. You can probably guess which I&amp;#8217;m going to try out on Hypsography, but whether or not you can, you&amp;#8217;ll be hearing more about the results here.&lt;/p&gt;

&lt;h2 id='a_historical_aside'&gt;A historical aside.&lt;/h2&gt;

&lt;p&gt;Since &lt;a href='/articles/three-things-about-pivot/'&gt;I wrote once before about static site generation&lt;/a&gt;, I&amp;#8217;ve taken this opportunity to begin restoring old articles to the Hypsometry Blog. As such, there is now an article zero: &lt;a href='/articles/nulla/'&gt;Nulla&lt;/a&gt;, actually, since &lt;a href='http://en.wikipedia.org/wiki/Roman_numerals#Zero'&gt;the Romans didn&amp;#8217;t really have notation for zero.&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Nulla serves as a marker. All articles older than it are reprints, numbered negatively (which is also an anachronism, but hey), and probably slightly altered from their original forms. All articles newer are indeed new, part of &lt;a href='/articles/ashland-mccarthy-and-the-field-guide/'&gt;this latest iteration of the Hypsometry Blog.&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;As time passes, I&amp;#8217;ll continue working my way through the Hypsometry archives, digging out other older articles perhaps worthy of a second look. Or at least worthy of having their links preserved. Don&amp;#8217;t take them too seriously &amp;#8211; they&amp;#8217;re oldies, but not necessarily goodies.&lt;/p&gt;
    &lt;img src="http://feeds.feedburner.com/~r/hypsometry/blog/articles/~4/RqGkMYtjvl4" height="1" width="1"/&gt;</summary>
  </entry>
  
  <entry>
    <published>2010-06-29T19:11:00-07:00</published>
    <updated>2010-06-29T19:11:00-07:00</updated>
  
    <title>X.</title>
    <id>tag:blog.hypsometry.com,2010-06-29:/articles/art-not-ads/</id>
  
    <author>
      <name>Christopher Boone</name>
    </author>
    <rights type="text">Copyright 2009 Christopher Boone.</rights>
  
    <link rel="alternate" type="text/html" href="http://blog.hypsometry.com/articles/art-not-ads/" />
  
    <summary type="html">
      &lt;a href='http://www.adfreeblog.org/'&gt;
  &lt;img src='http://www.adfreeblog.org/art_not_ads.jpg' alt='Art Not Ads' /&gt;
&lt;/a&gt;
    &lt;img src="http://feeds.feedburner.com/~r/hypsometry/blog/articles/~4/2VnXvUO9A44" height="1" width="1"/&gt;</summary>
  </entry>
  
  <entry>
    <published>2010-06-23T15:56:00-07:00</published>
    <updated>2010-06-23T15:56:00-07:00</updated>
  
    <title>IX.</title>
    <id>tag:blog.hypsometry.com,2010-06-23:/articles/the-serfdom-of-crowds/</id>
  
    <author>
      <name>Christopher Boone</name>
    </author>
    <rights type="text">Copyright 2009 Christopher Boone.</rights>
  
    <link rel="alternate" type="text/html" href="http://blog.hypsometry.com/articles/the-serfdom-of-crowds/" />
  
    <summary type="html">
      &lt;p&gt;Sometime in the mid-nineties, around the time I stopped reading &lt;a href='http://en.wikipedia.org/wiki/Mondo_2000'&gt;Mondo 2000&lt;/a&gt;, &lt;a href='http://www.jaronlanier.com/'&gt;Jaron Lanier&lt;/a&gt; stopped annoying me. I assumed he was still out there, being all far out and dreaded and inter-disciplinary, but he no longer forced his way into my attention, and was thus out of mind.&lt;/p&gt;

&lt;p&gt;Apparently he&amp;#8217;s not yet out of sight. He has in the interim, however, become more articulate, more insightful, and more interesting. This past January his newest book, &lt;a href='http://books.google.com/books?id=sqNWqEB8Ie0C'&gt;&lt;em&gt;You Are Not a Gadget,&lt;/em&gt;&lt;/a&gt; was published, and in February &lt;a href='http://harpers.org/'&gt;&lt;em&gt;Harper&amp;#8217;s Magazine&lt;/em&gt;&lt;/a&gt; published an excerpt called &lt;a href='http://harpers.org/archive/2010/02/0082805'&gt;&amp;#8216;The serfdom of crowds.&amp;#8217;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;(The complete article is only available online to &lt;em&gt;Harper&amp;#8217;s&lt;/em&gt; subscribers, but there is &lt;a href='http://www.scribd.com/doc/25828774/James-Lanier-The-Serfdom-of-Crowds'&gt;an illicit version available on Scribd&lt;/a&gt;, in beautiful HTML5. That said, I recommend that you go to &lt;a href='http://nces.ed.gov/surveys/libraries/librarysearch/'&gt;your local library&lt;/a&gt; and read the damn thing in print.)&lt;/p&gt;

&lt;p&gt;Let me quote from it at length, to give you something of its full flavor. Here is Lanier discussing the collapse of the financial markets in 2008 and how that related to, and derived from, the essential inequality of the current structure of the web:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;True believers in the hive mind seem to think that no number of layers of abstraction in a financial system can dull the system’s efficacy. The crowd works for free, and statistical algorithms supposedly take the risk out of making bets if you are a lord of the cloud. But who is that lord who owns the cloud that connects the crowd? Not just anybody. A lucky few (for luck is all that can possibly be involved) will own it. Entitlement has achieved its singularity and become infinite.&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;What has allowed this infinite entitlement, this neo-feudalism? We have, in a thousand little ways:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;People degrade themselves all the time in order to make machines seem smart. We have repeatedly demonstrated our species’s bottomless ability to lower our standards to make information technology good.&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;I would amend the last sentence to refer more generally to &amp;#8216;technology&amp;#8217;, rather than just to &amp;#8216;information technology,&amp;#8217; for this lowering of standards is wide-spread. For example, it is precisely what allows us to claim that items fabricated from synthetic chemicals and compounds and shaped roughly into the appearance of traditional foodstuffs are, in any way, actually food.&lt;/p&gt;

&lt;p&gt;Lanier is focused here specifically on the web side of this argument, not on the general case; but many of the things he writes apply more generally. For example:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;Enlightened designers leave open the possibility of metaphysical specialness either in humans or in the potential for for unforeseen creative processes that we can’t yet capture in software systems. That kind of modesty is the signature quality of being human-centered.&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;To return to my example, this is the difference between manufacturing bread in factories and baking loaves in a wood-fired oven. (Brief aside: When did we begin using &lt;a href='http://www.etymonline.com/index.php?term=manufacture'&gt;&amp;#8216;manufactured&amp;#8217;&lt;/a&gt; to mean &amp;#8216;not manufactured?&amp;#8217;)&lt;/p&gt;

&lt;p&gt;The former method asserts that there is nothing special about having a human bake bread; everything involved can be simplified down such that mechanical and software systems can handle it. The latter method, on the other hand, recognizes that there is potential inherent in the baking process that only a baker can explore. Choosing the first method devalues the second &amp;#8211; devalues the method, devalues the bread, and devalues both the baker and the eater.&lt;/p&gt;

&lt;p&gt;To return to Lanier, on this devaluation and its causes:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;What computerized analysis of all the country’s school tests has done to education is exactly what Facebook has done to friendships. In both cases, life is turned into a database. Both degradations are based on the same philosophical mistake, which is the belief that computers can presently represent human thought or human relationships. These are things computers cannot currently do.&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;And on the resultant effects of this devaluation, this forced technological simplification, this database as life:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;When technologists deploy a computer model of something like learning or friendship in a way that has an effect on real lives, they are relying on faith. When they ask people to live their lives through their models, they are potentially reducing life itself.&lt;/p&gt;
&lt;/blockquote&gt;
    &lt;img src="http://feeds.feedburner.com/~r/hypsometry/blog/articles/~4/j1k8m9W8qZo" height="1" width="1"/&gt;</summary>
  </entry>
  
  <entry>
    <published>2010-06-14T12:56:00-07:00</published>
    <updated>2010-06-14T12:56:00-07:00</updated>
  
    <title>VIII.</title>
    <id>tag:blog.hypsometry.com,2010-06-14:/articles/html5-and-safari-reader/</id>
  
    <author>
      <name>Christopher Boone</name>
    </author>
    <rights type="text">Copyright 2009 Christopher Boone.</rights>
  
    <link rel="alternate" type="text/html" href="http://blog.hypsometry.com/articles/html5-and-safari-reader/" />
  
    <summary type="html">
      &lt;p&gt;As you know, &lt;a href='http://www.apple.com/safari/'&gt;Safari 5&lt;/a&gt; came out last week. Two of its best features are &lt;a href='http://www.apple.com/safari/whats-new.html#reader'&gt;the Safari Reader&lt;/a&gt; and &lt;a href='http://www.apple.com/safari/whats-new.html#html5'&gt;much improved support for HTML5&lt;/a&gt;.&lt;/p&gt;

&lt;p&gt;Reader you know about. You might not know, however, that &lt;a href='http://rakaz.nl/2010/06/html5-test-updated-how-well-does-your-browser-support-html5-now.html'&gt;Safari 5 now outscores all other browsers&lt;/a&gt; on &lt;a href='http://html5test.com/'&gt;the HTML5 test&lt;/a&gt;. That&amp;#8217;s exciting. It&amp;#8217;s not complete support, but it&amp;#8217;s a lot of the essentials. And, after all, the spec itself isn&amp;#8217;t even complete yet.&lt;/p&gt;

&lt;p&gt;Another thing you might not know is that I&amp;#8217;m working almost exclusively in &lt;a href='http://en.wikipedia.org/wiki/Html5'&gt;HTML5&lt;/a&gt; these days. If there&amp;#8217;s a reason not to use it, I&amp;#8217;m not; but it&amp;#8217;s my default and my preference. That means that my photography portfolio site &amp;#8211; &lt;a href='http://hypsography.com/'&gt;Hypsography&lt;/a&gt; &amp;#8211; is all HTML5 under the surface. And that, in turn, means that &lt;a href='http://hypsography.com/news/'&gt;the news articles I write for Hypsography&lt;/a&gt; make appropriate use of &lt;a href='http://www.whatwg.org/specs/web-apps/current-work/#the-article-element'&gt;the &lt;code&gt;article&lt;/code&gt; element&lt;/a&gt;, along with many other semantic elements. One &lt;code&gt;&amp;lt;article&amp;gt;&lt;/code&gt; equals one article. Simple and clear.&lt;/p&gt;

&lt;p&gt;Let&amp;#8217;s review what &lt;a href='http://www.apple.com/safari/whats-new.html#reader'&gt;Apple says about Safari Reader&lt;/a&gt;:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;As you browse the web, Safari detects if you’re on a web page with an article. Click the Reader icon in the Smart Address Field, and the article appears instantly in one continuous, clutter-free view. You see every page of the article — whether two or twenty.&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;Totally. And it works really well, at least when you&amp;#8217;re reading &lt;a href='http://nytimes.com/'&gt;the Times&lt;/a&gt;. When you&amp;#8217;re reading Hypsography, however, it works a little less well:&lt;/p&gt;
&lt;img src='/images/html5-and-safari-reader/year-review-reader-top-720x408.png' height='408' alt='' width='720' /&gt;
&lt;p&gt;That&amp;#8217;s not ideal. The ice photograph that&amp;#8217;s intruding in the middle of the text is enclosed in an &lt;a href='http://www.whatwg.org/specs/web-apps/current-work/#the-aside-element'&gt;&lt;code&gt;aside&lt;/code&gt;&lt;/a&gt;, which should be considered &amp;#8220;tangentially related to the content around&amp;#8221; it, but Safari apparently doesn&amp;#8217;t get that. But at least it&amp;#8217;s readable, somewhat. And, looking under the surface with the Web Inspector, this misinterpretation looks fixable via CSS.&lt;/p&gt;

&lt;p&gt;What&amp;#8217;s worse is what happens when you scroll to the end of the article:&lt;/p&gt;
&lt;img src='/images/html5-and-safari-reader/year-review-reader-bottom-720x408.png' height='408' alt='' width='720' /&gt;
&lt;p&gt;Safari has decided that the article ends there. Arbitrarily decided, it seems, since the article does not end there. In fact, of the five sections into which that article &amp;#8211; &lt;a href='http://hypsography.com/news/end-of-the-year-review-2009/'&gt;An end of the year review, inspired by Mr. Dalton Rooney&lt;/a&gt; &amp;#8211; is divided, Safari has chosen to include only two of them. The first and the third sections. Naturally.&lt;/p&gt;

&lt;p&gt;Let me clarify this a smidge more: The five sections into which this article is divided are delineated by &lt;a href='http://www.whatwg.org/specs/web-apps/current-work/#the-section-element'&gt;&lt;code&gt;section&lt;/code&gt;&lt;/a&gt; tags, all of which are contained with the one parent &lt;code&gt;article&lt;/code&gt;. This is semantic, this is simple, and this is clear. You might figure it&amp;#8217;d be easy too.&lt;/p&gt;

&lt;p&gt;Oh well.&lt;/p&gt;

&lt;p&gt;If anybody out there has an understanding of what precisely Safari Reader looks for in an article, please let me know. Thanks, and good luck.&lt;/p&gt;
    &lt;img src="http://feeds.feedburner.com/~r/hypsometry/blog/articles/~4/lc7BD5aM7-8" height="1" width="1"/&gt;</summary>
  </entry>
  
  <entry>
    <published>2010-06-07T13:59:00-07:00</published>
    <updated>2010-06-07T13:59:00-07:00</updated>
  
    <title>VII.</title>
    <id>tag:blog.hypsometry.com,2010-06-07:/articles/hypsometrys-simple-portfolio/</id>
  
    <author>
      <name>Christopher Boone</name>
    </author>
    <rights type="text">Copyright 2009 Christopher Boone.</rights>
  
    <link rel="alternate" type="text/html" href="http://blog.hypsometry.com/articles/hypsometrys-simple-portfolio/" />
  
    <summary type="html">
      &lt;p&gt;After a diapause of several years, &lt;a href='http://hypsometry.com/#portfolio'&gt;Hypsometry again has a portfolio section.&lt;/a&gt;&lt;/p&gt;
&lt;a href='http://hypsometry.com/#portfolio'&gt;
  &lt;img src='/images/hypsometrys-simple-portfolio/hpm-portfolio-fritzhorstman-720x240.png' height='240' alt='' width='720' /&gt;
&lt;/a&gt;
    &lt;img src="http://feeds.feedburner.com/~r/hypsometry/blog/articles/~4/3U1IyGwBjDw" height="1" width="1"/&gt;</summary>
  </entry>
  
  <entry>
    <published>2010-01-15T11:27:00-08:00</published>
    <updated>2010-01-15T11:27:00-08:00</updated>
  
    <title>VI.</title>
    <id>tag:blog.hypsometry.com,2010-01-15:/articles/true-small-capitals-with-font-face/</id>
  
    <author>
      <name>Christopher Boone</name>
    </author>
    <rights type="text">Copyright 2009 Christopher Boone.</rights>
  
    <link rel="alternate" type="text/html" href="http://blog.hypsometry.com/articles/true-small-capitals-with-font-face/" />
  
    <summary type="html">
      &lt;p&gt;One small, but quite good, reason to rejoice at the coming of a widely useable &lt;code&gt;@font-face:&lt;/code&gt; &lt;strong&gt;True small capitals are now possible on the web.&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;Small capitals are, &lt;a href='http://ilovetypography.com/2008/02/20/small-caps/' title='Read about small capitals on I Love Typography.'&gt;as Alec Julien put it&lt;/a&gt;, &amp;#8220;upper case glyphs drawn at a lower case scale.&amp;#8221; They are not, however, simply regular capitals shrunk down; they are properly their own font, with their own characteristics, designed to work with both regular capital and lower case letters.&lt;/p&gt;

&lt;p&gt;To be more precise: 1. The cap height of a small capital is the same as, or just slightly larger than, the x-height of the typeface&amp;#8217;s lower case letters. 2. The weight of the strokes of a small capital are comparable, visually speaking, to the weight of the strokes of the typeface in general, at the size being used. 3. The proportions of a small capital are also comparable, visually speaking, to the proportions of the characters of the typeface in general, at the size being used.&lt;/p&gt;

&lt;p&gt;Two implications of the latter two points are that the strokes and proportions of a given small capital letter will be heavier and more spread out than the strokes and proportions of the same letter upper cased, at the same point size. This is because small capitals have the form of regular capital letters, but the characteristics of the lower case.&lt;/p&gt;

&lt;p&gt;Unfortunately, true small capitals are hard to come by these days. Computer software, as a rule, uses fake small capitals, created simply by scaling down upper case letters so that they are smaller than the originals, but larger than the associated lower case. This is true of web browsers as well as word processors, desktop publishing applications, and vector editors.&lt;/p&gt;

&lt;p&gt;For instance, the second line above should look about like this, using true, properly designed small capitals: &lt;img src='/images/true-small-capitals-with-font-face/first-paragraph-true-small-capitals.png' alt='' /&gt; But, had I not &lt;code&gt;@font-face&lt;/code&gt; to rely on, your web browser&amp;#8217;s fake small capitals would make it look more like this: &lt;img src='/images/true-small-capitals-with-font-face/first-paragraph-fake-small-capitals.png' alt='' /&gt; Not at all the same thing, clearly. The proportions of the second example are all wrong &amp;#8211; simultaneously too big and too thin, tracked too tightly, and rather difficult to read. The first example is balanced, strong, eminently legible.&lt;/p&gt;

&lt;p&gt;Using true small capitals on the web was not possible until recently, at least not with type that is actually type. Let&amp;#8217;s look at how it works, and also, along the way, at several ways to fake small capitals. Comparing them all side by side will make even clearer the import of the differences I described above.&lt;/p&gt;

&lt;h2 id='1_setting_the__property_to_'&gt;1. Setting the &lt;code&gt;font-variant&lt;/code&gt; property to &lt;code&gt;small-caps&lt;/code&gt;.&lt;/h2&gt;

&lt;p&gt;This is what should work. &lt;a href='http://www.w3.org/TR/CSS21/fonts.html#small-caps' title='Read about the font-variant property in the CSS standard on the W3C website.'&gt;The W3C CSS standard tells us that &lt;code&gt;font-variant: small-caps&lt;/code&gt; will instruct the browser to do the right thing.&lt;/a&gt; &amp;#8220;A value of &amp;#8216;small-caps&amp;#8217; selects a small-caps font&amp;#8221;, it says.&lt;/p&gt;

&lt;p&gt;This is how your browser interprets &lt;code&gt;font-variant: small-caps&lt;/code&gt;:&lt;/p&gt;
&lt;p class='small-capitals-example'&gt;
  &lt;span class='small-capitals-font-variant'&gt;
    Giambattista Bodoni: February 16, 1740 in Saluzzo &amp;ndash; November 29, 1813 in Parma.
  &lt;/span&gt;
&lt;/p&gt;
&lt;p&gt;That looks okay, I guess. In comparison to the small capitals, the upper case letters and numerals look overly heavy. Some of the small capital letters &amp;#8211; the &lt;em&gt;t&lt;/em&gt; and the &lt;em&gt;m&lt;/em&gt;, for instance &amp;#8211; have strokes that are so thin as to almost vanish.&lt;/p&gt;

&lt;p&gt;Let&amp;#8217;s look at a second example, to make the differences clearer:&lt;/p&gt;
&lt;p class='small-capitals-example'&gt;
  &lt;span class='small-capitals-font-variant-partial'&gt;
    A &lt;span&gt;a&lt;/span&gt; a &amp;mdash; M &lt;span&gt;m&lt;/span&gt; m &amp;mdash; X &lt;span&gt;x&lt;/span&gt; x
  &lt;/span&gt;
&lt;/p&gt;
&lt;p&gt;Now you can see quite clearly that the cap height of the small capitals is substantially larger than the x-height of the lower case letters, to say nothing of the overshoot of letters like &lt;em&gt;a&lt;/em&gt; and &lt;em&gt;m&lt;/em&gt;. Also, you can see how the proportions and weights of these fake small capitals match neither the upper case nor the lower case. All in all, this style of fake small capitals works quite poorly.&lt;/p&gt;

&lt;p&gt;But why is this? The typeface in which this page is set &amp;#8211; &lt;a href='http://iginomarini.com/fell/the-revival-fonts/' title='Go to the IM Fell revival page.'&gt;IM Fell Great Primer&lt;/a&gt; &amp;#8211; has a small capitals variant, so why do the browsers not use it? After all, the CSS standard says that they should when &lt;code&gt;font-variant: small-caps&lt;/code&gt; is used.&lt;/p&gt;

&lt;p&gt;Sadly, no browser has actually implemented this. Instead of looking to see whether true small capitals are available, they all jump to the next portion of the standard:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;It is acceptable (but not required) if the small-caps font is a created by taking a normal font and replacing the lower case letters by scaled upper case characters.&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;I&amp;#8217;m not sure who, precisely, thinks that that is acceptable, but even if it were, it is surely not acceptable to ignore existing small capital fonts created by proper methods in favor of bogus ones created on the fly.&lt;/p&gt;

&lt;h2 id='2_the_joe_clark_method'&gt;2. The Joe Clark method.&lt;/h2&gt;

&lt;p&gt;Faced with the problems above, &lt;a href='http://joeclark.org/' title='Go to joeclark.org.'&gt;Joe Clark&lt;/a&gt; suggested &lt;a href='http://joeclark.org/' title='Go to joeclark.org.'&gt;a simple alternative&lt;/a&gt;: Convert the text to capitals and reduce its size. This is, of course, exactly what the browsers do when you specify &lt;code&gt;font-variant: small-caps&lt;/code&gt;. The slight theoretical advantage provided by Joe Clark&amp;#8217;s method is that you can more precisely and carefully control how much the fake small capitals are scaled down, leading, perhaps to better matching of heights, proportions, and weights. A simple example:&lt;/p&gt;
&lt;p class='small-capitals-example'&gt;
  &lt;span class='small-capitals-joe-clark'&gt;
    Giambattista Bodoni: February 16, 1740 in Saluzzo &amp;ndash; November 29, 1813 in Parma.
  &lt;/span&gt;
&lt;/p&gt;
&lt;p&gt;Of course, applied like that, Joe Clark&amp;#8217;s method forces all letters and numerals to small capitals, even if that&amp;#8217;s not what you desired. A slightly more sophisticated version of his method would apply the technique selectively &amp;#8211; say, to letters that are already lower cased. Let&amp;#8217;s assume that you have an automatic way to do so &amp;#8211; a CMS plugin, for example, or a clever piece of Javascript:&lt;/p&gt;
&lt;p class='small-capitals-example'&gt;
  &lt;span class='small-capitals-clever-joe-clark'&gt;
    G&lt;span&gt;iambattista&lt;/span&gt; B&lt;span&gt;odoni&lt;/span&gt;:
    F&lt;span&gt;ebruary&lt;/span&gt; 16, 1740 &lt;span&gt;in&lt;/span&gt; S&lt;span&gt;aluzzo&lt;/span&gt; &amp;ndash;
    N&lt;span&gt;ovember&lt;/span&gt; 29, 1813 &lt;span&gt;in&lt;/span&gt; P&lt;span&gt;arma&lt;/span&gt;.
  &lt;/span&gt;
&lt;/p&gt;
&lt;p&gt;This, of course, is a total pain in the ass, and it makes a bit of a hash of the text&amp;#8217;s HTML. On the other hand, it does allow for more precise control of the size of the fake small capitals, which might be helpful.&lt;/p&gt;

&lt;p&gt;To see that more clearly, here is a third example &amp;#8211; the same as the one in &amp;#167;1:&lt;/p&gt;
&lt;p class='small-capitals-example'&gt;
  &lt;span class='small-capitals-clever-joe-clark'&gt;
    A &lt;span&gt;a&lt;/span&gt; a &amp;mdash; M &lt;span&gt;m&lt;/span&gt; m &amp;mdash; X &lt;span&gt;x&lt;/span&gt; x
  &lt;/span&gt;
&lt;/p&gt;
&lt;p&gt;You see the same problems as in &amp;#167;1: The Joe Clark small capitals are too big and their proportions are wrong. The weights, however, are not quite as bad. Let&amp;#8217;s look at a fourth example, comparing the &lt;code&gt;font-variant&lt;/code&gt; method and the Joe Clark method, in that order, to see how the two compare:&lt;/p&gt;
&lt;p class='small-capitals-example'&gt;
  &lt;span class='small-capitals-font-variant'&gt;a&lt;/span&gt;
  &lt;span class='small-capitals-joe-clark'&gt;a&lt;/span&gt; &amp;mdash;
  &lt;span class='small-capitals-font-variant'&gt;m&lt;/span&gt;
  &lt;span class='small-capitals-joe-clark'&gt;m&lt;/span&gt; &amp;mdash;
  &lt;span class='small-capitals-font-variant'&gt;x&lt;/span&gt;
  &lt;span class='small-capitals-joe-clark'&gt;x&lt;/span&gt;
&lt;/p&gt;
&lt;p&gt;The proportions and weights of Joe Clark&amp;#8217;s fake small capitals are better than those of the &lt;code&gt;font-variant&lt;/code&gt; method, but only because the letters themselves are even larger. Hard to call that an improvement.&lt;/p&gt;

&lt;h2 id='3_the_nick_shinn_method'&gt;3. The Nick Shinn method.&lt;/h2&gt;

&lt;p&gt;This problem of how to fake small capitals when no proper ones exist, or the software will not let you access them, is not unique to the web. &lt;a href='http://shinntype.com/' title='Go to shinntype.com.'&gt;Nick Shinn&lt;/a&gt; has suggested that, in addition to capitalizing and reducing the size of the text, &lt;a href='http://typophile.com/node/56161' title='Read about Nick Shinn style fake small capitals on Typophile.'&gt;you should increase its weight.&lt;/a&gt; This allows for making the small capitals a little smaller &amp;#8211; a little closer to the actual x-height of the typeface &amp;#8211; while better preserving their weights and proportions.&lt;/p&gt;

&lt;p&gt;A simple example:&lt;/p&gt;
&lt;p class='small-capitals-example'&gt;
  &lt;span class='small-capitals-nick-shinn'&gt;
    Giambattista Bodoni: February 16, 1740 in Saluzzo &amp;ndash; November 29, 1813 in Parma.
  &lt;/span&gt;
&lt;/p&gt;
&lt;p&gt;A more sophisticated example, again &amp;#8211; as in &amp;#167;2 &amp;#8211; imagining some sort of automated helper, and ignoring the complexity of the technique and the hash it makes of the HTML:&lt;/p&gt;
&lt;p class='small-capitals-example'&gt;
  &lt;span class='small-capitals-clever-nick-shinn'&gt;
    G&lt;span&gt;iambattista&lt;/span&gt; B&lt;span&gt;odoni&lt;/span&gt;:
    F&lt;span&gt;ebruary&lt;/span&gt; 16, 1740 &lt;span&gt;in&lt;/span&gt; S&lt;span&gt;aluzzo&lt;/span&gt; &amp;ndash;
    N&lt;span&gt;ovember&lt;/span&gt; 29, 1813 &lt;span&gt;in&lt;/span&gt; P&lt;span&gt;arma&lt;/span&gt;.
  &lt;/span&gt;
&lt;/p&gt;
&lt;p&gt;This looks better in some ways, and worse in others. It is still basically unacceptable. Perhaps in some contexts, with some combinations of typeface and size, this might work well. Here, despite the improvement in small capital size, the overly heavy weight is too much. Of course, the typeface you see here has no true bold weight, so your browser is faking it; perhaps it is too much to hope that a faked heavy weight could help us, in turn, fake small capitals.&lt;/p&gt;

&lt;p&gt;Let&amp;#8217;s compare upper case, lower case, and Nick Shinn small capitals:&lt;/p&gt;
&lt;p class='small-capitals-example'&gt;
  &lt;span class='small-capitals-clever-nick-shinn'&gt;
    A &lt;span&gt;a&lt;/span&gt; a &amp;mdash; M &lt;span&gt;m&lt;/span&gt; m &amp;mdash; X &lt;span&gt;x&lt;/span&gt; x
  &lt;/span&gt;
&lt;/p&gt;
&lt;p&gt;Correct height and proportions with excessively heavy weight is no better than incorrect height. And it turns out that the x-heights are not in fact correct: They only appear correct at this size of type. Try resizing the text in your browser window, and you&amp;#8217;ll see that the evenness is limited to the sizes I&amp;#8217;ve set here.&lt;/p&gt;

&lt;p&gt;A fourth example, this time comparing the &lt;code&gt;font-variant&lt;/code&gt; method, the Joe Clark method, and the Nick Shinn method, presented in that order:&lt;/p&gt;
&lt;p class='small-capitals-example'&gt;
  &lt;span class='small-capitals-font-variant'&gt;a&lt;/span&gt;
  &lt;span class='small-capitals-joe-clark'&gt;a&lt;/span&gt;
  &lt;span class='small-capitals-nick-shinn'&gt;a&lt;/span&gt; &amp;mdash;
  &lt;span class='small-capitals-font-variant'&gt;m&lt;/span&gt;
  &lt;span class='small-capitals-joe-clark'&gt;m&lt;/span&gt;
  &lt;span class='small-capitals-nick-shinn'&gt;m&lt;/span&gt; &amp;mdash;
  &lt;span class='small-capitals-font-variant'&gt;x&lt;/span&gt;
  &lt;span class='small-capitals-joe-clark'&gt;x&lt;/span&gt;
  &lt;span class='small-capitals-nick-shinn'&gt;x&lt;/span&gt;
&lt;/p&gt;
&lt;p&gt;Of these three, the browser scaling method seems the best, despite is many flaws. None produce good results, and it&amp;#8217;s far and away the simplest.&lt;/p&gt;

&lt;h2 id='4_using_'&gt;4. Using &lt;code&gt;@font-face&lt;/code&gt;.&lt;/h2&gt;

&lt;p&gt;There is an additional problem here, besides the technical failings of the browsers and the limits of what you can express using CSS: Proper small capital fonts are a rarity. Type designers design them, foundries sell them, but few non&amp;#8211;professionals have them on their computers.&lt;/p&gt;

&lt;p&gt;The typeface in which the Hypsometry Blog is set is &lt;a href='http://iginomarini.com/fell/the-revival-fonts/' title='Go to the IM Fell revival page.'&gt;IM Fell Great Primer&lt;/a&gt;, a beautiful typeface first cut by Peter de Walpergen, acquired by John Fell in the late 1680s, and digitally revived by &lt;a href='http://iginomarini.com/' title='Go to iginomarini.com.'&gt;Igino Marini&lt;/a&gt;. In its original metal, IM Fell Great Primer consisted of romans, italics, and small capitals. Sr Marini has created OpenType versions of all three, and made them freely available. As such, I can use &lt;code&gt;@font-face&lt;/code&gt; to specify the use of the small capitals variant.&lt;/p&gt;

&lt;p&gt;An example:&lt;/p&gt;
&lt;p class='small-capitals-example'&gt;
  &lt;span class='small-capitals-font-face'&gt;
    Giambattista Bodoni: February 16, 1740 in Saluzzo &amp;ndash; November 29, 1813 in Parma.
  &lt;/span&gt;
&lt;/p&gt;
&lt;p&gt;And, again, a comparison with the upper and lower cases:&lt;/p&gt;
&lt;p class='small-capitals-example'&gt;
  &lt;span class='small-capitals-font-face-partial'&gt;
    A &lt;span&gt;a&lt;/span&gt; a &amp;mdash; M &lt;span&gt;m&lt;/span&gt; m &amp;mdash; X &lt;span&gt;x&lt;/span&gt; x
  &lt;/span&gt;
&lt;/p&gt;
&lt;p&gt;Glorious. The cap height of the small capital &lt;em&gt;x&lt;/em&gt; is precisely the same as the x-height of the lower case &lt;em&gt;x&lt;/em&gt; &amp;#8211; and this holds true even if you resize the text away from how I&amp;#8217;ve set it here. The cap heights of the small capitals &lt;em&gt;a&lt;/em&gt; and &lt;em&gt;m&lt;/em&gt; are smaller than the overshoot of the lowercase &lt;em&gt;a&lt;/em&gt; and &lt;em&gt;m&lt;/em&gt;. The visual weight and proportions of the small capitals are all quite similar to those of the lower case letters, even while the forms of the small capitals remain true to the appearance of the upper case.&lt;/p&gt;

&lt;p&gt;Just to be absolutely clear, let&amp;#8217;s see all four methods lined up side by side &amp;#8211; &lt;code&gt;font-variant: small-caps&lt;/code&gt; on the left, followed by the Joe Clark method, the Nick Shinn method, and the true small capitals of &lt;code&gt;@font-face&lt;/code&gt;:&lt;/p&gt;
&lt;p class='small-capitals-example'&gt;
  &lt;span class='small-capitals-font-variant'&gt;a&lt;/span&gt;
  &lt;span class='small-capitals-joe-clark'&gt;a&lt;/span&gt;
  &lt;span class='small-capitals-nick-shinn'&gt;a&lt;/span&gt;
  &lt;span class='small-capitals-font-face'&gt;a&lt;/span&gt; &amp;mdash;
  &lt;span class='small-capitals-font-variant'&gt;m&lt;/span&gt;
  &lt;span class='small-capitals-joe-clark'&gt;m&lt;/span&gt;
  &lt;span class='small-capitals-nick-shinn'&gt;m&lt;/span&gt;
  &lt;span class='small-capitals-font-face'&gt;m&lt;/span&gt; &amp;mdash;
  &lt;span class='small-capitals-font-variant'&gt;x&lt;/span&gt;
  &lt;span class='small-capitals-joe-clark'&gt;x&lt;/span&gt;
  &lt;span class='small-capitals-nick-shinn'&gt;x&lt;/span&gt;
  &lt;span class='small-capitals-font-face'&gt;x&lt;/span&gt;
&lt;/p&gt;
&lt;p&gt;The &lt;code&gt;@font-face&lt;/code&gt; method is far and away the best. Unfortunately, it is the best in appearance and the worst to use.&lt;/p&gt;

&lt;p&gt;The biggest problem, as mentioned above, is that few typefaces have proper small capital variants. Of those that do, some include them within the regular roman file, which puts them off limits to web use. &lt;a href='http://en.wikipedia.org/wiki/Small_capitals#Unicode' title='Read about small capitals in Unicode on Wikipedia.'&gt;Unicode currently does not define a place for small capitals&lt;/a&gt;, which means that browser cannot access them.&lt;/p&gt;

&lt;p&gt;For example, you&amp;#8217;re likely to have &lt;a href='http://typedia.com/explore/typeface/linotype-didot/' title='Read about Linotype Didot on Typedia.'&gt;the typeface Didot&lt;/a&gt; on your computer. The roman of that Didot includes small capitals, but as glyphs 264&amp;#8211;389, located in the Unicode range called &amp;#8220;Glyph Variants&amp;#8221;, which you cannot access within a browser.&lt;/p&gt;

&lt;p&gt;Assuming that you&amp;#8217;re using a typeface that includes proper small capitals, and that those small capitals are included as their own distinct font file, then you must declare a &lt;code&gt;@font-face&lt;/code&gt; rule that makes use of them. &lt;a href='http://www.w3.org/TR/css3-fonts/#the-font-face-rule' title='Read about the @font-face rule on the W3C website.'&gt;In theory,&lt;/a&gt; you would do have already defined your romans and italics something like this:&lt;/p&gt;

&lt;pre&gt;&lt;code&gt;@font-face {
  font-family: &amp;quot;IM Fell Great Primer&amp;quot;;
  src: local(&amp;quot;IM FELL Great Primer&amp;quot;);
}

@font-face {
  font-family: &amp;quot;IM Fell Great Primer&amp;quot;;
  font-style: italic;
  src: local(&amp;quot;IM FELL Great Primer Italic&amp;quot;);
}&lt;/code&gt;&lt;/pre&gt;

&lt;p&gt;In other words, we&amp;#8217;re defining a font family named IM Fell Great Primer, the roman of which can be found locally as &amp;#8220;IM FELL Great Primer&amp;#8221;, and the italic of which as &amp;#8220;IM FELL Great Primer Italic.&amp;#8221; The browser loads both of those fonts, and when a reference to &lt;code&gt;font-family: IM Fell Great Primer&lt;/code&gt; is found it uses the former when &lt;code&gt;font-style&lt;/code&gt; is &lt;code&gt;normal&lt;/code&gt;, and the latter when &lt;code&gt;italic.&lt;/code&gt;&lt;/p&gt;

&lt;p&gt;According to the W3C standard, there should be no difference when defining a small capitals variant:&lt;/p&gt;

&lt;pre&gt;&lt;code&gt;@font-face {
  font-family: &amp;quot;IM Fell Great Primer&amp;quot;;
  font-variant: small-caps;
  src: local(&amp;quot;IM FELL Great Primer SC&amp;quot;);
}&lt;/code&gt;&lt;/pre&gt;

&lt;p&gt;In other words, the font referred to by this &lt;code&gt;@font-face&lt;/code&gt; rule is the small capitals variant of the IM Fell Great Primer family, and can be found locally under the name &amp;#8220;IM FELL Great Primer SC.&amp;#8221; When the browser encounters a reference to &lt;code&gt;font-family: IM Fell Great Primer&lt;/code&gt; with &lt;code&gt;font-variant: small-caps&lt;/code&gt;, it should then go ahead and use the font referenced above. An example of such a reference:&lt;/p&gt;

&lt;pre&gt;&lt;code&gt;p strong {
  font-variant: small-caps;
}&lt;/code&gt;&lt;/pre&gt;

&lt;p&gt;However, the browsers do not yet understand this. &lt;a href='https://developer.mozilla.org/en/CSS/@font-face' title='Read about @font-face on the Mozilla Developer Center.'&gt;Firefox, for instance, only understands &lt;code&gt;font-weight&lt;/code&gt; and &lt;code&gt;font-style&lt;/code&gt; within &lt;code&gt;@font-face&lt;/code&gt; rules.&lt;/a&gt; That means that you cannot rely on the browsers to automatically use the proper small capitals variant, even when you have explicitly told them the necessary details. Instead, you must define a redundant rule like this:&lt;/p&gt;

&lt;pre&gt;&lt;code&gt;@font-face {
  font-family: &amp;quot;IM Fell Great Primer SC&amp;quot;;
  src: local(&amp;quot;IM FELL Great Primer SC&amp;quot;);
}&lt;/code&gt;&lt;/pre&gt;

&lt;p&gt;And then use it like this:&lt;/p&gt;

&lt;pre&gt;&lt;code&gt;p strong {
  font-family: &amp;quot;IM Fell Great Primer SC&amp;quot;;
}&lt;/code&gt;&lt;/pre&gt;

&lt;p&gt;That way you have explicitly told your browser where to find the small capitals variant and when to use it. And, when forced in this fashion, the browsers do finally get things right.&lt;/p&gt;

&lt;h2 id='5_other_details'&gt;5. Other details.&lt;/h2&gt;

&lt;p&gt;It&amp;#8217;s a bit convoluted, all this, and I haven&amp;#8217;t even touched on how to properly prepare your font files for browser use, or how to really make use of &lt;code&gt;@font-face&lt;/code&gt;. To summarize, &lt;a href='http://www.fontsquirrel.com/' title='Go to fontsquirrel.com.'&gt;use the Font Squirrel.&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;To see the CSS for all the methods discussed above, &lt;a href='http://github.com/cboone/hypsometric-css/tree/master/typography/small-capitals/' title='Go to the small capitals section of the Hypsometric CSS project on Github.'&gt;take a look at my Hypsometric CSS project.&lt;/a&gt; If you have any questions or suggestions, do let me know.&lt;/p&gt;
&lt;style type='text/css'&gt;
  #everything p.small-capitals-example {
    margin: 1.5em auto; /* 24px = 1 line, centered */

    text-indent: 0;
    text-align: center;
  }
  
  #everything p.small-capitals-example span.small-capitals-font-variant,
  #everything p.small-capitals-example span.small-capitals-font-variant-partial span {
    font-variant: small-caps;
  }
  
  #everything p.small-capitals-example span.small-capitals-joe-clark,
  #everything p.small-capitals-example span.small-capitals-clever-joe-clark span {
    font-size: smaller;
    text-transform: uppercase;
  }
  
  #everything p.small-capitals-example span.small-capitals-nick-shinn,
  #everything p.small-capitals-example span.small-capitals-clever-nick-shinn span {
    font-size: 0.6875em; /* 11px */
    font-weight: bolder;
    text-transform: uppercase;
  }
  
  #everything p.small-capitals-example span.small-capitals-font-face,
  #everything p.small-capitals-example span.small-capitals-font-face-partial span {
    font-family: "IM FELL Great Primer SC";
  }
&lt;/style&gt;
    &lt;img src="http://feeds.feedburner.com/~r/hypsometry/blog/articles/~4/cTSPMMtQ22c" height="1" width="1"/&gt;</summary>
  </entry>
  
  <entry>
    <published>2010-01-07T11:00:00-08:00</published>
    <updated>2010-01-07T12:00:00-08:00</updated>
  
    <title>V.</title>
    <id>tag:blog.hypsometry.com,2010-01-07:/articles/hypsography-news/</id>
  
    <author>
      <name>Christopher Boone</name>
    </author>
    <rights type="text">Copyright 2009 Christopher Boone.</rights>
  
    <link rel="alternate" type="text/html" href="http://blog.hypsometry.com/articles/hypsography-news/" />
  
    <summary type="html">
      &lt;p&gt;Over at &lt;a href='http://hypsography.com/' title='Go to hypsography.com.'&gt;Hypsography&lt;/a&gt; my work is continuing apace, and that pace is increasing. I&amp;#8217;m continuing my explorations of &lt;a href='http://books.google.com/books?id=44Yq6UplAbAC' title='Read about *An Essay on Typography* by Eric Gill, on Google Books.'&gt;humane typography&lt;/a&gt; there. The site is now set in &lt;a href='http://code.google.com/p/sortsmill/' title='Go to the Google Code project page for Sorts Mill Goudy.'&gt;Sorts Mill Goudy&lt;/a&gt;, &lt;a href='http://www.theleagueofmoveabletype.com/fonts/6-sorts-mill-goudy' title='Read more about the revival of Goudy Old Style, by Barry Schwartz, on the League of Moveable Type.'&gt;an excellent revival&lt;/a&gt; of &lt;a href='http://en.wikipedia.org/wiki/Frederic_W._Goudy' title='Read about Frederic Goudy on Wikipedia.'&gt;Frederic Goudy&amp;#8217;s&lt;/a&gt; incomparable &lt;a href='http://en.wikipedia.org/wiki/Goudy_Old_Style' title='Read about Goudy Old Style on Wikipedia.'&gt;Goudy Old Style&lt;/a&gt;.&lt;/p&gt;
&lt;a href='http://hypsography.com'&gt;
  &lt;img src='/images/hypsography-news/hypsography-heading-720x72.png' height='72' alt='' width='720' /&gt;
&lt;/a&gt;
&lt;p&gt;If you view the site using &lt;a href='http://www.mozilla.com/' title='Download the latest version of Firefox.'&gt;a recent version of Firefox&lt;/a&gt;, you&amp;#8217;ll even see that the &lt;em&gt;f&lt;/em&gt; and &lt;em&gt;i&lt;/em&gt; of &lt;em&gt;field&lt;/em&gt; are joined into one ligature &amp;#8211; as they should be. Firefox is currently the only browser that supports &lt;a href='http://en.wikipedia.org/wiki/Opentype#Advanced_typography' title='Read about OpenType and its typographic abilities on Wikipedia.'&gt;serious OpenType typographic enhancements&lt;/a&gt;. Where by &lt;em&gt;serious&lt;/em&gt; I mean &lt;a href='http://opentype.info/blog/2008/06/14/kerning-and-opentype-features-in-firefox-3/' title='Read about the newly acquired typographic abilities of Firefox on the blog OpenType.'&gt;kerning&lt;/a&gt; and &lt;a href='http://www.dria.org/wordpress/archives/2008/06/10/651/' title='Read more about the newly acquired typographic abilities of Firefox on dria.org.'&gt;ligatures&lt;/a&gt;. Yes, 460 years have passed since Gutenberg began printing with moveable type, and we are just now returning to those basic capabilities.&lt;/p&gt;

&lt;p&gt;At any rate, Sorts Mill Goudy is a beautifully rendered typeface. &lt;a href='http://crudfactory.com/' title='Go to The Crud Factory, the main website of Barry Schwartz.'&gt;Barry Schwartz&lt;/a&gt; is its author, and he has made it available under both &lt;a href='http://en.wikipedia.org/wiki/SIL_Open_Font_License' title='Read about the Open Font License on Wikipedia.'&gt;the Open Font License&lt;/a&gt; and &lt;a href='http://www.opensource.org/licenses/mit-license.php' title='Read about the MIT License on the Open Source Initiative site.'&gt;the MIT License&lt;/a&gt;: &lt;a href='http://www.theleagueofmoveabletype.com/fonts/6-sorts-mill-goudy' title='Read more about the revival of Goudy Old Style, by Barry Schwartz, on the League of Moveable Type.'&gt;OFL Sorts Mill Goudy&lt;/a&gt; and &lt;a href='http://code.google.com/p/sortsmill/' title='Go to the Google Code project page for Sorts Mill Goudy.'&gt;MIT Sorts Mill Goudy&lt;/a&gt;. You can also find it &lt;a href='http://typedia.com/explore/typeface/sorts-mill-goudy/' title='Read about Sorts Mill Goudy on the Typedia.'&gt;in the Typedia&lt;/a&gt;, along with another excellent, though less completely realized, Goudy revival by Mr Schwartz: &lt;a href='http://typedia.com/explore/typeface/goudy-bookletter-1911/' title='Read about Goudy Bookletter 1911 on the Typedia.'&gt;Goudy Bookletter 1911&lt;/a&gt;.&lt;/p&gt;

&lt;p&gt;I used &lt;a href='http://www.fontsquirrel.com/' title='Go to the Font Squirrel website.'&gt;the Font Squirrel&amp;#8217;s&lt;/a&gt; &lt;a href='http://www.fontsquirrel.com/fontface/generator' title='Go to the @font-face generator on fontsquirrel.com.'&gt;&lt;code&gt;@font-face&lt;/code&gt; generator&lt;/a&gt; to prepare the files for Hypsography, and I highly recommend it. To make the process even simpler, the Font Squirrel already has &lt;a href='http://www.fontsquirrel.com/fonts/OFL-Sorts-Mill-Goudy' title='Go to the OFL Sorts Mill Goudy page on Font Squirrel.'&gt;OFL Sorts Mill Goudy&lt;/a&gt; in its archive, along with &lt;a href='http://www.fontsquirrel.com/fontfacedemo/OFL-Sorts-Mill-Goudy' title='Go to the OFL Sorts Mill Goudy @font-face demo page on fontsquirrel.com, where you can download a pre-made @font-face kit.'&gt;a pre-generated &lt;code&gt;@font-face&lt;/code&gt; kit.&lt;/a&gt; Or, if you prefer, both &lt;a href='http://the-crud-factory.kernest.com/fonts/ofl-sorts-mill-goudy-regular' title='Go to the OFL Sorts Mill Goudy page on kernest.com.'&gt;Kernest&lt;/a&gt; and &lt;a href='http://typekit.com/fonts/494' title='Go to the the OFL Sorts Mill Goudy page on typekit.com.'&gt;Typekit&lt;/a&gt; also include Mr Schwartz&amp;#8217;s Goudy revival.&lt;/p&gt;

&lt;p&gt;From the information available on the project site, Sorts Mill Goudy appears to be a work in progress. Nonetheless, it seems quite ready for use right now. Using &lt;a href='http://nicewebtype.com/' title='Go to Nice Web Type.'&gt;Tim Brown&amp;#8217;s&lt;/a&gt; &lt;a href='http://webfontspecimen.com/' title='Go to the Web Font Specimen site, by Tim Brown.'&gt;web font specimen&lt;/a&gt;, I&amp;#8217;ve put up &lt;a href='http://hypsography.com/typefaces/specimens/mill-sorts-goudy/' title='Go to the Sorts Mill Goudy web font specimen on Hypsography.'&gt;a demonstration page for Sorts Mill Goudy on Hypsography&lt;/a&gt;, for your further inspection.&lt;/p&gt;

&lt;p&gt;To return to my initial point: &lt;a href='http://hypsography.com/' title='Go to hypsography.com.'&gt;Hypsography&lt;/a&gt; has a new look, &lt;a href='http://hypsography.com/news/' title='Go to the News section on hypsography.com.'&gt;a new section for news and other ephemera&lt;/a&gt;, and &lt;a href='http://hypsography.com/guide/forests/' title='Go to the Forests page of the Hypsography guide.'&gt;a newly added tetraptych.&lt;/a&gt; Enjoy.&lt;/p&gt;
&lt;a href='http://hypsography.com'&gt;
  &lt;img src='/images/hypsography-news/hypsography-forests-720x144.jpg' height='144' alt='' width='720' /&gt;
&lt;/a&gt;
    &lt;img src="http://feeds.feedburner.com/~r/hypsometry/blog/articles/~4/efXWh0Bq5vM" height="1" width="1"/&gt;</summary>
  </entry>
  
  <entry>
    <published>2009-11-27T00:00:00-08:00</published>
    <updated>2009-11-27T00:00:00-08:00</updated>
  
    <title>IV.</title>
    <id>tag:blog.hypsometry.com,2009-11-27:/articles/wildcat-strike/</id>
  
    <author>
      <name>Christopher Boone</name>
    </author>
    <rights type="text">Copyright 2009 Christopher Boone.</rights>
  
    <link rel="alternate" type="text/html" href="http://blog.hypsometry.com/articles/wildcat-strike/" />
  
    <summary type="html">
      &lt;a href='https://www.adbusters.org/campaigns/bnd'&gt;
  &lt;img src='/images/wildcat-strike/wildcat.png' height='360' alt='Wildcat strike.' width='668' /&gt;
&lt;/a&gt;
    &lt;img src="http://feeds.feedburner.com/~r/hypsometry/blog/articles/~4/FuAw8usnyTM" height="1" width="1"/&gt;</summary>
  </entry>
  
  <entry>
    <published>2009-11-22T10:00:00-08:00</published>
    <updated>2009-11-22T10:00:00-08:00</updated>
  
    <title>III.</title>
    <id>tag:blog.hypsometry.com,2009-11-22:/articles/html5-default-styles/</id>
  
    <author>
      <name>Christopher Boone</name>
    </author>
    <rights type="text">Copyright 2009 Christopher Boone.</rights>
  
    <link rel="alternate" type="text/html" href="http://blog.hypsometry.com/articles/html5-default-styles/" />
  
    <summary type="html">
      &lt;p&gt;While &lt;a href='/articles/reset-stylesheets-and-html5/' title='Read my blog post about my updated reset stylesheet.'&gt;updating my reset stylesheet&lt;/a&gt; last week, I realized that if I wanted to reset &lt;a href='http://www.w3.org/TR/html5-diff/#new-elements' title='Read about the new HTML5 elements on the W3C website.'&gt;the new HTML5 elements&lt;/a&gt; I would have to determine precisely how they were supposed to be styled. Which proved to be a challenge, since &lt;a href='http://en.wikipedia.org/wiki/Comparison_of_layout_engines_%28HTML_5%29#Elements' title='A table, on Wikipedia, detailing which of the new HTML5 elements are supported by which browsers. The short version: Almost none of them.'&gt;no browser yet supports anything like the full array of new elements and styles.&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Luckily, &lt;a href='http://www.whatwg.org/specs/web-apps/current-work/' title='Read the latest draft of the HTML5 standard, at the WHATWG site.'&gt;the current HTML5 specification&lt;/a&gt; contains &lt;a href='http://www.whatwg.org/specs/web-apps/current-work/multipage/rendering.html' title='Read section 11 of the HTML5 standard, on rendering, at the WHATWG site.'&gt;extremely detailed descriptions of how browsers should render HTML documents.&lt;/a&gt; These are not requirements, of course, but rather &amp;#8220;a set of suggestions.&amp;#8221; These descriptions, found in &lt;em&gt;&amp;#167;11 Rendering&lt;/em&gt;, are of reasonable expectations; and thus it seems reasonable, in turn, that I base my expectations for the future behavior of browsers on them. (Realizing full well how deeply foolhardy that might be.)&lt;/p&gt;

&lt;p&gt;Within the many suggestions listed in &amp;#167;11 &amp;#8211; and they are many and detailed &amp;#8211; there is one in particular that is relevant here: &lt;a href='http://www.whatwg.org/specs/web-apps/current-work/multipage/rendering.html#the-css-user-agent-style-sheet-and-presentational-hints' title='Read section 11.2 of the HTML5 standard, on CSS rendering, at the WHATWG site. '&gt;&lt;em&gt;&amp;#167;11.2 The CSS user agent style sheet and presentational hints.&lt;/em&gt;&lt;/a&gt; This section walks through the varieties of default styles and describes how each HTML element is to be handled. Specific CSS is provided, and additional instructions and suggestions are noted. From time to time, the additional notes refer to styles best handled by CSS, though for the most part they don&amp;#8217;t.&lt;/p&gt;

&lt;p&gt;Regarding the new HTML5 elements, my goals are to:&lt;/p&gt;

&lt;ol&gt;
&lt;li&gt;Set up the appropriate display properties, so that blocks display as blocks by default.&lt;/li&gt;

&lt;li&gt;Make sure that any elements that shouldn&amp;#8217;t be visible are not.&lt;/li&gt;

&lt;li&gt;Counteract, in a speculative, preventative manner, any styling that browsers are likely to apply.&lt;/li&gt;
&lt;/ol&gt;

&lt;p&gt;&amp;#167;11 contains all the information I need to meet these goals. It describes the display types of the elements, including their visibility, and it describes all the other styling that should be applied by the browsers, once they support HTML5 more completely.&lt;/p&gt;

&lt;p&gt;Therefore I compiled all the recommended CSS into one stylesheet. In doing so, I realized that the styles recommended are entirely too comprehensive. Styles for &lt;a href='http://www.w3.org/TR/html5-diff/#absent-elements' title='Read about which elements have been deprecated in HTML5, on the W3C website.'&gt;deprecated elements&lt;/a&gt; and &lt;a href='http://www.w3.org/TR/html5-diff/#absent-attributes' title='Read about which attributes have been deprecated in HTML5, on the W3C website.'&gt;elements modified by deprecated attributes&lt;/a&gt; are listed, so I removed them from my stylesheet. CSS bindings for each element are listed in &lt;a href='http://www.whatwg.org/specs/web-apps/current-work/multipage/rendering.html#bindings' title='Read about how CSS bindings work in HTML5, at the WHATWG site.'&gt;&amp;#167;11.4&lt;/a&gt; &amp;#8211; but &lt;a href='https://developer.mozilla.org/En/CSS/-moz-binding' title='Read about the -moz-binding CSS property, on the Mozilla Developer Center site.'&gt;only Gecko supports that functionality&lt;/a&gt;, and it currently only supports it in a proprietary way; so I left out the bindings styles too.&lt;/p&gt;

&lt;p&gt;In other ways, the recommended CSS does not go far enough. Two sets of styles, describing the appearance of &lt;code&gt;h1&lt;/code&gt; elements nested within the new semantic content elements, are so complicated that the draft standard only summarizes how they are supposed to work. Both &lt;a href='http://www.whatwg.org/specs/web-apps/current-work/multipage/rendering.html#margins-and-padding' title='Read section 11.2.3 of the HTML5 standard, on rendering margins and padding, at the WHATWG site.'&gt;&amp;#167;11.2.3&lt;/a&gt; and &lt;a href='http://www.whatwg.org/specs/web-apps/current-work/multipage/rendering.html#fonts-and-colors' title='Read section 11.2.5 of the HTML5 standard, on rendering fonts and colors, at the WHATWG site.'&gt;&amp;#167;11.2.5&lt;/a&gt; note that the styling of an &lt;code&gt;h1&lt;/code&gt; element varies depending on its context. Of course, &lt;code&gt;h1&lt;/code&gt; has its own default styling &amp;#8211; &lt;code&gt;font-size: 2.00em&lt;/code&gt;, for instance. But when you have an &lt;code&gt;h1&lt;/code&gt; nested within a &lt;code&gt;section element&lt;/code&gt; &amp;#8211; &lt;code&gt;section h1&lt;/code&gt;, that is &amp;#8211; it should receive &lt;code&gt;font-size: 1.50em&lt;/code&gt;. And if you have another heading, nested even further - &lt;code&gt;article section aside h1&lt;/code&gt;, for example &amp;#8211; that should have &lt;code&gt;font-size: 1.00em&lt;/code&gt; applied. This is important, since &lt;a href='http://boblet.tumblr.com/post/134276674/html5-structure2' title='Read Oli Studholme'&gt;HTML5 has radically redefined how we are supposed to use headings.&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Sadly, the draft standard authors have left it as an exercise to the reader to actually write the relevant styles, for all the nesting depths. I have done so, though I&amp;#8217;m not entirely sure I&amp;#8217;ve done so correctly. The permutations involved are reasonably complicated, particularly since &lt;code&gt;section&lt;/code&gt; elements can nest within each other, though none of the others can.&lt;/p&gt;

&lt;p&gt;There is only one additional change that I&amp;#8217;ve made, a quite small one, but potentially useful. &lt;a href='http://www.whatwg.org/specs/web-apps/current-work/multipage/rendering.html#display-types' title='Read section 11.2.2 of the HTML5 standard, on display types, at the WHATWG site.'&gt;&amp;#167;11.2.2 Display types&lt;/a&gt; describes how each element should be displayed by default &amp;#8211; &lt;code&gt;head&lt;/code&gt; is hidden, &lt;code&gt;blockquote&lt;/code&gt; is a block, &lt;code&gt;table&lt;/code&gt; is a table, &lt;code&gt;ruby&lt;/code&gt; elements are displayed like &lt;a href='http://en.wikipedia.org/wiki/Ruby_character' title='Read about ruby characters on Wikipedia.'&gt;ruby characters&lt;/a&gt;, &lt;em&gt;et cetera.&lt;/em&gt; The list of block level elements, however, does not include the &lt;code&gt;details&lt;/code&gt; element.&lt;/p&gt;

&lt;p&gt;An element new to HTML5, &lt;em&gt;&amp;#8220;the details element represents a disclosure widget from which the user can obtain additional information or controls&amp;#8221;&lt;/em&gt;, &lt;a href='http://www.whatwg.org/specs/web-apps/current-work/multipage/interactive-elements.html#the-details-element' title='Read about the details element at the WHATWG site.'&gt;according to &amp;#167;4.11.1.&lt;/a&gt; It is what the standard calls an interactive element, and is meant to act as a wrapper for other content which may be displayed or hidden as the reader prefers. The usage example provided &amp;#8211; as well as the description of how to use the &lt;code&gt;details&lt;/code&gt; element &amp;#8211; suggests wrapping it around a &lt;code&gt;dt&lt;/code&gt; and a &lt;code&gt;dd&lt;/code&gt;, as if it were a special type of &lt;a href='http://www.whatwg.org/specs/web-apps/current-work/multipage/grouping-content.html#the-dl-element' title='Read about the dl element at the WHATWG site.'&gt;definition list.&lt;/a&gt; As such, it seems appropriate to style the &lt;code&gt;details&lt;/code&gt; element as a block, and I&amp;#8217;ve done so.&lt;/p&gt;

&lt;p&gt;You can see &lt;a href='http://github.com/cboone/hypsometric-css/blob/master/html5/html5-defaults.css' title='Read html5-defaults.css on GitHub.'&gt;the stylesheet that resulted from my compilation and editing on GitHub&lt;/a&gt;, along with &lt;a href='http://github.com/cboone/hypsometric-css/tree/master/html5/' title='Read my notes about the latest version of html5-defaults.css, on GitHub.'&gt;some notes.&lt;/a&gt; You&amp;#8217;re free to use it as you like. As always, please do let me know if you notice any problems or have any suggestions.&lt;/p&gt;
    &lt;img src="http://feeds.feedburner.com/~r/hypsometry/blog/articles/~4/pigWpncClMI" height="1" width="1"/&gt;</summary>
  </entry>
  
  <entry>
    <published>2009-11-16T00:00:00-08:00</published>
    <updated>2009-11-16T00:00:00-08:00</updated>
  
    <title>II.</title>
    <id>tag:blog.hypsometry.com,2009-11-16:/articles/reset-stylesheets-and-html5/</id>
  
    <author>
      <name>Christopher Boone</name>
    </author>
    <rights type="text">Copyright 2009 Christopher Boone.</rights>
  
    <link rel="alternate" type="text/html" href="http://blog.hypsometry.com/articles/reset-stylesheets-and-html5/" />
  
    <summary type="html">
      &lt;p&gt;There are two important reset stylesheets out there, on the loose: &lt;a href='http://meyerweb.com/eric/tools/css/reset/' title='Eric Meyer'&gt;Eric Meyer&amp;#8217;s &lt;code&gt;reset.css&lt;/code&gt;&lt;/a&gt; and &lt;a href='http://developer.yahoo.com/yui/3/cssreset/' title='YUI 3 CSS Reset.'&gt;YUI&amp;#8217;s CSS Reset&lt;/a&gt;. Both are highly useful, though they differ slightly in the details of their approach and implementation. Eric intends for you to take his CSS and alter it to your needs, creating a reset stylesheet that works for your own projects. He describes it as:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;The reset styles given here are intentionally very generic.&amp;#8230; In other words, this is a starting point, not a self-contained black box of no-touchiness.&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;Yahoo, on the other hand, is aiming for a more complete resetting. They write:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;The foundational CSS Reset removes the inconsistent styling of HTML elements provided by browsers. This creates a dependably flat foundation to built upon.&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;For a couple of years now, since &lt;a href='http://meyerweb.com/eric/thoughts/2007/04/12/reset-styles/' title='Read Eric'&gt;Eric first described his ideas&lt;/a&gt;, I&amp;#8217;ve used my own &lt;code&gt;reset.css&lt;/code&gt;. A combination of Eric&amp;#8217;s original code and YUI&amp;#8217;s more comprehensive styles, modified here and there as needed. It has served well on many projects.&lt;/p&gt;

&lt;p&gt;Now that &lt;a href='http://www.whatwg.org/specs/web-apps/current-work/' title='Read the latest draft of the HTML5 standard, at the WHATWG site.'&gt;HTML5&lt;/a&gt; is at last upon us, my &lt;code&gt;reset.css&lt;/code&gt; no longer quite fits the bill. For one thing, there are &lt;a href='http://www.w3.org/TR/html5-diff/#new-elements' title='Read about the new HTML5 elements.'&gt;new elements&lt;/a&gt; that bring with them new default styles, which of course need resetting. For a second, &lt;a href='http://www.w3.org/TR/html5-diff/#absent-elements' title='Read about which elements have been deprecated in HTML5.'&gt;other elements have been deprecated&lt;/a&gt;, and so I no longer need to worry about them. (Of course, you might, since your project might be different.) And for a third, and possibly most important, &lt;a href='http://en.wikipedia.org/wiki/Comparison_of_layout_engines_%28HTML_5%29#Elements' title='A table, on Wikipedia, detailing which of the new HTML5 elements are supported by which browsers. The short version: Almost none of them.'&gt;few of the new elements are supported sufficiently by the browsers&lt;/a&gt;.&lt;/p&gt;

&lt;p&gt;Given all this, I&amp;#8217;ve updated my reset stylesheet. It ignores deprecated elements, and gives the new ones display styles as needed. This also is not a self-contained box of resetting, but I do find it quite useful. You can &lt;a href='http://github.com/cboone/hypsometric-css/blob/master/reset/reset.css' title='Read my reset.css on GitHub.'&gt;find it on GitHub&lt;/a&gt;, along with &lt;a href='http://github.com/cboone/hypsometric-css/blob/master/reset/' title='Read my notes about the latest iteration of my reset.css, on GitHub.'&gt;some additional notes&lt;/a&gt;. You&amp;#8217;re free to use it as you like. As always, please do let me know if you notice any problems or have any suggestions.&lt;/p&gt;
    &lt;img src="http://feeds.feedburner.com/~r/hypsometry/blog/articles/~4/_w6B3PG9iIA" height="1" width="1"/&gt;</summary>
  </entry>
  
  <entry>
    <published>2009-11-07T00:00:00-08:00</published>
    <updated>2010-01-07T10:00:00-08:00</updated>
  
    <title>I.</title>
    <id>tag:blog.hypsometry.com,2009-11-07:/articles/ashland-mccarthy-and-the-field-guide/</id>
  
    <author>
      <name>Christopher Boone</name>
    </author>
    <rights type="text">Copyright 2009 Christopher Boone.</rights>
  
    <link rel="alternate" type="text/html" href="http://blog.hypsometry.com/articles/ashland-mccarthy-and-the-field-guide/" />
  
    <summary type="html">
      &lt;p&gt;It&amp;#8217;s not yet a new year, but I have a new home, this blog has a new life, and I&amp;#8217;ve begun work on a new &amp;#8212; though long overdue &amp;#8212; project. The project is the realization of &lt;a href='http://hypsography.com'&gt;Hypsography, my field guide&lt;/a&gt;. This blog was given new form based on the beautiful typography of &lt;em&gt;Cities of the Plain&lt;/em&gt;. And I&amp;#8217;ve moved back across the country, to &lt;a href='http://www.kswild.org/ksregion' title='Read more about the Klamath-Siskiyou bioregion.'&gt;a valley limited by the Cascade and Siskiyou mountain ranges&lt;/a&gt;.&lt;/p&gt;

&lt;p&gt;Let&amp;#8217;s begin with the mountains. They call this valley the Rogue, but the Rogue River is north of here. The Klamath is to the south. Both rivers run from the Cascades to the Pacific, along vaguely parallel courses. Between the two lies a range of mountains called the Siskiyous, which are the northernmost of the Klamath ranges. The Klamath ranges extend inland from the Coast, covering the territory of what are &amp;#8212; to the north and south, that is &amp;#8212; the Coast ranges, though they are not two parts of the same system of mountains in geological or historical terms. Just south of here, around the border, the Siskiyous finish their eastern push where they collide with the Cascades. Ashland, the town where I now live, sits in the valley of a creek that flows into the Rogue, just north of that Siskiyou-Cascade intersection.&lt;/p&gt;
&lt;a href='http://thesfi.org/Page.asp?NavID=397' title='Read the paper from which this map is drawn: Vegetation of the Siskiyou Mountains, Oregon and California, R.H. Whittaker, Ecological Monographs, 1960, Volume 30, Number 3, Page 280.'&gt;
  &lt;img src='/images/ashland-mccarthy-and-the-field-guide/whittaker-map-excerpt-720x240.png' height='240' alt='Hand drawn map of the Siskiyou and Cascade mountains, in Oregon.' width='720' /&gt;
&lt;/a&gt;
&lt;p&gt;And, as you can see, &lt;a href='http://blog.hypsometry.com/'&gt;the Hypsometry blog&lt;/a&gt; is back, for yet another go round. I&amp;#8217;ve lost count of what incarnation this is &amp;#8212; perhaps the sixth? The driving force here, this time, is simplicity.&lt;/p&gt;

&lt;p&gt;The design was inspired by the gorgeous work done on Cormac McCarthy&amp;#8217;s border trilogy; in particular, the title page of the first edition of &lt;em&gt;Cities of the Plain&lt;/em&gt;, the concluding volume of the three.&lt;/p&gt;

&lt;p&gt;In technical terms also, this site is as simple as it has ever been. Since I began designing and building websites &amp;#8212; five years ago now &amp;#8212; I&amp;#8217;ve worked with a wide array of techniques for producing blogs. None has ever been quite right for my needs, so I&amp;#8217;m trying yet another. With luck, this new system will have a little more sticking power. Whether it does or does not, expect my notes on the subject sometime soon.&lt;/p&gt;

&lt;p&gt;&lt;a href='http://hypsography.com'&gt;Hypsography&lt;/a&gt; is my newest project, though I&amp;#8217;ve been planning it for a couple years now. I have a hard time summarizing exactly &lt;em&gt;what&lt;/em&gt; it is that I&amp;#8217;m working on, in part because there&amp;#8217;s so much to come and &amp;#8212; so far &amp;#8212; so little to show. I&amp;#8217;ve written &lt;a href='http://hypsography.com/about/' title='Read more about Hypsography, on Hypsography.'&gt;a few words about it on the site itself&lt;/a&gt;. But really, it&amp;#8217;d be better if &lt;a href='http://hypsography.com'&gt;you just took a look yourself&lt;/a&gt;.&lt;/p&gt;
&lt;a href='http://hypsography.com'&gt;
  &lt;img src='/images/ashland-mccarthy-and-the-field-guide/hypsography-moonlit-718x310.jpg' height='312' alt='Excerpt from a pair of photographs published on Hypsography.' width='720' /&gt;
&lt;/a&gt;
    &lt;img src="http://feeds.feedburner.com/~r/hypsometry/blog/articles/~4/rLnQjdY22Oc" height="1" width="1"/&gt;</summary>
  </entry>
  
  <entry>
    <published>2010-07-22T10:07:00-07:00</published>
    <updated>2010-07-22T10:07:00-07:00</updated>
  
    <title>Nulla.</title>
    <id>tag:blog.hypsometry.com,2010-07-22:/articles/nulla/</id>
  
    <author>
      <name>Christopher Boone</name>
    </author>
    <rights type="text">Copyright 2009 Christopher Boone.</rights>
  
    <link rel="alternate" type="text/html" href="http://blog.hypsometry.com/articles/nulla/" />
  
    <summary type="html">
      &lt;p&gt;This article serves an imaginary purpose: Dividing the old Hypsometry from the new. All articles older than this one are on their second or third go round the course; all articles newer are fresh, on their first legs.&lt;/p&gt;

&lt;p&gt;Thus, do not take the old ones too seriously. They are preserved here, in internautical amber, for reference, for humor, and to help keep the links alive.&lt;/p&gt;
    &lt;img src="http://feeds.feedburner.com/~r/hypsometry/blog/articles/~4/NGqc-lIQm5o" height="1" width="1"/&gt;</summary>
  </entry>
  
  <entry>
    <published>2006-02-20T21:00:00-08:00</published>
    <updated>2010-07-22T10:00:00-07:00</updated>
  
    <title>-I.</title>
    <id>tag:blog.hypsometry.com,2006-02-21:/articles/three-things-about-pivot/</id>
  
    <author>
      <name>Christopher Boone</name>
    </author>
    <rights type="text">Copyright 2009 Christopher Boone.</rights>
  
    <link rel="alternate" type="text/html" href="http://blog.hypsometry.com/articles/three-things-about-pivot/" />
  
    <summary type="html">
      &lt;p&gt;Since last summer I&amp;#8217;ve been working with &lt;a href='http://Xenium'&gt;Xenium Group&amp;#8217;s&lt;/a&gt; excellent &lt;a href='http://pivotcms.com/'&gt;PivotCMS&lt;/a&gt;. At the time I started using it, my only real CMS experience was with &lt;a href='http://textpattern.com/'&gt;TextPattern&lt;/a&gt; &amp;#8211; a CMS of a fundamentally different design.&lt;/p&gt;

&lt;p&gt;TextPattern is one of the new breed of small CMSes: very dynamic, conditionally structured, blog-oriented (which is to say: chronologically-oriented). Pivot, on the other hand, has been around as long as &lt;a href='http://blogger.com/'&gt;Blogger&lt;/a&gt;, and seemed more static and stodgy, overly concerned with things like security and documents.&lt;/p&gt;

&lt;p&gt;In hindsight, I realize that Pivot&amp;#8217;s intended audience is not that of TextPattern&amp;#8217;s. As Xenium Group puts it: Pivot&amp;#8217;s &amp;#8220;targeted feature set is not all things to all people.&amp;#8221;&lt;/p&gt;

&lt;p&gt;Since last summer I&amp;#8217;ve continued to build sites with TextPattern and Pivot, and have become quite familiar with &lt;a href='http://expressionengine.com/'&gt;ExpressionEngine&lt;/a&gt; and &lt;a href='http://github.com/fdv/typo'&gt;Typo&lt;/a&gt;. Doing so has made three of Pivot&amp;#8217;s best features stand out clearly.&lt;/p&gt;

&lt;h2 id='pivot_is_a_hosted_cms'&gt;Pivot is a hosted CMS.&lt;/h2&gt;

&lt;p&gt;Being hosted means no installation, no need to familiarize myself with a client&amp;#8217;s hosting arrangement, no need to talk to tech support, no dealing with &lt;code&gt;.htaccess&lt;/code&gt; files, et cetera &amp;#8211; all of which means less time spent by me and less money spent by my client.&lt;/p&gt;

&lt;p&gt;That also means that Xenium Group provides support for Pivot&amp;#8217;s operation, as part of the package, which means that my clients don&amp;#8217;t have to wait for a hole in my schedule to get help &amp;#8211; they can just go straight to the source.&lt;/p&gt;

&lt;h2 id='pivot_publishes_sites_via_ftp'&gt;Pivot publishes sites via FTP.&lt;/h2&gt;

&lt;p&gt;At first I hated this idea: Why not generate the site dynamically? That&amp;#8217;s the slick way to do it. Creating the site in one place, then pushing it to another via FTP seemed unnecessarily complicated and needlessly time-consuming.&lt;/p&gt;

&lt;p&gt;Now I get it.&lt;/p&gt;

&lt;p&gt;When I redesign a site using ExpressionEngine, I build the new version on a staging server of my own. Then, when it comes time to launch, I have to do a multi-part dance:&lt;/p&gt;

&lt;ol&gt;
&lt;li&gt;The customized installation of EE needs to be moved to the client&amp;#8217;s server, though without disturbing the old site that&amp;#8217;s already in place;&lt;/li&gt;

&lt;li&gt;That installation needs to be tweaked to match the client&amp;#8217;s server&amp;#8217;s setup, which &lt;em&gt;always&lt;/em&gt; differs from mine; and&lt;/li&gt;

&lt;li&gt;The old site needs to be turned off, and the new site turned on, simultaneously, and without interfering with each other.&lt;/li&gt;
&lt;/ol&gt;

&lt;p&gt;That operation can go well, or it can go poorly; but it&amp;#8217;s never simple. There&amp;#8217;s always too much room for error.&lt;/p&gt;

&lt;p&gt;When I redesign a site that uses Pivot, I can mess about with things on the CMS side to my heart&amp;#8217;s content. Then, when everything&amp;#8217;s ready to go live, I just click the &lt;em&gt;Publish&lt;/em&gt; button and the new version gets sent out, via FTP. Simple as can be.&lt;/p&gt;

&lt;h2 id='pivot_offers_real_previews'&gt;Pivot offers real previews.&lt;/h2&gt;

&lt;p&gt;Every CMS lets you preview articles; that&amp;#8217;s a given. But Pivot&amp;#8217;s the only one I&amp;#8217;ve seen that lets you see a preview that &lt;em&gt;actually shows what the final web page will look like&lt;/em&gt;.&lt;/p&gt;

&lt;p&gt;Again, this is because Pivot is hosted and publishes its sites statically, via FTP. When you&amp;#8217;re working with Pivot, you&amp;#8217;re working on a Xenium Group server. You make changes to a document and click &lt;em&gt;Preview&lt;/em&gt;, and Pivot generates a new version of that document from the appropriate templates, including all images and stylesheets, and serves it up for your previewing pleasure.&lt;/p&gt;

&lt;p&gt;Makes sense, right? On the other small CMSes I have to jump through hoops to accomplish the same thing.&lt;/p&gt;

&lt;h2 id='in_conclusion'&gt;In conclusion.&lt;/h2&gt;

&lt;p&gt;Pivot isn&amp;#8217;t right for every project, but then it isn&amp;#8217;t meant to be. For sites that are suited for Pivot, it offers a solid array of features, plus a few stand-outs. It&amp;#8217;s worth a look.&lt;/p&gt;
    &lt;img src="http://feeds.feedburner.com/~r/hypsometry/blog/articles/~4/qyZF9gw4Egk" height="1" width="1"/&gt;</summary>
  </entry>
  
</feed>
