Вход Регистрация
Файл: Main Website Files/assets/bower_components/jquery/src/sizzle/dist/sizzle.js
Строк: 2468
<?php
/*!
 * Sizzle CSS Selector Engine v2.2.0-pre
 * http://sizzlejs.com/
 *
 * Copyright 2008, 2014 jQuery Foundation, Inc. and other contributors
 * Released under the MIT license
 * http://jquery.org/license
 *
 * Date: 2014-12-16
 */
(function( window ) {

var 
i,
    
support,
    
Expr,
    
getText,
    
isXML,
    
tokenize,
    
compile,
    
select,
    
outermostContext,
    
sortInput,
    
hasDuplicate,

    
// Local document vars
    
setDocument,
    
document,
    
docElem,
    
documentIsHTML,
    
rbuggyQSA,
    
rbuggyMatches,
    
matches,
    
contains,

    
// Instance-specific data
    
expando "sizzle" * new Date(),
    
preferredDoc window.document,
    
dirruns 0,
    
done 0,
    
classCache createCache(),
    
tokenCache createCache(),
    
compilerCache createCache(),
    
sortOrder = function( a) {
        if ( 
=== ) {
            
hasDuplicate true;
        }
        return 
0;
    },

    
// General-purpose constants
    
MAX_NEGATIVE << 31,

    
// Instance methods
    
hasOwn = ({}).hasOwnProperty,
    
arr = [],
    
pop arr.pop,
    
push_native arr.push,
    
push arr.push,
    
slice arr.slice,
    
// Use a stripped-down indexOf as it's faster than native
    // http://jsperf.com/thor-indexof-vs-for/5
    
indexOf = function( list, elem ) {
        var 
0,
            
len = list.length;
        for ( ; 
leni++ ) {
            if ( list[
i] === elem ) {
                return 
i;
            }
        }
        return -
1;
    },

    
booleans "checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",

    
// Regular expressions

    // Whitespace characters http://www.w3.org/TR/css3-selectors/#whitespace
    
whitespace "[\x20\t\r\n\f]",
    
// http://www.w3.org/TR/css3-syntax/#characters
    
characterEncoding "(?:\\.|[\w-]|[^\x00-\xa0])+",

    
// Loosely modeled on CSS identifier characters
    // An unquoted value should be a CSS identifier http://www.w3.org/TR/css3-selectors/#attribute-selectors
    // Proper syntax: http://www.w3.org/TR/CSS21/syndata.html#value-def-identifier
    
identifier characterEncoding.replace"w""w#" ),

    
// Attribute selectors: http://www.w3.org/TR/selectors/#attribute-selectors
    
attributes "\[" whitespace "*(" characterEncoding ")(?:" whitespace +
        
// Operator (capture 2)
        
"*([*^$|!~]?=)" whitespace +
        
// "Attribute values must be CSS identifiers [capture 5] or strings [capture 3 or capture 4]"
        
"*(?:'((?:\\.|[^\\'])*)'|"((?:\\.|[^\\"])*)"|(" + identifier + "))|)" + whitespace +
        "
*\]",

    pseudos = "
:(" + characterEncoding + ")(?:\((" +
        // To reduce the number of selectors needing tokenize in the preFilter, prefer arguments:
        // 1. quoted (capture 3; capture 4 or capture 5)
        "
('((?:\\.|[^\\'])*)'|"((?:\\.|[^\\"])*)")|" +
        // 2. simple (capture 6)
        "((?:\\.|[^\\()[\]]|" + attributes + ")*)|" +
        // 3. anything else (capture 2)
        ".*" +
        ")\)|)",

    // Leading and non-escaped trailing whitespace, capturing some non-whitespace characters preceding the latter
    rwhitespace = new RegExp( whitespace + "+", "g" ),
    rtrim = new RegExp( "^" + whitespace + "+|((?:^|[^\\])(?:\\.)*)" + whitespace + "+$", "g" ),

    rcomma = new RegExp( "^" + whitespace + "*," + whitespace + "*" ),
    rcombinators = new RegExp( "^" + whitespace + "*([>+~]|" + whitespace + ")" + whitespace + "*" ),

    rattributeQuotes = new RegExp( "=" + whitespace + "*([^\]'"]*?)" 
whitespace "*\]""g" ),

    
rpseudo = new RegExppseudos ),
    
ridentifier = new RegExp"^" identifier "$" ),

    
matchExpr = {
        
"ID": new RegExp"^#(" characterEncoding ")" ),
        
"CLASS": new RegExp"^\.(" characterEncoding ")" ),
        
"TAG": new RegExp"^(" characterEncoding.replace"w""w*" ) + ")" ),
        
"ATTR": new RegExp"^" attributes ),
        
"PSEUDO": new RegExp"^" pseudos ),
        
"CHILD": new RegExp"^:(only|first|last|nth|nth-last)-(child|of-type)(?:\(" whitespace +
            
"*(even|odd|(([+-]|)(\d*)n|)" whitespace "*(?:([+-]|)" whitespace +
            
"*(\d+)|))" whitespace "*\)|)""i" ),
        
"bool": new RegExp"^(?:" booleans ")$""i" ),
        
// For use in libraries implementing .is()
        // We use this for POS matching in `select`
        
"needsContext": new RegExp"^" whitespace "*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\(" +
            
whitespace "*((?:-\d)?\d*)" whitespace "*\)|)(?=[^-]|$)""i" )
    },

    
rinputs = /^(?:input|select|textarea|button)$/i,
    
rheader = /^hd$/i,

    
rnative = /^[^{]+{s*[native w/,

    
// Easily-parseable/retrievable ID or TAG or CLASS selectors
    
rquickExpr = /^(?:#([w-]+)|(w+)|.([w-]+))$/,

    
rsibling = /[+~]/,
    
rescape = /'|\/g,

    // CSS escapes http://www.w3.org/TR/CSS21/syndata.html#escaped-characters
    runescape = new RegExp( "\\([\da-f]{1,6}" + whitespace + "?|(" + whitespace + ")|.)", "ig" ),
    funescape = function( _, escaped, escapedWhitespace ) {
        var high = "0x" + escaped - 0x10000;
        // NaN means non-codepoint
        // Support: Firefox<24
        // Workaround erroneous numeric interpretation of +"0x"
        return high !== high || escapedWhitespace ?
            escaped :
            high < 0 ?
                // BMP codepoint
                String.fromCharCode( high + 0x10000 ) :
                // Supplemental Plane codepoint (surrogate pair)
                String.fromCharCode( high >> 10 | 0xD800, high & 0x3FF | 0xDC00 );
    },

    // Used for iframes
    // See setDocument()
    // Removing the function wrapper causes a "Permission Denied"
    // error in IE
    unloadHandler = function() {
        setDocument();
    };

// Optimize for push.apply( _, NodeList )
try {
    push.apply(
        (arr = slice.call( preferredDoc.childNodes )),
        preferredDoc.childNodes
    );
    // Support: Android<4.0
    // Detect silently failing push.apply
    arr[ preferredDoc.childNodes.length ].nodeType;
} catch ( e ) {
    push = { apply: arr.length ?

        // Leverage slice if possible
        function( target, els ) {
            push_native.apply( target, slice.call(els) );
        } :

        // Support: IE<9
        // Otherwise append directly
        function( target, els ) {
            var j = target.length,
                i = 0;
            // Can'
t trust NodeList.length
            
while ( (target[j++] = els[i++]) ) {}
            
target.length 1;
        }
    };
}

function 
Sizzleselectorcontextresultsseed ) {
    var 
matchelemmnodeType,
        
// QSA vars
        
igroupsoldnidnewContextnewSelector;

    if ( ( 
context context.ownerDocument || context preferredDoc ) !== document ) {
        
setDocumentcontext );
    }

    
context context || document;
    
results results || [];
    
nodeType context.nodeType;

    if ( 
typeof selector !== "string" || !selector ||
        
nodeType !== && nodeType !== && nodeType !== 11 ) {

        return 
results;
    }

    if ( !
seed && documentIsHTML ) {

        
// Try to shortcut find operations when possible (e.g., not under DocumentFragment)
        
if ( nodeType !== 11 && (match rquickExpr.execselector )) ) {
            
// Speed-up: Sizzle("#ID")
            
if ( (match[1]) ) {
                if ( 
nodeType === ) {
                    
elem context.getElementById);
                    
// Check parentNode to catch when Blackberry 4.6 returns
                    // nodes that are no longer in the document (jQuery #6963)
                    
if ( elem && elem.parentNode ) {
                        
// Handle the case where IE, Opera, and Webkit return items
                        // by name instead of ID
                        
if ( elem.id === ) {
                            
results.pushelem );
                            return 
results;
                        }
                    } else {
                        return 
results;
                    }
                } else {
                    
// Context is not a document
                    
if ( context.ownerDocument && (elem context.ownerDocument.getElementById)) &&
                        
containscontextelem ) && elem.id === ) {
                        
results.pushelem );
                        return 
results;
                    }
                }

            
// Speed-up: Sizzle("TAG")
            
} else if ( match[2] ) {
                
push.applyresultscontext.getElementsByTagNameselector ) );
                return 
results;

            
// Speed-up: Sizzle(".CLASS")
            
} else if ( (match[3]) && support.getElementsByClassName ) {
                
push.applyresultscontext.getElementsByClassName) );
                return 
results;
            }
        }

        
// QSA path
        
if ( support.qsa && (!rbuggyQSA || !rbuggyQSA.testselector )) ) {
            
nid old expando;
            
newContext context;
            
newSelector nodeType !== && selector;

            
// qSA works strangely on Element-rooted queries
            // We can work around this by specifying an extra ID on the root
            // and working up from there (Thanks to Andrew Dupont for the technique)
            // IE 8 doesn't work on object elements
            
if ( nodeType === && context.nodeName.toLowerCase() !== "object" ) {
                
groups tokenizeselector );

                if ( (
old context.getAttribute("id")) ) {
                    
nid old.replacerescape"\$&" );
                } else {
                    
context.setAttribute"id"nid );
                }
                
nid "[id='" nid "'] ";

                
groups.length;
                while ( 
i-- ) {
                    
groups[i] = nid toSelectorgroups[i] );
                }
                
newContext rsibling.testselector ) && testContextcontext.parentNode ) || context;
                
newSelector groups.join(",");
            }

            if ( 
newSelector ) {
                try {
                    
push.applyresults,
                        
newContext.querySelectorAllnewSelector )
                    );
                    return 
results;
                } catch(
qsaError) {
                } finally {
                    if ( !
old ) {
                        
context.removeAttribute("id");
                    }
                }
            }
        }
    }

    
// All others
    
return selectselector.replacertrim"$1" ), contextresultsseed );
}

/**
 * Create key-value caches of limited size
 * @returns {Function(string, Object)} Returns the Object data after storing it on itself with
 *    property name the (space-suffixed) string and (if the cache is larger than Expr.cacheLength)
 *    deleting the oldest entry
 */
function createCache() {
    var 
keys = [];

    function 
cachekeyvalue ) {
        
// Use (key + " ") to avoid collision with native prototype properties (see Issue #157)
        
if ( keys.pushkey " " ) > Expr.cacheLength ) {
            
// Only keep the most recent entries
            
delete cachekeys.shift() ];
        }
        return (
cachekey " " ] = value);
    }
    return 
cache;
}

/**
 * Mark a function for special use by Sizzle
 * @param {Function} fn The function to mark
 */
function markFunction( fn ) {
    fn[ 
expando ] = true;
    return fn;
}

/**
 * Support testing using an element
 * @param {Function} fn Passed the created div and expects a boolean result
 */
function assert( fn ) {
    var 
div document.createElement("div");

    try {
        return !!fn( 
div );
    } catch (
e) {
        return 
false;
    } finally {
        
// Remove from its parent by default
        
if ( div.parentNode ) {
            
div.parentNode.removeChilddiv );
        }
        
// release memory in IE
        
div null;
    }
}

/**
 * Adds the same handler for all of the specified attrs
 * @param {String} attrs Pipe-separated list of attributes
 * @param {Function} handler The method that will be applied
 */
function addHandleattrshandler ) {
    var 
arr attrs.split("|"),
        
attrs.length;

    while ( 
i-- ) {
        
Expr.attrHandlearr[i] ] = handler;
    }
}

/**
 * Checks document order of two siblings
 * @param {Element} a
 * @param {Element} b
 * @returns {Number} Returns less than 0 if a precedes b, greater than 0 if a follows b
 */
function siblingChecka) {
    var 
cur && a,
        
diff cur && a.nodeType === && b.nodeType === &&
            ( ~
b.sourceIndex || MAX_NEGATIVE ) -
            ( ~
a.sourceIndex || MAX_NEGATIVE );

    
// Use IE sourceIndex if available on both nodes
    
if ( diff ) {
        return 
diff;
    }

    
// Check if b follows a
    
if ( cur ) {
        while ( (
cur cur.nextSibling) ) {
            if ( 
cur === ) {
                return -
1;
            }
        }
    }

    return 
: -1;
}

/**
 * Returns a function to use in pseudos for input types
 * @param {String} type
 */
function createInputPseudotype ) {
    return function( 
elem ) {
        var 
name elem.nodeName.toLowerCase();
        return 
name === "input" && elem.type === type;
    };
}

/**
 * Returns a function to use in pseudos for buttons
 * @param {String} type
 */
function createButtonPseudotype ) {
    return function( 
elem ) {
        var 
name elem.nodeName.toLowerCase();
        return (
name === "input" || name === "button") && elem.type === type;
    };
}

/**
 * Returns a function to use in pseudos for positionals
 * @param {Function} fn
 */
function createPositionalPseudo( fn ) {
    return 
markFunction(function( argument ) {
        
argument = +argument;
        return 
markFunction(function( seedmatches ) {
            var 
j,
                
matchIndexes = fn( [], seed.lengthargument ),
                
matchIndexes.length;

            
// Match elements found at the specified indexes
            
while ( i-- ) {
                if ( 
seed[ (matchIndexes[i]) ] ) {
                    
seed[j] = !(matches[j] = seed[j]);
                }
            }
        });
    });
}

/**
 * Checks a node for validity as a Sizzle context
 * @param {Element|Object=} context
 * @returns {Element|Object|Boolean} The input node if acceptable, otherwise a falsy value
 */
function testContextcontext ) {
    return 
context && typeof context.getElementsByTagName !== "undefined" && context;
}

// Expose support vars for convenience
support Sizzle.support = {};

/**
 * Detects XML nodes
 * @param {Element|Object} elem An element or a document
 * @returns {Boolean} True iff elem is a non-HTML XML node
 */
isXML Sizzle.isXML = function( elem ) {
    
// documentElement is verified for cases where it doesn't yet exist
    // (such as loading iframes in IE - #4833)
    
var documentElement elem && (elem.ownerDocument || elem).documentElement;
    return 
documentElement documentElement.nodeName !== "HTML" false;
};

/**
 * Sets document-related variables once based on the current document
 * @param {Element|Object} [doc] An element or document object to use to set the document
 * @returns {Object} Returns the current document
 */
setDocument Sizzle.setDocument = function( node ) {
    var 
hasCompareparent,
        
doc node node.ownerDocument || node preferredDoc;

    
// If no document and documentElement is available, return
    
if ( doc === document || doc.nodeType !== || !doc.documentElement ) {
        return 
document;
    }

    
// Set our document
    
document doc;
    
docElem doc.documentElement;
    
parent doc.defaultView;

    
// Support: IE>8
    // If iframe document is assigned to "document" variable and if iframe has been reloaded,
    // IE will throw "permission denied" error when accessing "document" variable, see jQuery #13936
    // IE6-8 do not support the defaultView property so parent will be undefined
    
if ( parent && parent !== parent.top ) {
        
// IE11 does not have attachEvent, so all must suffer
        
if ( parent.addEventListener ) {
            
parent.addEventListener"unload"unloadHandlerfalse );
        } else if ( 
parent.attachEvent ) {
            
parent.attachEvent"onunload"unloadHandler );
        }
    }

    
/* Support tests
    ---------------------------------------------------------------------- */
    
documentIsHTML = !isXMLdoc );

    
/* Attributes
    ---------------------------------------------------------------------- */

    // Support: IE<8
    // Verify that getAttribute really returns attributes and not properties
    // (excepting IE8 booleans)
    
support.attributes assert(function( div ) {
        
div.className "i";
        return !
div.getAttribute("className");
    });

    
/* getElement(s)By*
    ---------------------------------------------------------------------- */

    // Check if getElementsByTagName("*") returns only elements
    
support.getElementsByTagName assert(function( div ) {
        
div.appendChilddoc.createComment("") );
        return !
div.getElementsByTagName("*").length;
    });

    
// Support: IE<9
    
support.getElementsByClassName rnative.testdoc.getElementsByClassName );

    
// Support: IE<10
    // Check if getElementById returns elements by name
    // The broken getElementById methods don't pick up programatically-set names,
    // so use a roundabout getElementsByName test
    
support.getById assert(function( div ) {
        
docElem.appendChilddiv ).id expando;
        return !
doc.getElementsByName || !doc.getElementsByNameexpando ).length;
    });

    
// ID find and filter
    
if ( support.getById ) {
        
Expr.find["ID"] = function( idcontext ) {
            if ( 
typeof context.getElementById !== "undefined" && documentIsHTML ) {
                var 
context.getElementByIdid );
                
// Check parentNode to catch when Blackberry 4.6 returns
                // nodes that are no longer in the document #6963
                
return && m.parentNode ? [ ] : [];
            }
        };
        
Expr.filter["ID"] = function( id ) {
            var 
attrId id.replacerunescapefunescape );
            return function( 
elem ) {
                return 
elem.getAttribute("id") === attrId;
            };
        };
    } else {
        
// Support: IE6/7
        // getElementById is not reliable as a find shortcut
        
delete Expr.find["ID"];

        
Expr.filter["ID"] =  function( id ) {
            var 
attrId id.replacerunescapefunescape );
            return function( 
elem ) {
                var 
node typeof elem.getAttributeNode !== "undefined" && elem.getAttributeNode("id");
                return 
node && node.value === attrId;
            };
        };
    }

    
// Tag
    
Expr.find["TAG"] = support.getElementsByTagName ?
        function( 
tagcontext ) {
            if ( 
typeof context.getElementsByTagName !== "undefined" ) {
                return 
context.getElementsByTagNametag );

            
// DocumentFragment nodes don't have gEBTN
            
} else if ( support.qsa ) {
                return 
context.querySelectorAlltag );
            }
        } :

        function( 
tagcontext ) {
            var 
elem,
                
tmp = [],
                
0,
                
// By happy coincidence, a (broken) gEBTN appears on DocumentFragment nodes too
                
results context.getElementsByTagNametag );

            
// Filter out possible comments
            
if ( tag === "*" ) {
                while ( (
elem results[i++]) ) {
                    if ( 
elem.nodeType === ) {
                        
tmp.pushelem );
                    }
                }

                return 
tmp;
            }
            return 
results;
        };

    
// Class
    
Expr.find["CLASS"] = support.getElementsByClassName && function( classNamecontext ) {
        if ( 
documentIsHTML ) {
            return 
context.getElementsByClassNameclassName );
        }
    };

    
/* QSA/matchesSelector
    ---------------------------------------------------------------------- */

    // QSA and matchesSelector support

    // matchesSelector(:active) reports false when true (IE9/Opera 11.5)
    
rbuggyMatches = [];

    
// qSa(:focus) reports false when true (Chrome 21)
    // We allow this because of a bug in IE8/9 that throws an error
    // whenever `document.activeElement` is accessed on an iframe
    // So, we allow :focus to pass through QSA all the time to avoid the IE error
    // See http://bugs.jquery.com/ticket/13378
    
rbuggyQSA = [];

    if ( (
support.qsa rnative.testdoc.querySelectorAll )) ) {
        
// Build QSA regex
        // Regex strategy adopted from Diego Perini
        
assert(function( div ) {
            
// Select is set to empty string on purpose
            // This is to test IE's treatment of not explicitly
            // setting a boolean content attribute,
            // since its presence should be enough
            // http://bugs.jquery.com/ticket/12359
            
docElem.appendChilddiv ).innerHTML "<a id='" expando "'></a>" +
                
"<select id='" expando "-f]' msallowcapture=''>" +
                
"<option selected=''></option></select>";

            
// Support: IE8, Opera 11-12.16
            // Nothing should be selected when empty strings follow ^= or $= or *=
            // The test attribute must be unknown in Opera but "safe" for WinRT
            // http://msdn.microsoft.com/en-us/library/ie/hh465388.aspx#attribute_section
            
if ( div.querySelectorAll("[msallowcapture^='']").length ) {
                
rbuggyQSA.push"[*^$]=" whitespace "*(?:''|"")" );
            }

            
// Support: IE8
            // Boolean attributes and "value" are not treated correctly
            
if ( !div.querySelectorAll("[selected]").length ) {
                
rbuggyQSA.push"\[" whitespace "*(?:value|" booleans ")" );
            }

            
// Support: Chrome<29, Android<4.2+, Safari<7.0+, iOS<7.0+, PhantomJS<1.9.7+
            
if ( !div.querySelectorAll"[id~=" expando "-]" ).length ) {
                
rbuggyQSA.push("~=");
            }

            
// Webkit/Opera - :checked should return selected option elements
            // http://www.w3.org/TR/2011/REC-css3-selectors-20110929/#checked
            // IE8 throws error here and will not see later tests
            
if ( !div.querySelectorAll(":checked").length ) {
                
rbuggyQSA.push(":checked");
            }

            
// Support: Safari 8+, iOS 8+
            // https://bugs.webkit.org/show_bug.cgi?id=136851
            // In-page `selector#id sibing-combinator selector` fails
            
if ( !div.querySelectorAll"a#" expando "+*" ).length ) {
                
rbuggyQSA.push(".#.+[+~]");
            }
        });

        
assert(function( div ) {
            
// Support: Windows 8 Native Apps
            // The type and name attributes are restricted during .innerHTML assignment
            
var input doc.createElement("input");
            
input.setAttribute"type""hidden" );
            
div.appendChildinput ).setAttribute"name""D" );

            
// Support: IE8
            // Enforce case-sensitivity of name attribute
            
if ( div.querySelectorAll("[name=d]").length ) {
                
rbuggyQSA.push"name" whitespace "*[*^$|!~]?=" );
            }

            
// FF 3.5 - :enabled/:disabled and hidden elements (hidden elements are still enabled)
            // IE8 throws error here and will not see later tests
            
if ( !div.querySelectorAll(":enabled").length ) {
                
rbuggyQSA.push":enabled"":disabled" );
            }

            
// Opera 10-11 does not throw on post-comma invalid pseudos
            
div.querySelectorAll("*,:x");
            
rbuggyQSA.push(",.*:");
        });
    }

    if ( (
support.matchesSelector rnative.test( (matches docElem.matches ||
        
docElem.webkitMatchesSelector ||
        
docElem.mozMatchesSelector ||
        
docElem.oMatchesSelector ||
        
docElem.msMatchesSelector) )) ) {

        
assert(function( div ) {
            
// Check to see if it's possible to do matchesSelector
            // on a disconnected node (IE 9)
            
support.disconnectedMatch matches.calldiv"div" );

            
// This should fail with an exception
            // Gecko does not error, returns false instead
            
matches.calldiv"[s!='']:x" );
            
rbuggyMatches.push"!="pseudos );
        });
    }

    
rbuggyQSA rbuggyQSA.length && new RegExprbuggyQSA.join("|") );
    
rbuggyMatches rbuggyMatches.length && new RegExprbuggyMatches.join("|") );

    
/* Contains
    ---------------------------------------------------------------------- */
    
hasCompare rnative.testdocElem.compareDocumentPosition );

    
// Element contains another
    // Purposefully does not implement inclusive descendent
    // As in, an element does not contain itself
    
contains hasCompare || rnative.testdocElem.contains ) ?
        function( 
a) {
            var 
adown a.nodeType === a.documentElement a,
                
bup && b.parentNode;
            return 
=== bup || !!( bup && bup.nodeType === && (
                
adown.contains ?
                    
adown.containsbup ) :
                    
a.compareDocumentPosition && a.compareDocumentPositionbup ) & 16
            
));
        } :
        function( 
a) {
            if ( 
) {
                while ( (
b.parentNode) ) {
                    if ( 
=== ) {
                        return 
true;
                    }
                }
            }
            return 
false;
        };

    
/* Sorting
    ---------------------------------------------------------------------- */

    // Document order sorting
    
sortOrder hasCompare ?
    function( 
a) {

        
// Flag for duplicate removal
        
if ( === ) {
            
hasDuplicate true;
            return 
0;
        }

        
// Sort on method existence if only one input has compareDocumentPosition
        
var compare = !a.compareDocumentPosition - !b.compareDocumentPosition;
        if ( 
compare ) {
            return 
compare;
        }

        
// Calculate position if both inputs belong to the same document
        
compare = ( a.ownerDocument || ) === ( b.ownerDocument || ) ?
            
a.compareDocumentPosition) :

            
// Otherwise we know they are disconnected
            
1;

        
// Disconnected nodes
        
if ( compare ||
            (!
support.sortDetached && b.compareDocumentPosition) === compare) ) {

            
// Choose the first element that is related to our preferred document
            
if ( === doc || a.ownerDocument === preferredDoc && contains(preferredDoca) ) {
                return -
1;
            }
            if ( 
=== doc || b.ownerDocument === preferredDoc && contains(preferredDocb) ) {
                return 
1;
            }

            
// Maintain original order
            
return sortInput ?
                ( 
indexOfsortInput) - indexOfsortInput) ) :
                
0;
        }

        return 
compare ? -1;
    } :
    function( 
a) {
        
// Exit early if the nodes are identical
        
if ( === ) {
            
hasDuplicate true;
            return 
0;
        }

        var 
cur,
            
0,
            
aup a.parentNode,
            
bup b.parentNode,
            
ap = [ ],
            
bp = [ ];

        
// Parentless nodes are either documents or disconnected
        
if ( !aup || !bup ) {
            return 
=== doc ? -:
                
=== doc :
                
aup ? -:
                
bup :
                
sortInput ?
                ( 
indexOfsortInput) - indexOfsortInput) ) :
                
0;

        
// If the nodes are siblings, we can do a quick check
        
} else if ( aup === bup ) {
            return 
siblingChecka);
        }

        
// Otherwise we need full lists of their ancestors for comparison
        
cur a;
        while ( (
cur cur.parentNode) ) {
            
ap.unshiftcur );
        }
        
cur b;
        while ( (
cur cur.parentNode) ) {
            
bp.unshiftcur );
        }

        
// Walk down the tree looking for a discrepancy
        
while ( ap[i] === bp[i] ) {
            
i++;
        }

        return 
?
            
// Do a sibling check if the nodes have a common ancestor
            
siblingCheckap[i], bp[i] ) :

            
// Otherwise nodes in our document sort first
            
ap[i] === preferredDoc ? -:
            
bp[i] === preferredDoc :
            
0;
    };

    return 
doc;
};

Sizzle.matches = function( exprelements ) {
    return 
Sizzleexprnullnullelements );
};

Sizzle.matchesSelector = function( elemexpr ) {
    
// Set document vars if needed
    
if ( ( elem.ownerDocument || elem ) !== document ) {
        
setDocumentelem );
    }

    
// Make sure that attribute selectors are quoted
    
expr expr.replacerattributeQuotes"='$1']" );

    if ( 
support.matchesSelector && documentIsHTML &&
        ( !
rbuggyMatches || !rbuggyMatches.testexpr ) ) &&
        ( !
rbuggyQSA     || !rbuggyQSA.testexpr ) ) ) {

        try {
            var 
ret matches.callelemexpr );

            
// IE 9's matchesSelector returns false on disconnected nodes
            
if ( ret || support.disconnectedMatch ||
                    
// As well, disconnected nodes are said to be in a document
                    // fragment in IE 9
                    
elem.document && elem.document.nodeType !== 11 ) {
                return 
ret;
            }
        } catch (
e) {}
    }

    return 
Sizzleexprdocumentnull, [ elem ] ).length 0;
};

Sizzle.contains = function( contextelem ) {
    
// Set document vars if needed
    
if ( ( context.ownerDocument || context ) !== document ) {
        
setDocumentcontext );
    }
    return 
containscontextelem );
};

Sizzle.attr = function( elemname ) {
    
// Set document vars if needed
    
if ( ( elem.ownerDocument || elem ) !== document ) {
        
setDocumentelem );
    }

    var fn = 
Expr.attrHandlename.toLowerCase() ],
        
// Don't get fooled by Object.prototype properties (jQuery #13807)
        
val = fn && hasOwn.callExpr.attrHandlename.toLowerCase() ) ?
            fn( 
elemname, !documentIsHTML ) :
            
undefined;

    return 
val !== undefined ?
        
val :
        
support.attributes || !documentIsHTML ?
            
elem.getAttributename ) :
            (
val elem.getAttributeNode(name)) && val.specified ?
                
val.value :
                
null;
};

Sizzle.error = function( msg ) {
    throw new 
Error"Syntax error, unrecognized expression: " msg );
};

/**
 * Document sorting and removing duplicates
 * @param {ArrayLike} results
 */
Sizzle.uniqueSort = function( results ) {
    var 
elem,
        
duplicates = [],
        
0,
        
0;

    
// Unless we *know* we can detect duplicates, assume their presence
    
hasDuplicate = !support.detectDuplicates;
    
sortInput = !support.sortStable && results.slice);
    
results.sortsortOrder );

    if ( 
hasDuplicate ) {
        while ( (
elem results[i++]) ) {
            if ( 
elem === results] ) {
                
duplicates.push);
            }
        }
        while ( 
j-- ) {
            
results.spliceduplicates], );
        }
    }

    
// Clear input after sorting to release objects
    // See https://github.com/jquery/sizzle/pull/225
    
sortInput null;

    return 
results;
};

/**
 * Utility function for retrieving the text value of an array of DOM nodes
 * @param {Array|Element} elem
 */
getText Sizzle.getText = function( elem ) {
    var 
node,
        
ret "",
        
0,
        
nodeType elem.nodeType;

    if ( !
nodeType ) {
        
// If no nodeType, this is expected to be an array
        
while ( (node elem[i++]) ) {
            
// Do not traverse comment nodes
            
ret += getTextnode );
        }
    } else if ( 
nodeType === || nodeType === || nodeType === 11 ) {
        
// Use textContent for elements
        // innerText usage removed for consistency of new lines (jQuery #11153)
        
if ( typeof elem.textContent === "string" ) {
            return 
elem.textContent;
        } else {
            
// Traverse its children
            
for ( elem elem.firstChildelemelem elem.nextSibling ) {
                
ret += getTextelem );
            }
        }
    } else if ( 
nodeType === || nodeType === ) {
        return 
elem.nodeValue;
    }
    
// Do not include comment or processing instruction nodes

    
return ret;
};

Expr Sizzle.selectors = {

    
// Can be adjusted by the user
    
cacheLength50,

    
createPseudomarkFunction,

    
matchmatchExpr,

    
attrHandle: {},

    
find: {},

    
relative: {
        
">": { dir"parentNode"firsttrue },
        
" ": { dir"parentNode" },
        
"+": { dir"previousSibling"firsttrue },
        
"~": { dir"previousSibling" }
    },

    
preFilter: {
        
"ATTR": function( match ) {
            
match[1] = match[1].replacerunescapefunescape );

            
// Move the given value to match[3] whether quoted or unquoted
            
match[3] = ( match[3] || match[4] || match[5] || "" ).replacerunescapefunescape );

            if ( 
match[2] === "~=" ) {
                
match[3] = " " match[3] + " ";
            }

            return 
match.slice0);
        },

        
"CHILD": function( match ) {
            
/* matches from matchExpr["CHILD"]
                1 type (only|nth|...)
                2 what (child|of-type)
                3 argument (even|odd|d*|d*n([+-]d+)?|...)
                4 xn-component of xn+y argument ([+-]?d*n|)
                5 sign of xn-component
                6 x of xn-component
                7 sign of y-component
                8 y of y-component
            */
            
match[1] = match[1].toLowerCase();

            if ( 
match[1].slice0) === "nth" ) {
                
// nth-* requires argument
                
if ( !match[3] ) {
                    
Sizzle.errormatch[0] );
                }

                
// numeric x and y parameters for Expr.filter.CHILD
                // remember that false/true cast respectively to 0/1
                
match[4] = +( match[4] ? match[5] + (match[6] || 1) : * ( match[3] === "even" || match[3] === "odd" ) );
                
match[5] = +( ( match[7] + match[8] ) || match[3] === "odd" );

            
// other types prohibit arguments
            
} else if ( match[3] ) {
                
Sizzle.errormatch[0] );
            }

            return 
match;
        },

        
"PSEUDO": function( match ) {
            var 
excess,
                
unquoted = !match[6] && match[2];

            if ( 
matchExpr["CHILD"].testmatch[0] ) ) {
                return 
null;
            }

            
// Accept quoted arguments as-is
            
if ( match[3] ) {
                
match[2] = match[4] || match[5] || "";

            
// Strip excess characters from unquoted arguments
            
} else if ( unquoted && rpseudo.testunquoted ) &&
                
// Get excess from tokenize (recursively)
                
(excess tokenizeunquotedtrue )) &&
                
// advance to the next closing parenthesis
                
(excess unquoted.indexOf")"unquoted.length excess ) - unquoted.length) ) {

                
// excess is a negative index
                
match[0] = match[0].slice0excess );
                
match[2] = unquoted.slice0excess );
            }

            
// Return only captures needed by the pseudo filter method (type and argument)
            
return match.slice0);
        }
    },

    
filter: {

        
"TAG": function( nodeNameSelector ) {
            var 
nodeName nodeNameSelector.replacerunescapefunescape ).toLowerCase();
            return 
nodeNameSelector === "*" ?
                function() { return 
true; } :
                function( 
elem ) {
                    return 
elem.nodeName && elem.nodeName.toLowerCase() === nodeName;
                };
        },

        
"CLASS": function( className ) {
            var 
pattern classCacheclassName " " ];

            return 
pattern ||
                (
pattern = new RegExp"(^|" whitespace ")" className "(" whitespace "|$)" )) &&
                
classCacheclassName, function( elem ) {
                    return 
pattern.testtypeof elem.className === "string" && elem.className || typeof elem.getAttribute !== "undefined" && elem.getAttribute("class") || "" );
                });
        },

        
"ATTR": function( nameoperatorcheck ) {
            return function( 
elem ) {
                var 
result Sizzle.attrelemname );

                if ( 
result == null ) {
                    return 
operator === "!=";
                }
                if ( !
operator ) {
                    return 
true;
                }

                
result += "";

                return 
operator === "=" result === check :
                    
operator === "!=" result !== check :
                    
operator === "^=" check && result.indexOfcheck ) === :
                    
operator === "*=" check && result.indexOfcheck ) > -:
                    
operator === "$=" check && result.slice( -check.length ) === check :
                    
operator === "~=" ? ( " " result.replacerwhitespace" " ) + " " ).indexOfcheck ) > -:
                    
operator === "|=" result === check || result.slice0check.length ) === check "-" :
                    
false;
            };
        },

        
"CHILD": function( typewhatargumentfirstlast ) {
            var 
simple type.slice0) !== "nth",
                
forward type.slice( -) !== "last",
                
ofType what === "of-type";

            return 
first === && last === ?

                
// Shortcut for :nth-*(n)
                
function( elem ) {
                    return !!
elem.parentNode;
                } :

                function( 
elemcontextxml ) {
                    var 
cacheouterCachenodediffnodeIndexstart,
                        
dir simple !== forward "nextSibling" "previousSibling",
                        
parent elem.parentNode,
                        
name ofType && elem.nodeName.toLowerCase(),
                        
useCache = !xml && !ofType;

                    if ( 
parent ) {

                        
// :(first|last|only)-(child|of-type)
                        
if ( simple ) {
                            while ( 
dir ) {
                                
node elem;
                                while ( (
node nodedir ]) ) {
                                    if ( 
ofType node.nodeName.toLowerCase() === name node.nodeType === ) {
                                        return 
false;
                                    }
                                }
                                
// Reverse direction for :only-* (if we haven't yet done so)
                                
start dir type === "only" && !start && "nextSibling";
                            }
                            return 
true;
                        }

                        
start = [ forward parent.firstChild parent.lastChild ];

                        
// non-xml :nth-child(...) stores cache data on `parent`
                        
if ( forward && useCache ) {
                            
// Seek `elem` from a previously-cached index
                            
outerCache parentexpando ] || (parentexpando ] = {});
                            
cache outerCachetype ] || [];
                            
nodeIndex cache[0] === dirruns && cache[1];
                            
diff cache[0] === dirruns && cache[2];
                            
node nodeIndex && parent.childNodesnodeIndex ];

                            while ( (
node = ++nodeIndex && node && nodedir ] ||

                                
// Fallback to seeking `elem` from the start
                                
(diff nodeIndex 0) || start.pop()) ) {

                                
// When found, cache indexes on `parent` and break
                                
if ( node.nodeType === && ++diff && node === elem ) {
                                    
outerCachetype ] = [ dirrunsnodeIndexdiff ];
                                    break;
                                }
                            }

                        
// Use previously-cached element index if available
                        
} else if ( useCache && (cache = (elemexpando ] || (elemexpando ] = {}))[ type ]) && cache[0] === dirruns ) {
                            
diff cache[1];

                        
// xml :nth-child(...) or :nth-last-child(...) or :nth(-last)?-of-type(...)
                        
} else {
                            
// Use the same loop as above to seek `elem` from the start
                            
while ( (node = ++nodeIndex && node && nodedir ] ||
                                (
diff nodeIndex 0) || start.pop()) ) {

                                if ( ( 
ofType node.nodeName.toLowerCase() === name node.nodeType === ) && ++diff ) {
                                    
// Cache the index of each encountered element
                                    
if ( useCache ) {
                                        (
nodeexpando ] || (nodeexpando ] = {}))[ type ] = [ dirrunsdiff ];
                                    }

                                    if ( 
node === elem ) {
                                        break;
                                    }
                                }
                            }
                        }

                        
// Incorporate the offset, then check against cycle size
                        
diff -= last;
                        return 
diff === first || ( diff first === && diff first >= );
                    }
                };
        },

        
"PSEUDO": function( pseudoargument ) {
            
// pseudo-class names are case-insensitive
            // http://www.w3.org/TR/selectors/#pseudo-classes
            // Prioritize by case sensitivity in case custom pseudos are added with uppercase letters
            // Remember that setFilters inherits from pseudos
            
var args,
                fn = 
Expr.pseudospseudo ] || Expr.setFilterspseudo.toLowerCase() ] ||
                    
Sizzle.error"unsupported pseudo: " pseudo );

            
// The user may use createPseudo to indicate that
            // arguments are needed to create the filter function
            // just as Sizzle does
            
if ( fn[ expando ] ) {
                return fn( 
argument );
            }

            
// But maintain support for old signatures
            
if ( fn.length ) {
                
args = [ pseudopseudo""argument ];
                return 
Expr.setFilters.hasOwnPropertypseudo.toLowerCase() ) ?
                    
markFunction(function( seedmatches ) {
                        var 
idx,
                            
matched = fn( seedargument ),
                            
matched.length;
                        while ( 
i-- ) {
                            
idx indexOfseedmatched[i] );
                            
seedidx ] = !( matchesidx ] = matched[i] );
                        }
                    }) :
                    function( 
elem ) {
                        return fn( 
elem0args );
                    };
            }

            return fn;
        }
    },

    
pseudos: {
        
// Potentially complex pseudos
        
"not"markFunction(function( selector ) {
            
// Trim the selector passed to compile
            // to avoid treating leading and trailing
            // spaces as combinators
            
var input = [],
                
results = [],
                
matcher compileselector.replacertrim"$1" ) );

            return 
matcherexpando ] ?
                
markFunction(function( seedmatchescontextxml ) {
                    var 
elem,
                        
unmatched matcherseednullxml, [] ),
                        
seed.length;

                    
// Match elements unmatched by `matcher`
                    
while ( i-- ) {
                        if ( (
elem unmatched[i]) ) {
                            
seed[i] = !(matches[i] = elem);
                        }
                    }
                }) :
                function( 
elemcontextxml ) {
                    
input[0] = elem;
                    
matcherinputnullxmlresults );
                    
// Don't keep the element (issue #299)
                    
input[0] = null;
                    return !
results.pop();
                };
        }),

        
"has"markFunction(function( selector ) {
            return function( 
elem ) {
                return 
Sizzleselectorelem ).length 0;
            };
        }),

        
"contains"markFunction(function( text ) {
            
text text.replacerunescapefunescape );
            return function( 
elem ) {
                return ( 
elem.textContent || elem.innerText || getTextelem ) ).indexOftext ) > -1;
            };
        }),

        
// "Whether an element is represented by a :lang() selector
        // is based solely on the element's language value
        // being equal to the identifier C,
        // or beginning with the identifier C immediately followed by "-".
        // The matching of C against the element's language value is performed case-insensitively.
        // The identifier C does not have to be a valid language name."
        // http://www.w3.org/TR/selectors/#lang-pseudo
        
"lang"markFunction( function( lang ) {
            
// lang value must be a valid identifier
            
if ( !ridentifier.test(lang || "") ) {
                
Sizzle.error"unsupported lang: " lang );
            }
            
lang lang.replacerunescapefunescape ).toLowerCase();
            return function( 
elem ) {
                var 
elemLang;
                do {
                    if ( (
elemLang documentIsHTML ?
                        
elem.lang :
                        
elem.getAttribute("xml:lang") || elem.getAttribute("lang")) ) {

                        
elemLang elemLang.toLowerCase();
                        return 
elemLang === lang || elemLang.indexOflang "-" ) === 0;
                    }
                } while ( (
elem elem.parentNode) && elem.nodeType === );
                return 
false;
            };
        }),

        
// Miscellaneous
        
"target": function( elem ) {
            var 
hash window.location && window.location.hash;
            return 
hash && hash.slice) === elem.id;
        },

        
"root": function( elem ) {
            return 
elem === docElem;
        },

        
"focus": function( elem ) {
            return 
elem === document.activeElement && (!document.hasFocus || document.hasFocus()) && !!(elem.type || elem.href || ~elem.tabIndex);
        },

        
// Boolean properties
        
"enabled": function( elem ) {
            return 
elem.disabled === false;
        },

        
"disabled": function( elem ) {
            return 
elem.disabled === true;
        },

        
"checked": function( elem ) {
            
// In CSS3, :checked should return both checked and selected elements
            // http://www.w3.org/TR/2011/REC-css3-selectors-20110929/#checked
            
var nodeName elem.nodeName.toLowerCase();
            return (
nodeName === "input" && !!elem.checked) || (nodeName === "option" && !!elem.selected);
        },

        
"selected": function( elem ) {
            
// Accessing this property makes selected-by-default
            // options in Safari work properly
            
if ( elem.parentNode ) {
                
elem.parentNode.selectedIndex;
            }

            return 
elem.selected === true;
        },

        
// Contents
        
"empty": function( elem ) {
            
// http://www.w3.org/TR/selectors/#empty-pseudo
            // :empty is negated by element (1) or content nodes (text: 3; cdata: 4; entity ref: 5),
            //   but not by others (comment: 8; processing instruction: 7; etc.)
            // nodeType < 6 works because attributes (2) do not appear as children
            
for ( elem elem.firstChildelemelem elem.nextSibling ) {
                if ( 
elem.nodeType ) {
                    return 
false;
                }
            }
            return 
true;
        },

        
"parent": function( elem ) {
            return !
Expr.pseudos["empty"]( elem );
        },

        
// Element/input types
        
"header": function( elem ) {
            return 
rheader.testelem.nodeName );
        },

        
"input": function( elem ) {
            return 
rinputs.testelem.nodeName );
        },

        
"button": function( elem ) {
            var 
name elem.nodeName.toLowerCase();
            return 
name === "input" && elem.type === "button" || name === "button";
        },

        
"text": function( elem ) {
            var 
attr;
            return 
elem.nodeName.toLowerCase() === "input" &&
                
elem.type === "text" &&

                
// Support: IE<8
                // New HTML5 attribute values (e.g., "search") appear with elem.type === "text"
                
( (attr elem.getAttribute("type")) == null || attr.toLowerCase() === "text" );
        },

        
// Position-in-collection
        
"first"createPositionalPseudo(function() {
            return [ 
];
        }),

        
"last"createPositionalPseudo(function( matchIndexeslength ) {
            return [ 
length ];
        }),

        
"eq"createPositionalPseudo(function( matchIndexeslengthargument ) {
            return [ 
argument argument length argument ];
        }),

        
"even"createPositionalPseudo(function( matchIndexeslength ) {
            var 
0;
            for ( ; 
length+= ) {
                
matchIndexes.push);
            }
            return 
matchIndexes;
        }),

        
"odd"createPositionalPseudo(function( matchIndexeslength ) {
            var 
1;
            for ( ; 
length+= ) {
                
matchIndexes.push);
            }
            return 
matchIndexes;
        }),

        
"lt"createPositionalPseudo(function( matchIndexeslengthargument ) {
            var 
argument argument length argument;
            for ( ; --
>= 0; ) {
                
matchIndexes.push);
            }
            return 
matchIndexes;
        }),

        
"gt"createPositionalPseudo(function( matchIndexeslengthargument ) {
            var 
argument argument length argument;
            for ( ; ++
length; ) {
                
matchIndexes.push);
            }
            return 
matchIndexes;
        })
    }
};

Expr.pseudos["nth"] = Expr.pseudos["eq"];

// Add button/input type pseudos
for ( i in radiotruecheckboxtruefiletruepasswordtrueimagetrue } ) {
    
Expr.pseudos] = createInputPseudo);
}
for ( 
i in submittrueresettrue } ) {
    
Expr.pseudos] = createButtonPseudo);
}

// Easy API for creating new setFilters
function setFilters() {}
setFilters.prototype Expr.filters Expr.pseudos;
Expr.setFilters = new setFilters();

tokenize Sizzle.tokenize = function( selectorparseOnly ) {
    var 
matchedmatchtokenstype,
        
soFargroupspreFilters,
        
cached tokenCacheselector " " ];

    if ( 
cached ) {
        return 
parseOnly cached.slice);
    }

    
soFar selector;
    
groups = [];
    
preFilters Expr.preFilter;

    while ( 
soFar ) {

        
// Comma and first run
        
if ( !matched || (match rcomma.execsoFar )) ) {
            if ( 
match ) {
                
// Don't consume trailing commas as valid
                
soFar soFar.slicematch[0].length ) || soFar;
            }
            
groups.push( (tokens = []) );
        }

        
matched false;

        
// Combinators
        
if ( (match rcombinators.execsoFar )) ) {
            
matched match.shift();
            
tokens.push({
                
valuematched,
                
// Cast descendant combinators to space
                
typematch[0].replacertrim" " )
            });
            
soFar soFar.slicematched.length );
        }

        
// Filters
        
for ( type in Expr.filter ) {
            if ( (
match matchExprtype ].execsoFar )) && (!preFilterstype ] ||
                (
match preFilterstype ]( match ))) ) {
                
matched match.shift();
                
tokens.push({
                    
valuematched,
                    
typetype,
                    
matchesmatch
                
});
                
soFar soFar.slicematched.length );
            }
        }

        if ( !
matched ) {
            break;
        }
    }

    
// Return the length of the invalid excess
    // if we're just parsing
    // Otherwise, throw an error or return tokens
    
return parseOnly ?
        
soFar.length :
        
soFar ?
            
Sizzle.errorselector ) :
            
// Cache the tokens
            
tokenCacheselectorgroups ).slice);
};

function 
toSelectortokens ) {
    var 
0,
        
len tokens.length,
        
selector "";
    for ( ; 
leni++ ) {
        
selector += tokens[i].value;
    }
    return 
selector;
}

function 
addCombinatormatchercombinatorbase ) {
    var 
dir combinator.dir,
        
checkNonElements base && dir === "parentNode",
        
doneName done++;

    return 
combinator.first ?
        
// Check against closest ancestor/preceding element
        
function( elemcontextxml ) {
            while ( (
elem elemdir ]) ) {
                if ( 
elem.nodeType === || checkNonElements ) {
                    return 
matcherelemcontextxml );
                }
            }
        } :

        
// Check against all ancestor/preceding elements
        
function( elemcontextxml ) {
            var 
oldCacheouterCache,
                
newCache = [ dirrunsdoneName ];

            
// We can't set arbitrary data on XML nodes, so they don't benefit from dir caching
            
if ( xml ) {
                while ( (
elem elemdir ]) ) {
                    if ( 
elem.nodeType === || checkNonElements ) {
                        if ( 
matcherelemcontextxml ) ) {
                            return 
true;
                        }
                    }
                }
            } else {
                while ( (
elem elemdir ]) ) {
                    if ( 
elem.nodeType === || checkNonElements ) {
                        
outerCache elemexpando ] || (elemexpando ] = {});
                        if ( (
oldCache outerCachedir ]) &&
                            
oldCache] === dirruns && oldCache] === doneName ) {

                            
// Assign to newCache so results back-propagate to previous elements
                            
return (newCache] = oldCache]);
                        } else {
                            
// Reuse newcache so results back-propagate to previous elements
                            
outerCachedir ] = newCache;

                            
// A match means we're done; a fail means we have to keep checking
                            
if ( (newCache] = matcherelemcontextxml )) ) {
                                return 
true;
                            }
                        }
                    }
                }
            }
        };
}

function 
elementMatchermatchers ) {
    return 
matchers.length ?
        function( 
elemcontextxml ) {
            var 
matchers.length;
            while ( 
i-- ) {
                if ( !
matchers[i]( elemcontextxml ) ) {
                    return 
false;
                }
            }
            return 
true;
        } :
        
matchers[0];
}

function 
multipleContextsselectorcontextsresults ) {
    var 
0,
        
len contexts.length;
    for ( ; 
leni++ ) {
        
Sizzleselectorcontexts[i], results );
    }
    return 
results;
}

function 
condenseunmatchedmapfiltercontextxml ) {
    var 
elem,
        
newUnmatched = [],
        
0,
        
len unmatched.length,
        
mapped map != null;

    for ( ; 
leni++ ) {
        if ( (
elem unmatched[i]) ) {
            if ( !
filter || filterelemcontextxml ) ) {
                
newUnmatched.pushelem );
                if ( 
mapped ) {
                    
map.push);
                }
            }
        }
    }

    return 
newUnmatched;
}

function 
setMatcherpreFilterselectormatcherpostFilterpostFinderpostSelector ) {
    if ( 
postFilter && !postFilterexpando ] ) {
        
postFilter setMatcherpostFilter );
    }
    if ( 
postFinder && !postFinderexpando ] ) {
        
postFinder setMatcherpostFinderpostSelector );
    }
    return 
markFunction(function( seedresultscontextxml ) {
        var 
tempielem,
            
preMap = [],
            
postMap = [],
            
preexisting results.length,

            
// Get initial elements from seed or context
            
elems seed || multipleContextsselector || "*"context.nodeType ? [ context ] : context, [] ),

            
// Prefilter to get matcher input, preserving a map for seed-results synchronization
            
matcherIn preFilter && ( seed || !selector ) ?
                
condenseelemspreMappreFiltercontextxml ) :
                
elems,

            
matcherOut matcher ?
                
// If we have a postFinder, or filtered seed, or non-seed postFilter or preexisting results,
                
postFinder || ( seed preFilter preexisting || postFilter ) ?

                    
// ...intermediate processing is necessary
                    
[] :

                    
// ...otherwise use results directly
                    
results :
                
matcherIn;

        
// Find primary matches
        
if ( matcher ) {
            
matchermatcherInmatcherOutcontextxml );
        }

        
// Apply postFilter
        
if ( postFilter ) {
            
temp condensematcherOutpostMap );
            
postFiltertemp, [], contextxml );

            
// Un-match failing elements by moving them back to matcherIn
            
temp.length;
            while ( 
i-- ) {
                if ( (
elem temp[i]) ) {
                    
matcherOutpostMap[i] ] = !(matcherInpostMap[i] ] = elem);
                }
            }
        }

        if ( 
seed ) {
            if ( 
postFinder || preFilter ) {
                if ( 
postFinder ) {
                    
// Get the final matcherOut by condensing this intermediate into postFinder contexts
                    
temp = [];
                    
matcherOut.length;
                    while ( 
i-- ) {
                        if ( (
elem matcherOut[i]) ) {
                            
// Restore matcherIn since elem is not yet a final match
                            
temp.push( (matcherIn[i] = elem) );
                        }
                    }
                    
postFindernull, (matcherOut = []), tempxml );
                }

                
// Move matched elements from seed to results to keep them synchronized
                
matcherOut.length;
                while ( 
i-- ) {
                    if ( (
elem matcherOut[i]) &&
                        (
temp postFinder indexOfseedelem ) : preMap[i]) > -) {

                        
seed[temp] = !(results[temp] = elem);
                    }
                }
            }

        
// Add elements to results, through postFinder if defined
        
} else {
            
matcherOut condense(
                
matcherOut === results ?
                    
matcherOut.splicepreexistingmatcherOut.length ) :
                    
matcherOut
            
);
            if ( 
postFinder ) {
                
postFindernullresultsmatcherOutxml );
            } else {
                
push.applyresultsmatcherOut );
            }
        }
    });
}

function 
matcherFromTokenstokens ) {
    var 
checkContextmatcherj,
        
len tokens.length,
        
leadingRelative Expr.relativetokens[0].type ],
        
implicitRelative leadingRelative || Expr.relative[" "],
        
leadingRelative 0,

        
// The foundational matcher ensures that elements are reachable from top-level context(s)
        
matchContext addCombinator( function( elem ) {
            return 
elem === checkContext;
        }, 
implicitRelativetrue ),
        
matchAnyContext addCombinator( function( elem ) {
            return 
indexOfcheckContextelem ) > -1;
        }, 
implicitRelativetrue ),
        
matchers = [ function( elemcontextxml ) {
            var 
ret = ( !leadingRelative && ( xml || context !== outermostContext ) ) || (
                (
checkContext context).nodeType ?
                    
matchContextelemcontextxml ) :
                    
matchAnyContextelemcontextxml ) );
            
// Avoid hanging onto element (issue #299)
            
checkContext null;
            return 
ret;
        } ];

    for ( ; 
leni++ ) {
        if ( (
matcher Expr.relativetokens[i].type ]) ) {
            
matchers = [ addCombinator(elementMatchermatchers ), matcher) ];
        } else {
            
matcher Expr.filtertokens[i].type ].applynulltokens[i].matches );

            
// Return special upon seeing a positional matcher
            
if ( matcherexpando ] ) {
                
// Find the next relative operator (if any) for proper handling
                
= ++i;
                for ( ; 
lenj++ ) {
                    if ( 
Expr.relativetokens[j].type ] ) {
                        break;
                    }
                }
                return 
setMatcher(
                    
&& elementMatchermatchers ),
                    
&& toSelector(
                        
// If the preceding token was a descendant combinator, insert an implicit any-element `*`
                        
tokens.slice0).concat({ valuetokens].type === " " "*" "" })
                    ).
replacertrim"$1" ),
                    
matcher,
                    
&& matcherFromTokenstokens.slicei) ),
                    
len && matcherFromTokens( (tokens tokens.slice)) ),
                    
len && toSelectortokens )
                );
            }
            
matchers.pushmatcher );
        }
    }

    return 
elementMatchermatchers );
}

function 
matcherFromGroupMatcherselementMatcherssetMatchers ) {
    var 
bySet setMatchers.length 0,
        
byElement elementMatchers.length 0,
        
superMatcher = function( seedcontextxmlresultsoutermost ) {
            var 
elemjmatcher,
                
matchedCount 0,
                
"0",
                
unmatched seed && [],
                
setMatched = [],
                
contextBackup outermostContext,
                
// We must always have either seed elements or outermost context
                
elems seed || byElement && Expr.find["TAG"]( "*"outermost ),
                
// Use integer dirruns iff this is the outermost matcher
                
dirrunsUnique = (dirruns += contextBackup == null Math.random() || 0.1),
                
len elems.length;

            if ( 
outermost ) {
                
outermostContext context !== document && context;
            }

            
// Add elements passing elementMatchers directly to results
            // Keep `i` a string if there are no elements so `matchedCount` will be "00" below
            // Support: IE<9, Safari
            // Tolerate NodeList properties (IE: "length"; Safari: <number>) matching elements by id
            
for ( ; !== len && (elem elems[i]) != nulli++ ) {
                if ( 
byElement && elem ) {
                    
0;
                    while ( (
matcher elementMatchers[j++]) ) {
                        if ( 
matcherelemcontextxml ) ) {
                            
results.pushelem );
                            break;
                        }
                    }
                    if ( 
outermost ) {
                        
dirruns dirrunsUnique;
                    }
                }

                
// Track unmatched elements for set filters
                
if ( bySet ) {
                    
// They will have gone through all possible matchers
                    
if ( (elem = !matcher && elem) ) {
                        
matchedCount--;
                    }

                    
// Lengthen the array for every element, matched or not
                    
if ( seed ) {
                        
unmatched.pushelem );
                    }
                }
            }

            
// Apply set filters to unmatched elements
            
matchedCount += i;
            if ( 
bySet && !== matchedCount ) {
                
0;
                while ( (
matcher setMatchers[j++]) ) {
                    
matcherunmatchedsetMatchedcontextxml );
                }

                if ( 
seed ) {
                    
// Reintegrate element matches to eliminate the need for sorting
                    
if ( matchedCount ) {
                        while ( 
i-- ) {
                            if ( !(
unmatched[i] || setMatched[i]) ) {
                                
setMatched[i] = pop.callresults );
                            }
                        }
                    }

                    
// Discard index placeholder values to get only actual matches
                    
setMatched condensesetMatched );
                }

                
// Add matches to results
                
push.applyresultssetMatched );

                
// Seedless set matches succeeding multiple successful matchers stipulate sorting
                
if ( outermost && !seed && setMatched.length &&
                    ( 
matchedCount setMatchers.length ) > ) {

                    
Sizzle.uniqueSortresults );
                }
            }

            
// Override manipulation of globals by nested matchers
            
if ( outermost ) {
                
dirruns dirrunsUnique;
                
outermostContext contextBackup;
            }

            return 
unmatched;
        };

    return 
bySet ?
        
markFunctionsuperMatcher ) :
        
superMatcher;
}

compile Sizzle.compile = function( selectormatch /* Internal Use Only */ ) {
    var 
i,
        
setMatchers = [],
        
elementMatchers = [],
        
cached compilerCacheselector " " ];

    if ( !
cached ) {
        
// Generate a function of recursive functions that can be used to check each element
        
if ( !match ) {
            
match tokenizeselector );
        }
        
match.length;
        while ( 
i-- ) {
            
cached matcherFromTokensmatch[i] );
            if ( 
cachedexpando ] ) {
                
setMatchers.pushcached );
            } else {
                
elementMatchers.pushcached );
            }
        }

        
// Cache the compiled function
        
cached compilerCacheselectormatcherFromGroupMatcherselementMatcherssetMatchers ) );

        
// Save selector and tokenization
        
cached.selector selector;
    }
    return 
cached;
};

/**
 * A low-level selection function that works with Sizzle's compiled
 *  selector functions
 * @param {String|Function} selector A selector or a pre-compiled
 *  selector function built with Sizzle.compile
 * @param {Element} context
 * @param {Array} [results]
 * @param {Array} [seed] A set of elements to match against
 */
select Sizzle.select = function( selectorcontextresultsseed ) {
    var 
itokenstokentypefind,
        
compiled typeof selector === "function" && selector,
        
match = !seed && tokenize( (selector compiled.selector || selector) );

    
results results || [];

    
// Try to minimize operations if there is no seed and only one group
    
if ( match.length === ) {

        
// Take a shortcut and set the context if the root selector is an ID
        
tokens match[0] = match[0].slice);
        if ( 
tokens.length && (token tokens[0]).type === "ID" &&
                
support.getById && context.nodeType === && documentIsHTML &&
                
Expr.relativetokens[1].type ] ) {

            
context = ( Expr.find["ID"]( token.matches[0].replace(runescapefunescape), context ) || [] )[0];
            if ( !
context ) {
                return 
results;

            
// Precompiled matchers will still verify ancestry, so step up a level
            
} else if ( compiled ) {
                
context context.parentNode;
            }

            
selector selector.slicetokens.shift().value.length );
        }

        
// Fetch a seed set for right-to-left matching
        
matchExpr["needsContext"].testselector ) ? tokens.length;
        while ( 
i-- ) {
            
token tokens[i];

            
// Abort if we hit a combinator
            
if ( Expr.relative[ (type token.type) ] ) {
                break;
            }
            if ( (
find Expr.findtype ]) ) {
                
// Search, expanding context for leading sibling combinators
                
if ( (seed find(
                    
token.matches[0].replacerunescapefunescape ),
                    
rsibling.testtokens[0].type ) && testContextcontext.parentNode ) || context
                
)) ) {

                    
// If seed is empty or no tokens remain, we can return early
                    
tokens.splicei);
                    
selector seed.length && toSelectortokens );
                    if ( !
selector ) {
                        
push.applyresultsseed );
                        return 
results;
                    }

                    break;
                }
            }
        }
    }

    
// Compile and execute a filtering function if one is not provided
    // Provide `match` to avoid retokenization if we modified the selector above
    
compiled || compileselectormatch ) )(
        
seed,
        
context,
        !
documentIsHTML,
        
results,
        
rsibling.testselector ) && testContextcontext.parentNode ) || context
    
);
    return 
results;
};

// One-time assignments

// Sort stability
support.sortStable expando.split("").sortsortOrder ).join("") === expando;

// Support: Chrome 14-35+
// Always assume duplicates if they aren't passed to the comparison function
support.detectDuplicates = !!hasDuplicate;

// Initialize against the default document
setDocument();

// Support: Webkit<537.32 - Safari 6.0.3/Chrome 25 (fixed in Chrome 27)
// Detached nodes confoundingly follow *each other*
support.sortDetached assert(function( div1 ) {
    
// Should return 1, but returns 4 (following)
    
return div1.compareDocumentPositiondocument.createElement("div") ) & 1;
});

// Support: IE<8
// Prevent attribute/property "interpolation"
// http://msdn.microsoft.com/en-us/library/ms536429%28VS.85%29.aspx
if ( !assert(function( div ) {
    
div.innerHTML "<a href='#'></a>";
    return 
div.firstChild.getAttribute("href") === "#" ;
}) ) {
    
addHandle"type|href|height|width", function( elemnameisXML ) {
        if ( !
isXML ) {
            return 
elem.getAttributenamename.toLowerCase() === "type" );
        }
    });
}

// Support: IE<9
// Use defaultValue in place of getAttribute("value")
if ( !support.attributes || !assert(function( div ) {
    
div.innerHTML "<input/>";
    
div.firstChild.setAttribute"value""" );
    return 
div.firstChild.getAttribute"value" ) === "";
}) ) {
    
addHandle"value", function( elemnameisXML ) {
        if ( !
isXML && elem.nodeName.toLowerCase() === "input" ) {
            return 
elem.defaultValue;
        }
    });
}

// Support: IE<9
// Use getAttributeNode to fetch booleans when getAttribute lies
if ( !assert(function( div ) {
    return 
div.getAttribute("disabled") == null;
}) ) {
    
addHandlebooleans, function( elemnameisXML ) {
        var 
val;
        if ( !
isXML ) {
            return 
elemname ] === true name.toLowerCase() :
                    (
val elem.getAttributeNodename )) && val.specified ?
                    
val.value :
                
null;
        }
    });
}

// EXPOSE
if ( typeof define === "function" && define.amd ) {
    
define(function() { return Sizzle; });
// Sizzle requires that there be a global window in Common-JS like environments
} else if ( typeof module !== "undefined" && module.exports ) {
    
module.exports Sizzle;
} else {
    
window.Sizzle Sizzle;
}
// EXPOSE

})( window );
?>
Онлайн: 1
Реклама