<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN"
"http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head><meta http-equiv="content-type" content="text/html; charset=utf-8" /><style type="text/css"><!--
#msg dl { border: 1px #006 solid; background: #369; padding: 6px; color: #fff; }
#msg dt { float: left; width: 6em; font-weight: bold; }
#msg dt:after { content:':';}
#msg dl, #msg dt, #msg ul, #msg li, #header, #footer { font-family: verdana,arial,helvetica,sans-serif; font-size: 10pt;  }
#msg dl a { font-weight: bold}
#msg dl a:link    { color:#fc3; }
#msg dl a:active  { color:#ff0; }
#msg dl a:visited { color:#cc6; }
h3 { font-family: verdana,arial,helvetica,sans-serif; font-size: 10pt; font-weight: bold; }
#msg pre, #msg p { overflow: auto; background: #ffc; border: 1px #fc0 solid; padding: 6px; }
#msg ul { overflow: auto; }
#header, #footer { color: #fff; background: #636; border: 1px #300 solid; padding: 6px; }
#patch { width: 100%; }
#patch h4 {font-family: verdana,arial,helvetica,sans-serif;font-size:10pt;padding:8px;background:#369;color:#fff;margin:0;}
#patch .propset h4, #patch .binary h4 {margin:0;}
#patch pre {padding:0;line-height:1.2em;margin:0;}
#patch .diff {width:100%;background:#eee;padding: 0 0 10px 0;overflow:auto;}
#patch .propset .diff, #patch .binary .diff  {padding:10px 0;}
#patch span {display:block;padding:0 10px;}
#patch .modfile, #patch .addfile, #patch .delfile, #patch .propset, #patch .binary, #patch .copfile {border:1px solid #ccc;margin:10px 0;}
#patch ins {background:#dfd;text-decoration:none;display:block;padding:0 10px;}
#patch del {background:#fdd;text-decoration:none;display:block;padding:0 10px;}
#patch .lines, .info {color:#888;background:#fff;}
--></style>
<title>[12021] trunk:
  Show the login form in a popup when autosave hits the login grace period,
  fixes #10704</title>
</head>
<body>

<div id="msg">
<dl>
<dt>Revision</dt> <dd><a href="http://trac.wordpress.org/changeset/12021">12021</a></dd>
<dt>Author</dt> <dd>azaozz</dd>
<dt>Date</dt> <dd>2009-10-11 11:26:59 +0000 (Sun, 11 Oct 2009)</dd>
</dl>

<h3>Log Message</h3>
<pre>Show the login form in a popup when autosave hits the login grace period, fixes <a href="http://trac.wordpress.org/ticket/10704">#10704</a></pre>

<h3>Modified Paths</h3>
<ul>
<li><a href="#trunkwpadminadminajaxphp">trunk/wp-admin/admin-ajax.php</a></li>
<li><a href="#trunkwpadmincsslogincss">trunk/wp-admin/css/login.css</a></li>
<li><a href="#trunkwpadmincsslogindevcss">trunk/wp-admin/css/login.dev.css</a></li>
<li><a href="#trunkwpincludesjsautosavedevjs">trunk/wp-includes/js/autosave.dev.js</a></li>
<li><a href="#trunkwpincludesjsautosavejs">trunk/wp-includes/js/autosave.js</a></li>
<li><a href="#trunkwpincludespluggablephp">trunk/wp-includes/pluggable.php</a></li>
<li><a href="#trunkwpincludesscriptloaderphp">trunk/wp-includes/script-loader.php</a></li>
<li><a href="#trunkwploginphp">trunk/wp-login.php</a></li>
</ul>

</div>
<div id="patch">
<h3>Diff</h3>
<a id="trunkwpadminadminajaxphp"></a>
<div class="modfile"><h4>Modified: trunk/wp-admin/admin-ajax.php (12020 => 12021)</h4>
<pre class="diff"><span>
<span class="info">--- trunk/wp-admin/admin-ajax.php        2009-10-11 00:37:26 UTC (rev 12020)
+++ trunk/wp-admin/admin-ajax.php        2009-10-11 11:26:59 UTC (rev 12021)
</span><span class="lines">@@ -891,6 +891,8 @@
</span><span class="cx">         $message = sprintf( __('Draft Saved at %s.'), date_i18n( $draft_saved_date_format ) );
</span><span class="cx"> 
</span><span class="cx">         $supplemental = array();
</span><ins>+        if ( isset($login_grace_period) )
+                $supplemental['session_expired'] = add_query_arg( 'interim-login', 1, wp_login_url() );
</ins><span class="cx"> 
</span><span class="cx">         $id = $revision_id = 0;
</span><span class="cx">         if($_POST['post_ID'] &lt; 0) {
</span></span></pre></div>
<a id="trunkwpadmincsslogincss"></a>
<div class="modfile"><h4>Modified: trunk/wp-admin/css/login.css (12020 => 12021)</h4>
<pre class="diff"><span>
<span class="info">--- trunk/wp-admin/css/login.css        2009-10-11 00:37:26 UTC (rev 12020)
+++ trunk/wp-admin/css/login.css        2009-10-11 11:26:59 UTC (rev 12021)
</span><span class="lines">@@ -1 +1 @@
</span><del>-*{margin:0;padding:0;}body{border-top-width:30px;border-top-style:solid;font:11px &quot;Lucida Grande&quot;,Verdana,Arial,&quot;Bitstream Vera Sans&quot;,sans-serif;}form{margin-left:8px;padding:16px 16px 40px 16px;font-weight:normal;-moz-border-radius:11px;-khtml-border-radius:11px;-webkit-border-radius:11px;border-radius:5px;background:#fff;border:1px solid #e5e5e5;-moz-box-shadow:rgba(200,200,200,1) 0 4px 18px;-webkit-box-shadow:rgba(200,200,200,1) 0 4px 18px;-khtml-box-shadow:rgba(200,200,200,1) 0 4px 18px;box-shadow:rgba(200,200,200,1) 0 4px 18px;}form .forgetmenot{font-weight:normal;float:left;margin-bottom:0;}.button-primary{font-family:&quot;Lucida Grande&quot;,Verdana,Arial,&quot;Bitstream Vera Sans&quot;,sans-serif;padding:3px 10px;border:none;font-size:12px;border-width:1px;border-style:solid;-moz-border-radius:11px;-khtml-border-radius:11px;-webkit-border-radius:11px;border-radius:11px;cursor:pointer;text-decoration:none;margin-top:-3px;}#login form p{margin-bottom:0;}label{color:#777;font-size:13px;}form .forgetmenot label{font-size:11px;line-height:19px;}form .submit{float:right;}form p{margin-bottom:24px;}h1 a{background:url(../images/logo-login.gif) no-repeat top center;width:326px;height:67px;text-indent:-9999px;overflow:hidden;padding-bottom:15px;display:block;}#nav{text-shadow:rgba(255,255,255,1) 0 1px 0;}#backtoblog a{position:absolute;top:7px;left:15px;text-decoration:none;}#login{width:320px;margin:7em auto;}#login_error,.message{margin:0 0 16px 8px;border-width:1px;border-style:solid;padding:12px;-moz-border-radius:3px;-khtml-border-radius:3px;-webkit-border-radius:3px;border-radius:3px;}#nav{margin:0 0 0 8px;padding:16px;}#user_pass,#user_login,#user_email{font-size:24px;width:97%;padding:3px;margin-top:2px;margin-right:6px;margin-bottom:16px;border:1px solid #e5e5e5;background:#fbfbfb;}input{color:#555;}.clear{clear:both;}
</del><span class="cx">\ No newline at end of file
</span><ins>+*{margin:0;padding:0;}body{border-top-width:30px;border-top-style:solid;font:11px &quot;Lucida Grande&quot;,Verdana,Arial,&quot;Bitstream Vera Sans&quot;,sans-serif;}form{margin-left:8px;padding:16px 16px 40px 16px;font-weight:normal;-moz-border-radius:11px;-khtml-border-radius:11px;-webkit-border-radius:11px;border-radius:5px;background:#fff;border:1px solid #e5e5e5;-moz-box-shadow:rgba(200,200,200,1) 0 4px 18px;-webkit-box-shadow:rgba(200,200,200,1) 0 4px 18px;-khtml-box-shadow:rgba(200,200,200,1) 0 4px 18px;box-shadow:rgba(200,200,200,1) 0 4px 18px;}form .forgetmenot{font-weight:normal;float:left;margin-bottom:0;}.button-primary{font-family:&quot;Lucida Grande&quot;,Verdana,Arial,&quot;Bitstream Vera Sans&quot;,sans-serif;padding:3px 10px;border:none;font-size:12px;border-width:1px;border-style:solid;-moz-border-radius:11px;-khtml-border-radius:11px;-webkit-border-radius:11px;border-radius:11px;cursor:pointer;text-decoration:none;margin-top:-3px;}#login form p{margin-bottom:0;}label{color:#777;font-size:13px;}form .forgetmenot label{font-size:11px;line-height:19px;}form .submit,.alignright{float:right;}form p{margin-bottom:24px;}h1 a{background:url(../images/logo-login.gif) no-repeat top center;width:326px;height:67px;text-indent:-9999px;overflow:hidden;padding-bottom:15px;display:block;}#nav{text-shadow:rgba(255,255,255,1) 0 1px 0;}#backtoblog a{position:absolute;top:7px;left:15px;text-decoration:none;}#login{width:320px;margin:7em auto;}#login_error,.message{margin:0 0 16px 8px;border-width:1px;border-style:solid;padding:12px;-moz-border-radius:3px;-khtml-border-radius:3px;-webkit-border-radius:3px;border-radius:3px;}#nav{margin:0 0 0 8px;padding:16px;}#user_pass,#user_login,#user_email{font-size:24px;width:97%;padding:3px;margin-top:2px;margin-right:6px;margin-bottom:16px;border:1px solid #e5e5e5;background:#fbfbfb;}input{color:#555;}.clear{clear:both;}
</ins><span class="cx">\ No newline at end of file
</span></span></pre></div>
<a id="trunkwpadmincsslogindevcss"></a>
<div class="modfile"><h4>Modified: trunk/wp-admin/css/login.dev.css (12020 => 12021)</h4>
<pre class="diff"><span>
<span class="info">--- trunk/wp-admin/css/login.dev.css        2009-10-11 00:37:26 UTC (rev 12020)
+++ trunk/wp-admin/css/login.dev.css        2009-10-11 11:26:59 UTC (rev 12021)
</span><span class="lines">@@ -58,7 +58,8 @@
</span><span class="cx">         line-height: 19px;
</span><span class="cx"> }
</span><span class="cx"> 
</span><del>-form .submit {
</del><ins>+form .submit,
+.alignright {
</ins><span class="cx">         float: right;
</span><span class="cx"> }
</span><span class="cx"> 
</span></span></pre></div>
<a id="trunkwpincludesjsautosavedevjs"></a>
<div class="modfile"><h4>Modified: trunk/wp-includes/js/autosave.dev.js (12020 => 12021)</h4>
<pre class="diff"><span>
<span class="info">--- trunk/wp-includes/js/autosave.dev.js        2009-10-11 00:37:26 UTC (rev 12020)
+++ trunk/wp-includes/js/autosave.dev.js        2009-10-11 11:26:59 UTC (rev 12021)
</span><span class="lines">@@ -1,4 +1,4 @@
</span><del>-var autosave, autosaveLast = '', autosavePeriodical, autosaveOldMessage = '', autosaveDelayPreview = false, notSaved = true, blockSave = false;
</del><ins>+var autosave, autosaveLast = '', autosavePeriodical, autosaveOldMessage = '', autosaveDelayPreview = false, notSaved = true, blockSave = false, interimLogin = false;
</ins><span class="cx"> 
</span><span class="cx"> jQuery(document).ready( function($) {
</span><span class="cx">         var dotabkey = true;
</span><span class="lines">@@ -81,17 +81,25 @@
</span><span class="cx"> });
</span><span class="cx"> 
</span><span class="cx"> function autosave_parse_response(response) {
</span><del>-        var res = wpAjax.parseAjaxResponse(response, 'autosave'), message = '', postID;
</del><ins>+        var res = wpAjax.parseAjaxResponse(response, 'autosave'), message = '', postID, sup, url;
</ins><span class="cx"> 
</span><span class="cx">         if ( res &amp;&amp; res.responses &amp;&amp; res.responses.length ) {
</span><span class="cx">                 message = res.responses[0].data; // The saved message or error.
</span><span class="cx">                 // someone else is editing: disable autosave, set errors
</span><span class="cx">                 if ( res.responses[0].supplemental ) {
</span><del>-                        if ( 'disable' == res.responses[0].supplemental['disable_autosave'] ) {
</del><ins>+                        sup = res.responses[0].supplemental;
+                        if ( 'disable' == sup['disable_autosave'] ) {
</ins><span class="cx">                                 autosave = function() {};
</span><span class="cx">                                 res = { errors: true };
</span><span class="cx">                         }
</span><del>-                        jQuery.each(res.responses[0].supplemental, function(selector, value) {
</del><ins>+                        if ( sup['session_expired'] &amp;&amp; (url = sup['session_expired']) ) {
+                                if ( !interimLogin || interimLogin.closed ) {
+                                        interimLogin = window.open(url, 'login', 'width=600,height=450,resizable=yes,scrollbars=yes,status=yes');
+                                        interimLogin.focus();
+                                }
+                                delete sup['session_expired'];
+                        }
+                        jQuery.each(sup, function(selector, value) {
</ins><span class="cx">                                 if ( selector.match(/^replace-/) ) {
</span><span class="cx">                                         jQuery('#'+selector.replace('replace-', '')).val(value);
</span><span class="cx">                                 }
</span></span></pre></div>
<a id="trunkwpincludesjsautosavejs"></a>
<div class="modfile"><h4>Modified: trunk/wp-includes/js/autosave.js (12020 => 12021)</h4>
<pre class="diff"><span>
<span class="info">--- trunk/wp-includes/js/autosave.js        2009-10-11 00:37:26 UTC (rev 12020)
+++ trunk/wp-includes/js/autosave.js        2009-10-11 11:26:59 UTC (rev 12021)
</span><span class="lines">@@ -1 +1 @@
</span><del>-var autosave,autosaveLast=&quot;&quot;,autosavePeriodical,autosaveOldMessage=&quot;&quot;,autosaveDelayPreview=false,notSaved=true,blockSave=false;jQuery(document).ready(function(b){var a=true;autosaveLast=b(&quot;#post #title&quot;).val()+b(&quot;#post #content&quot;).val();autosavePeriodical=b.schedule({time:autosaveL10n.autosaveInterval*1000,func:function(){autosave()},repeat:true,protect:true});b(&quot;#post&quot;).submit(function(){b.cancel(autosavePeriodical)});b('input[type=&quot;submit&quot;], a.submitdelete',&quot;#submitpost&quot;).click(function(){blockSave=true;window.onbeforeunload=null;b(&quot;:button, :submit&quot;,&quot;#submitpost&quot;).each(function(){var c=b(this);if(c.hasClass(&quot;button-primary&quot;)){c.addClass(&quot;button-primary-disabled&quot;)}else{c.addClass(&quot;button-disabled&quot;)}});b(&quot;#ajax-loading&quot;).css(&quot;visibility&quot;,&quot;visible&quot;)});window.onbeforeunload=function(){var c=typeof(tinyMCE)!=&quot;undefined&quot;?tinyMCE.activeEditor:false,e,d;if(c&amp;&amp;!c.isHidden()){if(c.isDirty()){return autosaveL10n.saveAlert}}else{e=b(&quot;#post #title&quot;).val(),d=b(&quot;#post #content&quot;).val();if((e||d)&amp;&amp;e+d!=autosaveLast){return autosaveL10n.saveAlert}}};b(&quot;#post-preview&quot;).click(function(){if(1&gt;b(&quot;#post_ID&quot;).val()&amp;&amp;notSaved){autosaveDelayPreview=true;autosave();return false}doPreview();return false});doPreview=function(){b(&quot;input#wp-preview&quot;).val(&quot;dopreview&quot;);b(&quot;form#post&quot;).attr(&quot;target&quot;,&quot;wp-preview&quot;).submit().attr(&quot;target&quot;,&quot;&quot;);b(&quot;input#wp-preview&quot;).val(&quot;&quot;)};if(typeof tinyMCE!=&quot;undefined&quot;){b(&quot;#title&quot;)[b.browser.opera?&quot;keypress&quot;:&quot;keydown&quot;](function(c){if(c.which==9&amp;&amp;!c.shiftKey&amp;&amp;!c.controlKey&amp;&amp;!c.altKey){if((b(&quot;#post_ID&quot;).val()&lt;1)&amp;&amp;(b(&quot;#title&quot;).val().length&gt;0)){autosave()}if(tinyMCE.activeEditor&amp;&amp;!tinyMCE.activeEditor.isHidden()&amp;&amp;a){c.preventDefault();a=false;tinyMCE.activeEditor.focus();return false}}})}if(0&gt;b(&quot;#post_ID&quot;).val()){b(&quot;#title&quot;).blur(function(){if(!this.value||0&lt;b(&quot;#post_ID&quot;).val()){return}delayed_autosave()})}});function autosave_parse_response(b){var c=wpAjax.parseAjaxResponse(b,&quot;autosave&quot;),d=&quot;&quot;,a;if(c&amp;&amp;c.responses&amp;&amp;c.responses.length){d=c.responses[0].data;if(c.responses[0].supplemental){if(&quot;disable&quot;==c.responses[0].supplemental.disable_autosave){autosave=function(){};c={errors:true}}jQuery.each(c.responses[0].supplemental,function(e,f){if(e.match(/^replace-/)){jQuery(&quot;#&quot;+e.replace(&quot;replace-&quot;,&quot;&quot;)).val(f)}})}if(!c.errors){a=parseInt(c.responses[0].id,10);if(!isNaN(a)&amp;&amp;a&gt;0){autosave_update_slug(a)}}}if(d){jQuery(&quot;#autosave&quot;).html(d)}else{if(autosaveOldMessage&amp;&amp;c){jQuery(&quot;#autosave&quot;).html(autosaveOldMessage)}}return c}function autosave_saved(a){autosave_parse_response(a);autosave_enable_buttons()}function autosave_saved_new(b){var d=autosave_parse_response(b),c,a;if(d&amp;&amp;d.responses.length&amp;&amp;!d.errors){c=jQuery(&quot;#post_ID&quot;).val();a=parseInt(d.responses[0].id,10);autosave_update_post_ID(a);if(c&lt;0&amp;&amp;a&gt;0){notSaved=false;jQuery(&quot;#media-buttons a&quot;).each(function(){this.href=this.href.replace(c,a)})}if(autosaveDelayPreview){autosaveDelayPreview=false;doPreview()}}else{autosave_enable_buttons()}}function autosave_update_post_ID(a){if(!isNaN(a)&amp;&amp;a&gt;0){if(a==parseInt(jQuery(&quot;#post_ID&quot;).val(),10)){return}jQuery(&quot;#post_ID&quot;).attr({name:&quot;post_ID&quot;});jQuery(&quot;#post_ID&quot;).val(a);jQuery.post(autosaveL10n.requestFile,{action:&quot;autosave-generate-nonces&quot;,post_ID:a,autosavenonce:jQuery(&quot;#autosavenonce&quot;).val(),post_type:jQuery(&quot;#post_type&quot;).val()},function(b){jQuery(&quot;#_wpnonce&quot;).val(b.updateNonce);jQuery(&quot;#delete-action a.submitdelete&quot;).attr(&quot;href&quot;,b.deleteURL);autosave_enable_buttons();jQuery(&quot;#delete-action a.submitdelete&quot;).fadeIn()},&quot;json&quot;);jQuery(&quot;#hiddenaction&quot;).val(&quot;editpost&quot;)}}function autosave_update_slug(a){if(jQuery.isFunction(make_slugedit_clickable)&amp;&amp;!jQuery(&quot;#edit-slug-box &gt; *&quot;).size()){jQuery.post(slugL10n.requestFile,{action:&quot;sample-permalink&quot;,post_id:a,new_title:jQuery(&quot;#title&quot;).val(),samplepermalinknonce:jQuery(&quot;#samplepermalinknonce&quot;).val()},function(b){jQuery(&quot;#edit-slug-box&quot;).html(b);make_slugedit_clickable()})}}function autosave_loading(){jQuery(&quot;#autosave&quot;).html(autosaveL10n.savingText)}function autosave_enable_buttons(){setTimeout(function(){jQuery(&quot;:button, :submit&quot;,&quot;#submitpost&quot;).removeAttr(&quot;disabled&quot;);jQuery(&quot;#ajax-loading&quot;).css(&quot;visibility&quot;,&quot;hidden&quot;)},500)}function autosave_disable_buttons(){jQuery(&quot;:button, :submit&quot;,&quot;#submitpost&quot;).attr(&quot;disabled&quot;,&quot;disabled&quot;);setTimeout(autosave_enable_buttons,5000)}function delayed_autosave(){setTimeout(function(){if(blockSave){return}autosave()},200)}autosave=function(){var c=(typeof tinyMCE!=&quot;undefined&quot;)&amp;&amp;tinyMCE.activeEditor&amp;&amp;!tinyMCE.activeEditor.isHidden(),d,f,b,e,a;autosave_disable_buttons();d={action:&quot;autosave&quot;,post_ID:jQuery(&quot;#post_ID&quot;).val()||0,post_title:jQuery(&quot;#title&quot;).val()||&quot;&quot;,autosavenonce:jQuery(&quot;#autosavenonce&quot;).val(),post_type:jQuery(&quot;#post_type&quot;).val()||&quot;&quot;,autosave:1};jQuery(&quot;.tags-input&quot;).each(function(){d[this.name]=this.value});f=true;if(jQuery(&quot;#TB_window&quot;).css(&quot;display&quot;)==&quot;block&quot;){f=false}if(c&amp;&amp;f){b=tinyMCE.activeEditor;if(b.plugins.spellchecker&amp;&amp;b.plugins.spellchecker.active){f=false}else{if(&quot;mce_fullscreen&quot;==b.id){tinyMCE.get(&quot;content&quot;).setContent(b.getContent({format:&quot;raw&quot;}),{format:&quot;raw&quot;})}tinyMCE.get(&quot;content&quot;).save()}}d.content=jQuery(&quot;#content&quot;).val();if(jQuery(&quot;#post_name&quot;).val()){d.post_name=jQuery(&quot;#post_name&quot;).val()}if((d.post_title.length==0&amp;&amp;d.content.length==0)||d.post_title+d.content==autosaveLast){f=false}e=jQuery(&quot;#original_post_status&quot;).val();goodcats=([]);jQuery(&quot;[name='post_category[]']:checked&quot;).each(function(g){goodcats.push(this.value)});d.catslist=goodcats.join(&quot;,&quot;);if(jQuery(&quot;#comment_status&quot;).attr(&quot;checked&quot;)){d.comment_status=&quot;open&quot;}if(jQuery(&quot;#ping_status&quot;).attr(&quot;checked&quot;)){d.ping_status=&quot;open&quot;}if(jQuery(&quot;#excerpt&quot;).size()){d.excerpt=jQuery(&quot;#excerpt&quot;).val()}if(jQuery(&quot;#post_author&quot;).size()){d.post_author=jQuery(&quot;#post_author&quot;).val()}d.user_ID=jQuery(&quot;#user-id&quot;).val();if(f){autosaveLast=jQuery(&quot;#title&quot;).val()+jQuery(&quot;#content&quot;).val()}else{d.autosave=0}if(parseInt(d.post_ID,10)&lt;1){d.temp_ID=d.post_ID;a=autosave_saved_new}else{a=autosave_saved}autosaveOldMessage=jQuery(&quot;#autosave&quot;).html();jQuery.ajax({data:d,beforeSend:f?autosave_loading:null,type:&quot;POST&quot;,url:autosaveL10n.requestFile,success:a})};
</del><span class="cx">\ No newline at end of file
</span><ins>+var autosave,autosaveLast=&quot;&quot;,autosavePeriodical,autosaveOldMessage=&quot;&quot;,autosaveDelayPreview=false,notSaved=true,blockSave=false,interimLogin=false;jQuery(document).ready(function(b){var a=true;autosaveLast=b(&quot;#post #title&quot;).val()+b(&quot;#post #content&quot;).val();autosavePeriodical=b.schedule({time:autosaveL10n.autosaveInterval*1000,func:function(){autosave()},repeat:true,protect:true});b(&quot;#post&quot;).submit(function(){b.cancel(autosavePeriodical)});b('input[type=&quot;submit&quot;], a.submitdelete',&quot;#submitpost&quot;).click(function(){blockSave=true;window.onbeforeunload=null;b(&quot;:button, :submit&quot;,&quot;#submitpost&quot;).each(function(){var c=b(this);if(c.hasClass(&quot;button-primary&quot;)){c.addClass(&quot;button-primary-disabled&quot;)}else{c.addClass(&quot;button-disabled&quot;)}});b(&quot;#ajax-loading&quot;).css(&quot;visibility&quot;,&quot;visible&quot;)});window.onbeforeunload=function(){var c=typeof(tinyMCE)!=&quot;undefined&quot;?tinyMCE.activeEditor:false,e,d;if(c&amp;&amp;!c.isHidden()){if(c.isDirty()){return autosaveL10n.saveAlert}}else{e=b(&quot;#post #title&quot;).val(),d=b(&quot;#post #content&quot;).val();if((e||d)&amp;&amp;e+d!=autosaveLast){return autosaveL10n.saveAlert}}};b(&quot;#post-preview&quot;).click(function(){if(1&gt;b(&quot;#post_ID&quot;).val()&amp;&amp;notSaved){autosaveDelayPreview=true;autosave();return false}doPreview();return false});doPreview=function(){b(&quot;input#wp-preview&quot;).val(&quot;dopreview&quot;);b(&quot;form#post&quot;).attr(&quot;target&quot;,&quot;wp-preview&quot;).submit().attr(&quot;target&quot;,&quot;&quot;);b(&quot;input#wp-preview&quot;).val(&quot;&quot;)};if(typeof tinyMCE!=&quot;undefined&quot;){b(&quot;#title&quot;)[b.browser.opera?&quot;keypress&quot;:&quot;keydown&quot;](function(c){if(c.which==9&amp;&amp;!c.shiftKey&amp;&amp;!c.controlKey&amp;&amp;!c.altKey){if((b(&quot;#post_ID&quot;).val()&lt;1)&amp;&amp;(b(&quot;#title&quot;).val().length&gt;0)){autosave()}if(tinyMCE.activeEditor&amp;&amp;!tinyMCE.activeEditor.isHidden()&amp;&amp;a){c.preventDefault();a=false;tinyMCE.activeEditor.focus();return false}}})}if(0&gt;b(&quot;#post_ID&quot;).val()){b(&quot;#title&quot;).blur(function(){if(!this.value||0&lt;b(&quot;#post_ID&quot;).val()){return}delayed_autosave()})}});function autosave_parse_response(c){var e=wpAjax.parseAjaxResponse(c,&quot;autosave&quot;),f=&quot;&quot;,a,b,d;if(e&amp;&amp;e.responses&amp;&amp;e.responses.length){f=e.responses[0].data;if(e.responses[0].supplemental){b=e.responses[0].supplemental;if(&quot;disable&quot;==b.disable_autosave){autosave=function(){};e={errors:true}}if(b.session_expired&amp;&amp;(d=b.session_expired)){if(!interimLogin||interimLogin.closed){interimLogin=window.open(d,&quot;login&quot;,&quot;width=600,height=450,resizable=yes,scrollbars=yes,status=yes&quot;);interimLogin.focus()}delete b.session_expired}jQuery.each(b,function(g,h){if(g.match(/^replace-/)){jQuery(&quot;#&quot;+g.replace(&quot;replace-&quot;,&quot;&quot;)).val(h)}})}if(!e.errors){a=parseInt(e.responses[0].id,10);if(!isNaN(a)&amp;&amp;a&gt;0){autosave_update_slug(a)}}}if(f){jQuery(&quot;#autosave&quot;).html(f)}else{if(autosaveOldMessage&amp;&amp;e){jQuery(&quot;#autosave&quot;).html(autosaveOldMessage)}}return e}function autosave_saved(a){autosave_parse_response(a);autosave_enable_buttons()}function autosave_saved_new(b){var d=autosave_parse_response(b),c,a;if(d&amp;&amp;d.responses.length&amp;&amp;!d.errors){c=jQuery(&quot;#post_ID&quot;).val();a=parseInt(d.responses[0].id,10);autosave_update_post_ID(a);if(c&lt;0&amp;&amp;a&gt;0){notSaved=false;jQuery(&quot;#media-buttons a&quot;).each(function(){this.href=this.href.replace(c,a)})}if(autosaveDelayPreview){autosaveDelayPreview=false;doPreview()}}else{autosave_enable_buttons()}}function autosave_update_post_ID(a){if(!isNaN(a)&amp;&amp;a&gt;0){if(a==parseInt(jQuery(&quot;#post_ID&quot;).val(),10)){return}jQuery(&quot;#post_ID&quot;).attr({name:&quot;post_ID&quot;});jQuery(&quot;#post_ID&quot;).val(a);jQuery.post(autosaveL10n.requestFile,{action:&quot;autosave-generate-nonces&quot;,post_ID:a,autosavenonce:jQuery(&quot;#autosavenonce&quot;).val(),post_type:jQuery(&quot;#post_type&quot;).val()},function(b){jQuery(&quot;#_wpnonce&quot;).val(b.updateNonce);jQuery(&quot;#delete-action a.submitdelete&quot;).attr(&quot;href&quot;,b.deleteURL);autosave_enable_buttons();jQuery(&quot;#delete-action a.submitdelete&quot;).fadeIn()},&quot;json&quot;);jQuery(&quot;#hiddenaction&quot;).val(&quot;editpost&quot;)}}function autosave_update_slug(a){if(jQuery.isFunction(make_slugedit_clickable)&amp;&amp;!jQuery(&quot;#edit-slug-box &gt; *&quot;).size()){jQuery.post(slugL10n.requestFile,{action:&quot;sample-permalink&quot;,post_id:a,new_title:jQuery(&quot;#title&quot;).val(),samplepermalinknonce:jQuery(&quot;#samplepermalinknonce&quot;).val()},function(b){jQuery(&quot;#edit-slug-box&quot;).html(b);make_slugedit_clickable()})}}function autosave_loading(){jQuery(&quot;#autosave&quot;).html(autosaveL10n.savingText)}function autosave_enable_buttons(){setTimeout(function(){jQuery(&quot;:button, :submit&quot;,&quot;#submitpost&quot;).removeAttr(&quot;disabled&quot;);jQuery(&quot;#ajax-loading&quot;).css(&quot;visibility&quot;,&quot;hidden&quot;)},500)}function autosave_disable_buttons(){jQuery(&quot;:button, :submit&quot;,&quot;#submitpost&quot;).attr(&quot;disabled&quot;,&quot;disabled&quot;);setTimeout(autosave_enable_buttons,5000)}function delayed_autosave(){setTimeout(function(){if(blockSave){return}autosave()},200)}autosave=function(){var c=(typeof tinyMCE!=&quot;undefined&quot;)&amp;&amp;tinyMCE.activeEditor&amp;&amp;!tinyMCE.activeEditor.isHidden(),d,f,b,e,a;autosave_disable_buttons();d={action:&quot;autosave&quot;,post_ID:jQuery(&quot;#post_ID&quot;).val()||0,post_title:jQuery(&quot;#title&quot;).val()||&quot;&quot;,autosavenonce:jQuery(&quot;#autosavenonce&quot;).val(),post_type:jQuery(&quot;#post_type&quot;).val()||&quot;&quot;,autosave:1};jQuery(&quot;.tags-input&quot;).each(function(){d[this.name]=this.value});f=true;if(jQuery(&quot;#TB_window&quot;).css(&quot;display&quot;)==&quot;block&quot;){f=false}if(c&amp;&amp;f){b=tinyMCE.activeEditor;if(b.plugins.spellchecker&amp;&amp;b.plugins.spellchecker.active){f=false}else{if(&quot;mce_fullscreen&quot;==b.id){tinyMCE.get(&quot;content&quot;).setContent(b.getContent({format:&quot;raw&quot;}),{format:&quot;raw&quot;})}tinyMCE.get(&quot;content&quot;).save()}}d.content=jQuery(&quot;#content&quot;).val();if(jQuery(&quot;#post_name&quot;).val()){d.post_name=jQuery(&quot;#post_name&quot;).val()}if((d.post_title.length==0&amp;&amp;d.content.length==0)||d.post_title+d.content==autosaveLast){f=false}e=jQuery(&quot;#original_post_status&quot;).val();goodcats=([]);jQuery(&quot;[name='post_category[]']:checked&quot;).each(function(g){goodcats.push(this.value)});d.catslist=goodcats.join(&quot;,&quot;);if(jQuery(&quot;#comment_status&quot;).attr(&quot;checked&quot;)){d.comment_status=&quot;open&quot;}if(jQuery(&quot;#ping_status&quot;).attr(&quot;checked&quot;)){d.ping_status=&quot;open&quot;}if(jQuery(&quot;#excerpt&quot;).size()){d.excerpt=jQuery(&quot;#excerpt&quot;).val()}if(jQuery(&quot;#post_author&quot;).size()){d.post_author=jQuery(&quot;#post_author&quot;).val()}d.user_ID=jQuery(&quot;#user-id&quot;).val();if(f){autosaveLast=jQuery(&quot;#title&quot;).val()+jQuery(&quot;#content&quot;).val()}else{d.autosave=0}if(parseInt(d.post_ID,10)&lt;1){d.temp_ID=d.post_ID;a=autosave_saved_new}else{a=autosave_saved}autosaveOldMessage=jQuery(&quot;#autosave&quot;).html();jQuery.ajax({data:d,beforeSend:f?autosave_loading:null,type:&quot;POST&quot;,url:autosaveL10n.requestFile,success:a})};
</ins><span class="cx">\ No newline at end of file
</span></span></pre></div>
<a id="trunkwpincludespluggablephp"></a>
<div class="modfile"><h4>Modified: trunk/wp-includes/pluggable.php (12020 => 12021)</h4>
<pre class="diff"><span>
<span class="info">--- trunk/wp-includes/pluggable.php        2009-10-11 00:37:26 UTC (rev 12020)
+++ trunk/wp-includes/pluggable.php        2009-10-11 11:26:59 UTC (rev 12021)
</span><span class="lines">@@ -539,6 +539,9 @@
</span><span class="cx">                 return false;
</span><span class="cx">         }
</span><span class="cx"> 
</span><ins>+        if ( $expiration &lt; time() ) // AJAX/POST grace period set above
+                $GLOBALS['login_grace_period'] = 1;
+
</ins><span class="cx">         do_action('auth_cookie_valid', $cookie_elements, $user);
</span><span class="cx"> 
</span><span class="cx">         return $user-&gt;ID;
</span></span></pre></div>
<a id="trunkwpincludesscriptloaderphp"></a>
<div class="modfile"><h4>Modified: trunk/wp-includes/script-loader.php (12020 => 12021)</h4>
<pre class="diff"><span>
<span class="info">--- trunk/wp-includes/script-loader.php        2009-10-11 00:37:26 UTC (rev 12020)
+++ trunk/wp-includes/script-loader.php        2009-10-11 11:26:59 UTC (rev 12021)
</span><span class="lines">@@ -98,7 +98,7 @@
</span><span class="cx">                 'l10n_print_after' =&gt; 'try{convertEntities(wpAjax);}catch(e){};'
</span><span class="cx">         ) );
</span><span class="cx"> 
</span><del>-        $scripts-&gt;add( 'autosave', &quot;/wp-includes/js/autosave$suffix.js&quot;, array('schedule', 'wp-ajax-response'), '20090913' );
</del><ins>+        $scripts-&gt;add( 'autosave', &quot;/wp-includes/js/autosave$suffix.js&quot;, array('schedule', 'wp-ajax-response'), '20091010' );
</ins><span class="cx">         $scripts-&gt;add_data( 'autosave', 'group', 1 );
</span><span class="cx"> 
</span><span class="cx">         $scripts-&gt;add( 'wp-lists', &quot;/wp-includes/js/wp-lists$suffix.js&quot;, array('wp-ajax-response'), '20091007' );
</span><span class="lines">@@ -479,7 +479,7 @@
</span><span class="cx">         $styles-&gt;add( 'theme-editor', &quot;/wp-admin/css/theme-editor$suffix.css&quot;, array(), '20090625' );
</span><span class="cx">         $styles-&gt;add( 'press-this', &quot;/wp-admin/css/press-this$suffix.css&quot;, array(), '20090514' );
</span><span class="cx">         $styles-&gt;add( 'thickbox', '/wp-includes/js/thickbox/thickbox.css', array(), '20090514' );
</span><del>-        $styles-&gt;add( 'login', &quot;/wp-admin/css/login$suffix.css&quot;, array(), '20090824' );
</del><ins>+        $styles-&gt;add( 'login', &quot;/wp-admin/css/login$suffix.css&quot;, array(), '20091010' );
</ins><span class="cx">         $styles-&gt;add( 'plugin-install', &quot;/wp-admin/css/plugin-install$suffix.css&quot;, array(), '20090514' );
</span><span class="cx">         $styles-&gt;add( 'theme-install', &quot;/wp-admin/css/theme-install$suffix.css&quot;, array(), '20090610' );
</span><span class="cx">         $styles-&gt;add( 'farbtastic', '/wp-admin/css/farbtastic.css', array(), '1.2' );
</span></span></pre></div>
<a id="trunkwploginphp"></a>
<div class="modfile"><h4>Modified: trunk/wp-login.php (12020 => 12021)</h4>
<pre class="diff"><span>
<span class="info">--- trunk/wp-login.php        2009-10-11 00:37:26 UTC (rev 12020)
+++ trunk/wp-login.php        2009-10-11 11:26:59 UTC (rev 12021)
</span><span class="lines">@@ -39,7 +39,7 @@
</span><span class="cx">  * @param WP_Error $wp_error Optional. WordPress Error Object
</span><span class="cx">  */
</span><span class="cx"> function login_header($title = 'Log In', $message = '', $wp_error = '') {
</span><del>-        global $error, $is_iphone;
</del><ins>+        global $error, $is_iphone, $interim_login;
</ins><span class="cx"> 
</span><span class="cx">         // Don't index any of these forms
</span><span class="cx">         add_filter( 'pre_option_blog_public', create_function( '$a', 'return 0;' ) );
</span><span class="lines">@@ -53,18 +53,22 @@
</span><span class="cx"> &lt;head&gt;
</span><span class="cx">         &lt;title&gt;&lt;?php bloginfo('name'); ?&gt; &amp;rsaquo; &lt;?php echo $title; ?&gt;&lt;/title&gt;
</span><span class="cx">         &lt;meta http-equiv=&quot;Content-Type&quot; content=&quot;&lt;?php bloginfo('html_type'); ?&gt;; charset=&lt;?php bloginfo('charset'); ?&gt;&quot; /&gt;
</span><del>-        &lt;?php
</del><ins>+&lt;?php
</ins><span class="cx">         wp_admin_css( 'login', true );
</span><span class="cx">         wp_admin_css( 'colors-fresh', true );
</span><span class="cx"> 
</span><del>-        if ( $is_iphone ) {
-        ?&gt;
</del><ins>+        if ( $is_iphone ) { ?&gt;
</ins><span class="cx">         &lt;meta name=&quot;viewport&quot; content=&quot;width=320; initial-scale=0.9; maximum-scale=1.0; user-scalable=0;&quot; /&gt;
</span><span class="cx">         &lt;style type=&quot;text/css&quot; media=&quot;screen&quot;&gt;
</span><span class="cx">         form { margin-left: 0px; }
</span><span class="cx">         #login { margin-top: 20px; }
</span><span class="cx">         &lt;/style&gt;
</span><del>-        &lt;?php
</del><ins>+&lt;?php
+        } elseif ( isset($interim_login) &amp;&amp; $interim_login ) { ?&gt;
+        &lt;style type=&quot;text/css&quot; media=&quot;all&quot;&gt;
+        .login #login { margin: 20px auto; }
+        &lt;/style&gt;
+&lt;?php
</ins><span class="cx">         }
</span><span class="cx"> 
</span><span class="cx">         do_action('login_head'); ?&gt;
</span><span class="lines">@@ -282,7 +286,7 @@
</span><span class="cx">         $action = 'resetpass';
</span><span class="cx"> 
</span><span class="cx"> // validate action so as to default to the login screen
</span><del>-if ( !in_array($action, array('logout', 'lostpassword', 'retrievepassword', 'resetpass', 'rp', 'register', 'login')) &amp;&amp; false === has_filter('login_form_' . $action) )
</del><ins>+if ( !in_array($action, array('logout', 'lostpassword', 'retrievepassword', 'resetpass', 'rp', 'register', 'login'), true) &amp;&amp; false === has_filter('login_form_' . $action) )
</ins><span class="cx">         $action = 'login';
</span><span class="cx"> 
</span><span class="cx"> nocache_headers();
</span><span class="lines">@@ -443,6 +447,7 @@
</span><span class="cx"> case 'login' :
</span><span class="cx"> default:
</span><span class="cx">         $secure_cookie = '';
</span><ins>+        $interim_login = isset($_REQUEST['interim-login']);
</ins><span class="cx"> 
</span><span class="cx">         // If the user wants ssl but the session is not ssl, force a secure cookie.
</span><span class="cx">         if ( !empty($_POST['log']) &amp;&amp; !force_ssl_admin() ) {
</span><span class="lines">@@ -472,6 +477,15 @@
</span><span class="cx">         $redirect_to = apply_filters('login_redirect', $redirect_to, isset( $_REQUEST['redirect_to'] ) ? $_REQUEST['redirect_to'] : '', $user);
</span><span class="cx"> 
</span><span class="cx">         if ( !is_wp_error($user) ) {
</span><ins>+                if ( $interim_login ) {
+                        $message = '&lt;p class=&quot;message&quot;&gt;' . __('You have logged in successfully.') . '&lt;/p&gt;';
+                        login_header( '', $message ); ?&gt;
+                        &lt;script type=&quot;text/javascript&quot;&gt;setTimeout( function(){window.close()}, 8000);&lt;/script&gt;
+                        &lt;p class=&quot;alignright&quot;&gt;
+                        &lt;input type=&quot;button&quot; class=&quot;button-primary&quot; value=&quot;&lt;?php esc_attr_e('Close'); ?&gt;&quot; onclick=&quot;window.close()&quot; /&gt;&lt;/p&gt;
+                        &lt;/div&gt;&lt;/body&gt;&lt;/html&gt;
+&lt;?php                exit;
+                }
</ins><span class="cx">                 // If the user can't edit posts, send them to their profile.
</span><span class="cx">                 if ( !$user-&gt;has_cap('edit_posts') &amp;&amp; ( empty( $redirect_to ) || $redirect_to == 'wp-admin/' || $redirect_to == admin_url() ) )
</span><span class="cx">                         $redirect_to = admin_url('profile.php');
</span><span class="lines">@@ -489,11 +503,18 @@
</span><span class="cx">                 $errors-&gt;add('test_cookie', __(&quot;&lt;strong&gt;ERROR&lt;/strong&gt;: Cookies are blocked or not supported by your browser. You must &lt;a href='http://www.google.com/cookies.html'&gt;enable cookies&lt;/a&gt; to use WordPress.&quot;));
</span><span class="cx"> 
</span><span class="cx">         // Some parts of this script use the main login form to display a message
</span><del>-        if                ( isset($_GET['loggedout']) &amp;&amp; TRUE == $_GET['loggedout'] )                        $errors-&gt;add('loggedout', __('You are now logged out.'), 'message');
-        elseif        ( isset($_GET['registration']) &amp;&amp; 'disabled' == $_GET['registration'] )        $errors-&gt;add('registerdisabled', __('User registration is currently not allowed.'));
-        elseif        ( isset($_GET['checkemail']) &amp;&amp; 'confirm' == $_GET['checkemail'] )        $errors-&gt;add('confirm', __('Check your e-mail for the confirmation link.'), 'message');
-        elseif        ( isset($_GET['checkemail']) &amp;&amp; 'newpass' == $_GET['checkemail'] )        $errors-&gt;add('newpass', __('Check your e-mail for your new password.'), 'message');
-        elseif        ( isset($_GET['checkemail']) &amp;&amp; 'registered' == $_GET['checkemail'] )        $errors-&gt;add('registered', __('Registration complete. Please check your e-mail.'), 'message');
</del><ins>+        if                ( isset($_GET['loggedout']) &amp;&amp; TRUE == $_GET['loggedout'] )
+                $errors-&gt;add('loggedout', __('You are now logged out.'), 'message');
+        elseif        ( isset($_GET['registration']) &amp;&amp; 'disabled' == $_GET['registration'] )
+                $errors-&gt;add('registerdisabled', __('User registration is currently not allowed.'));
+        elseif        ( isset($_GET['checkemail']) &amp;&amp; 'confirm' == $_GET['checkemail'] )
+                $errors-&gt;add('confirm', __('Check your e-mail for the confirmation link.'), 'message');
+        elseif        ( isset($_GET['checkemail']) &amp;&amp; 'newpass' == $_GET['checkemail'] )
+                $errors-&gt;add('newpass', __('Check your e-mail for your new password.'), 'message');
+        elseif        ( isset($_GET['checkemail']) &amp;&amp; 'registered' == $_GET['checkemail'] )
+                $errors-&gt;add('registered', __('Registration complete. Please check your e-mail.'), 'message');
+        elseif        ( $interim_login )
+                $errors-&gt;add('expired', __('Your session has expired. Please log-in again.'), 'message');
</ins><span class="cx"> 
</span><span class="cx">         login_header(__('Log In'), '', $errors);
</span><span class="cx"> 
</span><span class="lines">@@ -515,12 +536,17 @@
</span><span class="cx">         &lt;p class=&quot;forgetmenot&quot;&gt;&lt;label&gt;&lt;input name=&quot;rememberme&quot; type=&quot;checkbox&quot; id=&quot;rememberme&quot; value=&quot;forever&quot; tabindex=&quot;90&quot; /&gt; &lt;?php esc_attr_e('Remember Me'); ?&gt;&lt;/label&gt;&lt;/p&gt;
</span><span class="cx">         &lt;p class=&quot;submit&quot;&gt;
</span><span class="cx">                 &lt;input type=&quot;submit&quot; name=&quot;wp-submit&quot; id=&quot;wp-submit&quot; class=&quot;button-primary&quot; value=&quot;&lt;?php esc_attr_e('Log In'); ?&gt;&quot; tabindex=&quot;100&quot; /&gt;
</span><ins>+&lt;?php        if ( $interim_login ) { ?&gt;
+                &lt;input type=&quot;hidden&quot; name=&quot;interim-login&quot; value=&quot;1&quot; /&gt;
+&lt;?php        } else { ?&gt;
</ins><span class="cx">                 &lt;input type=&quot;hidden&quot; name=&quot;redirect_to&quot; value=&quot;&lt;?php echo esc_attr($redirect_to); ?&gt;&quot; /&gt;
</span><ins>+&lt;?php         } ?&gt;
</ins><span class="cx">                 &lt;input type=&quot;hidden&quot; name=&quot;testcookie&quot; value=&quot;1&quot; /&gt;
</span><span class="cx">         &lt;/p&gt;
</span><span class="cx"> &lt;/form&gt;
</span><span class="cx"> &lt;?php endif; ?&gt;
</span><span class="cx"> 
</span><ins>+&lt;?php if ( !$interim_login ) { ?&gt;
</ins><span class="cx"> &lt;p id=&quot;nav&quot;&gt;
</span><span class="cx"> &lt;?php if ( isset($_GET['checkemail']) &amp;&amp; in_array( $_GET['checkemail'], array('confirm', 'newpass') ) ) : ?&gt;
</span><span class="cx"> &lt;?php elseif (get_option('users_can_register')) : ?&gt;
</span><span class="lines">@@ -531,12 +557,12 @@
</span><span class="cx"> &lt;?php endif; ?&gt;
</span><span class="cx"> &lt;/p&gt;
</span><span class="cx"> 
</span><ins>+&lt;p id=&quot;backtoblog&quot;&gt;&lt;a href=&quot;&lt;?php bloginfo('url'); ?&gt;/&quot; title=&quot;&lt;?php _e('Are you lost?') ?&gt;&quot;&gt;&lt;?php printf(__('&amp;larr; Back to %s'), get_bloginfo('title', 'display' )); ?&gt;&lt;/a&gt;&lt;/p&gt;
+&lt;?php } ?&gt;
</ins><span class="cx"> &lt;/div&gt;
</span><span class="cx"> 
</span><del>-&lt;p id=&quot;backtoblog&quot;&gt;&lt;a href=&quot;&lt;?php bloginfo('url'); ?&gt;/&quot; title=&quot;&lt;?php _e('Are you lost?') ?&gt;&quot;&gt;&lt;?php printf(__('&amp;larr; Back to %s'), get_bloginfo('title', 'display' )); ?&gt;&lt;/a&gt;&lt;/p&gt;
-
</del><span class="cx"> &lt;script type=&quot;text/javascript&quot;&gt;
</span><del>-&lt;?php if ( $user_login ) { ?&gt;
</del><ins>+&lt;?php if ( $user_login || $interim_login ) { ?&gt;
</ins><span class="cx"> setTimeout( function(){ try{
</span><span class="cx"> d = document.getElementById('user_pass');
</span><span class="cx"> d.value = '';
</span></span></pre>
</div>
</div>

</body>
</html>