<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Seagull Code Nodes &#187; Blog</title>
	<atom:link href="http://blog.joshuasiegal.com/category/blog/feed/" rel="self" type="application/rss+xml" />
	<link>https://blog.joshuasiegal.com</link>
	<description></description>
	<lastBuildDate>Tue, 05 Oct 2010 06:25:03 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.1.2</generator>
		<item>
		<title>10 Ways Agile Development Fails</title>
		<link>https://blog.joshuasiegal.com/2010/10-ways-agile-development-fails/</link>
		<comments>https://blog.joshuasiegal.com/2010/10-ways-agile-development-fails/#comments</comments>
		<pubDate>Tue, 05 Oct 2010 05:15:34 +0000</pubDate>
		<dc:creator>josh</dc:creator>
				<category><![CDATA[Blog]]></category>

		<guid isPermaLink="false">http://blog.joshuasiegal.com/?p=208</guid>
		<description><![CDATA[I recently read through 37 Signals&#8217; excellent manual, Getting Real.  It describes in detail a successful method for developing and launching web-based software.  Many of its tenets are based on the principles of Agile Development, first articulated by Kent Beck et al in The Agile Manifesto.  There is so much hope and good will in [...]]]></description>
			<content:encoded><![CDATA[<p>I recently read through 37 Signals&#8217; excellent manual, <em><a title="Getting Real" href="http://gettingreal.37signals.com/toc.php" target="_blank">Getting Real</a></em>.  It describes in detail a successful method for developing and launching web-based software.  Many of its tenets are based on the principles of Agile Development, first articulated by Kent Beck et al in <em><a title="The Agile Manifesto" href="http://agilemanifesto.org/principles.html" target="_blank">The Agile Manifesto</a></em>.  There is so much hope and good will in these documents &#8211; it makes me a little sad.  Agile started out as a way to free software developers from the chains of a brittle, dogmatic technology age, where change was viewed as expensive and collaboration dangerous.  Agile is supposed to tilt development toward the ways in which developers naturally work.  Despite its promise, agile has become one of those professional chew-toys that has been so thoroughly mangled and salivated over, it&#8217;s barely recognizable anymore.  Many of its principles have been diluted by blind adoption.  At the same time, Agile Development has a dark side.  It&#8217;s the perfect crutch for refusing to do the diligence that&#8217;s required on many tech projects, and, sadly, for denying developers the avenues it was meant to open.</p>
<p>Agile Development is in danger of slipping into the ditch already occupied by brainstorming sessions, train-the-trainer, and team-building: that of management double-speak and great ideas used as excuses to continue the same old practices.<span id="more-208"></span></p>
<p>I know I&#8217;m not the first person to point all this out &#8211; however, unlike many of them, I don&#8217;t see Agile as a panacea or a ploy.  It is precisely because I believe in the principles of Agile Development that I feel a little twinge of pain when I see it going wrong.  Rather than trying to forecast why it must fail or trumpet its invincibility, this post is simply trying to paint some yellow stripes on the bumps in the road, in the inevitable web list format:</p>
<p><strong>1) Working From Small To Large</strong> &#8211; Agile Development aims to put practical decision-making in the hands of the people doing the work.  This sounds dangerous to the people who ostensibly have the &#8220;vision&#8221;, as they realize that real-world concerns are shaping &#8220;their&#8221; project.  However, this is only a problem when there are errors in the vision in the first place.  As <em>Getting Real</em> aptly points out, this style can only work when a motivated team understands and embraces the vision of the project.  If management thinks, &#8220;well, I&#8217;ve got a superb and agile team of developers over here and a great concept over here &#8211; now all I have to do is start assigning tasks&#8221;, the project is doomed to snarl.  After all, agile development teams don&#8217;t need reams of documentation and planning, right?  <em>Sometimes</em> that&#8217;s true, and then only if they deeply understand the goals of the project.  Agile Development is like high-end audio gear.  It can make everything shine, but it will also highlight all the flaws.  Make the effort to get your direction aligned before you start your project running.  You want a nimble bobsled team, not a game of tag.</p>
<p><strong>2) Agile Development on a Non-Agile Project</strong> &#8211; How many workstations have felt the concussion of a developer&#8217;s forehead after the project manager (or the project manager&#8217;s manager) stops by to report that the glorious, elegant solution the developer came up with is nixed for a reason that the developer herself had pointed out weeks, maybe months ago.  Agile teams are supposed to respond to change quickly and enthusiastically.  However, agile precepts are corrupting when applied to non-agile projects.  If the business isn&#8217;t sure what they want, it means trouble for most projects, but an immediate fail for an agile project, which is better adapted to change, but also more vulnerable to it.  Even cases where the business side is focused may not be suitable for agile methods.  For example, one of the main tenets of Agile Development is that developers and business units collaborate to find the best approach for the customer.  If you are Apple, you make your living by exceeding the curve and leading your customers (in theory) to the right place.  However, if you are in an industry that requires stable, trusted solutions (banking would be one that comes to mind), you would do well to temper that agile enthusiasm with a solid dose of risk assessment.</p>
<p><strong>3) Teams Not Independent</strong> &#8211; Unlike the previous examples, this one is a prime example of giving lip service to an idea while ignoring it completely in the day-to-day life of a project.  Micromanagement and agile do not go well together.  Though this is a well-known problem in many types of projects, it actually goes against everything agile stands for.  <em>The Agile Manifesto</em> points out that face-to-face discussions are the most effective means of conveying information.  But what do you do when you&#8217;re having a face-to-face conversation with someone who wants to insert personal preferences into his developers&#8217; work?  Or when management cannot protect the team from peripheral, time-sapping requests?  In these cases, it may be best to put your nose to the grindstone and polish up your resume.</p>
<p><strong>4) Over-Employment</strong> &#8211; So far, we&#8217;ve touched on common problems, but this point is rooted directly in the areas where agile excels.  The concepts of Agile Development have proven so successful that many developers expect to find them on day one: being able to call on business personnel to clarify / collaborate over requirements and solutions; the use of small teams to accomplish discrete tasks; flexibility in planning; experimentation and prototyping as integral to the development process.  When you&#8217;ve got it, you don&#8217;t need to push it.  You don&#8217;t want to show off the strings you just cut and find yourself holding the strings in the process.  If your developers are in the comfort zone, don&#8217;t push them out of it just to try and fulfill what someone says is &#8220;properly&#8221; agile.</p>
<p><strong>5) Scope Defenses Are Down</strong> &#8211; We&#8217;ve all heard that change is key to success, and in the world of software development, the ability to rapidly change direction can mean a decisive edge on the competition.  But there is a big difference between an agile redirection of resources and a stumbling, careening project that no longer knows where it&#8217;s going.  Part of this involves scope.  Imagine a current of water traveling through a gulley.  You realize you need to divert the gulley 90 degrees to the left.  What happens if you dig out a leftward channel but also leave the gulley intact?  Imagine doing this every time the project needs a change &#8211; you are left with a flooded delta, not an effective change.  If developers or managers are thinking &#8220;this is an agile project, so scope creep shouldn&#8217;t matter&#8221;, they are lining themselves up for a waste of resources and a messy, unfocused project &#8211; there is nothing agile about that.</p>
<p><strong>6) Weak Push-Back</strong> &#8211; If <em>Getting Real</em> gets unrealistic at points, it&#8217;s probably in the area of push-back on feature requests.  Sure, if you&#8217;re a crack team of multitalented developers and designers with a shared vision and a successful product, you can afford to ride out an initial wave of resistance as customers adjust to your latest release.  When you have a corporate customer relations manager whose phone banks are blowing up, and he&#8217;s coming over to speak with your boss, things &#8220;get real&#8221; in a hurry.  For Agile Development to fulfill its promise of responsiveness, developers must &#8211; somewhat ironically &#8211; be allowed to provide context to the business.  As usual, communication early and often is key.  Remember that good developers want their applications to be effective and well-received.  Imagine that your team and the business are on the same page, you think you have a brilliant answer, you roll it out, and the users hate it &#8211; and continue hating it.  Agile Development can really shine for you here.  Now imagine the same situation, except that the developers knew users would hate it, and they said so, but you didn&#8217;t listen?  How is the fix going to go?</p>
<p><strong>7) Paying The Bills</strong> &#8211; An agile team should, according to <em>The Agile Manifesto</em>, be able to run indefinitely, making changes and adjustments, keeping up a regular pace.  This does not mean, however, that kludges and workarounds should be allowed to fester when they can be cleaned up.  <em>Get Real</em> puts it well: &#8220;The same way you should regularly put aside some of your income for taxes, regularly put aside some time to pay off your code and design debt. If you don&#8217;t, you&#8217;ll just be paying interest (fixing hacks) instead of paying down the principal (and moving forward).&#8221;  If your team is maintaining a constant pace, they&#8217;ll be fixing these issues eventually.  Better to account for it.</p>
<p><strong>8) How Do We Do This</strong> &#8211; Agile Development requires not just developer feedback on the project itself, but developer feedback on the process.  <em>The Agile Manifesto</em> calls this &#8220;tuning&#8221;, and requires it at regular (and, we can assume, scheduled) intervals.  Failure to pay heed to this tenet of the manifesto results in what I like to call &#8220;Casual Development&#8221;, with everyone plugging along, ignoring opportunities to create efficiency and save time and money.  Can there be a better rationale to the business side than &#8220;this will save you time and money&#8221;?  A regular reflective breather helps create more smoothly running teams and exposes issues that may be silently eating away at a project.  It also gives deeper meaning to the term &#8220;agile&#8221; itself: the ability for a team to self-diagnose and fix issues before they arise.</p>
<p><strong>9) Docu-drama</strong> &#8211; As someone who enjoys writing, making diagrams, and having sensible project outlines, I&#8217;ve never had a problem with documentation, unless it&#8217;s bad documentation.  Some developers and managers act like documentation is a pure waste of time, or else as archaic as stone tablets.  This is hubris.  Thinking that having an agile project means documentation is superfluous is to ignore the experience and wisdom of others &#8211; is your project so cutting edge that no one has ever attempted anything like it before?  Then maybe you don&#8217;t need documentation, and you can just wing it on the strength of your genius.  Will no one ever touch your application besides you and your team?  Surely if they do, they will simply read through your sublimely intuitive and graciously commented code and instantly intuit exactly what is going on.  Just like pre-writing is a great creative exercise for all kinds of non-linguistic projects, documentation is immensely helpful to produce, even if you think you&#8217;ll never need it.  Go ahead, get your thoughts, your vision, your risks and assumptions, you technical specs down on paper.  You may be very glad you did.</p>
<p><strong>10) Users?  What users?</strong> &#8211; Oh, the poor, poor users.  Who is looking out for them in the world of Agile Development?  One of the main creeds of Agile Development is that <em>everyone</em> should be looking out for the souls who have to use our wonderful applications.  Too often, no one is looking out for the user, so caught up are they in the idea that in the modern, agile era of development, all the user has to do is wait until the next release.  The truth is that sometimes the business and the development teams get together and end up with zero idea of how users are going to react.  Here we come full-circle: some projects are well cut out for Agile Development, and some are not.  If you are a small startup and you&#8217;re desperately trying to get your app to market, agile may be what you&#8217;re looking for.  If you&#8217;re in the midst of transitioning a legacy application that thousands of users are relying on daily, you may want to (shudder) think of your users first and your developers second.  As I&#8217;ve pointed out, many agile habits have already worked their way into the mainstream, so don&#8217;t be afraid to be a bit selective about how far you want to push the methodology on any given project.  At 37 Signals, users can marvel at the process, but that doesn&#8217;t mean your users necessarily want to be made aware of your process.  It pays to spend the time and effort to get to know your users.</p>
<p>Agile Development is neither a gift from above nor a mere trend &#8211; it&#8217;s an important crystallization of ideas that can often provide real clarity of purpose for developers and help projects adjust to a fast-changing world.  But it can also be a destructive force if used carelessly.  It&#8217;s like business casual: it can be fun and freeing, but in some circumstances and some hands, it can be disastrous.  I hope this post helps you choose your outfit wisely.</p>
]]></content:encoded>
			<wfw:commentRss>https://blog.joshuasiegal.com/2010/10-ways-agile-development-fails/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Flash in the Pan?  Hardly</title>
		<link>https://blog.joshuasiegal.com/2010/flash-in-the-pan-hardly/</link>
		<comments>https://blog.joshuasiegal.com/2010/flash-in-the-pan-hardly/#comments</comments>
		<pubDate>Fri, 30 Apr 2010 16:49:44 +0000</pubDate>
		<dc:creator>josh</dc:creator>
				<category><![CDATA[Blog]]></category>
		<category><![CDATA[flash]]></category>
		<category><![CDATA[HTML]]></category>
		<category><![CDATA[mobile]]></category>

		<guid isPermaLink="false">http://blog.joshuasiegal.com/?p=204</guid>
		<description><![CDATA[By now, I would guess that over 95% of people interested in Flash have read the Steve Jobs blog rant about why Apple will never implement it on its mobile devices.  That&#8217;s the same percentage of web browsers that have Flash installed, beating Java, Quicktime, Windows Media Player, and so on.  There is a greater [...]]]></description>
			<content:encoded><![CDATA[<p>By now, I would guess that over 95% of people interested in Flash have read the <a title="Jobs Jobbing Flash" href="http://www.apple.com/hotnews/thoughts-on-flash/" target="_blank">Steve Jobs blog rant</a> about why Apple will never implement it on its mobile devices.  That&#8217;s the <a title="Browser Plugin Stats" href="http://lh4.ggpht.com/_GlFxNI53m0o/S8oYyVt0ysI/AAAAAAAAAGA/-yNo-tjCaP4/browser%20chart.PNG" target="_blank">same percentage of web browsers that have Flash installed</a>, beating Java, Quicktime, Windows Media Player, and so on.  There is a greater likelihood that your site is going to be viewed correctly in Flash than in any browser, no matter how standards-compliant.</p>
<p>With the iPod and iPhone, Apple looked like world-beaters, and when the app store opened, developers flocked to pay Apple $100 for the privilege of downloading the app SDK; they began furiously pumping out apps and biting their fingernails while Apple&#8217;s team personally verified the worthiness of each app.  Okay, we get it: part of the iPhone experience is knowing that every app has been tested and approved; it&#8217;s quality control.</p>
<p>It seems that much of the debate right now is whether Flash is an open standard and/or whether apps written in objective C are open and/or which company is behaving like the biggest crybaby.  Really, neither is an open standard.  If you want to develop an iPhone app on a Windows machine or if you&#8217;re looking to compile some Actionscript without running Flash, you have to use third-party software in either case.  These companies are like two toddlers whining at one another for not wanting to share their toys.</p>
<p><span id="more-204"></span></p>
<p>Jobs does have some points &#8211; Flash is not the best for use in iPhone apps, and not just because adopting it for the app store would punish all of Apple&#8217;s loyal developer community, who plunked down dollars for the SDK.  Having developed in Flash, I&#8217;m willing to believe Apple&#8217;s claims about Flash&#8217;s memory issues (remember ye olde garbage collection issues?).  However, WebKit is the best mobile browser anyone has ever seen, and it doesn&#8217;t support Flash.  On this point, there seems to be no good rationale.</p>
<p>Let Apple keep Flash out of the app store.  That&#8217;s their bread and butter &#8211; okay.  But creating a mobile web browser that doesn&#8217;t support the plugin that&#8217;s installed on over 95% of desktop browsers &#8211; including safari &#8211; is just bitterness manifested.  Other mobile browsers support Flash, and yet Apple seems too content to let the market pass them by in this regard.</p>
<p>The worst part is that Jobs and his supporters are offering HTML5 as a panacea.  Sure, it&#8217;ll be great &#8211; whenever it&#8217;s fully supported &#8211; but its video component will lack much that Flash is able to do fairly easily now (real interactivity, for example), and its codec of choice, H.264, is proprietary.  Having most players agree on a proprietary format is not the same thing as an open standard.  Oh, and it <a title="Flash Here To Stay?" href="http://theiphonefever.blogspot.com/2010/04/5-reasons-flash-is-here-to-stay.html" target="_blank">leaves out Firefox</a>, which is, by the way, open.   It&#8217;s like telling commuters that everything will be great when we get our hovercars that run on solar power.  In the meantime, your car is not welcome on our road.  Jobs and his backers may have a point that Adobe treated Apple like a second-class citizen back in the 90s.  Which they were.  Now, I love my Apple products like anyone else drinking the multimedia development koolaid, but wasn&#8217;t Adobe doing the same thing to Apple back then that Apple is trying to do to Adobe now?  If the open revolution proved anything, it&#8217;s that having a zen-like indifference to such petty squabbles produces winners.  Did Zend worry about Microsoft?</p>
<p>Jobs&#8217; blog post hints at the decades of recrimination by recalling the early days when Adobe and Apple were both based in similar garages.  Get over it.  It&#8217;s Final Cut Pro and Aftereffects.  No one will ever use the combination of Premiere and Motion.  Flash is better for the web.  Mac apps are better for Apple devices.</p>
<p>It seems that offering Flash support in Apple&#8217;s mobile WebKit browser while keeping Adobe out of the app store market would make everyone relatively happy, but unfortunately, it seems such realism is lacking in the relatively closed and high-ego world of large-scale software development.</p>
<p><span style="text-decoration: underline;">update</span>: <a title="Proof of Flash on iPhone?" href="http://www.techradar.com/news/computing/apple/steve-jobs-doesn-t-know-what-the-iphone-can-do-says-adobe-641520" target="_blank">proof Flash can hang on Apple mobile devices after all?</a></p>
]]></content:encoded>
			<wfw:commentRss>https://blog.joshuasiegal.com/2010/flash-in-the-pan-hardly/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Rel Isn&#8217;t That Nice</title>
		<link>https://blog.joshuasiegal.com/2010/rel-isnt-that-nice/</link>
		<comments>https://blog.joshuasiegal.com/2010/rel-isnt-that-nice/#comments</comments>
		<pubDate>Thu, 22 Apr 2010 17:44:25 +0000</pubDate>
		<dc:creator>josh</dc:creator>
				<category><![CDATA[Blog]]></category>
		<category><![CDATA[HTML]]></category>
		<category><![CDATA[jQuery]]></category>
		<category><![CDATA[semantic]]></category>

		<guid isPermaLink="false">http://blog.joshuasiegal.com/?p=202</guid>
		<description><![CDATA[Just a quick post to talk about how much I&#8217;m loving the rel tag these days.   Defining custom values for this attribute may not be strictly validated, but there seems to be some debate about this, and with HTML 5, we&#8217;re going to be moving that way with the all-encompassing data- tag. But for now, [...]]]></description>
			<content:encoded><![CDATA[<p>Just a quick post to talk about how much I&#8217;m loving the rel tag these days.   Defining custom values for this attribute may not be strictly validated, but there seems to be some debate about this, and with HTML 5, we&#8217;re going to be moving that way with the all-encompassing <a title="The HTML5 data tag" href="http://www.danwebb.net/2010/1/27/put-that-data-attribute-away-son-you-might-hurt-someone" target="_blank">data-</a> tag.</p>
<p>But for now, the rel tag is easy, supported, and makes getting a little bit of meta information to your script quite easy.</p>
<p>Two uses I&#8217;ve written recently are:</p>
<p>(1) Creating abstracted div collapse scripts.  The script just looks at the rel tag for the link and finds the matching rel tag among a class of divs on the page.  Anything matching is shown, anything not matching is hidden.  I never have to go back and touch the script, and I only have to add a rel tag to my divs.</p>
<p>(2) Letting my css-based navigation know which page we&#8217;re currently on.  With includes, the idea that your navigation should reflect your current page location fell out of favor a bit.  Kind of suspicious, if you ask me.  It often seems designers and front-end developers adapt their pet styles to suit the latest technology.  Regardless, it&#8217;s dang easy with the rel tag to revert to the &#8220;old&#8221; style of location-aware navigation.  I just drop a rel tag in my nav links and a matching rel tag in my content div within the content include file.  They search for each other.  They find one another.  It&#8217;s like an interface component romance paperback.</p>
<p>Part of the reason that HTML 5 is going to include some developer-defined tags is that people have been using rel and a few other tags to include meta data (and sometimes some not-so-meta data) in their front-end code.  I completely understand the cold chill that comes over some folks when they start contemplating gobs of data gooping up the front end.  I also think it&#8217;s possible to fret too much.  As the linked article above points out well, it&#8217;s possible to include some meta data inline and still be semantically useful, degrade nicely, and not offend the browser.</p>
<p>If people hadn&#8217;t been expanding on the uses of the rel attribute so effectively, we may not have had the push for user-defined attributes in HTML 5.  This is a good thing.  It&#8217;s important to remember this truism: no amount of standards will stop people from writing ugly code.  But, paying attention to what developers are doing in practice and honoring those practices in new standards definitions can benefit everyone.</p>
]]></content:encoded>
			<wfw:commentRss>https://blog.joshuasiegal.com/2010/rel-isnt-that-nice/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>jsFloater is top ten on google!</title>
		<link>https://blog.joshuasiegal.com/2010/jsfloater-is-top-ten-on-google/</link>
		<comments>https://blog.joshuasiegal.com/2010/jsfloater-is-top-ten-on-google/#comments</comments>
		<pubDate>Wed, 10 Feb 2010 23:38:53 +0000</pubDate>
		<dc:creator>josh</dc:creator>
				<category><![CDATA[Blog]]></category>
		<category><![CDATA[AS3]]></category>
		<category><![CDATA[flash]]></category>
		<category><![CDATA[jsFloater]]></category>
		<category><![CDATA[liquid]]></category>

		<guid isPermaLink="false">http://blog.joshuasiegal.com/?p=189</guid>
		<description><![CDATA[Celebrating jsFloater&#8217;s appearance on the first result page in a google search for &#8220;Flash Liquid GUI&#8221;! We&#8217;re just psyched to be in a google result page with the likes of James O&#8217;Reilly and actionscript.org. Hooray!  If you haven&#8217;t checked out the code yet, by all means please do.]]></description>
			<content:encoded><![CDATA[<p>Celebrating jsFloater&#8217;s appearance on the first result  page in a <a title="google search for &quot;flash liquid gui&quot;" href="http://www.google.com/#hl=en&amp;q=flash+liquid+gui&amp;aq=f&amp;aqi=&amp;oq=&amp;fp=c26c79a56c95bda8" target="_blank">google search</a> for &#8220;Flash Liquid GUI&#8221;!</p>
<div id="attachment_193" class="wp-caption aligncenter" style="width: 410px"><a href="http://www.google.com/#hl=en&amp;q=flash+liquid+gui&amp;aq=f&amp;aqi=&amp;oq=&amp;fp=c26c79a56c95bda8" target="_blank"><img class="size-full wp-image-193  " style="border: 0pt none;" title="jsFloater in google's top ten results for flash liquid gui" src="http://blog.joshuasiegal.com/wp-content/uploads/2010/02/jsFloaterTopTen1.png" alt="Hangin at the Bottom" width="400" height="129" /></a><p class="wp-caption-text">Hangin at the Bottom</p></div>
<p>We&#8217;re just psyched to be in a google result page with the likes of James O&#8217;Reilly and actionscript.org.</p>
<p>Hooray!  If you haven&#8217;t checked out the code yet, by all means <a title="jsFloater" href="http://blog.joshuasiegal.com/jsFloater/" target="_blank">please do</a>.</p>
]]></content:encoded>
			<wfw:commentRss>https://blog.joshuasiegal.com/2010/jsfloater-is-top-ten-on-google/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>CSS Three, Can&#8217;t Wait for Thee</title>
		<link>https://blog.joshuasiegal.com/2010/css-three-cant-wait-for-thee/</link>
		<comments>https://blog.joshuasiegal.com/2010/css-three-cant-wait-for-thee/#comments</comments>
		<pubDate>Fri, 05 Feb 2010 18:22:13 +0000</pubDate>
		<dc:creator>josh</dc:creator>
				<category><![CDATA[Blog]]></category>
		<category><![CDATA[CSS]]></category>

		<guid isPermaLink="false">http://blog.joshuasiegal.com/?p=182</guid>
		<description><![CDATA[Well, it&#8217;s not exactly what I&#8217;ve been asking for, but it&#8217;s actually quite a bit better than what I thought we might get.  Like wanting a pony for christmas and getting a great dane. It looks like CSS3 will have some pretty cool new attributes available for us developers.  Of course, it&#8217;s all proposed and [...]]]></description>
			<content:encoded><![CDATA[<p style="text-align: left;">Well, it&#8217;s not exactly what I&#8217;ve been <a title="A Call For CSS Math" href="http://blog.joshuasiegal.com/2009/a-call-for-css-math/">asking for</a>, but it&#8217;s actually quite a bit better than what I thought we might get.  Like wanting a pony for christmas and getting a great dane.</p>
<p style="text-align: center;"><img class="aligncenter" src="http://theblackboxoffice.com/wp-content/uploads/marmaduke.gif" alt="http://theblackboxoffice.com/wp-content/uploads/marmaduke.gif" /></p>
<p style="text-align: left;">It looks like CSS3 will have some pretty cool new attributes available for us developers.  Of course, it&#8217;s all proposed and not released yet, but let&#8217;s start salivating anyway:</p>
<p><span id="more-182"></span></p>
<p style="text-align: left;">One really cool thing with the potential for hilarious abuse of power is a proposed scale attribute.  Use your own imagination on that one.</p>
<p style="text-align: left;">But that&#8217;s not the best.  The best (if truly implemented) would be a set of CSS specs for creating a multicolumn layout without having to resort to javascript trickery, fakey background images, or ridiculous amounts of div nesting.  <em>Great news, everyone!</em></p>
<p style="text-align: center;"><em><img class="size-full wp-image-198 alignnone" title="professor farnsworth" src="http://blog.joshuasiegal.com/wp-content/uploads/2010/02/farnsworth.jpg" alt="professor farnsworth" width="470" height="330" /><br />
</em></p>
<p style="text-align: left;">Found on these <a title="sixrevisions: CSS3 techniques" href="http://sixrevisions.com/css/css3-techniques-you-should-know/" target="_blank">sixrevisions</a> <a title="sixrevisions: CSS3 resources" href="http://sixrevisions.com/css/20-useful-resources-for-learning-about-css3/" target="_blank">posts</a>.</p>
]]></content:encoded>
			<wfw:commentRss>https://blog.joshuasiegal.com/2010/css-three-cant-wait-for-thee/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Sufferin Semantics! XML, HTML, jQuery, and MSIE</title>
		<link>https://blog.joshuasiegal.com/2010/sufferin-semantics-xml-html-jquery-msie/</link>
		<comments>https://blog.joshuasiegal.com/2010/sufferin-semantics-xml-html-jquery-msie/#comments</comments>
		<pubDate>Thu, 04 Feb 2010 22:54:32 +0000</pubDate>
		<dc:creator>josh</dc:creator>
				<category><![CDATA[Blog]]></category>
		<category><![CDATA[AJAX]]></category>
		<category><![CDATA[API]]></category>
		<category><![CDATA[HTML]]></category>
		<category><![CDATA[jQuery]]></category>
		<category><![CDATA[semantic]]></category>
		<category><![CDATA[XML]]></category>

		<guid isPermaLink="false">http://blog.joshuasiegal.com/?p=168</guid>
		<description><![CDATA[So, in a recent project, I&#8217;m consuming xml data and pulling out some text for a description field on an html page.  I&#8217;ve got some basic stuff, text for title information, paths to asset files stored as node attributes, the usual.  But something is bugging me.  I&#8217;ve included some html in my descriptions, all formatted [...]]]></description>
			<content:encoded><![CDATA[<p>So, in a recent project, I&#8217;m consuming xml data and pulling out some text for a description field on an html page.  I&#8217;ve got some basic stuff, text for title information, paths to asset files stored as node attributes, the usual.  But something is bugging me.  I&#8217;ve included some html in my descriptions, all formatted according to xhtml standards, but it won&#8217;t be parsed by jQuery.</p>
<p>Dagnabit!  What is the point of combining xml and html standards if I can&#8217;t use them together all the time?  I know, you may be thinking, but xml is not html , no matter what you throw into your nodes.  You&#8217;re right, and this is exactly what jQuery tells us.  You can grab the text contents of any node, but if you have html tags in there, the <a title="jQuery API - text method" href="http://api.jquery.com/text/" target="_blank">.text()</a> method in jQuery will just look right past them.  As it should.  This works fine, for little snippets like my titles, but what if I want to put some (ostensibly) well-formatted html code in my data?  Further, what about all those applications where you want to store html snips in a database and read them out in XML?  How do you get around this?</p>
<p><span id="more-168"></span></p>
<p>For that, we&#8217;d want to use the <a title="jQuery API - html method" href="http://api.jquery.com/html/" target="_blank">.html()</a> method of jQuery, and for that, my friends, we suddenly get quite strict.  XML, according to jQuery, is not html, and so has no innerHTML quality for the .html() method to grab.  It doesn&#8217;t matter, says jQuery, if your html code is so well formatted that it can be parsed as xml&#8230;it&#8217;s just not possible to access an html-specific property that does not exist.</p>
<p>Like fun, I say!</p>
<p>But before we get to the solution, let&#8217;s heartlessly go over some available options:</p>
<p>1) We could punt on the whole jQuery thing and use Flash, which knows just what to do with a string of html parsed from within an xml node.  Furthermore, Flash has a nifty .htmlText property on its text fields, and although the formatting of said html pales compared to real css, it will faithfully render as html anything you tell it to, caveat codeur.  Since the project in question did involve some Flash, this was an option, but one of the points of the project was to take the same xml data and have both flash and jQuery parse it for different purposes, and thereby provide ease for content providers and improve accessibility.  So doing the whole thing in Flash was out.</p>
<p>2) We could escape the heck out of all our characters and turn the whole node into a mess of html character codes.  Un-fun to code and messy for the content people.  Also, I tried that and it rendered out a block of actual html onto my screen.  I&#8217;m sure I could have reconverted those characters back into actual html behind the scenes, but again, un-fun and a hassle.</p>
<p>3) Use a fancy xml consuming plugin or script.  There are some neat ones out there, and I tried one in particular that looked pretty good, but it seems they have a common issue &#8211; you have to know what tags you&#8217;re looking for in order to seek and replace within the script.  Some of them will hunt for anything that looks like an html tag in the string and convert that, but mostly these plugins seem like scripts that people wrote to perform functions for themselves, and then extracted and shared.  Which I applaud.  But these were not what I was looking for, and I found the implementation sometimes troublesome.</p>
<p>4)<strong> [Warning: bad solution]</strong> Hand jQuery a bag of grapes and say it&#8217;s &#8220;nature&#8217;s jellybeans&#8221; (at least that&#8217;s what my mom used to do to us).  It goes like so: grab your xml file with an <a title="jQuery API - ajax method" href="http://api.jquery.com/jQuery.ajax/" target="_blank">ajax()</a> call, and use the optional key/value pair:</p>
<blockquote><p>dataType: &#8220;html&#8221;</p></blockquote>
<p>And then you&#8217;d do ike so:</p>
<blockquote><p>$.ajax({ url: &#8220;myXMLdoc.xml&#8221;,<br />
dataType: &#8220;html&#8221;,<br />
success: function(xml){<br />
var myHtmlContent = $(&#8216;node&#8217;,xml).eq(id).find(&#8220;nodeName&#8221;).html();<br />
$(&#8220;#targetdiv&#8221;).html(myHtmlContent);<br />
}<br />
});</p></blockquote>
<p>&#8230;and there you have it!  Or, would&#8230;if&#8230;</p>
<p>&#8230;can you see where this is going?</p>
<p>&#8230;search your feelings, Luke&#8230;</p>
<p>&#8230;if only Internet Explorer handled the XMLHTTPRequest result like the rest of the world!  Like most Microsoft stuff, IE, with its <strong>own</strong> version of the XMLHTTPRequest (someone <a title="Microsoft XMLHTTPRequest documentation" href="http://msdn.microsoft.com/en-us/library/ms535874%28VS.85%29.aspx" target="_blank">correct me if I&#8217;m wrong on that</a>), wants to get too clever and won&#8217;t let you, the developer, tell it what kind of data you&#8217;d like to see (even if it&#8217;s either of several types that are verging toward common standard).  No siree!</p>
<p>Supposedly, recent versions of IE (7+) have their own XMLHTTPRequest, not the previous Microsoft HTTPRequest.  However, the Microsoft XMLHTTPRequest doesn&#8217;t behave like the other girls and boys, even in the recent versions of IE.  Now, this post didn&#8217;t start off to be a discussion of the supposed evils of Microsoft&#8217;s proprietary habits.  But who else has almost 11 million results on a <a title="google search: internet explorer sucks" href="http://www.google.com/#hl=en&amp;q=internet+explorer+sucks&amp;aq=f&amp;aqi=&amp;oq=&amp;fp=c26c79a56c95bda8" target="_blank">google search of how much they suck</a>?  Hint: not Chrome (3 M), Firefox (1 M), or Safari (1 M).  (Can&#8217;t evaluate Opera on this critrion because sadly a lot of people out there think that real, actual opera &#8211; the music &#8211; sucks too).  For comparison: &#8220;yanni sucks&#8221; (400 K), &#8220;death metal sucks&#8221; (700 K), &#8220;paris hilton sucks&#8221; (1 M), &#8220;the lions suck&#8221; (1 M), &#8220;tv sucks&#8221; (11 M), and &#8220;new york sucks&#8221; (12 M).  So, yeah.</p>
<p>Anyway, after that turgid digression, <em>finally,</em> we come to the solution.  And&#8230;</p>
<p>It&#8217;s simple!  Maybe I&#8217;m, like, the last one to figure this out, but you just use XML&#8217;s <a title="W3C XML CDATA" href="http://www.w3schools.com/XML/xml_cdata.asp" target="_blank">CDATA</a> declaration, and wrap it around our html code within our xml node.  If I had found that idea earlier, it would have saved me some time, but I would have missed a brain-scratching moment or ten for sure.</p>
<p>Anyway, this is fascinating to me for several reasons:</p>
<p>a) When oh when is Microsoft going to just give up and give us a truly standards-compliant web browser?  Maybe they should spin off a company whose software is intuitive and flexible and plays nice with others.  Oh wait, <a title="apple" href="http://www.apple.com/" target="_blank">they already did that</a>.</p>
<p>b) With the XHTML standard in full force, it seems totally silly that one would have to pass off perfectly valid XHTML within an xml document as CDATA.  Isn&#8217;t the whole point of XHTML to be able to one day have a semantic web, where code itself can be meaningful?  How far away are we when it&#8217;s trouble to get even well-formatted html out of my xml nodes without basically commenting it out?  In theory, that means I can&#8217;t parse through my html elements, which seems to go against the whole ethos of XHMTL.</p>
<p>Well, heck.  I remember when CSS was going to put an end to bad code.</p>
]]></content:encoded>
			<wfw:commentRss>https://blog.joshuasiegal.com/2010/sufferin-semantics-xml-html-jquery-msie/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>Straight to the Wall (USB)</title>
		<link>https://blog.joshuasiegal.com/2009/straight-to-the-wall-usb/</link>
		<comments>https://blog.joshuasiegal.com/2009/straight-to-the-wall-usb/#comments</comments>
		<pubDate>Wed, 02 Dec 2009 18:51:43 +0000</pubDate>
		<dc:creator>josh</dc:creator>
				<category><![CDATA[Blog]]></category>
		<category><![CDATA[DIY]]></category>
		<category><![CDATA[electronics]]></category>
		<category><![CDATA[USB]]></category>

		<guid isPermaLink="false">http://blog.joshuasiegal.com/?p=121</guid>
		<description><![CDATA[I love this instructable that I found through Make magazine: converting your wall outlet to a permanent, in-wall USB charger. I mean, you could simply get a USB plug power adapter with cord, plug that sucker into your existing wall outlet, and staple-gun the cord to the wall.  But that would just be ugly.  This [...]]]></description>
			<content:encoded><![CDATA[<p>I love this instructable that I found through Make magazine: converting your wall outlet to <a title="USB wall charger instructable" href="http://www.instructables.com/id/Outlets-of-the-Future-aka-in-wall-USB-Charger/" target="_blank">a permanent, in-wall USB charger</a>.</p>
<p>I mean, you <em>could</em> simply get a USB plug power adapter with cord, plug that sucker into your existing wall outlet, and staple-gun the cord to the wall.  But that would just be ugly.  This is way more elegant, more fun, and more dangerous.</p>
<p><span id="more-121"></span></p>
<p>The author of the article also makes a fascinating point, however dubious it may be, that one day all wall outlets will be USB.  This makes me think of a smart grid with smart appliances sharing data on energy consumption and using sophisticated algorithms to allocate power just where it&#8217;s needed, when it&#8217;s needed.  Since 26% of the cost of our electricity comes from <a title="Factors affecting US electrical prices" href="http://tonto.eia.doe.gov/energyexplained/index.cfm?page=electricity_factors_affecting_prices" target="_blank">distribution</a> (not counting loss through transmission), this could be a real boon.</p>
<p>However, it also makes me a little nervous to think of my household appliances having the ability to share data.  While it&#8217;s totally innocuous, do I <em>want</em> the electric company (or, theoretically, any good hacker with a USB connection) knowing how many times I used my toaster this month?  With the immense amount of personal information that is now being bartered without our consent from our internet use, TV viewing habits, and credit card purchases, I kind of cringe when I think of data on every household appliance use being available for some marketer to collect and sell.</p>
<p>Imagine your washing machine saying, &#8220;hello!  I notice it&#8217;s been a few days since you&#8217;ve done the wash.  Welcome back!  You haven&#8217;t been using fabric softener lately.  Did you know that Snuggle fabric softener is on sale at your local supermarket?  Push the green button to have some Snuggle fabric softener shipped to you right now!&#8221;</p>
<p>To some people, this may seem like we finally have reached the <em>Jetsons</em>-esque world of the <a title="image: foodarackacycle" href="http://blog.joshuasiegal.com/wp-content/uploads/2009/12/foodarackacycle.jpg" target="_blank">foodarackacycle</a> and <a title="image: jetsons computer" href="http://blog.joshuasiegal.com/wp-content/uploads/2009/12/jetsons_computer.jpg" target="_blank">appliances that are our pals</a>.  To me, it seems like digital marketing hell.</p>
<p>If we ever get to the days of data sharing over the power lines, you might see hackers doing the opposite &#8211; posting DIY articles about converting their ubiquitous USB smart power outlets back into good ol&#8217; fashioned &#8220;dumb&#8221; power.</p>
<p>In the mean time, though, this outlet looks pretty sharp.  There&#8217;s nothing wrong with being ahead of the curve, until the curve catches up with you.</p>
]]></content:encoded>
			<wfw:commentRss>https://blog.joshuasiegal.com/2009/straight-to-the-wall-usb/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>A Call for CSS Math</title>
		<link>https://blog.joshuasiegal.com/2009/a-call-for-css-math/</link>
		<comments>https://blog.joshuasiegal.com/2009/a-call-for-css-math/#comments</comments>
		<pubDate>Wed, 25 Nov 2009 17:59:58 +0000</pubDate>
		<dc:creator>josh</dc:creator>
				<category><![CDATA[Blog]]></category>
		<category><![CDATA[CSS]]></category>
		<category><![CDATA[HTML]]></category>
		<category><![CDATA[math]]></category>
		<category><![CDATA[semantic]]></category>

		<guid isPermaLink="false">http://blog.joshuasiegal.com/?p=81</guid>
		<description><![CDATA[Not talking about MathML here, but the addition of simple addition, subtraction, multiplication and division in CSS values. By this time, I&#8217;ve worked my head around the idea that, to many developers (and clients) out there, CSS is the one true way and tables are only good for displaying data &#8211; that is, data that [...]]]></description>
			<content:encoded><![CDATA[<p>Not talking about <a title="MathML" href="http://www.w3.org/Math/" target="_blank">MathML</a> here, but the addition of simple addition, subtraction, multiplication and division in CSS values.</p>
<p>By this time, I&#8217;ve worked my head around the idea that, to many developers (and clients) out there, CSS is the one true way and tables are only good for displaying data &#8211; that is, data that they consider data and not data that someone else might consider data.  See my <a title="Semantic HTML Literacy" href="http://blog.joshuasiegal.com/2009/semantic-html-literacy/">previous post on semantic html</a> for more carping on this topic.  But enough negativity &#8211; I would hereby like to add my voice to the growing number of developers calling for a new future in CSS: [paraphrase] &#8220;If CSS is the golden chalice of front-end web development, how come it can interpret between pixels, point sizes, and em sizes, but it can&#8217;t add 1 + 1?&#8221;</p>
<p>Now, I know, purists will say that Javascript is for math, and CSS is for styling.  Just simply get a good Javascript library and do your math there.  The problem is that other purists will say that using Javascript to generate your CSS positions is pure hackery.  And yet other purists will say &#8220;everyone come to my website to check out my awesome CSS hacks!&#8221;</p>
<p><span id="more-81"></span></p>
<p>Let&#8217;s face up to it: there are some things that CSS is just not that good at.  The idea that you are ruining your SEO by adding three lines of table code to get your column heights equalized seems dubious.  But, I&#8217;m willing to go with that and check out some truly <a title="Matthew James Taylor's Holy Grail 3-Column Layout" href="http://matthewjamestaylor.com/blog/perfect-3-column.htm" target="_blank">weird and wonderful</a> tricks to arrive at the same solution that would take literally half a dozen lines of code using old clunky tables.  But yeah, I&#8217;m sure google&#8217;s robots are completely fooled by a table and a couple of &lt;tr&gt; tags&#8230; [sarcsasm alert].</p>
<p>Anyway, if CSS is going to be responsible for our layout and can have access to and control some of the DOM, why can&#8217;t we just do:</p>
<blockquote><p>#layerid {<br />
width:20%;<br />
margin:10px auto;<br />
height:width * 0.5;<br />
}</p></blockquote>
<p>That would really open things up and allow for some more creative, interactive layouts.  Hopefully, CSS 4 will allow for some of this.  It should be, in my opinion, a no-brainer.</p>
]]></content:encoded>
			<wfw:commentRss>https://blog.joshuasiegal.com/2009/a-call-for-css-math/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Follow You!</title>
		<link>https://blog.joshuasiegal.com/2009/follow-you/</link>
		<comments>https://blog.joshuasiegal.com/2009/follow-you/#comments</comments>
		<pubDate>Fri, 30 Oct 2009 20:43:34 +0000</pubDate>
		<dc:creator>josh</dc:creator>
				<category><![CDATA[Blog]]></category>
		<category><![CDATA[AS3]]></category>
		<category><![CDATA[filters]]></category>
		<category><![CDATA[flash]]></category>
		<category><![CDATA[particles]]></category>

		<guid isPermaLink="false">http://blog.joshuasiegal.com/?p=6</guid>
		<description><![CDATA[No, it&#8217;s not an annoying javascript mouse-follower; it&#8217;s a little bit of actionscript (3) I wrote to test particle generation, color theming and randomization, and interactive filters. Hope you enjoy.]]></description>
			<content:encoded><![CDATA[<p>No, it&#8217;s not an annoying javascript mouse-follower; it&#8217;s a little bit of actionscript (3) I wrote to test particle generation, color theming and randomization, and interactive filters.</p>
<p><a title="Followers Experiment" href="http://joshuasiegal.com/followers/" target="_blank">Hope you enjoy</a>.</p>
]]></content:encoded>
			<wfw:commentRss>https://blog.joshuasiegal.com/2009/follow-you/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Semantic HTML Literacy</title>
		<link>https://blog.joshuasiegal.com/2009/semantic-html-literacy/</link>
		<comments>https://blog.joshuasiegal.com/2009/semantic-html-literacy/#comments</comments>
		<pubDate>Fri, 30 Oct 2009 17:56:22 +0000</pubDate>
		<dc:creator>josh</dc:creator>
				<category><![CDATA[Blog]]></category>
		<category><![CDATA[CSS]]></category>
		<category><![CDATA[divs]]></category>
		<category><![CDATA[HTML]]></category>
		<category><![CDATA[semantic]]></category>
		<category><![CDATA[XML]]></category>

		<guid isPermaLink="false">http://joshuasiegal.com/blog/?p=1</guid>
		<description><![CDATA[Since shortly after people started using markup to organize data, the dream has been knocked around that one day the structure and the content would become seamlessly intertwined.  However, this is a tiny bit counterintuitive, as I see it, as one of the features of XML, for example, is to delineate data and content apart [...]]]></description>
			<content:encoded><![CDATA[<p>Since shortly after <a title="History of XML - Wikipedia" href="http://en.wikipedia.org/wiki/XML#History" target="_blank">people started using markup to organize data</a>, the dream has been knocked around that one day the structure and the content would become seamlessly intertwined.  However, this is a tiny bit counterintuitive, as I see it, as one of the features of XML, for example, is to delineate data and content apart from the meta-data that applies to it.</p>
<p>The real dream has been that one day, HTML and XML would be combined (not just in terms of the XHTML standard), and that the web would turn into a big soup of meta information.  This would allow all sorts of wonderfully customizable content, searching, cross-threading, and possibly, someday, even help create some kind of internet based solely on context, rather than infrastructure and IP.  Positives: super-personalized web-browsing, advertisements, and content aggregation.  Negatives: super-personalized web-browsing, advertisements, and content aggregation.</p>
<p>But I digress.  The flock to div tags as cleaner and more semantically meaningful has been a beneficial one, but for we web developers who remember the [good?] [bad?] old days, there are more than a few cases in memory of the development community rushing en masse to the next greatest thing, and then flipping it into reverse with the release of the next IE browser / web standard / greatest thing.</p>
<p><span id="more-1"></span></p>
<p>It has gotten to the point where I have seen postings looking for people who write div- and css-based code &#8211; <em>no tables allowed!</em></p>
<p>This is madness.  What is XML, after all, than a method of organizing data?  When you&#8217;re getting an XML feed from a backend, you are converting your data from a table-based format (database) to a markup-based format.  Same data (we hope).  The real question here is page layout.  Surely web developers who are using and editing one another&#8217;s code would rather see:</p>
<blockquote><p>&lt;div id=&#8221;header&#8221;&gt;&lt;!&#8211; header &#8211;&gt;&lt;/div&gt;</p></blockquote>
<p>than</p>
<blockquote><p>&lt;table border=&#8221;0&#8243; class=&#8221;table&#8221; cellpadding=&#8221;0&#8243; cellspacing=&#8221;0&#8243;&gt;<br />
&lt;tr&gt;<br />
&lt;th&gt;&lt;!&#8211; header &#8211;&gt;&lt;/th&gt;<br />
&lt;tr&gt;<br />
etc.</p></blockquote>
<p>But while that div is nice and neat and it allows for better accessibility, it does not do as well when it comes time for, let&#8217;s say:</p>
<p><a title="One good use for tables" href="http://espn.go.com/nfl/statistics/team/_/stat/downs/sort/thirdDownConvPct" target="_blank">this</a>.</p>
<p>Also, despite the wonderful blessing that is CSS (<a title="CSS Zen Garden" href="http://csszengarden.com/" target="_blank">it can be quite soothing</a>), when something goes wrong with the style sheet, the result can be disastrous.  Of course, we all want to write code that degrades gracefully, but the fact is that, the more we ask of our code &#8211; especially as we utilize style sheets &#8211; the more risk we run that if something breaks on the backend (certainly our code would never break), or a user is tied to a hopelessly outdated browser, the result will be unintelligible.</p>
<p>But back to semantics, for their own sake.  Perhaps it comes down to a particular aesthetic, but the notion of a fully semantic web makes me think of those kitschy items that have the word for the item printed on them, for example a mug that says &#8220;MUG&#8221;.  Maybe there is a bit too much big-picture here, for a change.  Net neutrality&#8217;s goal is access and publishing rights for anyone with an internet connection.   It&#8217;s not hard to imagine a semantic web that wants to take choices out of our hands and push certain content in front of our eyeballs for us.</p>
<p>As for us developers, if the goal is good, solid code, the answer seems to be, like with much else, a healthy mix of new and old, with an eye towards every tool and its best use.</p>
]]></content:encoded>
			<wfw:commentRss>https://blog.joshuasiegal.com/2009/semantic-html-literacy/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>
