OSDN Git Service

Version 0.3.34, fix X.Dom.Builder, fix X.Timer, detect ScrollBar size.
authoritozyun <itozyun@user.sourceforge.jp>
Fri, 11 Apr 2014 13:59:11 +0000 (22:59 +0900)
committeritozyun <itozyun@user.sourceforge.jp>
Fri, 11 Apr 2014 13:59:11 +0000 (22:59 +0900)
0.6.x/js/core/05_XTimer.js
0.6.x/js/dom/10_XDom.js
0.6.x/js/dom/12_XDomEvent.js
0.6.x/js/dom/13_XDomBoxModel.js
0.6.x/js/dom/15_XDomStyle.js
0.6.x/js/dom/19_XDomParser.js
0.6.x/js/dom/22_XDomBuilder.js

index 3b1b261..6df8821 100644 (file)
@@ -8,7 +8,8 @@ X.Timer = ( function(){
                INTERVAL_TIME  = 16,\r
                TICKET_LIST    = [],\r
                uid            = 0,\r
-               timerId        = -1,\r
+               timerId        = 0,\r
+               endTime        = 0,\r
                next           = 0,\r
                INDEX_TIME     = 0,\r
                INDEX_LAST     = 1,\r
@@ -36,7 +37,7 @@ X.Timer = ( function(){
                        if( 1 < c ) --queue[ INDEX_COUNT ];\r
                        queue[ INDEX_LAST ] = queue[ INDEX_TIME ];\r
            };\r
-           timerId = -1;\r
+           timerId = 0;\r
            update();\r
        };\r
        function update(){\r
@@ -46,19 +47,31 @@ X.Timer = ( function(){
                        last;\r
                if( l === 0 ){\r
                        timerId !== -1 && clearTimeout( timerId );\r
-                       timerId = -1;\r
+                       timerId = 0;\r
                        return;\r
                };\r
            for( ; l; ){\r
                ( last = list[ --l ][ INDEX_LAST ] ) < n && ( n = last );\r
            };\r
-           if( n < next || timerId === -1 ){\r
-               timerId !== -1 && clearTimeout( timerId );\r
-               timerId = setTimeout( loop, INTERVAL_TIME * n );\r
+           if( n < next || timerId === 0 ){\r
+               timerId !== 0 && clearTimeout( timerId );\r
+               timerId   = setTimeout( loop, INTERVAL_TIME * n );\r
+               endTime   = X.getTime() + INTERVAL_TIME * n;\r
                next = n;\r
            };\r
        };\r
        \r
+       // http://havelog.ayumusato.com/develop/javascript/e528-ios6_scrolling_timer_notcall.html\r
+       // iOS6 スクロール中のタイマー発火絡みのバグ備忘\r
+       if( X.UA.iOS ){\r
+                window.addEventListener( 'scroll', function(){\r
+                       if( timerId ){\r
+                               clearTimeout( timerId );\r
+                               timerId = setTimeout( loop, Math.max( 0, endTime - X.getTime() ) );\r
+                       };\r
+                } );\r
+       };\r
+       \r
        var enterFrame =\r
                        window.requestAnimationFrame ||\r
                        window.webkitRequestAnimationFrame ||\r
index 55804c0..7d3313f 100644 (file)
@@ -63,8 +63,9 @@
                         * X.Dom.Event.XDOM_READY 以後に listen した場合の対策\r
                         */\r
                        listen : function( type ){\r
+                               var size;\r
                                if( type <= X.Dom.readyState ){\r
-                                       var size = X.Dom.getSize();\r
+                                       size = X.Dom.getSize();\r
                                        X.Dom.asyncDispatch( 0, { type : type, w : size[ 0 ], h : size[ 1 ] } );\r
                                };\r
                                return X.EventDispatcher.prototype.listen.apply( X.Dom, arguments );\r
                                        .listen( 'beforeunload', X.Dom )\r
                                        .listenOnce( 'unload', X.Dom );\r
 \r
-                               if (document[ 'hidden' ] !== undefined ) {// iOS 7+\r
+                               ifdocument[ 'hidden' ] !== undefined ) {// iOS 7+\r
                                        Node._document.listen( 'visibilitychange', X.Dom );\r
                                } else\r
-                               if (document[ 'webkitHidden' ] !== undefined ) {\r
+                               ifdocument[ 'webkitHidden' ] !== undefined ) {\r
                                        Node._document.listen( 'webkitvisibilitychange', X.Dom );\r
                                } else\r
-                               if ( X.UA.iOS && window[ 'onpageshow' ] !== undefined ) {\r
+                               if( X.UA.iOS && window[ 'onpageshow' ] !== undefined ) {\r
                                        Node._window.listen('pageshow', X.Dom );\r
                                        Node._window.listen('pagehide', X.Dom );\r
                                } else {\r
                        handleEvent : function( e ){\r
                                switch( e.type ){\r
                                        case 'beforeunload' :\r
+                                               // ie では a href="javascript" な要素でも beforeunload が起こる\r
                                                return X.Dom.dispatch( { type : X.Dom.Event.BEFORE_UNLOAD } );\r
                                        case 'unload' :\r
                                                X.Dom.dispatch( { type : X.Dom.Event.UNLOAD } );\r
                                                Node._html._actualRemove( true );\r
                                                break;\r
                                        case 'visibilitychange' :\r
+                                               X.Dom.dispatch( { type : document[ 'hidden' ] ? X.Dom.Event.VIEW_DEACTIVATE : X.Dom.Event.VIEW_ACTIVATE } );\r
                                                break;\r
                                        case 'webkitvisibilitychange' :\r
+                                               X.Dom.dispatch( { type : document[ 'webkitHidden' ] ? X.Dom.Event.VIEW_DEACTIVATE : X.Dom.Event.VIEW_ACTIVATE } );\r
                                                break;\r
                                        case 'pageshow' :\r
-                                       \r
-                                       \r
                                        case 'focus' :\r
                                                X.Dom.dispatch( { type : X.Dom.Event.VIEW_ACTIVATE } );\r
                                                break;\r
@@ -244,9 +246,9 @@ X.Dom.cleanupWhiteSpace = function( text ){
 X.Dom.whiteSpaceToTag = function( text ){\r
     if( text == null ) return '';\r
     return text.toString()\r
-       .split( '\r\n\r\n' ).join( '<br>' )\r
-       .split( '\n\r\n\r' ).join( '<br>' )\r
-       .split( '\r\n' ).join( '<br>' )\r
+       //.split( '\r\n\r\n' ).join( '<br>' )\r
+       //.split( '\n\r\n\r' ).join( '<br>' )\r
+       //.split( '\r\n' ).join( '<br>' )\r
        .split( '\n\r' ).join( '<br>' )\r
        .split( '\r' ).join( '<br>' )\r
        .split( '\n' ).join( '<br>' )\r
index 2b90001..cda5cd6 100644 (file)
@@ -143,6 +143,7 @@ X.Dom.Event.VIEW_ACTIVATE       = ++X.Event._LAST_EVENT;
 X.Dom.Event.VIEW_DEACTIVATE     = ++X.Event._LAST_EVENT;\r
 X.Dom.Event.VIEW_RESIZED        = ++X.Event._LAST_EVENT;\r
 X.Dom.Event.BASE_FONT_RESIZED   = ++X.Event._LAST_EVENT;\r
+// same_page_jump\r
 // on_screen_keyboard_show\r
 // on_screen_keyboard_hide\r
 X.Dom.Event.BEFORE_UPDATE       = ++X.Event._LAST_EVENT;\r
index 3d76460..a67c532 100644 (file)
@@ -5,7 +5,13 @@ X.Dom.BoxModel = {
        MARGIN_BOX       : 4,\r
                \r
        defaultBoxModel  : 0,\r
-       boxSizingEnabled : false\r
+       boxSizingEnabled : false,\r
+       \r
+       // TODO: offsetLeft, offsetTop の基準位置\r
+       absoluteOffset   : 0,\r
+       \r
+       vScrollbarSize   : 0,\r
+       hScrollbarSize   : 0\r
 };\r
 \r
 X.Dom.listenOnce( X.Dom.Event.DOM_INIT, function(){\r
@@ -27,7 +33,18 @@ X.Dom.listenOnce( X.Dom.Event.DOM_INIT, function(){
        // margin\r
        // top\r
 \r
+       elm.style.cssText = 'width:90px;height:90px;overflow:auto;';\r
+       elm.innerHTML = '<div style="width:100px;height:100px;"></div>';\r
+       \r
+       X.Dom.BoxModel.vScrollbarSize = 90 - elm.clientWidth;\r
+       X.Dom.BoxModel.hScrollbarSize = 90 - elm.clientHeight;\r
+\r
+       elm.style.cssText = 'position:absolute;top:0;left:0;margin:1px;border:2px solid #000;padding:4px;';\r
+       elm.children[ 0 ].style.cssText = 'position:absolute;top:8px;left:8px;margin:16px;border:32px solid #666;padding:64px;';\r
+\r
+       X.Dom.BoxModel.absoluteOffset = elm.children[ 0 ].offsetTop;\r
 \r
+       elm.style.cssText = elm.innerHTML = '';\r
 });\r
 \r
 /* --------------------------------------\r
index 31ddc30..b567484 100644 (file)
@@ -1018,8 +1018,17 @@ X.Dom.Node.prototype.css = function( nameOrObj /* orUnitID, valuOrUnitOrName */
 
 X.Dom.Node.prototype.cssText = function( v ){
        var obj, i, l, attr, name;
+       if( v === '' ){
+               delete this._css;
+               this._state &= ~X.Dom.State.IE5_DISPLAY_NONE_FIX;
+               this._dirty |= X.Dom.Dirty.CSS;
+               this.parent && this._reserveUpdate();
+               delete this._cssText;
+               return this;
+       } else
        if( X.Type.isString( v ) ){
                delete this._css;
+               this._state &= ~X.Dom.State.IE5_DISPLAY_NONE_FIX;
                obj = {};
                v   = v.split( ';' );
                for( i = 0, l = v.length; i < l; ++i ){
@@ -1186,6 +1195,9 @@ X.Dom.listenOnce( X.Dom.Event.DOM_INIT, function(){
                output[ size ] = xnode.css( 'fontSize', size ).height();// / base;
        };
        
-       xnode.cssText( '' ).empty();
+       // 以下解決、scroll 中に timer が無視される iOS の問題が原因(dom追加で起こったスクロール?)
+       // ipod touch 1st で必要なんですけど、、、
+       //xnode._rawNode.style.cssText = ''; 
+       xnode.cssText( '' ).empty(); //._startUpdate();
 } );
 
index 18eb8cf..a067ce4 100644 (file)
@@ -49,7 +49,7 @@ X.Dom.Parser = {
        // Special Elements (can contain anything)\r
        special : {script:1,style:1},\r
        \r
-       start : function( html, handler, async ){\r
+       exec : function( html, handler, async ){\r
                var special        = X.Dom.Parser.special,\r
                        startTime      = async && X.getTime(),\r
                        _parseStartTag = X.Dom.Parser._parseStartTag,\r
@@ -113,7 +113,7 @@ X.Dom.Parser = {
                        \r
                        if( async && startTime + 15 <= X.getTime() && html ){\r
                                handler.progress( 1 - html.length / async[ 0 ] );\r
-                               X.Timer.once( 0, X.Dom.Parser.start, [ html, handler, async ] );\r
+                               X.Timer.once( 0, X.Dom.Parser.exec, [ html, handler, async ] );\r
                                return;\r
                        };\r
                        \r
@@ -345,7 +345,7 @@ X.Dom.parse = function( html, ignoreError ){
        worker.flat = [];\r
        worker.nest.length = 0;\r
        worker.ignoreError = ignoreError;\r
-       X.Dom.Parser.start( html, worker );\r
+       X.Dom.Parser.exec( html, worker );\r
        ret = worker.flat;\r
        delete worker.flat;\r
        return ret;\r
@@ -356,15 +356,9 @@ X.Dom._asyncHtmlStringToXNode = {
                X.Dom._htmlStringToXNode.err( html );\r
                this.asyncDispatch( 0, { type : X.Event.ERROR } );\r
        },\r
-       start : function( tagName, attrs, noChild, length ){\r
-               X.Dom._htmlStringToXNode.start( tagName, attrs, noChild, length );\r
-       },\r
-       end : function(){\r
-               X.Dom._htmlStringToXNode.end();\r
-       },\r
-       chars : function( text ){\r
-               X.Dom._htmlStringToXNode.chars( text );\r
-       },\r
+       start   : X.Dom._htmlStringToXNode.start,\r
+       end     : X.Dom._htmlStringToXNode.end,\r
+       chars   : X.Dom._htmlStringToXNode.chars,\r
        comment : X.emptyFunction,\r
        \r
        progress : function( pct ){\r
@@ -384,6 +378,6 @@ X.Dom.asyncParse = function( html, ignoreError ){
        worker.flat = [];\r
        worker.nest.length = 0;\r
        worker.ignoreError = ignoreError;\r
-       X.Dom.Parser.start( html, dispatcher, [ html.length, [] ] );\r
+       X.Dom.Parser.exec( html, dispatcher, [ html.length, [] ] );\r
        return dispatcher;\r
 };\r
index ce34616..de453f1 100644 (file)
@@ -39,7 +39,7 @@ X.Dom.listenOnce( X.Dom.Event.DOM_PRE_INIT,
                                                // pre タグ以下はスペースの置換は行わない\r
                                                node.childNodes && node.childNodes.length &&  me( node, skip || noncleanup.indexOf( tag ) !== -1, head );\r
                                        };\r
-                                       textNode = false;       \r
+                                       textNode = null;\r
                                        break;\r
                                case 3 :\r
                                        content = skip ? node.data : X.Dom.cleanupWhiteSpace( node.data );\r
@@ -101,33 +101,35 @@ document.all ?
                                elmProgress.style.width = ( e.progress * 100 | 0 ) + '%';\r
                        }\r
                )\r
-               .listenOnce( X.Event.SUCCESS, function( e ){\r
-                       var xnodes = Node.root._xnodes = [], t;\r
-                       xnodes.push.apply( xnodes, e.xnodes );\r
-                       \r
-                       X.Dom._asyncCreateTree( Node.root, body.childNodes || body.children, elmProgress );\r
-               } );\r
+               .listenOnce( X.Event.SUCCESS,\r
+                       function( e ){\r
+                               var xnodes = Node.root._xnodes = [], t;\r
+                               xnodes.push.apply( xnodes, e.xnodes );\r
+                               \r
+                               X.Dom._asyncCreateTree( Node.root, body.childNodes || body.children, elmProgress );\r
+                       }\r
+               );\r
 }) :\r
 (function(){\r
        \r
 }) );\r
 \r
 X.Dom._asyncCreateTree = function ( parent, elems, elmProgress, async ){\r
-       var xnodes      = async ? 0             : X.copyArray( parent._xnodes ),\r
-               l           = async ? 0             : xnodes.length,\r
+       var xnodes      = async ? 0           : X.copyArray( parent._xnodes ),\r
+               l           = async ? 0           : xnodes.length,\r
+               stack       = async ? async.stack : [],\r
+               done        = async ? async.done  : 0,\r
+               startTime   = X.getTime(),              \r
                current     = async ? async.current : {\r
                        me     : parent,\r
                        xnodes : xnodes,\r
                        l      : l,\r
                        i      : 0,\r
-                       elems  : elems,\r
+                       elems  : X.copyArray( elems ),\r
                        j      : 0,\r
                        xtext  : null,\r
                        flag   : 0\r
                },\r
-               stack       = async ? async.stack   : [],\r
-               done        = async ? async.done    : 0,\r
-               startTime = X.getTime(),\r
                xnode, i, dive;\r
        while( current || ( current = stack.pop() ) ){\r
                i = current.i;\r
@@ -175,206 +177,209 @@ X.Dom._asyncCreateTree = function ( parent, elems, elmProgress, async ){
 };\r
 \r
 bindElementToXnode =\r
-document.getElementById ?\r
-(function( parent, xnode, current ){\r
-       var elems = current.elems,\r
-               //j     = current.j,\r
-               m     = elems.length,\r
-               xtext = current.xtext,\r
-               skipCleanup = current.skipCleanup,\r
-               elm, tag, text;\r
-\r
-       xnode.parent = parent;\r
-\r
-       for( ; current.j < m; ++current.j ){\r
-               elm = elems[ current.j ];\r
-               tag = elm.tagName;\r
-               if( ( elm.nodeType !== 1 && elm.nodeType !== 3 ) || tag === '!' || ( tag && tag.charAt( 0 ) === '/' ) ){\r
-                       elm.parentNode.removeChild( elm );\r
-                       continue;\r
-               };\r
-\r
-               if( xnode._xnodeType === 1 ){\r
-                       if( elm.nodeType === 3 ){\r
-                               if( !( text = elm.data ) || ( text = X.Dom.cleanupWhiteSpace( text ) ) === ' ' ){\r
+       document.getElementById ?\r
+               (function( parent, xnode, current ){\r
+                       var elems = current.elems,\r
+                               //j     = current.j,\r
+                               m     = elems.length,\r
+                               xtext = current.xtext,\r
+                               skipCleanup = current.skipCleanup,\r
+                               inPreTag    = current.inPreTag,\r
+                               elm, tag, text;\r
+               \r
+                       xnode.parent = parent;\r
+               \r
+                       for( ; current.j < m; ++current.j ){\r
+                               elm = elems[ current.j ];\r
+                               tag = elm.tagName;\r
+                               if( ( elm.nodeType !== 1 && elm.nodeType !== 3 ) || tag === '!' || ( tag && tag.charAt( 0 ) === '/' ) ){\r
                                        elm.parentNode.removeChild( elm );\r
                                        continue;\r
                                };\r
-                               alert( '[' +parent._tag + '>' +xnode._tag + '] !== ' + elm.nodeType + '\n' + elm.data );\r
-                       } else\r
-                       if( xnode._tag.toUpperCase() !== tag ){\r
-                               alert( '[' +parent._tag + '>' +xnode._tag + ' ' + (xnode._xnodes ? xnode._xnodes.length : '' ) + '] !== ' + tag + ' ' + (elm.childNodes ? elm.childNodes.length : '' ) + '\n' + elm.outerHTML );\r
-                       } else {\r
-                               xnode._rawNode = elm;\r
-                               //if( ( doc = elm.ownerDocument || elm.document ) && ( doc.createElement( 'p' ).tagName === doc.createElement( 'P' ).tagName ) ){\r
-                                       if( tag.charAt( 0 ) === '/' ) tag = tag.slice( 1 );\r
-                                       xnode._tag = tag; // .toUpperCase()\r
-                               //};\r
-                               xnode._root = parent._root;\r
-                               elm.UID     = xnode._uid;\r
+               \r
+                               if( xnode._xnodeType === 1 ){\r
+                                       if( elm.nodeType === 3 ){\r
+                                               //if( !( text = elm.data ) || ( text = X.Dom.cleanupWhiteSpace( text ) ) === ' ' ){\r
+                                               //      elm.parentNode.removeChild( elm );\r
+                                               //      continue;\r
+                                               //};\r
+                                               alert( '[' +parent._tag + '>' +xnode._tag + '] !== ' + elm.nodeType + '\n' + elm.data );\r
+                                       } else\r
+                                       if( xnode._tag.toUpperCase() !== tag ){\r
+                                               alert( '[' +parent._tag + '>' +xnode._tag + ' ' + (xnode._xnodes ? xnode._xnodes.length : '' ) + '] !== ' + tag + ' ' + (elm.childNodes ? elm.childNodes.length : '' ) + '\n' + elm.outerHTML );\r
+                                       } else {\r
+                                               xnode._rawNode = elm;\r
+                                               //if( ( doc = elm.ownerDocument || elm.document ) && ( doc.createElement( 'p' ).tagName === doc.createElement( 'P' ).tagName ) ){\r
+                                                       if( tag.charAt( 0 ) === '/' ) tag = tag.slice( 1 );\r
+                                                       xnode._tag = tag; // .toUpperCase()\r
+                                               //};\r
+                                               xnode._root = parent._root;\r
+                                               elm.UID     = xnode._uid;\r
+                                               \r
+                                               if( tag === 'TEXTAREA' ){\r
+                                                       xnode.attr( 'value', xnode.html() ).empty();\r
+                                                       current.xtext = null;\r
+                                               } else\r
+                                               if( 0 <= X.Dom.cleanupTagNames.indexOf( tag.toLowerCase() ) || tag === 'SCRIPT' ){ // ie で body 内の script が2度よばれるのに対処\r
+                                                       //alert( '[' +parent._tag + '>' + xnode._tag + '] remove ... ' );\r
+                                                       xnode.destroy();\r
+                                               } else\r
+                                               if( elm.childNodes && elm.childNodes.length ){\r
+                                                       //alert( '[' +parent._tag + '>' + xnode._tag + ' ' + (xnode._xnodes ? xnode._xnodes.length : '' ) + '] === ' + tag + ' ' + (elm.childNodes ? elm.childNodes.length : '' ) + ' Hit\n' + elm.outerHTML );\r
+                                                       current.xtext = null;\r
+                                                       ++current.j;\r
+                                                       \r
+                                                       return {\r
+                                                               me     : xnode,\r
+                                                               xnodes : X.copyArray( xnode._xnodes ),\r
+                                                               xtext  : null,\r
+                                                               flag   : 0,\r
+                                                               i      : 0,\r
+                                                               l      : xnode._xnodes.length,\r
+                                                               elems  : X.copyArray( elm.childNodes ),\r
+                                                               j      : 0,\r
+                                                               skipCleanup : skipCleanup || 0 <= X.Dom.skipCleanupTagNames.indexOf( tag.toLowerCase() )\r
+                                                       };\r
+                                               };\r
+                                       };\r
+                                       ++current.j;\r
+                                       break;\r
+                               };\r
+                               \r
+                               if( elm.nodeType !== 3 ){\r
+                                       if( !( text = xnode._text ) || ( text = X.Dom.cleanupWhiteSpace( text ) ) === ' ' ){\r
+                                               console.log( '[' +parent._tag + '>' + xnode._uid + '] destroy ... ' );\r
+                                               xnode.destroy();\r
+                                               break;\r
+                                       };\r
+                                       alert(  parent._tag + '>' + '"' + xnode._text + '" !== ' + tag + '\n' + elm.outerHTML );\r
+                                       break;\r
+                               };\r
                                \r
-                               if( tag === 'TEXTAREA' ){\r
-                                       xnode.attr( 'value', xnode.html() ).empty();\r
+                               ++current.j;\r
+                               xnode._rawNode = elm;\r
+                               xnode._root    = parent._root;\r
+                               if( !skipCleanup ){\r
+                                       if( !( text = xnode._text ) || ( text = X.Dom.cleanupWhiteSpace( text ) ) === ' ' ){\r
+                                               console.log( '[' +parent._tag + '>' + xnode._uid + '] destroy ... ' );\r
+                                               xnode.destroy();\r
+                                       };\r
+                                       if( xtext ){\r
+                                               xtext.text( xtext._text + text );\r
+                                               console.log( '[' +parent._tag + '>' + xnode._uid + '] xtext,destroy ... ' );\r
+                                               xnode.destroy();\r
+                                       } else {\r
+                                               //alert( parent._tag + '>' + '"' + text + '"\n' + elm.data );\r
+                                               xnode.text( text );\r
+                                       };\r
                                } else\r
-                               if( 0 <= X.Dom.cleanupTagNames.indexOf( tag.toLowerCase() ) || tag === 'SCRIPT' ){ // ie で body 内の script が2度よばれるのに対処\r
-                                       //alert( '[' +parent._tag + '>' + xnode._tag + '] remove ... ' );\r
+                               if( xtext ){\r
+                                       xtext.text( xtext._text + xnode._text );\r
+                                       console.log( '[' +parent._tag + '>' + xnode._uid + '] xtext,destroy ... ' );\r
                                        xnode.destroy();\r
-                               } else\r
-                               if( elm.childNodes && elm.childNodes.length ){\r
-                                       //alert( '[' +parent._tag + '>' + xnode._tag + ' ' + (xnode._xnodes ? xnode._xnodes.length : '' ) + '] === ' + tag + ' ' + (elm.childNodes ? elm.childNodes.length : '' ) + ' Hit\n' + elm.outerHTML );\r
-                                       ++current.j;\r
-                                       return {\r
-                                               me     : xnode,\r
-                                               xnodes : X.copyArray( xnode._xnodes ),\r
-                                               xtext  : null,\r
-                                               flag   : 0,\r
-                                               i      : 0,\r
-                                               l      : xnode._xnodes.length,\r
-                                               elems  : elm.childNodes,\r
-                                               j      : 0,\r
-                                               skipCleanup : skipCleanup || 0 <= X.Dom.skipCleanupTagNames.indexOf( tag.toLowerCase() )\r
-                                       };\r
                                };\r
-                               current.xtext = null;\r
-                       };\r
-                       ++current.j;\r
-                       break;\r
-               };\r
-               \r
-               if( elm.nodeType !== 3 ){\r
-                       if( !( text = xnode._text ) || ( text = X.Dom.cleanupWhiteSpace( text ) ) === ' ' ){\r
-                               console.log( '[' +parent._tag + '>' + xnode._uid + '] destroy ... ' );\r
-                               xnode.destroy();\r
+                               current.xtext = xtext || xnode;\r
                                break;\r
                        };\r
-                       alert(  parent._tag + '>' + '"' + xnode._text + '" !== ' + tag + '\n' + elm.outerHTML );\r
-                       break;\r
-               };\r
+               }) :\r
+               (function ( parent, xnode, current ){\r
+                       var elems = current.elems,\r
+                               j     = current.j,\r
+                               m     = elems.length,\r
+                               xtext = current.xtext,\r
+                               skipCleanup = current.skipCleanup,\r
+                               elm, tag, text;\r
                \r
-               ++current.j;\r
-               xnode._rawNode = elm;\r
-               xnode._root    = parent._root;\r
-               if( !skipCleanup ){\r
-                       if( !( text = xnode._text ) || ( text = X.Dom.cleanupWhiteSpace( text ) ) === ' ' ){\r
-                               console.log( '[' +parent._tag + '>' + xnode._uid + '] destroy ... ' );\r
-                               xnode.destroy();\r
-                       };\r
-                       if( xtext ){\r
-                               xtext.text( xtext._text + text );\r
-                               console.log( '[' +parent._tag + '>' + xnode._uid + '] xtext,destroy ... ' );\r
-                               xnode.destroy();\r
-                       } else {\r
-                               //alert( parent._tag + '>' + '"' + text + '"\n' + elm.data );\r
-                               xnode.text( text );\r
-                       };\r
-               } else\r
-               if( xtext ){\r
-                       xtext.text( xtext._text + xnode._text );\r
-                       console.log( '[' +parent._tag + '>' + xnode._uid + '] xtext,destroy ... ' );\r
-                       xnode.destroy();\r
-               };\r
-               current.xtext = xtext || xnode;\r
-               break;\r
-       };\r
-}) :\r
-(function ( parent, xnode, current ){\r
-       var elems = current.elems,\r
-               j     = current.j,\r
-               m     = elems.length,\r
-               xtext = current.xtext,\r
-               skipCleanup = current.skipCleanup,\r
-               elm, tag, text;\r
-\r
-       xnode.parent = parent;\r
-       \r
-       if( xnode._xnodeType === 3 ){\r
-               //alert( X.Dom.cleanupWhiteSpace( xnode._text ) );\r
-               if( !skipCleanup ){\r
-                       if( !( text = xnode._text ) || ( text = X.Dom.cleanupWhiteSpace( text ) ) === ' ' ){\r
-                               xnode.destroy();\r
-                       } else\r
-                       if( xtext ){\r
-                               //alert( 'xtext ' + text.charCodeAt( 0 ) + ' : ' + text.length );\r
-                               xtext.text( xtext._text + text );\r
-                               xnode.destroy();\r
-                       } else {\r
-                               //alert( 'xnode ' + text.charCodeAt( 0 ) + ' : ' + text.length );\r
-                               xnode.text( text );\r
-                       };\r
-               } else\r
-               if( xtext ){\r
-                       //alert( 'skip ' + text.charCodeAt( 0 ) + ' : ' + text.length );\r
-                       xtext.text( xtext._text + xnode._text );\r
-                       xnode.destroy();\r
-               };\r
-               current.flag |= 4;\r
-               current.xtext = xtext || xnode;\r
-               return;\r
-       };\r
-       \r
-       if( xnode._xnodeType !== 1 ){\r
-               //alert( xnode._xnodeType )\r
-               return;\r
-       };\r
-       \r
-       for( ; j < m; ++j, ++current.j ){\r
-               elm = elems[ j ];\r
-               tag = elm.tagName;\r
-               /*\r
-                * 未知のタグについては、閉じタグも含めてタグ名扱いになる\r
-                */\r
-               if( tag === '!' || tag.charAt( 0 ) === '/' ){\r
-                       //alert( '## ' + tag );\r
-                       continue;\r
-               } else\r
-               if( xnode._tag !== tag ){\r
-                       alert( xnode._tag + ' ' + ' !== ' + tag + '\nxnode.html():' + xnode.attr('cite') + '\nelm.outerHTML:' +  elm.outerHTML );\r
-               } else {\r
-                       ++current.j;\r
+                       xnode.parent = parent;\r
                        \r
-                       xnode._rawNode = elm;\r
-                       xnode._root    = parent._root;\r
-                       //xnode._tag     = X.Dom.DTD.TAG_FIX[ tag ] || tag;\r
-                       if( 0 <= X.Dom.cleanupTagNames.indexOf( tag.toLowerCase() ) || tag === 'SCRIPT' ){\r
-                               xnode.destroy();\r
-                               break;\r
+                       if( xnode._xnodeType === 3 ){\r
+                               //alert( X.Dom.cleanupWhiteSpace( xnode._text ) );\r
+                               if( !skipCleanup ){\r
+                                       if( !( text = xnode._text ) || ( text = X.Dom.cleanupWhiteSpace( text ) ) === ' ' ){\r
+                                               xnode.destroy();\r
+                                       } else\r
+                                       if( xtext ){\r
+                                               //alert( 'xtext ' + text.charCodeAt( 0 ) + ' : ' + text.length );\r
+                                               xtext.text( xtext._text + text );\r
+                                               xnode.destroy();\r
+                                       } else {\r
+                                               //alert( 'xnode ' + text.charCodeAt( 0 ) + ' : ' + text.length );\r
+                                               xnode.text( text );\r
+                                       };\r
+                               } else\r
+                               if( xtext ){\r
+                                       //alert( 'skip ' + text.charCodeAt( 0 ) + ' : ' + text.length );\r
+                                       xtext.text( xtext._text + xnode._text );\r
+                                       xnode.destroy();\r
+                               };\r
+                               current.flag |= 4;\r
+                               current.xtext = xtext || xnode;\r
+                               return;\r
                        };\r
                        \r
-                       !xnode._id && elm.setAttribute( 'id', 'ie4uid' + xnode._uid );\r
-                       elm.setAttribute( 'UID', xnode._uid );\r
-                       \r
-                       tag === 'INPUT' && (\r
-                               !xnode._attrs ?\r
-                                       ( xnode._attrs = { type : 'text' } ) :\r
-                                       !xnode._attrs.type || ( xnode._attrs.type = 'text' )\r
-                       );\r
-                       current.flag |= 3;\r
-                       current.xtext = null;\r
+                       if( xnode._xnodeType !== 1 ){\r
+                               //alert( xnode._xnodeType )\r
+                               return;\r
+                       };\r
                        \r
-                       if( tag === 'TEXTAREA' ){\r
-                               xnode.attr( 'value', xnode.html() ).empty();\r
-                       } else\r
-                       if( xnode._xnodes && xnode._xnodes.length ){\r
-                               return {\r
-                                       me     : xnode,\r
-                                       xnodes : X.copyArray( xnode._xnodes ),\r
-                                       xtext  : null,\r
-                                       flag   : 0,\r
-                                       i      : 0,\r
-                                       l      : xnode._xnodes.length,\r
-                                       elems  : elm.children,\r
-                                       j      : 0,\r
-                                       skipCleanup : skipCleanup || 0 <= X.Dom.skipCleanupTagNames.indexOf( tag.toLowerCase() )\r
+                       for( ; j < m; ++j, ++current.j ){\r
+                               elm = elems[ j ];\r
+                               tag = elm.tagName;\r
+                               /*\r
+                                * 未知のタグについては、閉じタグも含めてタグ名扱いになる\r
+                                */\r
+                               if( tag === '!' || tag.charAt( 0 ) === '/' ){\r
+                                       //alert( '## ' + tag );\r
+                                       continue;\r
+                               } else\r
+                               if( xnode._tag !== tag ){\r
+                                       alert( xnode._tag + ' ' + ' !== ' + tag + '\nxnode.html():' + xnode.attr('cite') + '\nelm.outerHTML:' +  elm.outerHTML );\r
+                               } else {\r
+                                       ++current.j;\r
+                                       \r
+                                       xnode._rawNode = elm;\r
+                                       xnode._root    = parent._root;\r
+                                       //xnode._tag     = X.Dom.DTD.TAG_FIX[ tag ] || tag;\r
+                                       if( 0 <= X.Dom.cleanupTagNames.indexOf( tag.toLowerCase() ) || tag === 'SCRIPT' ){\r
+                                               xnode.destroy();\r
+                                               break;\r
+                                       };\r
+                                       \r
+                                       !xnode._id && elm.setAttribute( 'id', 'ie4uid' + xnode._uid );\r
+                                       elm.setAttribute( 'UID', xnode._uid );\r
+                                       \r
+                                       tag === 'INPUT' && (\r
+                                               !xnode._attrs ?\r
+                                                       ( xnode._attrs = { type : 'text' } ) :\r
+                                                       !xnode._attrs.type || ( xnode._attrs.type = 'text' )\r
+                                       );\r
+                                       current.flag |= 3;\r
+                                       current.xtext = null;\r
+                                       \r
+                                       if( tag === 'TEXTAREA' ){\r
+                                               xnode.attr( 'value', xnode.html() ).empty();\r
+                                       } else\r
+                                       if( xnode._xnodes && xnode._xnodes.length ){\r
+                                               return {\r
+                                                       me     : xnode,\r
+                                                       xnodes : X.copyArray( xnode._xnodes ),\r
+                                                       xtext  : null,\r
+                                                       flag   : 0,\r
+                                                       i      : 0,\r
+                                                       l      : xnode._xnodes.length,\r
+                                                       elems  : X.copyArray( elm.children ),\r
+                                                       j      : 0,\r
+                                                       skipCleanup : skipCleanup || 0 <= X.Dom.skipCleanupTagNames.indexOf( tag.toLowerCase() )\r
+                                               };\r
+                                       };\r
+                                       break;\r
                                };\r
                        };\r
-                       break;\r
-               };\r
-       };\r
-       // for\r
-       if( !xnode._rawNode ){\r
-               alert( xnode._tag + ' ' + xnode._id + ' !== none...' );\r
-       };\r
-\r
-       // textNode がある\r
-       ( current.flag & 6 ) && ( parent._dirty |= X.Dom.Dirty.IE4_TEXTNODE_FIX );\r
-});\r
+                       // for\r
+                       if( !xnode._rawNode ){\r
+                               alert( xnode._tag + ' ' + xnode._id + ' !== none...' );\r
+                       };\r
+               \r
+                       // textNode がある\r
+                       ( current.flag & 6 ) && ( parent._dirty |= X.Dom.Dirty.IE4_TEXTNODE_FIX );\r
+               });\r