OSDN Git Service

72eae6bda6633a21ec343386b27ec07a863d3c57
[pettanr/clientJs.git] / 0.6.x / js / 02_dom / 22_XTreeBuilder.js
1 \r
2 X_TEMP.X_Dom_useBuilder = true;\r
3 \r
4 X_TEMP._isCleanupTarget = function( elm ){\r
5         var cname = ' ' + elm.className + ' ',\r
6                 tag   = ( elm.tagName || '' ).toUpperCase();\r
7         return cname.indexOf( ' skip-cleanup ' ) === -1 &&\r
8                 ( X_Dom_DTD_CLEANUP_TAGS[ tag ] || cname.indexOf( ' cleanup-target ' ) !== -1 );\r
9 };\r
10 \r
11 if( X_UA[ 'MacIE' ] ){\r
12 \r
13         X_TEMP._fixed_remove = function( node, xnode ){\r
14                 var parent   = node.parentNode, l;\r
15 \r
16                 node.nodeType !== 3 && alert( node.nodeType + '\n' + ( node.outerHTML || node.data ) );\r
17                 if( node.nodeType === 1 ){\r
18                         //node.outerHTML = '';\r
19                         parent && parent.removeChild( node );\r
20                 } else\r
21                 if( node.nodeType === 3 ){\r
22                         //node.data = '';\r
23                         l = X_TEMP._removalTextNodes.length;\r
24                         if( parent ){\r
25                                 /*\r
26                                 !l && X_Timer_once( 0, X_TEMP._timerRemove );\r
27                                 X_TEMP._removalTextNodes[ l ] = node;\r
28                                 var str=[],p;\r
29                                 for( p in node ){\r
30                                         str[str.length] = p;\r
31                                 };\r
32                                 alert( str.join( ',' ) + parent.innerHTML );\r
33                                 node.nodeValue = '';\r
34                                 parent.replaceChild( document.createElement( 'span' ), node );\r
35                                 var e;\r
36                                 var f = document.createDocumentFragment();\r
37                                 f.appendChild( e = document.createElement( 'span' ) );\r
38                                 f.replaceChild( node, e );\r
39                                 e.appendChild( f );\r
40                                 parent.appendChild( e = document.createElement( 'span' ) );\r
41                                 e.appendChild( node );\r
42                                 parent.removeChild( e );\r
43                                 node.parentNode = null;\r
44                                 document.body.appendChild( node );\r
45                                 parent.replaceChild( document.createComment( '' ), node ); */\r
46                                 document.body.appendChild( node );\r
47                                 return;\r
48                                 if( parent.parentNode !== document.body ){\r
49                                         var clone = parent.cloneNode( true );\r
50                                         for( var i = 0, l = parent.childNodes.length; i < l; ++i ){\r
51                                                 if( parent.childNodes[ i ] !== node ){\r
52                                                         clone.removeChild( clone.childNodes[ i ] );\r
53                                                 };\r
54                                         };                                      \r
55                                         //parent.parentNode.insertBefore( clone, parent );\r
56                                         //parent.parentNode.removeChild( parent );\r
57                                         parent.parentNode.insertBefore( clone, parent );\r
58                                         parent.style.display = 'none';\r
59                                         if( xnode ){\r
60                                                 xnode.parent.parent[ '_rawObject' ] = clone;\r
61                                         };\r
62                                 } else {\r
63                                         // ignore\r
64                                 };\r
65 \r
66                         };\r
67                         //if( !node.ownerDocument ) alert( 'no owner' );\r
68                 } else {\r
69                         //node.data = '';\r
70                 };\r
71         };\r
72         \r
73         X_TEMP._removalTextNodes = [];\r
74         \r
75         X_TEMP._timerRemove = function(){\r
76                 var nodes = X_TEMP._removalTextNodes,\r
77                         i = 0, node;\r
78                 while( i < 5 && nodes.length ){\r
79                         node = nodes.shift();\r
80                         if( node.parentNode ){\r
81                                 //node.parentNode.removeChild( node );\r
82                                 ++i;\r
83                         };\r
84                 };\r
85                 \r
86                 //nodes.length && X_Timer_once( 1000, X_TEMP._timerRemove );\r
87         };\r
88         \r
89 } else\r
90 if( X_UA[ 'Opera7' ] ){\r
91 \r
92         X_TEMP._fixed_remove = function( node ){\r
93                 if( node.nodeType === 1 || node.nodeType === 3 ){\r
94                         node.parentNode && node.parentNode.removeChild( node );\r
95                 //} else {\r
96                         //node.data = '';\r
97                 };\r
98         };\r
99 };\r
100 \r
101 /* --------------------------------------\r
102  *  通常のwebページに対して使用する場合、dom ready で dom tree を写し取るために使う.\r
103  *  完全にワンページアプリで<body/>が空な場合、このコードはビルドに含める必要はない\r
104  * \r
105  * TODO (注4) IE6 の空白に関する“癖”について\r
106  * http://kojs.sukobuto.com/docs/visible-binding\r
107  * IE6 には、「空の span エレメントに続く空白は無視される」という謎な癖があります。 \r
108  */\r
109 \r
110 X_TEMP._onPreInit =\r
111         X_UA_DOM.W3C ?\r
112 (function(){\r
113         var r    = X_Node_body,\r
114                 body = r[ '_rawObject' ],\r
115                 copy, i, l, node, html,\r
116                 elmProgress;\r
117         \r
118         if( !X_TEMP.X_Dom_useBuilder ) return;\r
119         \r
120         X_HTMLParser_skipFixNesting = true;\r
121         \r
122         // TODO\r
123         // textarea の内容を控えて、消す。xnode tree 構築後に復帰。でないと、html パースでこける\r
124         //X_UA[ 'MacIE' ] && alert( body.innerHTML );\r
125         // cleanup tree \r
126         function cleanUpTree( elm, skip, head ){\r
127                 var nodes      = X_Array_copy( elm.childNodes ),\r
128                         i          = 0,\r
129                         l          = nodes.length,\r
130                         node, tag, textNode, content;\r
131                 for( ; i < l; ++i ){\r
132                         node = nodes[ i ];\r
133                         switch( node.nodeType ){\r
134                                 case 1 :\r
135                                         tag = node.tagName.toUpperCase();\r
136                                         if( X_Dom_DTD_MOVE_TO_HEAD[ tag ] ){\r
137                                                 head = head || document.getElementsByTagName( 'head' )[ 0 ];\r
138                                                 head.appendChild( node );\r
139                                                 continue;\r
140                                         } else\r
141                                         if( X_TEMP._isCleanupTarget( node ) ){\r
142                                                 elm.removeChild( node );\r
143                                                 continue;\r
144                                         } else {\r
145                                                 // pre タグ以下はスペースの置換は行わない\r
146                                                 node.childNodes && node.childNodes.length && cleanUpTree( node, skip || X_Dom_DTD_SKIP_CLEANUP_TAGS[ tag ], head );\r
147                                         };\r
148                                         textNode = null;\r
149                                         break;\r
150                                 case 3 :\r
151                                         content = skip ? node.data : X_String_cleanupWhiteSpace( node.data );\r
152                                         //console.log( 'Delete space ' + node.data.length + ' => ' + content.length );                          \r
153                                         if( !textNode && content !== ' ' && content.length ){\r
154                                                 node.data = content;\r
155                                                 textNode  = node;\r
156                                                 break;\r
157                                         } else\r
158                                         if( textNode ){\r
159                                                 textNode.data += content; // 直前が TextNode の場合 一本化して削除\r
160                                         };\r
161                                         // ブロック要素直下のスペースだけは削除??\r
162                                 default :\r
163                                         //console.log( 'Remove type: ' + node.nodeType + ' value: ' + node.nodeValue );\r
164                                         if( !X_UA[ 'Opera7' ] /*&& !X_UA[ 'MacIE' ] */ ){\r
165                                                 elm.removeChild( node );\r
166                                         } else {\r
167                                                 X_TEMP._fixed_remove( node );\r
168                                         };\r
169                                         //++count;\r
170                         };\r
171                 };\r
172         };\r
173 \r
174         cleanUpTree( X_UA[ 'MacIE' ] ? ( copy = body.cloneNode( true ) ) : body );\r
175 \r
176         if( X_UA[ 'MacIE' ] ){\r
177                 document.write( html = copy.innerHTML );\r
178         } else {\r
179                 // body の属性値の取得\r
180                 if( X_UA[ 'IE' ] <= 8 ){\r
181                         html = body.innerHTML.split( X_String_CRLF ).join( '' ); // 不要な改行が入る\r
182                 } else {\r
183                         html = body.innerHTML;\r
184                 };\r
185                 \r
186                 // Nokia s60 Safari\r
187                 if( html === 'fastinnerhtml!' ){\r
188                         html = '';\r
189                         for( i = 0, l = body.childNodes.length; i < l; ++i ){\r
190                                 node = body.childNodes[ i ];\r
191                                 html += ( node.outerHTML || node.data );\r
192                         };\r
193                 };              \r
194         };\r
195         \r
196         body.appendChild( X_TEMP.elmProgress = elmProgress = document.createElement( 'div' ) );\r
197         elmProgress.style.cssText = 'position:absolute;top:0;left:0;z-index:9999;width:0;height:0.5em;background:#00f;overflow:hidden;';\r
198         elmProgress.setAttribute( 'style', 'position:absolute;top:0;left:0;z-index:9999;width:0;height:0.5em;background:#00f;overflow:hidden;' );\r
199         \r
200         X_TEMP._body = body;\r
201         \r
202         X_HTMLParser_asyncParse( html, true )\r
203                 [ 'listen' ]( X_EVENT_PROGRESS, X_TEMP._handleEvent )\r
204                 [ 'listenOnce' ]( X_EVENT_SUCCESS, X_TEMP._handleEvent );\r
205 \r
206 }) :\r
207 // X_UA_DOM.IE4 ?\r
208 (function(){\r
209         var r    = X_Node_body,\r
210                 body = r[ '_rawObject' ],\r
211                 elmProgress = '_xdom_builder_progress',\r
212                 html;\r
213 \r
214         if( !X_TEMP.X_Dom_useBuilder ) return;\r
215         \r
216         /*\r
217          * http://support.microsoft.com/kb/812417/ja\r
218          * PRB: outerHTML の HTML 要素のプロパティは、既定の属性は表示されません。\r
219          * \r
220          * body.innerHTML でなく、 body.outerHTML にはできなかった、、、\r
221          */\r
222         html = body.innerHTML;\r
223         body.insertAdjacentHTML( 'BeforeEnd', '<div id="' + elmProgress + '" style="position:absolute;top:0;left:0;z-index:9999;width:0;height:0.5em;background:#00f;overflow:hidden;"></div>' );\r
224         X_TEMP.elmProgress = document.all[ elmProgress ];\r
225         \r
226         X_TEMP._body = body;\r
227         \r
228         X_HTMLParser_asyncParse( html, true )\r
229                 [ 'listen' ]( X_EVENT_PROGRESS, X_TEMP._handleEvent )\r
230                 [ 'listenOnce' ]( X_EVENT_SUCCESS, X_TEMP._handleEvent );\r
231 });\r
232 \r
233 X_ViewPort[ 'listenOnce' ]( X_EVENT_PRE_INIT, X_TEMP._onPreInit );\r
234 \r
235 X_TEMP._handleEvent = function( e ){\r
236         var elmProgress = X_TEMP.elmProgress, xnodes;\r
237         \r
238         switch( e.type ){\r
239                 case X_EVENT_PROGRESS :\r
240                         elmProgress.style.width = ( e.percent * 100 | 0 ) + '%';\r
241                         break;\r
242                         \r
243                 case X_EVENT_SUCCESS :\r
244                         xnodes = X_Node_body[ '_xnodes' ] = [];\r
245                         \r
246                         xnodes.push.apply( xnodes, e.xnodes );\r
247                         elmProgress.style.width = '100%';\r
248                         \r
249                         X_TEMP.asyncCreateTree( X_Node_body, X_TEMP._body.childNodes || X_TEMP._body.children, elmProgress );\r
250                         \r
251                         delete X_TEMP._onPreInit;\r
252                         delete X_TEMP._body;\r
253                         delete X_TEMP.elmProgress;\r
254                         break;\r
255         };\r
256 };\r
257 \r
258 X_TEMP.asyncCreateTree = function( parent, elems, elmProgress, async ){\r
259         var xnodes      = async ? 0           : X_Array_copy( parent[ '_xnodes' ] ),\r
260                 l           = async ? 0           : xnodes.length,\r
261                 stack       = async ? async.stack : [],\r
262                 done        = async ? async.done  : 0,\r
263                 startTime   = X_Timer_now(),            \r
264                 current     = async ? async.current : {\r
265                         me     : parent,\r
266                         xnodes : xnodes,\r
267                         l      : l,\r
268                         i      : 0,\r
269                         elems  : X_Array_copy( elems ),\r
270                         j      : 0,\r
271                         xtext  : null,\r
272                         flag   : 0\r
273                 },\r
274                 xnode, i, dive;\r
275         //alert( 'X_TEMP.asyncCreateTree' );\r
276         while( current || ( current = stack.pop() ) ){\r
277                 i = current.i;\r
278                 l = current.l;\r
279                 if( i < l ){\r
280                         parent = current.me;\r
281                         xnodes = current.xnodes;\r
282                         while( xnode = xnodes[ i ] ){                   \r
283                                 //\r
284                                 dive = X_TEMP.bindElementToXnode( parent, xnode, current );\r
285                                 \r
286                                 ++i;\r
287                                 ++done;\r
288                                 if( dive ){\r
289                                         current.i = i;\r
290                                         stack[ stack.length ] = current;\r
291                                         \r
292                                         current = dive;\r
293                                         i       = 0;\r
294                                         l       = dive.l;\r
295                                         parent  = xnode;\r
296                                         xnodes  = dive.xnodes;\r
297                                         continue;\r
298                                 };\r
299                                 \r
300                                 if( startTime + 16 <= X_Timer_now() ){\r
301                                         current.i = i;\r
302                                         if( async ){\r
303                                                 async.current = i < l && current;\r
304                                                 async.done    = done;\r
305                                         };\r
306                                         //alert( 'koko?' );\r
307                                         X_Timer_once( 0, X_TEMP.asyncCreateTree, [ null, null, elmProgress, async || { stack : stack, current : i < l && current, done : done } ] );\r
308                                         // progress\r
309                                         elmProgress.style.width = ( ( 1 - done / X_Node_CHASHE.length ) * 100 | 0 ) + '%';\r
310                                         return;\r
311                                 };\r
312                         };                      \r
313                 };\r
314                 current = null;\r
315         };\r
316         // complete\r
317         console.log( 'xtree 作成完了' );\r
318         X_ViewPort[ 'asyncDispatch' ]( X_EVENT_XTREE_READY );\r
319         elmProgress.parentNode ? elmProgress.parentNode.removeChild( elmProgress ) : ( elmProgress.outerHTML = '' );\r
320         \r
321         delete X_TEMP.asyncCreateTree;\r
322         delete X_TEMP.bindElementToXnode;\r
323         delete X_TEMP.X_Dom_useBuilder;\r
324         delete X_TEMP._isCleanupTarget;\r
325         \r
326         X_HTMLParser_skipFixNesting = false;\r
327 };\r
328 \r
329 X_TEMP.bindElementToXnode =\r
330         X_UA_DOM.W3C ?\r
331                 (function( parent, xnode, current ){\r
332                         var elems = current.elems,\r
333                                 //j     = current.j,\r
334                                 m     = elems.length,\r
335                                 xtext = current.xtext,\r
336                                 skipCleanup = current.skipCleanup,\r
337                                 inPreTag    = current.inPreTag,\r
338                                 elm, tag, text;\r
339                 \r
340                         xnode.parent = parent;\r
341                 \r
342                         for( ; current.j < m; ++current.j ){\r
343                                 elm = elems[ current.j ];\r
344                                 tag = elm.tagName && elm.tagName.toUpperCase();\r
345                                 if( ( elm.nodeType !== 1 && elm.nodeType !== 3 ) || tag === '!' || ( tag && tag.charAt( 0 ) === '/' ) ){\r
346                                         if( !X_UA[ 'Opera7' ] && !X_UA[ 'MacIE' ] ){\r
347                                                 elm.parentNode.removeChild( elm );\r
348                                         } else {\r
349                                                 X_TEMP._fixed_remove( elm );\r
350                                         };\r
351                                         continue;\r
352                                 };\r
353                 \r
354                                 if( xnode[ '_tag' ] ){\r
355                                         if( elm.nodeType === 3 ){\r
356                                                 if( !( text = elm.data ) || ( text = X_String_cleanupWhiteSpace( text ) ) === ' ' ){\r
357                                                         //alert( text.charCodeAt( 0 ) );\r
358                                                         if( !X_UA[ 'Opera7' ] && !X_UA[ 'MacIE' ] ){\r
359                                                                 elm.parentNode.removeChild( elm );\r
360                                                         } else {\r
361                                                                 X_TEMP._fixed_remove( elm );\r
362                                                         };\r
363                                                         continue;\r
364                                                 };\r
365                                                 alert( '1:[' +parent[ '_tag' ] + '>' +xnode[ '_tag' ] + '] !== ' + elm.nodeType + '\n' + ( elm.data ) );\r
366                                         } else\r
367                                         if( X_Dom_DTD_MOVE_TO_HEAD[ tag ] ){\r
368                                                 alert( tag );\r
369                                                 continue;\r
370                                         } else\r
371                                         if( xnode[ '_tag' ] !== tag ){\r
372                                                 alert( '2:[' +parent[ '_tag' ] + '>' +xnode[ '_tag' ] + ' len:' + (xnode[ '_xnodes' ] ? xnode[ '_xnodes' ].length : '' ) + '] !== ' + tag + ' ' + (elm.childNodes ? elm.childNodes.length : '' ) + '\n' + elm.outerHTML );\r
373                                         } else {\r
374                                                 xnode[ '_rawObject' ] = elm;\r
375                                                 //if( ( doc = elm.ownerDocument || elm.document ) && ( doc.createElement( 'p' ).tagName === doc.createElement( 'P' ).tagName ) ){\r
376                                                         if( tag.charAt( 0 ) === '/' ) tag = tag.slice( 1 );\r
377                                                         xnode[ '_tag' ] = tag;\r
378                                                 //};\r
379                                                 xnode[ '_flags' ] |= X_NodeFlags_IN_TREE;\r
380                                                 xnode[ '_flags' ] &= X_Node_BitMask_RESET_DIRTY;\r
381                                                 elm[ 'UID' ]       = xnode[ '_uid' ];\r
382                                                 current.xtext = null;\r
383                                                 \r
384                                                 if( tag === 'TEXTAREA' ){\r
385                                                         xnode[ 'attr' ]( 'value', xnode[ 'html' ]() )[ 'empty' ]();\r
386                                                         \r
387                                                 } else\r
388                                                 if( elm.childNodes && elm.childNodes.length ){\r
389                                                         //alert( '[' +parent[ '_tag' ] + '>' + xnode[ '_tag' ] + ' ' + (xnode[ '_xnodes' ] ? xnode[ '_xnodes' ].length : '' ) + '] === ' + tag + ' ' + (elm.childNodes ? elm.childNodes.length : '' ) + ' Hit\n' + elm.outerHTML );\r
390                                                         //current.xtext = null;\r
391                                                         ++current.j;\r
392                                                         \r
393                                                         return {\r
394                                                                 me     : xnode,\r
395                                                                 xnodes : X_Array_copy( xnode[ '_xnodes' ] ),\r
396                                                                 xtext  : null,\r
397                                                                 flag   : 0,\r
398                                                                 i      : 0,\r
399                                                                 l      : xnode[ '_xnodes' ].length,\r
400                                                                 elems  : X_Array_copy( elm.childNodes ),\r
401                                                                 j      : 0,\r
402                                                                 skipCleanup : skipCleanup || X_Dom_DTD_SKIP_CLEANUP_TAGS[ tag ]\r
403                                                         };\r
404                                                 };\r
405                                                 // nochild\r
406                                                 //current.xtext = null;\r
407                                         };\r
408                                         ++current.j;\r
409                                         break;\r
410                                 };\r
411                                 \r
412                                 if( elm.nodeType !== 3 ){\r
413                                         if( !( text = xnode[ '_text' ] ) || ( text = X_String_cleanupWhiteSpace( text ) ) === ' ' ){\r
414                                                 console.log( '[' +parent[ '_tag' ] + '> UID:' + xnode[ '_uid' ] + ' len:' + xnode[ '_text' ].length + ' code : ' + xnode[ '_text' ].charCodeAt( 0 ) + ',' + xnode[ '_text' ].charCodeAt( 1 ) + '] destroyed.' );\r
415                                                 xnode[ 'kill' ]();\r
416                                                 break;\r
417                                         };\r
418                                         alert(  parent[ '_tag' ] + ' > ' + '"' + xnode[ '_text' ] + '" !== ' + tag + '\n' +\r
419                                                 'prev : ' + ( xnode[ 'prev' ]() && xnode[ 'prev' ]()[ 'html' ]() ) + '\n' +\r
420                                                 'next : ' + ( xnode[ 'next' ]() && xnode[ 'next' ]()[ 'html' ]() ) + '\n' +\r
421                                                 'html : ' + elm.outerHTML );\r
422                                         break;\r
423                                 };\r
424                                 \r
425                                 ++current.j;\r
426                                 xnode[ '_rawObject' ] = elm;\r
427                                 xnode[ '_flags' ]    |= X_NodeFlags_IN_TREE;\r
428                                 xnode[ '_flags' ]    &= X_Node_BitMask_RESET_DIRTY;\r
429                                 xnode[ '_text' ]      = elm.data; // 正確\r
430                                 \r
431                                 if( !skipCleanup ){\r
432                                         if( !( text = xnode[ '_text' ] ) || ( text = X_String_cleanupWhiteSpace( text ) ) === ' ' ){\r
433                                                 console.log( '[' +parent[ '_tag' ] + '>' + xnode[ '_uid' ] + '] destroy ... ' );\r
434                                                 xnode[ 'kill' ]();\r
435                                         };\r
436                                         if( xtext ){\r
437                                                 xtext[ 'text' ]( xtext[ '_text' ] + text );\r
438                                                 console.log( '[' +parent[ '_tag' ] + '>' + xnode[ '_uid' ] + '] xtext,destroy ... ' );\r
439                                                 xnode[ 'kill' ]();\r
440                                         } else {\r
441                                                 //alert( parent[ '_tag' ] + '>' + '"' + text + '"\n' + elm.data );\r
442                                                 xnode[ 'text' ]( text );\r
443                                         };\r
444                                 } else\r
445                                 if( xtext ){\r
446                                         xtext[ 'text' ]( xtext[ '_text' ] + xnode[ '_text' ] );\r
447                                         console.log( '[' +parent[ '_tag' ] + '>' + xnode[ '_uid' ] + '] xtext,destroy ... ' );\r
448                                         xnode[ 'kill' ]();\r
449                                 };\r
450                                 current.xtext = xtext || xnode;\r
451                                 break;\r
452                         };\r
453                 }) :\r
454                 (function ( parent, xnode, current ){\r
455                         var elems = current.elems,\r
456                                 j     = current.j,\r
457                                 m     = elems.length,\r
458                                 xtext = current.xtext,\r
459                                 skipCleanup = current.skipCleanup,\r
460                                 elm, tag, text;\r
461                 \r
462                         xnode.parent = parent;\r
463                         \r
464                         if( !xnode[ '_tag' ] ){\r
465                                 xnode[ '_flags' ] |= X_NodeFlags_IN_TREE;\r
466                                 xnode[ '_flags' ] &= X_Node_BitMask_RESET_DIRTY;\r
467                                 //alert( X_String_cleanupWhiteSpace( xnode[ '_text' ] ) );\r
468                                 if( !skipCleanup ){\r
469                                         if( !( text = xnode[ '_text' ] ) || ( text = X_String_cleanupWhiteSpace( text ) ) === ' ' ){\r
470                                                 xnode[ 'kill' ]();\r
471                                                 xnode = null;\r
472                                         } else\r
473                                         if( xtext ){\r
474                                                 //alert( 'xtext ' + text.charCodeAt( 0 ) + ' : ' + text.length );\r
475                                                 xtext[ 'text' ]( xtext[ '_text' ] + text );\r
476                                                 xnode[ 'kill' ]();\r
477                                         } else {\r
478                                                 //alert( 'xnode ' + text.charCodeAt( 0 ) + ' : ' + text.length );\r
479                                                 xnode[ 'text' ]( text );\r
480                                         };\r
481                                 } else {\r
482                                         if( xtext ){\r
483                                                 //alert( 'skip ' + text.charCodeAt( 0 ) + ' : ' + text.length );\r
484                                                 xtext[ 'text' ]( xtext[ '_text' ] + xnode[ '_text' ] );\r
485                                                 xnode[ 'kill' ]();\r
486                                         };\r
487                                 };\r
488                                 current.xtext = xtext || xnode;\r
489                                 parent[ '_flags' ] |= X_NodeFlags_IE4_HAS_TEXTNODE;\r
490                                 return;\r
491                         };\r
492                         \r
493                         for( ; j < m; ++j, ++current.j ){\r
494                                 elm = elems[ j ];\r
495                                 tag = elm.tagName;\r
496                                 /*\r
497                                  * 未知のタグについては、閉じタグも含めてタグ名扱いになる\r
498                                  */\r
499                                 if( tag === '!' || tag.charAt( 0 ) === '/' ){\r
500                                         //alert( '## ' + tag );\r
501                                         continue;\r
502                                 } else\r
503                                 if( xnode[ '_tag' ] !== tag ){\r
504                                         alert( xnode[ '_tag' ] + ' ' + ' !== ' + tag + '\nxnode.html():' + xnode.attr('cite') + '\nelm.outerHTML:' +  elm.outerHTML );\r
505                                 } else {\r
506                                         ++current.j;\r
507                                         \r
508                                         xnode[ '_rawObject' ] = elm;\r
509                                         xnode[ '_flags' ]    |= X_NodeFlags_IN_TREE;\r
510                                         xnode[ '_flags' ]    &= X_Node_BitMask_RESET_DIRTY;\r
511                                         //xnode[ '_tag' ]     = X_Dom_DTD_TAG_FIX[ tag ] || tag;\r
512                                         if( X_TEMP._isCleanupTarget( elm ) ){ //!xnode[ 'hasClass' ]( 'skip-cleanup' ) && ( X_Dom_DTD_CLEANUP_TAGS[ tag ] || xnode[ 'hasClass' ]( 'cleanup-target' ) ) ){\r
513                                                 xnode[ 'kill' ]();\r
514                                                 break;\r
515                                         };\r
516                                         \r
517                                         !xnode[ '_id' ] && elm.setAttribute( 'id', 'ie4uid' + xnode[ '_uid' ] );\r
518                                         elm.setAttribute( 'UID', xnode[ '_uid' ] );\r
519                                         \r
520                                         tag === 'INPUT' && (\r
521                                                 !xnode[ '_attrs' ] ?\r
522                                                         ( xnode[ '_attrs' ] = { type : 'text' } ) :\r
523                                                         xnode[ '_attrs' ].type || ( xnode[ '_attrs' ].type = 'text' )\r
524                                         );\r
525                                         parent[ '_flags' ] |= X_NodeFlags_IE4_HAS_ELEMENT;\r
526                                         current.xtext = null;\r
527                                         \r
528                                         if( tag === 'TEXTAREA' ){\r
529                                                 xnode[ 'attr' ]( 'value', xnode[ 'html' ]() )[ 'empty' ]();\r
530                                         } else\r
531                                         if( xnode[ '_xnodes' ] && xnode[ '_xnodes' ].length ){\r
532                                                 return {\r
533                                                         me     : xnode,\r
534                                                         xnodes : X_Array_copy( xnode[ '_xnodes' ] ),\r
535                                                         xtext  : null,\r
536                                                         flag   : 0,\r
537                                                         i      : 0,\r
538                                                         l      : xnode[ '_xnodes' ].length,\r
539                                                         elems  : X_Array_copy( elm.children ),\r
540                                                         j      : 0,\r
541                                                         skipCleanup : skipCleanup || X_Dom_DTD_SKIP_CLEANUP_TAGS[ tag ]\r
542                                                 };\r
543                                         };\r
544                                         break;\r
545                                 };\r
546                         };\r
547                         // for\r
548                         if( !xnode[ '_rawObject' ] ){\r
549                                 alert( xnode[ '_tag' ] + ' ' + xnode[ '_id' ] + ' !== none...' );\r
550                         };\r
551                 });\r
552 \r
553 console.log( 'X.Dom.Builder' );\r
554 console.log( 'bootTime : ' + ( X_Timer_now() - X.bootTime ) );