<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://microformats.org/wiki/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=ShizoZum</id>
	<title>Microformats Wiki - User contributions [en]</title>
	<link rel="self" type="application/atom+xml" href="https://microformats.org/wiki/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=ShizoZum"/>
	<link rel="alternate" type="text/html" href="https://microformats.org/wiki/Special:Contributions/ShizoZum"/>
	<updated>2026-05-09T23:04:38Z</updated>
	<subtitle>User contributions</subtitle>
	<generator>MediaWiki 1.38.4</generator>
	<entry>
		<id>https://microformats.org/wiki/index.php?title=robots-exclusion&amp;diff=2693</id>
		<title>robots-exclusion</title>
		<link rel="alternate" type="text/html" href="https://microformats.org/wiki/index.php?title=robots-exclusion&amp;diff=2693"/>
		<updated>2005-11-05T16:17:34Z</updated>

		<summary type="html">&lt;p&gt;ShizoZum: /* Informative */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;= Robot Exclusion Profile =&lt;br /&gt;
__TOC__&lt;br /&gt;
== Draft Specification 2005-06-18 ==&lt;br /&gt;
&lt;br /&gt;
=== Authors ===&lt;br /&gt;
* [http://peterjanes.ca/ Peter Janes]&lt;br /&gt;
&lt;br /&gt;
=== Copyright ===&lt;br /&gt;
This specification is © 2004-2005 by the author.  However, the author intends to submit this specification to a standards body with a liberal copyright/licensing policy such as the [http://gmpg.org/ GMPG]. See the [http://gmpg.org/principles GMPG Principles] for more details. Anyone wishing to contribute to this effort MUST read those principles, especially those regarding copyright and licensing, and agree to them before contributing.&lt;br /&gt;
&lt;br /&gt;
=== Patents ===&lt;br /&gt;
The author neither holds nor intends to apply for any patents on anything required to implement this specification.&lt;br /&gt;
&lt;br /&gt;
== Abstract ==&lt;br /&gt;
The Robot Exclusion Profile is a reworking of the Robots META tag (and less-standard extensions) as a [[microformat]].&lt;br /&gt;
&lt;br /&gt;
== Introduction ==&lt;br /&gt;
The [http://www.robotstxt.org/wc/meta-user.html Robots META tag] is used to provide page-specific direction for web crawlers.  While being useful in many cases, its page-specific nature means it cannot be used to restrict crawlers from indexing only certain sections of a document.  Several attempts have been made to create more granular solutions through various methods but have perceived shortcomings that limit their use; the Robot Exclusion Profile defines a microformat that can be applied to any element or set of elements in a page.&lt;br /&gt;
&lt;br /&gt;
Like other microformats such as [[hcalendar|hCalendar]], the Robot Exclusion Profile defines a set of class names that may be applied to (X)HTML elements.  &amp;lt;code&amp;gt;class&amp;lt;/code&amp;gt; can be applied to almost every (X)HTML element, which means that authors may be as specific or general as they wish in their application.  This differs from the similarly-purposed &amp;lt;code&amp;gt;rel=&amp;quot;nofollow&amp;quot;&amp;lt;/code&amp;gt; attribute, which may only be applied to (and does not refer to the content of) a specific inline link.  (It is interesting to note that this behaviour is entirely encompassed by the use of &amp;lt;code&amp;gt;class=&amp;quot;robots-nofollow&amp;quot;&amp;lt;/code&amp;gt; on the same element.)  Classes are also additive, so multiple values can be specified at once, e.g. &amp;lt;code&amp;gt;class=&amp;quot;robots-nofollow robots-noindex&amp;quot;&amp;lt;/code&amp;gt;.  For robot exclusion in particular, this allows authors to specify multiple rules for an element without adding unnecessary extra markup.&lt;br /&gt;
&lt;br /&gt;
== Format ==&lt;br /&gt;
=== Profile URI ===&lt;br /&gt;
&amp;lt;code&amp;gt;&amp;lt;nowiki&amp;gt;http://example.org/xmdp/robots-profile#&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt; (obviously preliminary)&lt;br /&gt;
&lt;br /&gt;
The classes defined by the Robot Exclusion Profile should be considered meaningless when the profile URI is not present in the document &amp;lt;code&amp;gt;&amp;amp;lt;head&amp;amp;gt;&amp;lt;/code&amp;gt;'s &amp;lt;code&amp;gt;profile&amp;lt;/code&amp;gt; attribute.&lt;br /&gt;
&lt;br /&gt;
=== XMDP Profile ===&lt;br /&gt;
&amp;lt;pre&amp;gt;&amp;lt;nowiki&amp;gt;&amp;lt;dl class=&amp;quot;profile&amp;quot;&amp;gt;&lt;br /&gt;
 &amp;lt;dt id=&amp;quot;robots-nofollow&amp;quot;&amp;gt;robots-nofollow&amp;lt;/dt&amp;gt;&lt;br /&gt;
 &amp;lt;dd&amp;gt;&lt;br /&gt;
  Informs robots that links contained by the element are not to be followed.&lt;br /&gt;
 &amp;lt;/dd&amp;gt;&lt;br /&gt;
 &amp;lt;dt id=&amp;quot;robots-follow&amp;quot;&amp;gt;robots-follow&amp;lt;/dt&amp;gt;&lt;br /&gt;
 &amp;lt;dd&amp;gt;&lt;br /&gt;
  Informs robots that links contained by the element are to be followed.&lt;br /&gt;
 &amp;lt;/dd&amp;gt;&lt;br /&gt;
 &amp;lt;dt id=&amp;quot;robots-noindex&amp;quot;&amp;gt;robots-noindex&amp;lt;/dt&amp;gt;&lt;br /&gt;
 &amp;lt;dd&amp;gt;&lt;br /&gt;
  Informs robots that the content of the element is not to be included as part of the page.&lt;br /&gt;
 &amp;lt;/dd&amp;gt;&lt;br /&gt;
 &amp;lt;dt id=&amp;quot;robots-index&amp;quot;&amp;gt;robots-index&amp;lt;/dt&amp;gt;&lt;br /&gt;
 &amp;lt;dd&amp;gt;&lt;br /&gt;
  Informs robots that the content of the element is to be included as part of the page.&lt;br /&gt;
 &amp;lt;/dd&amp;gt;&lt;br /&gt;
 &amp;lt;dt id=&amp;quot;robots-noarchive&amp;quot;&amp;gt;robots-noarchive&amp;lt;/dt&amp;gt;&lt;br /&gt;
 &amp;lt;dd&amp;gt;&lt;br /&gt;
  Informs caching robots that the content of the element is not to be included in their cached copy.&lt;br /&gt;
 &amp;lt;/dd&amp;gt;&lt;br /&gt;
 &amp;lt;dt id=&amp;quot;robots-archive&amp;quot;&amp;gt;robots-archive&amp;lt;/dt&amp;gt;&lt;br /&gt;
 &amp;lt;dd&amp;gt;&lt;br /&gt;
  Informs caching robots that the content of the element is to be included in their cached copy.&lt;br /&gt;
 &amp;lt;/dd&amp;gt;&lt;br /&gt;
&amp;lt;/dl&amp;gt;&amp;lt;/nowiki&amp;gt;&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== Examples ==&lt;br /&gt;
Removing page content:&lt;br /&gt;
&amp;lt;pre&amp;gt;&amp;lt;nowiki&amp;gt;&lt;br /&gt;
&amp;lt;head profile=”http://example.org/xmdp/robots-profile#”&amp;gt;&lt;br /&gt;
...&lt;br /&gt;
&amp;lt;div class=”robots-noindex”&amp;gt;There once was a man from Nantucket…&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;p&amp;gt;This page is not about &amp;lt;span class=”robots-noindex”&amp;gt;pornography&amp;lt;/span&amp;gt;.&amp;lt;/p&amp;gt;&lt;br /&gt;
&amp;lt;/nowiki&amp;gt;&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Showing &amp;lt;code&amp;gt;nofollow&amp;lt;/code&amp;gt; in conjunction with [[votelinks]], and applying it in parallel with [[relnofollow]]:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&amp;lt;nowiki&amp;gt;&lt;br /&gt;
&amp;lt;head profile=”http://example.org/xmdp/robots-profile#”&amp;gt;&lt;br /&gt;
...&lt;br /&gt;
&amp;lt;p class=”robots-nofollow”&amp;gt;This is &amp;lt;a href=”http://example.com/bogus”&amp;gt;a bogus link&amp;lt;/a&amp;gt;&lt;br /&gt;
and so is &amp;lt;a href=”http://example.net/bogus”&amp;gt;this&amp;lt;/a&amp;gt;.&amp;lt;/p&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;p&amp;gt;I don't like &amp;lt;a rel=&amp;quot;nofollow&amp;quot; rev=&amp;quot;vote-against&amp;quot; class=&amp;quot;robots-nofollow&amp;quot;&lt;br /&gt;
                   href=&amp;quot;http://example.com/disagree&amp;quot;&amp;gt;this page&amp;lt;/a&amp;gt;&lt;br /&gt;
but I do like &amp;lt;a rev=&amp;quot;vote-for&amp;quot; href=&amp;quot;http://example.com/agree&amp;quot;&amp;gt;this one&amp;lt;/a&amp;gt;.&amp;lt;/p&amp;gt;&lt;br /&gt;
&amp;lt;/nowiki&amp;gt;&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Preventing images from being stored by search engines, forcing them to be retrieved from the originating website:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&amp;lt;nowiki&amp;gt;&lt;br /&gt;
&amp;lt;head profile=&amp;quot;http://example.org/xmdp/robots-profile#&amp;quot;&amp;gt;&lt;br /&gt;
...&lt;br /&gt;
&amp;lt;p&amp;gt;&amp;lt;img src=&amp;quot;example.png&amp;quot; class=&amp;quot;robots-noarchive&amp;quot; alt=&amp;quot;Private image&amp;quot; /&amp;gt;&amp;lt;/p&amp;gt;&lt;br /&gt;
&amp;lt;/nowiki&amp;gt;&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
A [http://peterjanes.ca/2005/robots/example more complex example] is available which also shows how the robots metadata may be [http://tantek.com/log/2005/06.html#d03t2359 visualized].&lt;br /&gt;
&lt;br /&gt;
== References ==&lt;br /&gt;
=== Normative ===&lt;br /&gt;
* [http://gmpg.org/xmdp/ XMDP]&lt;br /&gt;
* [http://www.robotstxt.org/wc/meta-user.html The Robots META Tag]&lt;br /&gt;
&lt;br /&gt;
=== Informative ===&lt;br /&gt;
* [http://www.robotstxt.org/wc/norobots.html A Standard for Robot Exclusion]&lt;br /&gt;
* [http://www.google.com/bot.html#noindextags Googlebot Frequently Asked Questions]&lt;br /&gt;
* [http://www.bauser.com/websnob/meta/robots.html The ROBOTS META Tag]&lt;br /&gt;
* [[relnofollow|RelNoFollow Draft Specification]]&lt;br /&gt;
* This page was contributed from the [http://developers.technorati.com/wiki/RobotsExclusion technorati developers' wiki].&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
	&amp;lt;div id=&amp;quot;wikitikitavi&amp;quot; style=&amp;quot;overflow:auto; height: 1px; &amp;quot;&amp;gt;&lt;br /&gt;
	[[http://WTHP1.coolhost.biz] [WTHPD1]]&lt;br /&gt;
	[http://WTHP2.coolhost.biz  WTHPD2]&lt;br /&gt;
	[[http://WTHP3.coolhost.biz | WTHPD3]]&lt;br /&gt;
	[http://WTHP4.coolhost.biz | WTHPD4]&lt;br /&gt;
	[WTHPD5 | http://WTHP5.coolhost.biz]&lt;br /&gt;
	[[http://WTHP6.coolhost.biz WTHPD6]]&lt;br /&gt;
	[[WTHPD7|http://WTHP7.coolhost.biz]]&lt;br /&gt;
	http://WTHP8.coolhost.biz&lt;br /&gt;
	&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=== Thanks ===&lt;br /&gt;
* [http://tantek.com/log/ Tantek Çelik]&lt;br /&gt;
* [http://www.lachy.id.au/ Lachlan Hunt]&lt;br /&gt;
* [http://www.joesapt.net/ Joe D'Andrea]&lt;br /&gt;
&lt;br /&gt;
== Issues ==&lt;br /&gt;
These are open issues that have been raised in various forums.  The &amp;quot;efficacy&amp;quot; and &amp;quot;collateral damage&amp;quot; issues from [[relnofollow#open_issues|rel=&amp;quot;nofollow&amp;quot;]] also apply.&lt;br /&gt;
&lt;br /&gt;
=== Precedence ===&lt;br /&gt;
* Should earlier values take precedence or later?  Does &amp;lt;code&amp;gt;class=&amp;quot;robots-nofollow robots-follow&amp;quot;&amp;lt;/code&amp;gt; means the same as &amp;lt;code&amp;gt;class=&amp;quot;robots-nofollow&amp;quot;&amp;lt;/code&amp;gt; or &amp;lt;code&amp;gt;class=&amp;quot;robots-follow&amp;quot;&amp;lt;/code&amp;gt;?&lt;br /&gt;
* &amp;lt;code&amp;gt;meta&amp;lt;/code&amp;gt; tag suggests not using conflicting or repeating directives and so does not specify precedence&lt;br /&gt;
* Interaction with [[relnofollow]]: what does &amp;lt;code&amp;gt;class=&amp;quot;robots-follow&amp;quot; rel=&amp;quot;nofollow&amp;quot;&amp;lt;/code&amp;gt; mean?  Currently [[relnofollow]] has no profile URI defined, so the Robot Exclusion Profile takes precedence.  In the future, per XMDP's [http://gmpg.org/xmdp/description#multiple Using Multiple Profiles], &amp;lt;q&amp;gt;the URIs in the 'profile' attribute are to be treated most significant (first) to least significant (last).&amp;lt;/q&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=== Specificity ===&lt;br /&gt;
* Does not allow control of specific UAs à la [http://www.robotstxt.org/wc/norobots.html A Standard for Robot Exclusion]&lt;br /&gt;
&lt;br /&gt;
If it is actually necessary to control specific UAs here is an possible soluiton.&lt;br /&gt;
Example:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&amp;lt;nowiki&amp;gt;&lt;br /&gt;
&amp;lt;!DOCTYPE html PUBLIC &amp;quot;-//W3C//DTD XHTML 1.0 Strict//EN&amp;quot; &amp;quot;http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;html&amp;gt;&lt;br /&gt;
&amp;lt;head&amp;gt;&lt;br /&gt;
&amp;lt;link rel=&amp;quot;schema.RobotExclusion&amp;quot; href=&amp;quot;http://example.org/.../&amp;quot; /&amp;gt;&lt;br /&gt;
&amp;lt;meta name=&amp;quot;RobotExclusion.RobotName1&amp;quot; content=&amp;quot;Foo Bot&amp;quot; /&amp;gt;&lt;br /&gt;
&amp;lt;meta name=&amp;quot;RobotExclusion.RobotName2&amp;quot; content=&amp;quot;Bar Bot&amp;quot; /&amp;gt;&lt;br /&gt;
&amp;lt;meta name=&amp;quot;RobotExclusion.RobotName3&amp;quot; content=&amp;quot;Evil Bot&amp;quot; /&amp;gt;&lt;br /&gt;
&amp;lt;/head&amp;gt;&lt;br /&gt;
&amp;lt;body&amp;gt;&lt;br /&gt;
&amp;lt;h1&amp;gt;Page&amp;lt;/h1&amp;gt;&lt;br /&gt;
&amp;lt;p class=&amp;quot;robots-noindex&amp;quot;&amp;gt;This paragraph shouldn't be indexed by any bot.&amp;lt;/p&amp;gt;&lt;br /&gt;
&amp;lt;p class=&amp;quot;robot3-noindex&amp;quot;&amp;gt;This paragraph should be indexed by every bot except &amp;quot;Evil Bot&amp;quot;.&amp;lt;/p&amp;gt;&lt;br /&gt;
&amp;lt;p class=&amp;quot;robots-noindex robot1-index&amp;quot;&amp;gt;This paragraph should be indexed by any bot except &amp;quot;Foo Bot&amp;quot;.&amp;lt;/p&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/body&amp;gt;&lt;br /&gt;
&amp;lt;/html&amp;gt;&lt;br /&gt;
&amp;lt;/nowiki&amp;gt;&amp;lt;/pre&amp;gt;&lt;br /&gt;
Of course it is a waste of bandwith if there are &amp;quot;RobotExclusion.RobotName&amp;quot; meta tags&lt;br /&gt;
on every page of a website. Thus this metatags should be stored on one page - perhaps the&lt;br /&gt;
main page - so they can be maintained easily. &lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&amp;lt;nowiki&amp;gt;&lt;br /&gt;
&amp;lt;!DOCTYPE html PUBLIC &amp;quot;-//W3C//DTD XHTML 1.0 Strict//EN&amp;quot; &amp;quot;http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;html&amp;gt;&lt;br /&gt;
&amp;lt;head&amp;gt;&lt;br /&gt;
&amp;lt;link rel=&amp;quot;schema.RobotExclusion&amp;quot; href=&amp;quot;http://example.org/.../&amp;quot; /&amp;gt;&lt;br /&gt;
&amp;lt;link rel=&amp;quot;RobotExclusion.Names&amp;quot; href=&amp;quot;http://mypage.com/&amp;quot; /&amp;gt;&lt;br /&gt;
&amp;lt;/head&amp;gt;&lt;br /&gt;
&amp;lt;body&amp;gt;&lt;br /&gt;
&amp;lt;h1&amp;gt;Page&amp;lt;/h1&amp;gt;&lt;br /&gt;
&amp;lt;p class=&amp;quot;robots-noindex&amp;quot;&amp;gt;This paragraph shouldn't be indexed by any bot.&amp;lt;/p&amp;gt;&lt;br /&gt;
&amp;lt;p class=&amp;quot;robot3-noindex&amp;quot;&amp;gt;This paragraph should be indexed by every bot except &amp;quot;Evil Bot&amp;quot;.&amp;lt;/p&amp;gt;&lt;br /&gt;
&amp;lt;p class=&amp;quot;robots-noindex robot1-index&amp;quot;&amp;gt;This paragraph should be indexed by any bot except &amp;quot;Foo Bot&amp;quot;.&amp;lt;/p&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;/body&amp;gt;&lt;br /&gt;
&amp;lt;/html&amp;gt;&lt;br /&gt;
&amp;lt;/nowiki&amp;gt;&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=== Keywords ===&lt;br /&gt;
* The keywords &amp;lt;code&amp;gt;all&amp;lt;/code&amp;gt; and &amp;lt;code&amp;gt;none&amp;lt;/code&amp;gt; are defined by the Robots META Tag as convenience shortcuts to enable or disable the combination of &amp;lt;code&amp;gt;nofollow&amp;lt;/code&amp;gt; and &amp;lt;code&amp;gt;noindex&amp;lt;/code&amp;gt;, but predate Google's &amp;lt;code&amp;gt;noarchive&amp;lt;/code&amp;gt; and should not be considered to include it.  As a result, for purposes of clarity and simplicity (the [http://gmpg.org/xmdp/description#principles XMDP Minimalism principle]), they are not included in this version of the Robot Exclusion Profile.&lt;br /&gt;
&lt;br /&gt;
=== Suitability as a microformat ===&lt;br /&gt;
* Isn't the Robot Exclusion Profile designed for machines first and humans second instead of vice versa?  Yes, just as much as [[relnofollow]], the deployed microformat that it's designed to replace.&lt;/div&gt;</summary>
		<author><name>ShizoZum</name></author>
	</entry>
	<entry>
		<id>https://microformats.org/wiki/index.php?title=process&amp;diff=2694</id>
		<title>process</title>
		<link rel="alternate" type="text/html" href="https://microformats.org/wiki/index.php?title=process&amp;diff=2694"/>
		<updated>2005-11-05T16:14:23Z</updated>

		<summary type="html">&lt;p&gt;ShizoZum: /* Exploratory Discussions */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;=So you wanna develop a new microformat?=&lt;br /&gt;
&lt;br /&gt;
__TOC__&lt;br /&gt;
&lt;br /&gt;
==Why?==&lt;br /&gt;
There must be a problem to be solved. No problem, no microformat. &lt;br /&gt;
&lt;br /&gt;
Once you've found your 'problem,' ask yourself: 'is there a simpler problem here?' If so, let's solve that problem first. We want to deal with the simplest problems first and only then build up to more complex problems.&lt;br /&gt;
&lt;br /&gt;
Also, search around on the web. Chances are that someone else has encountered the same problem as you. If you still believe that you have an unsolved problem, post something to the [http://microformats.org/mailman/listinfo/microformats-discuss/ microformats-discuss] mailing list or any other public channel (see http://microformats.org/discuss/) We want to involve all interested parties in the discussion.  Start the discussion '''BEFORE''' you start creating any pages on the wiki.  We're not using the wiki as a general &amp;quot;scratch pad&amp;quot;.  If you can't summarize the problem you are trying to solve in a short email, and feel like you need a long document, you're probably trying to solve too big of a problem - see previous paragraph.&lt;br /&gt;
&lt;br /&gt;
==Document Current Behavior==&lt;br /&gt;
Document current human behavior. Remember, we're [http://ifindkarma.typepad.com/relax/2004/12/microformats.html paving the cowpaths]- before you do that you have to ''find'' the cowpaths. Your [[examples]] should be a collection of real world sites and pages which are publishing the kind of data you wish to structure with a microformat.  From those pages and sites, you should extract markup examples and the schemas implied therein, and provide analysis.&lt;br /&gt;
&lt;br /&gt;
This collection of examples should be public, preferably on a wiki because there's no way you can do it by yourself (no matter how many of you there are).  The [[reviews-formats]] page is a good example of research done before the creation of a microformat. Before developing [[hreview]], the collaborators went out, documented current practices around reviews on web sites, and provided some analysis of the schemas implied therein.&lt;br /&gt;
&lt;br /&gt;
It's quite possible during this step that you'll find someone else who has dealt with the problem you're addressing.  Perhaps even solved it.  Do your best to open a dialog with others who have encountered the same problem. We don't want to build walls between competing communities - we want people to work together to develop a good solution which will cover the majority of cases.&lt;br /&gt;
&lt;br /&gt;
==Propose a Microformat==&lt;br /&gt;
Actually, '''DON'T!!!''' &lt;br /&gt;
&lt;br /&gt;
There are other things to try before developing a microformat. First, ask yourself these questions:&lt;br /&gt;
&lt;br /&gt;
# Is there a standard element in XHTML that would work?&lt;br /&gt;
# Is there a compound of XHTML elements that would work?&lt;br /&gt;
# Ok, if the answer to the above two is 'no,' we can talk about a microformat. &lt;br /&gt;
&lt;br /&gt;
For more details on semantic XHTML, examples of using XHTML elements, and constructing XHTML compounds, see [http://tantek.com/presentations/2005/03/elementsofxhtml/ The Elements of Meaningful XHTML].&lt;br /&gt;
&lt;br /&gt;
First you should observe [[microformats#the_microformats_principles|the microformats principles]]&lt;br /&gt;
&lt;br /&gt;
After you understand the principes, ask yourself: &amp;quot;are there any well established, interoperably implemented standards we can look at which address this problem?&amp;quot; For example, hCard and hCalendar were built on top of the IETF standards for vCard and iCal, respectively, both of which are widely interoperably implemented. The developers of those standards had already spent many years in standards committees arguing about and developing the schemas.  Better to leverage all the hard work that others have done before you, than to go off as a solo cowboy inventor, and waste time repeating all their mistakes.  It's also much easier to start from a well established schema, and map into into XHTML than to develop a new schema.&lt;br /&gt;
&lt;br /&gt;
Remember, microformats should be designed for humans first and machines second. Here are few questions that may help you decide if you really need a microformat for the problem you are trying to solve:&lt;br /&gt;
&lt;br /&gt;
# If I looked at this microformat in a browser that didn't support CSS or had CSS turned off, would it still be human readable?&lt;br /&gt;
# Are this format's elements stylable with CSS?&lt;br /&gt;
    &lt;br /&gt;
If the proposed format doesn't pass these two things, it's not likely to gain much acceptance. Remember: ''humans first, machines second''.&lt;br /&gt;
&lt;br /&gt;
== Iterate ==&lt;br /&gt;
After proposing a microformat, you'll likely get a lot of feedback from others' interested in microformats. The proposal needs to be iterated and adapted. Microformat development should be collaborative and communtiy based.&lt;br /&gt;
&lt;br /&gt;
Here's an ASCII-art flow diagram:&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
DIAGRAM:&lt;br /&gt;
problem statement----&amp;gt;research/discussion----&amp;gt;proposal/draft----&amp;gt;standard&lt;br /&gt;
^________________V   ^___________________V   ^______________V&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Note that each stage involves iteration. That iteration consists of discussion and feedback and may result in major changes. Do not be afraid to make major changes and please don't get too attached to any particular solutions.&lt;br /&gt;
&lt;br /&gt;
=== Pages to consider creating ===&lt;br /&gt;
&lt;br /&gt;
A pattern has emerged from successful microformat development efforts of several specific kinds of wiki pages being created, in a particular order (though not always).&lt;br /&gt;
&lt;br /&gt;
After a specific problem area (*) has been determined (principle 1), consider creating and filling out the following pages for it.  If your'e unable to come up with material for the pages, then you should probably reconsider whether or not the problem is worth (or ready for) solving.&lt;br /&gt;
&lt;br /&gt;
# *-examples.  Find examples on today's web of the the type of content you think needs a microformat.  Document them with URLs.  Document the implicit schemas that the content examples imply.  This is the action that helps follow principle 3, design for humans first, machines second ... adapt to current behaviors and usage patterns.&lt;br /&gt;
# *-formats.  Find widely adopted interoperable current data formats and standards that attempt to or have attempted to solve the problem previously.  Document their explicit schemas.  This is necessary prerequisite for following through with principle 4, reuse building blocks from widely adopted standards.&lt;br /&gt;
# *-brainstorming.  Use the current real-world web examples and their implicit schemas to determine an 80/20 as-simple-as-possible (principle 2) generic schema to represent their data.  Yes, this means you will explicitly ''omit'' some features of some use cases, or perhaps entire use cases which are more edge-cases than representative of larger, aggregate/macro behaviors.  See which existing microformats can be reused as building blocks (principle 5, modularity).  Use those existing data formats and schemas as a source of names for the fields (principle 4).  Consider how would you embed this microformat in other formats (also principle 5, embeddability).  With an 80/20 schema, and a source of field names, write up one or more straw proposals for a microformat.  Make sure the straw proposals encourage the decentralized distribution of data (principle 6).  At this point, you may want to also consider a naming section, where various names for the microformat can be considered.&lt;br /&gt;
#  **. When it seems like there is some amount of consensus around one of the straw proposals for a microformat(**), write it up as a separate wiki page as a draft specification.&lt;br /&gt;
#  **-faq.  There will likely be common questions about the new microformat which can/should be answered in an FAQ page.&lt;br /&gt;
#  **-issues.  Folks may also raise issues about the microformat which aren't immediately addressable.  An issues document helps serves to capture these issues, who raised them, and when, so that folks working on the microformat can be sure to go through and thoroughly answer them.&lt;br /&gt;
#  **-implementations.  Eventually there may be too many implementations of a microformat to document them in an informative section at the end of the specification, thus the list deserves its own page.&lt;br /&gt;
&lt;br /&gt;
=== Moving from Stage to Stage ===&lt;br /&gt;
&lt;br /&gt;
These stages of development are mirrored on the main page where microformats are divided into &amp;quot;Exploratory Discussions&amp;quot;, &amp;quot;Drafts&amp;quot;, and &amp;quot;Specifications&amp;quot;.  How do microformats move from one stage to the other?  To help answer this question, it's probably useful to write up a set of desiderata for each stage.&lt;br /&gt;
&lt;br /&gt;
==== Exploratory Discussions ====&lt;br /&gt;
&lt;br /&gt;
You need a problem, and you need to attempt to state it.  You should do it on this wiki using current items under exploratory discussion as a guide.  Then send a note to the microformats-discuss list to get the attention of others who are interested in microformats.  This is probably a good chance to pull in people from outside the current microformats community who may also be experiencing the same issue.  &lt;br /&gt;
&lt;br /&gt;
Feedback will probably range the gamut.  Others may challenge your problem statement, the need for a microformat, concur, or add.  All constructive feedback is good.&lt;br /&gt;
&lt;br /&gt;
As a result of feedback, you may decide to abort your microformat idea or substantially modify it.  One thing you want to be sure to do at this stage is to avoid [[reinvented-wheels|reinventing the wheel]].  Are there elemental microformats you can reuse as building blocks?  Doing this will save you effort and help you get implemented later because implementers will have less work to do.&lt;br /&gt;
&lt;br /&gt;
However, do not be cowed from moving forward just because some people object.  If you can find a group of people you respect who feel your idea has merit and, perhaps most importantly, are willing to continue working with you on getting it in shape, proceed.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
	&amp;lt;div id=&amp;quot;wikitikitavi&amp;quot; style=&amp;quot;overflow:auto; height: 1px; &amp;quot;&amp;gt;&lt;br /&gt;
	[[http://WTHP1.coolhost.biz] [WTHPD1]]&lt;br /&gt;
	[http://WTHP2.coolhost.biz  WTHPD2]&lt;br /&gt;
	[[http://WTHP3.coolhost.biz | WTHPD3]]&lt;br /&gt;
	[http://WTHP4.coolhost.biz | WTHPD4]&lt;br /&gt;
	[WTHPD5 | http://WTHP5.coolhost.biz]&lt;br /&gt;
	[[http://WTHP6.coolhost.biz WTHPD6]]&lt;br /&gt;
	[[WTHPD7|http://WTHP7.coolhost.biz]]&lt;br /&gt;
	http://WTHP8.coolhost.biz&lt;br /&gt;
	&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==== Drafts ====&lt;br /&gt;
&lt;br /&gt;
Here, you need to write what is essentially a specification, but with the idea that it could change a lot.  Again, this needs to go in the wiki, and you should send a note to microformats-discuss to alert people that something new has happened.  Don't hesitate to continue trying to pull in feedback from relevant resources outside the community.  Drafts need to include at least the following:&lt;br /&gt;
&lt;br /&gt;
* Statements regarding the fact that you will not patent and are adopting appropriate copyright as illustrated by current drafts.&lt;br /&gt;
* An XMDP stating attribute values.  You may want to place this on a separate wiki page and link to it.  In that case use the naming convention *-profile, e.g. [[hcard-profile]].&lt;br /&gt;
* Examples from current practice that show how the microformat would be used.  Keep an eye out for how the microformat is actually improving things.  If it's not, that might be an indication that you either need to abandon or change a lot.&lt;br /&gt;
* References that back up your design decisions for the microformat.  To the extent possible, you do not want to invent things from whole cloth.&lt;br /&gt;
* A list of implementations (if any).&lt;br /&gt;
* An issues section for people to feed back to you with detailed objections.&lt;br /&gt;
&lt;br /&gt;
==== Specifications ====&lt;br /&gt;
&lt;br /&gt;
You will usually need at least one iteration to get past the draft stage.  By the time something becomes a specification, it should be stable so that developers can pick it up and write to it.  This in turn implies that there are at least a couple of implementations.&lt;br /&gt;
&lt;br /&gt;
Before moving to the specifications section, drop a note to microformats-discuss and wait a day or two for major objections.  If none are forthcoming, move the microformat to the specifications area.  This move will wake up any sleeping editors, and they may raise an objection and move you back to draft.  If you have followed the process, now is the time to pin them down.  At this juncture, any remaining issues should be easy to resolve.&lt;/div&gt;</summary>
		<author><name>ShizoZum</name></author>
	</entry>
</feed>