Skip to content
Browse files

Add Qwery 3.4.1

  • Loading branch information...
1 parent ac50bac commit ed3801287af8d7cf7c6a8d8694e513a9be007294 @alejandroiglesias alejandroiglesias committed May 2, 2013
Showing with 401 additions and 0 deletions.
  1. +369 −0 ajax/libs/qwery/3.4.1/qwery.js
  2. +7 −0 ajax/libs/qwery/3.4.1/qwery.min.js
  3. +25 −0 ajax/libs/qwery/package.json
View
369 ajax/libs/qwery/3.4.1/qwery.js
@@ -0,0 +1,369 @@
+/*!
+ * @preserve Qwery - A Blazing Fast query selector engine
+ * https://github.com/ded/qwery
+ * copyright Dustin Diaz 2012
+ * MIT License
+ */
+
+(function (name, context, definition) {
+ if (typeof module != 'undefined' && module.exports) module.exports = definition()
+ else if (typeof define == 'function' && define.amd) define(definition)
+ else context[name] = definition()
+})('qwery', this, function () {
+ var doc = document
+ , html = doc.documentElement
+ , byClass = 'getElementsByClassName'
+ , byTag = 'getElementsByTagName'
+ , qSA = 'querySelectorAll'
+ , useNativeQSA = 'useNativeQSA'
+ , tagName = 'tagName'
+ , nodeType = 'nodeType'
+ , select // main select() method, assign later
+
+ , id = /#([\w\-]+)/
+ , clas = /\.[\w\-]+/g
+ , idOnly = /^#([\w\-]+)$/
+ , classOnly = /^\.([\w\-]+)$/
+ , tagOnly = /^([\w\-]+)$/
+ , tagAndOrClass = /^([\w]+)?\.([\w\-]+)$/
+ , splittable = /(^|,)\s*[>~+]/
+ , normalizr = /^\s+|\s*([,\s\+\~>]|$)\s*/g
+ , splitters = /[\s\>\+\~]/
+ , splittersMore = /(?![\s\w\-\/\?\&\=\:\.\(\)\!,@#%<>\{\}\$\*\^'"]*\]|[\s\w\+\-]*\))/
+ , specialChars = /([.*+?\^=!:${}()|\[\]\/\\])/g
+ , simple = /^(\*|[a-z0-9]+)?(?:([\.\#]+[\w\-\.#]+)?)/
+ , attr = /\[([\w\-]+)(?:([\|\^\$\*\~]?\=)['"]?([ \w\-\/\?\&\=\:\.\(\)\!,@#%<>\{\}\$\*\^]+)["']?)?\]/
+ , pseudo = /:([\w\-]+)(\(['"]?([^()]+)['"]?\))?/
+ , easy = new RegExp(idOnly.source + '|' + tagOnly.source + '|' + classOnly.source)
+ , dividers = new RegExp('(' + splitters.source + ')' + splittersMore.source, 'g')
+ , tokenizr = new RegExp(splitters.source + splittersMore.source)
+ , chunker = new RegExp(simple.source + '(' + attr.source + ')?' + '(' + pseudo.source + ')?')
+
+ var walker = {
+ ' ': function (node) {
+ return node && node !== html && node.parentNode
+ }
+ , '>': function (node, contestant) {
+ return node && node.parentNode == contestant.parentNode && node.parentNode
+ }
+ , '~': function (node) {
+ return node && node.previousSibling
+ }
+ , '+': function (node, contestant, p1, p2) {
+ if (!node) return false
+ return (p1 = previous(node)) && (p2 = previous(contestant)) && p1 == p2 && p1
+ }
+ }
+
+ function cache() {
+ this.c = {}
+ }
+ cache.prototype = {
+ g: function (k) {
+ return this.c[k] || undefined
+ }
+ , s: function (k, v, r) {
+ v = r ? new RegExp(v) : v
+ return (this.c[k] = v)
+ }
+ }
+
+ var classCache = new cache()
+ , cleanCache = new cache()
+ , attrCache = new cache()
+ , tokenCache = new cache()
+
+ function classRegex(c) {
+ return classCache.g(c) || classCache.s(c, '(^|\\s+)' + c + '(\\s+|$)', 1)
+ }
+
+ // not quite as fast as inline loops in older browsers so don't use liberally
+ function each(a, fn) {
+ var i = 0, l = a.length
+ for (; i < l; i++) fn(a[i])
+ }
+
+ function flatten(ar) {
+ for (var r = [], i = 0, l = ar.length; i < l; ++i) arrayLike(ar[i]) ? (r = r.concat(ar[i])) : (r[r.length] = ar[i])
+ return r
+ }
+
+ function arrayify(ar) {
+ var i = 0, l = ar.length, r = []
+ for (; i < l; i++) r[i] = ar[i]
+ return r
+ }
+
+ function previous(n) {
+ while (n = n.previousSibling) if (n[nodeType] == 1) break;
+ return n
+ }
+
+ function q(query) {
+ return query.match(chunker)
+ }
+
+ // called using `this` as element and arguments from regex group results.
+ // given => div.hello[title="world"]:foo('bar')
+ // div.hello[title="world"]:foo('bar'), div, .hello, [title="world"], title, =, world, :foo('bar'), foo, ('bar'), bar]
+ function interpret(whole, tag, idsAndClasses, wholeAttribute, attribute, qualifier, value, wholePseudo, pseudo, wholePseudoVal, pseudoVal) {
+ var i, m, k, o, classes
+ if (this[nodeType] !== 1) return false
+ if (tag && tag !== '*' && this[tagName] && this[tagName].toLowerCase() !== tag) return false
+ if (idsAndClasses && (m = idsAndClasses.match(id)) && m[1] !== this.id) return false
+ if (idsAndClasses && (classes = idsAndClasses.match(clas))) {
+ for (i = classes.length; i--;) if (!classRegex(classes[i].slice(1)).test(this.className)) return false
+ }
+ if (pseudo && qwery.pseudos[pseudo] && !qwery.pseudos[pseudo](this, pseudoVal)) return false
+ if (wholeAttribute && !value) { // select is just for existance of attrib
+ o = this.attributes
+ for (k in o) {
+ if (Object.prototype.hasOwnProperty.call(o, k) && (o[k].name || k) == attribute) {
+ return this
+ }
+ }
+ }
+ if (wholeAttribute && !checkAttr(qualifier, getAttr(this, attribute) || '', value)) {
+ // select is for attrib equality
+ return false
+ }
+ return this
+ }
+
+ function clean(s) {
+ return cleanCache.g(s) || cleanCache.s(s, s.replace(specialChars, '\\$1'))
+ }
+
+ function checkAttr(qualify, actual, val) {
+ switch (qualify) {
+ case '=':
+ return actual == val
+ case '^=':
+ return actual.match(attrCache.g('^=' + val) || attrCache.s('^=' + val, '^' + clean(val), 1))
+ case '$=':
+ return actual.match(attrCache.g('$=' + val) || attrCache.s('$=' + val, clean(val) + '$', 1))
+ case '*=':
+ return actual.match(attrCache.g(val) || attrCache.s(val, clean(val), 1))
+ case '~=':
+ return actual.match(attrCache.g('~=' + val) || attrCache.s('~=' + val, '(?:^|\\s+)' + clean(val) + '(?:\\s+|$)', 1))
+ case '|=':
+ return actual.match(attrCache.g('|=' + val) || attrCache.s('|=' + val, '^' + clean(val) + '(-|$)', 1))
+ }
+ return 0
+ }
+
+ // given a selector, first check for simple cases then collect all base candidate matches and filter
+ function _qwery(selector, _root) {
+ var r = [], ret = [], i, l, m, token, tag, els, intr, item, root = _root
+ , tokens = tokenCache.g(selector) || tokenCache.s(selector, selector.split(tokenizr))
+ , dividedTokens = selector.match(dividers)
+
+ if (!tokens.length) return r
+
+ token = (tokens = tokens.slice(0)).pop() // copy cached tokens, take the last one
+ if (tokens.length && (m = tokens[tokens.length - 1].match(idOnly))) root = byId(_root, m[1])
+ if (!root) return r
+
+ intr = q(token)
+ // collect base candidates to filter
+ els = root !== _root && root[nodeType] !== 9 && dividedTokens && /^[+~]$/.test(dividedTokens[dividedTokens.length - 1]) ?
+ function (r) {
+ while (root = root.nextSibling) {
+ root[nodeType] == 1 && (intr[1] ? intr[1] == root[tagName].toLowerCase() : 1) && (r[r.length] = root)
+ }
+ return r
+ }([]) :
+ root[byTag](intr[1] || '*')
+ // filter elements according to the right-most part of the selector
+ for (i = 0, l = els.length; i < l; i++) {
+ if (item = interpret.apply(els[i], intr)) r[r.length] = item
+ }
+ if (!tokens.length) return r
+
+ // filter further according to the rest of the selector (the left side)
+ each(r, function (e) { if (ancestorMatch(e, tokens, dividedTokens)) ret[ret.length] = e })
+ return ret
+ }
+
+ // compare element to a selector
+ function is(el, selector, root) {
+ if (isNode(selector)) return el == selector
+ if (arrayLike(selector)) return !!~flatten(selector).indexOf(el) // if selector is an array, is el a member?
+
+ var selectors = selector.split(','), tokens, dividedTokens
+ while (selector = selectors.pop()) {
+ tokens = tokenCache.g(selector) || tokenCache.s(selector, selector.split(tokenizr))
+ dividedTokens = selector.match(dividers)
+ tokens = tokens.slice(0) // copy array
+ if (interpret.apply(el, q(tokens.pop())) && (!tokens.length || ancestorMatch(el, tokens, dividedTokens, root))) {
+ return true
+ }
+ }
+ return false
+ }
+
+ // given elements matching the right-most part of a selector, filter out any that don't match the rest
+ function ancestorMatch(el, tokens, dividedTokens, root) {
+ var cand
+ // recursively work backwards through the tokens and up the dom, covering all options
+ function crawl(e, i, p) {
+ while (p = walker[dividedTokens[i]](p, e)) {
+ if (isNode(p) && (interpret.apply(p, q(tokens[i])))) {
+ if (i) {
+ if (cand = crawl(p, i - 1, p)) return cand
+ } else return p
+ }
+ }
+ }
+ return (cand = crawl(el, tokens.length - 1, el)) && (!root || isAncestor(cand, root))
+ }
+
+ function isNode(el, t) {
+ return el && typeof el === 'object' && (t = el[nodeType]) && (t == 1 || t == 9)
+ }
+
+ function uniq(ar) {
+ var a = [], i, j;
+ o:
+ for (i = 0; i < ar.length; ++i) {
+ for (j = 0; j < a.length; ++j) if (a[j] == ar[i]) continue o
+ a[a.length] = ar[i]
+ }
+ return a
+ }
+
+ function arrayLike(o) {
+ return (typeof o === 'object' && isFinite(o.length))
+ }
+
+ function normalizeRoot(root) {
+ if (!root) return doc
+ if (typeof root == 'string') return qwery(root)[0]
+ if (!root[nodeType] && arrayLike(root)) return root[0]
+ return root
+ }
+
+ function byId(root, id, el) {
+ // if doc, query on it, else query the parent doc or if a detached fragment rewrite the query and run on the fragment
+ return root[nodeType] === 9 ? root.getElementById(id) :
+ root.ownerDocument &&
+ (((el = root.ownerDocument.getElementById(id)) && isAncestor(el, root) && el) ||
+ (!isAncestor(root, root.ownerDocument) && select('[id="' + id + '"]', root)[0]))
+ }
+
+ function qwery(selector, _root) {
+ var m, el, root = normalizeRoot(_root)
+
+ // easy, fast cases that we can dispatch with simple DOM calls
+ if (!root || !selector) return []
+ if (selector === window || isNode(selector)) {
+ return !_root || (selector !== window && isNode(root) && isAncestor(selector, root)) ? [selector] : []
+ }
+ if (selector && arrayLike(selector)) return flatten(selector)
+ if (m = selector.match(easy)) {
+ if (m[1]) return (el = byId(root, m[1])) ? [el] : []
+ if (m[2]) return arrayify(root[byTag](m[2]))
+ if (hasByClass && m[3]) return arrayify(root[byClass](m[3]))
+ }
+
+ return select(selector, root)
+ }
+
+ // where the root is not document and a relationship selector is first we have to
+ // do some awkward adjustments to get it to work, even with qSA
+ function collectSelector(root, collector) {
+ return function (s) {
+ var oid, nid
+ if (splittable.test(s)) {
+ if (root[nodeType] !== 9) {
+ // make sure the el has an id, rewrite the query, set root to doc and run it
+ if (!(nid = oid = root.getAttribute('id'))) root.setAttribute('id', nid = '__qwerymeupscotty')
+ s = '[id="' + nid + '"]' + s // avoid byId and allow us to match context element
+ collector(root.parentNode || root, s, true)
+ oid || root.removeAttribute('id')
+ }
+ return;
+ }
+ s.length && collector(root, s, false)
+ }
+ }
+
+ var isAncestor = 'compareDocumentPosition' in html ?
+ function (element, container) {
+ return (container.compareDocumentPosition(element) & 16) == 16
+ } : 'contains' in html ?
+ function (element, container) {
+ container = container[nodeType] === 9 || container == window ? html : container
+ return container !== element && container.contains(element)
+ } :
+ function (element, container) {
+ while (element = element.parentNode) if (element === container) return 1
+ return 0
+ }
+ , getAttr = function () {
+ // detect buggy IE src/href getAttribute() call
+ var e = doc.createElement('p')
+ return ((e.innerHTML = '<a href="#x">x</a>') && e.firstChild.getAttribute('href') != '#x') ?
+ function (e, a) {
+ return a === 'class' ? e.className : (a === 'href' || a === 'src') ?
+ e.getAttribute(a, 2) : e.getAttribute(a)
+ } :
+ function (e, a) { return e.getAttribute(a) }
+ }()
+ , hasByClass = !!doc[byClass]
+ // has native qSA support
+ , hasQSA = doc.querySelector && doc[qSA]
+ // use native qSA
+ , selectQSA = function (selector, root) {
+ var result = [], ss, e
+ try {
+ if (root[nodeType] === 9 || !splittable.test(selector)) {
+ // most work is done right here, defer to qSA
+ return arrayify(root[qSA](selector))
+ }
+ // special case where we need the services of `collectSelector()`
+ each(ss = selector.split(','), collectSelector(root, function (ctx, s) {
+ e = ctx[qSA](s)
+ if (e.length == 1) result[result.length] = e.item(0)
+ else if (e.length) result = result.concat(arrayify(e))
+ }))
+ return ss.length > 1 && result.length > 1 ? uniq(result) : result
+ } catch (ex) { }
+ return selectNonNative(selector, root)
+ }
+ // no native selector support
+ , selectNonNative = function (selector, root) {
+ var result = [], items, m, i, l, r, ss
+ selector = selector.replace(normalizr, '$1')
+ if (m = selector.match(tagAndOrClass)) {
+ r = classRegex(m[2])
+ items = root[byTag](m[1] || '*')
+ for (i = 0, l = items.length; i < l; i++) {
+ if (r.test(items[i].className)) result[result.length] = items[i]
+ }
+ return result
+ }
+ // more complex selector, get `_qwery()` to do the work for us
+ each(ss = selector.split(','), collectSelector(root, function (ctx, s, rewrite) {
+ r = _qwery(s, ctx)
+ for (i = 0, l = r.length; i < l; i++) {
+ if (ctx[nodeType] === 9 || rewrite || isAncestor(r[i], root)) result[result.length] = r[i]
+ }
+ }))
+ return ss.length > 1 && result.length > 1 ? uniq(result) : result
+ }
+ , configure = function (options) {
+ // configNativeQSA: use fully-internal selector or native qSA where present
+ if (typeof options[useNativeQSA] !== 'undefined')
+ select = !options[useNativeQSA] ? selectNonNative : hasQSA ? selectQSA : selectNonNative
+ }
+
+ configure({ useNativeQSA: true })
+
+ qwery.configure = configure
+ qwery.uniq = uniq
+ qwery.is = is
+ qwery.pseudos = {}
+
+ return qwery
+});
View
7 ajax/libs/qwery/3.4.1/qwery.min.js
@@ -0,0 +1,7 @@
+/*!
+ * @preserve Qwery - A Blazing Fast query selector engine
+ * https://github.com/ded/qwery
+ * copyright Dustin Diaz 2012
+ * MIT License
+ */
+(function(e,t,n){typeof module!="undefined"&&module.exports?module.exports=n():typeof define=="function"&&define.amd?define(n):t[e]=n()})("qwery",this,function(){function L(){this.c={}}function D(e){return A.g(e)||A.s(e,"(^|\\s+)"+e+"(\\s+|$)",1)}function P(e,t){var n=0,r=e.length;for(;n<r;n++)t(e[n])}function H(e){for(var t=[],n=0,r=e.length;n<r;++n)$(e[n])?t=t.concat(e[n]):t[t.length]=e[n];return t}function B(e){var t=0,n=e.length,r=[];for(;t<n;t++)r[t]=e[t];return r}function j(e){while(e=e.previousSibling)if(e[u]==1)break;return e}function F(e){return e.match(C)}function I(e,t,n,r,i,s,a,c,h,p,d){var v,m,g,y,b;if(this[u]!==1)return!1;if(t&&t!=="*"&&this[o]&&this[o].toLowerCase()!==t)return!1;if(n&&(m=n.match(f))&&m[1]!==this.id)return!1;if(n&&(b=n.match(l)))for(v=b.length;v--;)if(!D(b[v].slice(1)).test(this.className))return!1;if(h&&Q.pseudos[h]&&!Q.pseudos[h](this,d))return!1;if(r&&!a){y=this.attributes;for(g in y)if(Object.prototype.hasOwnProperty.call(y,g)&&(y[g].name||g)==i)return this}return r&&!R(s,Z(this,i)||"",a)?!1:this}function q(e){return O.g(e)||O.s(e,e.replace(b,"\\$1"))}function R(e,t,n){switch(e){case"=":return t==n;case"^=":return t.match(M.g("^="+n)||M.s("^="+n,"^"+q(n),1));case"$=":return t.match(M.g("$="+n)||M.s("$="+n,q(n)+"$",1));case"*=":return t.match(M.g(n)||M.s(n,q(n),1));case"~=":return t.match(M.g("~="+n)||M.s("~="+n,"(?:^|\\s+)"+q(n)+"(?:\\s+|$)",1));case"|=":return t.match(M.g("|="+n)||M.s("|="+n,"^"+q(n)+"(-|$)",1))}return 0}function U(e,t){var n=[],i=[],s,a,f,l,h,p,d,v,m=t,g=_.g(e)||_.s(e,e.split(N)),y=e.match(T);if(!g.length)return n;l=(g=g.slice(0)).pop(),g.length&&(f=g[g.length-1].match(c))&&(m=K(t,f[1]));if(!m)return n;d=F(l),p=m!==t&&m[u]!==9&&y&&/^[+~]$/.test(y[y.length-1])?function(e){while(m=m.nextSibling)m[u]==1&&(d[1]?d[1]==m[o].toLowerCase():1)&&(e[e.length]=m);return e}([]):m[r](d[1]||"*");for(s=0,a=p.length;s<a;s++)if(v=I.apply(p[s],d))n[n.length]=v;return g.length?(P(n,function(e){W(e,g,y)&&(i[i.length]=e)}),i):n}function z(e,t,n){if(X(t))return e==t;if($(t))return!!~H(t).indexOf(e);var r=t.split(","),i,s;while(t=r.pop()){i=_.g(t)||_.s(t,t.split(N)),s=t.match(T),i=i.slice(0);if(I.apply(e,F(i.pop()))&&(!i.length||W(e,i,s,n)))return!0}return!1}function W(e,t,n,r){function s(e,r,o){while(o=k[n[r]](o,e))if(X(o)&&I.apply(o,F(t[r]))){if(!r)return o;if(i=s(o,r-1,o))return i}}var i;return(i=s(e,t.length-1,e))&&(!r||Y(i,r))}function X(e,t){return e&&typeof e=="object"&&(t=e[u])&&(t==1||t==9)}function V(e){var t=[],n,r;e:for(n=0;n<e.length;++n){for(r=0;r<t.length;++r)if(t[r]==e[n])continue e;t[t.length]=e[n]}return t}function $(e){return typeof e=="object"&&isFinite(e.length)}function J(t){return t?typeof t=="string"?Q(t)[0]:!t[u]&&$(t)?t[0]:t:e}function K(e,t,n){return e[u]===9?e.getElementById(t):e.ownerDocument&&((n=e.ownerDocument.getElementById(t))&&Y(n,e)&&n||!Y(e,e.ownerDocument)&&a('[id="'+t+'"]',e)[0])}function Q(e,t){var i,s,o=J(t);if(!o||!e)return[];if(e===window||X(e))return!t||e!==window&&X(o)&&Y(e,o)?[e]:[];if(e&&$(e))return H(e);if(i=e.match(x)){if(i[1])return(s=K(o,i[1]))?[s]:[];if(i[2])return B(o[r](i[2]));if(et&&i[3])return B(o[n](i[3]))}return a(e,o)}function G(e,t){return function(n){var r,i;if(v.test(n)){e[u]!==9&&((i=r=e.getAttribute("id"))||e.setAttribute("id",i="__qwerymeupscotty"),n='[id="'+i+'"]'+n,t(e.parentNode||e,n,!0),r||e.removeAttribute("id"));return}n.length&&t(e,n,!1)}}var e=document,t=e.documentElement,n="getElementsByClassName",r="getElementsByTagName",i="querySelectorAll",s="useNativeQSA",o="tagName",u="nodeType",a,f=/#([\w\-]+)/,l=/\.[\w\-]+/g,c=/^#([\w\-]+)$/,h=/^\.([\w\-]+)$/,p=/^([\w\-]+)$/,d=/^([\w]+)?\.([\w\-]+)$/,v=/(^|,)\s*[>~+]/,m=/^\s+|\s*([,\s\+\~>]|$)\s*/g,g=/[\s\>\+\~]/,y=/(?![\s\w\-\/\?\&\=\:\.\(\)\!,@#%<>\{\}\$\*\^'"]*\]|[\s\w\+\-]*\))/,b=/([.*+?\^=!:${}()|\[\]\/\\])/g,w=/^(\*|[a-z0-9]+)?(?:([\.\#]+[\w\-\.#]+)?)/,E=/\[([\w\-]+)(?:([\|\^\$\*\~]?\=)['"]?([ \w\-\/\?\&\=\:\.\(\)\!,@#%<>\{\}\$\*\^]+)["']?)?\]/,S=/:([\w\-]+)(\(['"]?([^()]+)['"]?\))?/,x=new RegExp(c.source+"|"+p.source+"|"+h.source),T=new RegExp("("+g.source+")"+y.source,"g"),N=new RegExp(g.source+y.source),C=new RegExp(w.source+"("+E.source+")?"+"("+S.source+")?"),k={" ":function(e){return e&&e!==t&&e.parentNode},">":function(e,t){return e&&e.parentNode==t.parentNode&&e.parentNode},"~":function(e){return e&&e.previousSibling},"+":function(e,t,n,r){return e?(n=j(e))&&(r=j(t))&&n==r&&n:!1}};L.prototype={g:function(e){return this.c[e]||undefined},s:function(e,t,n){return t=n?new RegExp(t):t,this.c[e]=t}};var A=new L,O=new L,M=new L,_=new L,Y="compareDocumentPosition"in t?function(e,t){return(t.compareDocumentPosition(e)&16)==16}:"contains"in t?function(e,n){return n=n[u]===9||n==window?t:n,n!==e&&n.contains(e)}:function(e,t){while(e=e.parentNode)if(e===t)return 1;return 0},Z=function(){var t=e.createElement("p");return(t.innerHTML='<a href="#x">x</a>')&&t.firstChild.getAttribute("href")!="#x"?function(e,t){return t==="class"?e.className:t==="href"||t==="src"?e.getAttribute(t,2):e.getAttribute(t)}:function(e,t){return e.getAttribute(t)}}(),et=!!e[n],tt=e.querySelector&&e[i],nt=function(e,t){var n=[],r,s;try{return t[u]===9||!v.test(e)?B(t[i](e)):(P(r=e.split(","),G(t,function(e,t){s=e[i](t),s.length==1?n[n.length]=s.item(0):s.length&&(n=n.concat(B(s)))})),r.length>1&&n.length>1?V(n):n)}catch(o){}return rt(e,t)},rt=function(e,t){var n=[],i,s,o,a,f,l;e=e.replace(m,"$1");if(s=e.match(d)){f=D(s[2]),i=t[r](s[1]||"*");for(o=0,a=i.length;o<a;o++)f.test(i[o].className)&&(n[n.length]=i[o]);return n}return P(l=e.split(","),G(t,function(e,r,i){f=U(r,e);for(o=0,a=f.length;o<a;o++)if(e[u]===9||i||Y(f[o],t))n[n.length]=f[o]})),l.length>1&&n.length>1?V(n):n},it=function(e){typeof e[s]!="undefined"&&(a=e[s]?tt?nt:rt:rt)};return it({useNativeQSA:!0}),Q.configure=it,Q.uniq=V,Q.is=z,Q.pseudos={},Q})
View
25 ajax/libs/qwery/package.json
@@ -0,0 +1,25 @@
+{
+ "name": "qwery"
+ , "description": "blazing fast CSS3 query selector engine"
+ , "version": "3.4.1"
+ , "homepage": "https://github.com/ded/qwery"
+ , "author": "Dustin Diaz <dustin@dustindiaz.com> (http://dustindiaz.com)"
+ , "contributors": [
+ "Jacob Thornton <> (https://github.com/fat)"
+ , "Rod Vagg <> (https://github.com/rvagg)"
+ , "Andrew McCollum <> (https://github.com/amccollum)"
+ ]
+ , "filename": "./qwery.js"
+ , "keywords": ["ender", "query", "css", "selector engine"]
+ , "ender": "./src/ender.js"
+ , "repository": {
+ "type": "git"
+ , "url": "https://github.com/ded/qwery.git"
+ }
+ , "devDependencies": {
+ "sink-test": ">= 1.0.1"
+ , "serve": "*"
+ , "smoosh": "0.4.0"
+ , "phantomjs": "0.2.3"
+ }
+}

0 comments on commit ed38012

Please sign in to comment.
Something went wrong with that request. Please try again.