If I am right, with this implementation, with "a, b, c" the results will be sorted twice. If so, would it be enough to replace line 115 with this one?
if ( sortOrder && !arguments[2] ) { Maybe it looks dirty... but anyway sorting is not an cheap operation... On Feb 14, 6:14 pm, John Resig <jere...@gmail.com> wrote: > So I'm looking at your code - it looks pretty good - but it can enjoy > from a huge optimization. The precedes method has 3 possible states. > > sourceIndex: Available in IE > compareDocumentPosition: Available in Firefox, Opera, and WebKit Nightlies > other: Safari/Chrome > > Now the "problem" is the other "other" slot - but currently the only > browsers that fall in to that slot (Safari and Chrome) ALSO support > querySelectorAll -- so we never end up needing the sorting code to > begin with (since that's handled by querySelectorAll exclusively). > > I did some work and landed a solution that takes care of both document > order and > uniqueness:http://github.com/jeresig/sizzle/commit/1702e1edb79c4c210b468c0eacc10...http://github.com/jeresig/sizzle/commit/99871e8c97e2cb6b619572be7f607... > > Works well in all browsers. I tossed a copy of the test suite online > here:http://ejohn.org/apps/sizzle/test/ > > --John > > On Fri, Feb 13, 2009 at 6:26 PM, Robert Katić <robert.ka...@gmail.com> wrote: > > > The querySelectorAll returns elements in documents order, but Sizzle > > (for now?) treat each selector separately. > > > Maybe this can be easily resolved joining each result array in one > > with nodes in documents order? > > If so, maybe something like this would help (not tested). Or you are > > thinking to sort results all together? > > > var precedes = ( document.documentElement.sourceIndex == 0 ) && > > function( a, b ) { > > return a.sourceIndex < b.sourceIndex; > > } > > || ( document.documentElement.compareDocumentPosition ) && > > function( a, b ) { > > return !!( a.compareDocumentPosition(b) & 4 ); > > } > > || function( a, b ) { > > if ( a === b || b.contains(a) ) > > return false > > > if ( a.contains(b) ) > > return true; > > > var c = a.parentNode; > > while ( !c.contains(b) ) { > > a = c; > > c = c.parentNode; > > } > > > var p = b.parentNode; > > while ( p !== c ) { > > b = p; > > p = p.parentNode; > > } > > > var nodes = c.childNodes; > > for ( var i = 0, node = nodes[0]; node; node = nodes[+ > > +i] ) { > > if ( node === a ) > > return true; > > if ( node === b ) > > return false; > > } > > > return false; > > }; > > > function joinResultsHelper( res, a, i, b, j ) { > > if ( b[j] ) { > > for ( var l = a.length; i < l; ++i ) { > > if ( a[i] === b[j] ) > > ++j; > > > else if ( precedes(a[i], b[j]) ) > > res.push( a[i] ); > > > else { > > res.push( b[j++] ); > > joinResultsHelper( res, b, j, a, i ); > > break; > > } > > } > > } else { > > for ( var l = a.length; i < l; ++i ) > > res.push( a[i] ); > > } > > > return res; > > } > > > function joinResults( a, b ) { > > if ( a.length === 0 ) > > return b; > > > if ( b.length === 0 ) > > return a; > > > return joinResultsHelper( [], a, 0, b, 0 ); > > } > > --~--~---------~--~----~------------~-------~--~----~ You received this message because you are subscribed to the Google Groups "jQuery Development" group. To post to this group, send email to jquery-dev@googlegroups.com To unsubscribe from this group, send email to jquery-dev+unsubscr...@googlegroups.com For more options, visit this group at http://groups.google.com/group/jquery-dev?hl=en -~----------~----~----~----~------~----~------~--~---