git.asbjorn.biz
/
jquery.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Reverting accidental test suite corruption from the Sizzle merge.
[jquery.git]
/
src
/
selector.js
diff --git
a/src/selector.js
b/src/selector.js
index
517ea60
..
96e339d
100644
(file)
--- a/
src/selector.js
+++ b/
src/selector.js
@@
-8,7
+8,8
@@
var chunker = /((?:\((?:\([^()]+\)|[^()]+)+\)|\[(?:\[[^[\]]*\]|['"][^'"]*['"]|[^[\]'"]+)+\]|\\.|[^ >+~,(\[\\]+)+|[>+~])(\s*,\s*)?/g,
done = 0,
var chunker = /((?:\((?:\([^()]+\)|[^()]+)+\)|\[(?:\[[^[\]]*\]|['"][^'"]*['"]|[^[\]'"]+)+\]|\\.|[^ >+~,(\[\\]+)+|[>+~])(\s*,\s*)?/g,
done = 0,
- toString = Object.prototype.toString;
+ toString = Object.prototype.toString,
+ hasDuplicate = false;
var Sizzle = function(selector, context, results, seed) {
results = results || [];
var Sizzle = function(selector, context, results, seed) {
results = results || [];
@@
-550,7
+551,7
@@
var Expr = Sizzle.selectors = {
} else if ( name === "not" ) {
var not = match[3];
} else if ( name === "not" ) {
var not = match[3];
- for ( var i = 0, l = not.length; i < l; i++ ) {
+ for ( i = 0, l = not.length; i < l; i++ ) {
if ( not[i] === elem ) {
return false;
}
if ( not[i] === elem ) {
return false;
}
@@
-564,13
+565,13
@@
var Expr = Sizzle.selectors = {
switch (type) {
case 'only':
case 'first':
switch (type) {
case 'only':
case 'first':
- while (node = node.previousSibling) {
+ while ( (node = node.previousSibling) ) {
if ( node.nodeType === 1 ) return false;
}
if ( type == 'first') return true;
node = elem;
case 'last':
if ( node.nodeType === 1 ) return false;
}
if ( type == 'first') return true;
node = elem;
case 'last':
- while (node = node.nextSibling) {
+ while ( (node = node.nextSibling) ) {
if ( node.nodeType === 1 ) return false;
}
return true;
if ( node.nodeType === 1 ) return false;
}
return true;
@@
-760,6
+761,7
@@
if ( document.documentElement.compareDocumentPosition ) {
}
root.removeChild( form );
}
root.removeChild( form );
+ root = form = null; // release memory in IE
})();
(function(){
})();
(function(){
@@
-800,6
+802,8
@@
if ( document.documentElement.compareDocumentPosition ) {
return elem.getAttribute("href", 2);
};
}
return elem.getAttribute("href", 2);
};
}
+
+ div = null; // release memory in IE
})();
if ( document.querySelectorAll ) (function(){
})();
if ( document.querySelectorAll ) (function(){
@@
-829,6
+833,8
@@
if ( document.querySelectorAll ) (function(){
for ( var prop in oldSizzle ) {
Sizzle[ prop ] = oldSizzle[ prop ];
}
for ( var prop in oldSizzle ) {
Sizzle[ prop ] = oldSizzle[ prop ];
}
+
+ div = null; // release memory in IE
})();
if ( document.getElementsByClassName && document.documentElement.getElementsByClassName ) (function(){
})();
if ( document.getElementsByClassName && document.documentElement.getElementsByClassName ) (function(){
@@
-851,6
+857,8
@@
if ( document.getElementsByClassName && document.documentElement.getElementsByCl
return context.getElementsByClassName(match[1]);
}
};
return context.getElementsByClassName(match[1]);
}
};
+
+ div = null; // release memory in IE
})();
function dirNodeCheck( dir, cur, doneName, checkSet, nodeCheck, isXML ) {
})();
function dirNodeCheck( dir, cur, doneName, checkSet, nodeCheck, isXML ) {
@@
-969,11
+977,21
@@
jQuery.expr = Sizzle.selectors;
jQuery.expr[":"] = jQuery.expr.filters;
Sizzle.selectors.filters.hidden = function(elem){
jQuery.expr[":"] = jQuery.expr.filters;
Sizzle.selectors.filters.hidden = function(elem){
- return elem.offsetWidth === 0 && elem.offsetHeight === 0;
+ var width = elem.offsetWidth, height = elem.offsetHeight;
+ return ( width === 0 && height === 0 ) ?
+ true :
+ ( width !== 0 && height !== 0 ) ?
+ false :
+ !!( jQuery.curCSS(elem, "display") === "none" );
};
Sizzle.selectors.filters.visible = function(elem){
};
Sizzle.selectors.filters.visible = function(elem){
- return elem.offsetWidth > 0 || elem.offsetHeight > 0;
+ var width = elem.offsetWidth, height = elem.offsetHeight;
+ return ( width === 0 && height === 0 ) ?
+ false :
+ ( width > 0 && height > 0 ) ?
+ true :
+ !!( jQuery.curCSS(elem, "display") !== "none" );
};
Sizzle.selectors.filters.animated = function(elem){
};
Sizzle.selectors.filters.animated = function(elem){