├── .gcloudignore ├── .gitignore ├── resources ├── static │ ├── favicon.ico │ ├── images │ │ ├── loader.gif │ │ ├── example1.png │ │ ├── example2.png │ │ ├── example3.png │ │ ├── example4.png │ │ ├── example5.png │ │ ├── example6.png │ │ ├── example6a.png │ │ ├── example7.png │ │ └── example7a.png │ ├── js │ │ ├── profiling │ │ │ ├── charts.swf │ │ │ ├── config.js │ │ │ ├── yahoo-profiling.css │ │ │ └── yahoo-profiling.min.js │ │ ├── plugins.js │ │ ├── script.js │ │ └── libs │ │ │ ├── dd_belatedpng.js │ │ │ ├── modernizr-1.6.min.js │ │ │ └── jquery-1.4.2.min.js │ └── robots.txt └── templates │ ├── contact.html │ ├── about.html │ ├── 404.html │ ├── links.html │ ├── index.html │ ├── graph.html │ ├── base.html │ ├── reference.html │ └── example.html ├── queue.yaml ├── requirements.txt ├── app.yaml ├── README.md ├── LICENSE ├── main.py └── graph.py /.gcloudignore: -------------------------------------------------------------------------------- 1 | queue.yaml 2 | lib 3 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | tmp/* 2 | */.svn 3 | .svn 4 | *.swp 5 | */*.pyc 6 | *.pyc 7 | creds.json -------------------------------------------------------------------------------- /resources/static/favicon.ico: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/grevian/GraphViz-Site/HEAD/resources/static/favicon.ico -------------------------------------------------------------------------------- /resources/static/images/loader.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/grevian/GraphViz-Site/HEAD/resources/static/images/loader.gif -------------------------------------------------------------------------------- /resources/static/images/example1.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/grevian/GraphViz-Site/HEAD/resources/static/images/example1.png -------------------------------------------------------------------------------- /resources/static/images/example2.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/grevian/GraphViz-Site/HEAD/resources/static/images/example2.png -------------------------------------------------------------------------------- /resources/static/images/example3.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/grevian/GraphViz-Site/HEAD/resources/static/images/example3.png -------------------------------------------------------------------------------- /resources/static/images/example4.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/grevian/GraphViz-Site/HEAD/resources/static/images/example4.png -------------------------------------------------------------------------------- /resources/static/images/example5.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/grevian/GraphViz-Site/HEAD/resources/static/images/example5.png -------------------------------------------------------------------------------- /resources/static/images/example6.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/grevian/GraphViz-Site/HEAD/resources/static/images/example6.png -------------------------------------------------------------------------------- /resources/static/images/example6a.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/grevian/GraphViz-Site/HEAD/resources/static/images/example6a.png -------------------------------------------------------------------------------- /resources/static/images/example7.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/grevian/GraphViz-Site/HEAD/resources/static/images/example7.png -------------------------------------------------------------------------------- /resources/static/images/example7a.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/grevian/GraphViz-Site/HEAD/resources/static/images/example7a.png -------------------------------------------------------------------------------- /resources/static/js/profiling/charts.swf: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/grevian/GraphViz-Site/HEAD/resources/static/js/profiling/charts.swf -------------------------------------------------------------------------------- /queue.yaml: -------------------------------------------------------------------------------- 1 | # Keep tasks from retrying forever 2 | queue: 3 | - name: default 4 | rate: 5/s 5 | retry_parameters: 6 | task_retry_limit: 3 7 | -------------------------------------------------------------------------------- /requirements.txt: -------------------------------------------------------------------------------- 1 | google-cloud-tasks 2 | google-cloud-datastore 3 | google-cloud-storage 4 | googleapis_common_protos 5 | requests 6 | jinja2 7 | flask -------------------------------------------------------------------------------- /resources/static/robots.txt: -------------------------------------------------------------------------------- 1 | # www.robotstxt.org/ 2 | # www.google.com/support/webmasters/bin/answer.py?hl=en&answer=156449 3 | 4 | User-agent: * 5 | Disallow: /graph/* 6 | 7 | -------------------------------------------------------------------------------- /resources/templates/contact.html: -------------------------------------------------------------------------------- 1 | {% extends "base.html" %} 2 | {% block content %} 3 |
My name is Josh Hayes-Sheen, and you can email me if you'd like, 5 | otherwise please use the form below to get in touch. 6 |
7 |This site runs on Google App Engine
5 | and is styled with Bootstrap, It uses a small containerized renderer to create charts based on
6 | GraphViz.
7 |
8 | The source code to this site is open and available here
9 |
:(
24 |Here's some links you may find relevant 5 |
Some clever people recognized that CS Majors suck at drawing, but still often need to draw graphs. Those 6 | noble souls 7 | made a program to draw graphs for us called GraphViz, it's free, open 8 | source, and great, 9 | but not incredibly easy to use, So I threw this web interface and tutorial on top of it to make it easy 10 | for us to make graphs for our assignments.
11 |Convert a simple language that describes graphs, to pretty pictures of graphs.
13 | 14 |
17 |
18 | graph {
19 | a -- b;
20 | b -- c;
21 | a -- c;
22 | d -- c;
23 | e -- c;
24 | e -- a;
25 | }
26 |
27 |
28 |
33 | Take a look at some Examples to see how this works, Then open the 39 | reference and the Graph page and go to work. 40 |
41 |Enter your DOT definition in the box below, and click Generate to display the resulting graph.
30 | {% else %}
31 | 34 | Error: 35 | 36 | {{ error|e }} 37 | 38 |
39 |6 | Graphs and Vertices (Called Nodes in the GraphViz notation) may have a large number of attributes 7 | that affect both the graph's actual layout, and details like colours, labels, and line types. 8 | I cover a few of the attributes below but for a full reference see the 10 | GraphViz Attribute Index 11 |
12 |label="My Graph";Label a graph itselfrankdir=LR;Lay the graph out from Left to Right, instead of Top to
18 | Bottom
19 | {rank=same; a, b, c }Group nodes together at the same level of a graph
21 | splines="line";Force edges to be straight, no curves or anglesK=0.6;Used to influence the 'spring' used in the layout, Can be used to
24 | push
25 | nodes further apart,
26 | which is especially useful for twopi and sfdp layouts
27 | [label="Some Label"]Labels the Vertex[color="red"]Colors the Vertex[fillcolor="blue"]Fills the Vertex with the specified colour[label="Some Label"]Labels the Edge (Useful for Weights)[color="red"]Colors the Vertex (Useful for Paths)[penwidth=2.0]Adjusts the thickness of the edge line, Very useful for
40 | Paths
41 | weight attribute, defined as
44 | [weight=0.5] for example,
45 | but note that this doesn't display the weight directly, It instead acts as a hint to the graph layout to
46 | give this
47 | edge a more
48 | direct routing.
49 | graph or a digraph
53 | using
54 | fairly standard syntax, similar to an edge list. graph {
56 | node1 -- node2;
57 | node3 -- node2;
58 | }
59 | digraph {
61 | node1 -> node2;
62 | node3 -> node2;
63 | }
64 |
65 | A, B, C, Test, Vertice1,
69 | some_vertex
70 | , etc.
71 | If you need a more complicated label you can declare the vertex first, before defining an edge, and give it
72 | a label
73 | attribute,
74 | for example: digraph {
76 | someVertex[label="A Complicated Label"];
77 | someVertex -> node2;
78 | node2 -> node3;
79 | }
80 | digraph {
87 | node1 -> node2[color="red"];
88 | }
89 | digraph {
93 | node1 -> node2[label="0.2"];
94 | node2 -> node3[label="0.2"];
95 | }
96 |
97 | digraph {
100 | node1 -> node2[label="edge1"];
101 | node2 -> node3[label="edge2"];
102 | }
103 |
104 | digraph {
107 | node1[label="Some Complicated Label"];
108 | node1 -> node2[label="An Edge",color=red];
109 | node2 -> node3;
110 | }
111 |
112 | GraphViz uses the DOT language to describe graphs, Below are examples
5 | of the language, with their resulting outputs.
22 |
23 | graph {
24 | a -- b;
25 | b -- c;
26 | a -- c;
27 | d -- c;
28 | e -- c;
29 | e -- a;
30 | }
31 |
32 |
33 |
36 |
46 |
47 | graph {
48 | a -- b;
49 | b -- c;
50 | c -- d;
51 | d -- e;
52 | e -- f;
53 | a -- f;
54 | a -- c;
55 | a -- d;
56 | a -- e;
57 | b -- d;
58 | b -- e;
59 | b -- f;
60 | c -- e;
61 | c -- f;
62 | d -- f;
63 | }
64 |
65 |
66 |
70 |
81 |
82 | digraph {
83 | a -> b;
84 | b -> c;
85 | c -> d;
86 | d -> a;
87 | }
88 |
89 |
90 |
94 |
106 |
107 | digraph {
108 | a -> b[label="0.2",weight="0.2"];
109 | a -> c[label="0.4",weight="0.4"];
110 | c -> b[label="0.6",weight="0.6"];
111 | c -> e[label="0.6",weight="0.6"];
112 | e -> e[label="0.1",weight="0.1"];
113 | e -> b[label="0.7",weight="0.7"];
114 | }
115 |
116 |
117 |
121 |
132 |
133 | graph {
134 | a -- b[color=red,penwidth=3.0];
135 | b -- c;
136 | c -- d[color=red,penwidth=3.0];
137 | d -- e;
138 | e -- f;
139 | a -- d;
140 | b -- d[color=red,penwidth=3.0];
141 | c -- f[color=red,penwidth=3.0];
142 | }
143 |
144 |
145 | Note that there's also a shorthand method as follows:
146 |
147 |
148 | graph {
149 | a -- b -- d -- c -- f[color=red,penwidth=3.0];
150 | b -- c;
151 | d -- e;
152 | e -- f;
153 | a -- d;
154 | }
155 |
156 |
157 |
161 | cluster_ as shown below, and second only the
171 | DOT and FDP
172 | layout methods seem to support subgraphs (See the graph generation page for more information on the layout
173 | methods)
174 |
177 |
178 | digraph {
179 | subgraph cluster_0 {
180 | label="Subgraph A";
181 | a -> b;
182 | b -> c;
183 | c -> d;
184 | }
185 |
186 | subgraph cluster_1 {
187 | label="Subgraph B";
188 | a -> f;
189 | f -> c;
190 | }
191 | }
192 |
193 |
194 |
197 | splines=line; to specify that edges should be drawn
201 | only as straight lines, no curves allowed.
202 |
205 |
206 | graph {
207 | splines=line;
208 | subgraph cluster_0 {
209 | label="Subgraph A";
210 | a; b; c
211 | }
212 |
213 | subgraph cluster_1 {
214 | label="Subgraph B";
215 | d; e;
216 | }
217 |
218 | a -- e;
219 | a -- d;
220 | b -- d;
221 | b -- e;
222 | c -- d;
223 | c -- e;
224 | }
225 |
226 |
227 |
230 |
243 |
244 | graph {
245 | rankdir=LR; // Left to Right, instead of Top to Bottom
246 | a -- { b c d };
247 | b -- { c e };
248 | c -- { e f };
249 | d -- { f g };
250 | e -- h;
251 | f -- { h i j g };
252 | g -- k;
253 | h -- { o l };
254 | i -- { l m j };
255 | j -- { m n k };
256 | k -- { n r };
257 | l -- { o m };
258 | m -- { o p n };
259 | n -- { q r };
260 | o -- { s p };
261 | p -- { s t q };
262 | q -- { t r };
263 | r -- t;
264 | s -- z;
265 | t -- z;
266 | }
267 |
268 |
269 | 
282 |
283 | graph {
284 | rankdir=LR;
285 | a -- { b c d }; b -- { c e }; c -- { e f }; d -- { f g }; e -- h;
286 | f -- { h i j g }; g -- k; h -- { o l }; i -- { l m j }; j -- { m n k };
287 | k -- { n r }; l -- { o m }; m -- { o p n }; n -- { q r };
288 | o -- { s p }; p -- { s t q }; q -- { t r }; r -- t; s -- z; t -- z;
289 | { rank=same; b, c, d }
290 | { rank=same; e, f, g }
291 | { rank=same; h, i, j, k }
292 | { rank=same; l, m, n }
293 | { rank=same; o, p, q, r }
294 | { rank=same; s, t }
295 | }
296 |
297 |
298 |
301 | =0))l||m.push(v);else if(l)h[p]=false;return false},ID:function(g){return g[1].replace(/\\/g,"")},TAG:function(g){return g[1].toLowerCase()}, 80 | CHILD:function(g){if(g[1]==="nth"){var h=/(-?)(\d*)n((?:\+|-)?\d*)/.exec(g[2]==="even"&&"2n"||g[2]==="odd"&&"2n+1"||!/\D/.test(g[2])&&"0n+"+g[2]||g[2]);g[2]=h[1]+(h[2]||1)-0;g[3]=h[3]-0}g[0]=e++;return g},ATTR:function(g,h,l,m,q,p){h=g[1].replace(/\\/g,"");if(!p&&n.attrMap[h])g[1]=n.attrMap[h];if(g[2]==="~=")g[4]=" "+g[4]+" ";return g},PSEUDO:function(g,h,l,m,q){if(g[1]==="not")if((f.exec(g[3])||"").length>1||/^\w/.test(g[3]))g[3]=k(g[3],null,null,h);else{g=k.filter(g[3],h,l,true^q);l||m.push.apply(m, 81 | g);return false}else if(n.match.POS.test(g[0])||n.match.CHILD.test(g[0]))return true;return g},POS:function(g){g.unshift(true);return g}},filters:{enabled:function(g){return g.disabled===false&&g.type!=="hidden"},disabled:function(g){return g.disabled===true},checked:function(g){return g.checked===true},selected:function(g){return g.selected===true},parent:function(g){return!!g.firstChild},empty:function(g){return!g.firstChild},has:function(g,h,l){return!!k(l[3],g).length},header:function(g){return/h\d/i.test(g.nodeName)}, 82 | text:function(g){return"text"===g.type},radio:function(g){return"radio"===g.type},checkbox:function(g){return"checkbox"===g.type},file:function(g){return"file"===g.type},password:function(g){return"password"===g.type},submit:function(g){return"submit"===g.type},image:function(g){return"image"===g.type},reset:function(g){return"reset"===g.type},button:function(g){return"button"===g.type||g.nodeName.toLowerCase()==="button"},input:function(g){return/input|select|textarea|button/i.test(g.nodeName)}}, 83 | setFilters:{first:function(g,h){return h===0},last:function(g,h,l,m){return h===m.length-1},even:function(g,h){return h%2===0},odd:function(g,h){return h%2===1},lt:function(g,h,l){return hl[3]-0},nth:function(g,h,l){return l[3]-0===h},eq:function(g,h,l){return l[3]-0===h}},filter:{PSEUDO:function(g,h,l,m){var q=h[1],p=n.filters[q];if(p)return p(g,l,h,m);else if(q==="contains")return(g.textContent||g.innerText||a([g])||"").indexOf(h[3])>=0;else if(q==="not"){h= 84 | h[3];l=0;for(m=h.length;l =0}},ID:function(g,h){return g.nodeType===1&&g.getAttribute("id")===h},TAG:function(g,h){return h==="*"&&g.nodeType===1||g.nodeName.toLowerCase()===h},CLASS:function(g,h){return(" "+(g.className||g.getAttribute("class"))+" ").indexOf(h)>-1},ATTR:function(g,h){var l=h[1];g=n.attrHandle[l]?n.attrHandle[l](g):g[l]!=null?g[l]:g.getAttribute(l);l=g+"";var m=h[2];h=h[4];return g==null?m==="!=":m=== 86 | "="?l===h:m==="*="?l.indexOf(h)>=0:m==="~="?(" "+l+" ").indexOf(h)>=0:!h?l&&g!==false:m==="!="?l!==h:m==="^="?l.indexOf(h)===0:m==="$="?l.substr(l.length-h.length)===h:m==="|="?l===h||l.substr(0,h.length+1)===h+"-":false},POS:function(g,h,l,m){var q=n.setFilters[h[2]];if(q)return q(g,l,h,m)}}},r=n.match.POS;for(var u in n.match){n.match[u]=new RegExp(n.match[u].source+/(?![^\[]*\])(?![^\(]*\))/.source);n.leftMatch[u]=new RegExp(/(^(?:.|\r|\n)*?)/.source+n.match[u].source.replace(/\\(\d+)/g,function(g, 87 | h){return"\\"+(h-0+1)}))}var z=function(g,h){g=Array.prototype.slice.call(g,0);if(h){h.push.apply(h,g);return h}return g};try{Array.prototype.slice.call(s.documentElement.childNodes,0)}catch(C){z=function(g,h){h=h||[];if(j.call(g)==="[object Array]")Array.prototype.push.apply(h,g);else if(typeof g.length==="number")for(var l=0,m=g.length;l ";var l=s.documentElement;l.insertBefore(g,l.firstChild);if(s.getElementById(h)){n.find.ID=function(m,q,p){if(typeof q.getElementById!=="undefined"&&!p)return(q=q.getElementById(m[1]))?q.id===m[1]||typeof q.getAttributeNode!=="undefined"&& 90 | q.getAttributeNode("id").nodeValue===m[1]?[q]:w:[]};n.filter.ID=function(m,q){var p=typeof m.getAttributeNode!=="undefined"&&m.getAttributeNode("id");return m.nodeType===1&&p&&p.nodeValue===q}}l.removeChild(g);l=g=null})();(function(){var g=s.createElement("div");g.appendChild(s.createComment(""));if(g.getElementsByTagName("*").length>0)n.find.TAG=function(h,l){l=l.getElementsByTagName(h[1]);if(h[1]==="*"){h=[];for(var m=0;l[m];m++)l[m].nodeType===1&&h.push(l[m]);l=h}return l};g.innerHTML=""; 91 | if(g.firstChild&&typeof g.firstChild.getAttribute!=="undefined"&&g.firstChild.getAttribute("href")!=="#")n.attrHandle.href=function(h){return h.getAttribute("href",2)};g=null})();s.querySelectorAll&&function(){var g=k,h=s.createElement("div");h.innerHTML="";if(!(h.querySelectorAll&&h.querySelectorAll(".TEST").length===0)){k=function(m,q,p,v){q=q||s;if(!v&&q.nodeType===9&&!x(q))try{return z(q.querySelectorAll(m),p)}catch(t){}return g(m,q,p,v)};for(var l in g)k[l]=g[l];h=null}}(); 92 | (function(){var g=s.createElement("div");g.innerHTML="";if(!(!g.getElementsByClassName||g.getElementsByClassName("e").length===0)){g.lastChild.className="e";if(g.getElementsByClassName("e").length!==1){n.order.splice(1,0,"CLASS");n.find.CLASS=function(h,l,m){if(typeof l.getElementsByClassName!=="undefined"&&!m)return l.getElementsByClassName(h[1])};g=null}}})();var E=s.compareDocumentPosition?function(g,h){return!!(g.compareDocumentPosition(h)&16)}: 93 | function(g,h){return g!==h&&(g.contains?g.contains(h):true)},x=function(g){return(g=(g?g.ownerDocument||g:0).documentElement)?g.nodeName!=="HTML":false},ga=function(g,h){var l=[],m="",q;for(h=h.nodeType?[h]:h;q=n.match.PSEUDO.exec(g);){m+=q[0];g=g.replace(n.match.PSEUDO,"")}g=n.relative[g]?g+"*":g;q=0;for(var p=h.length;q =0===d})};c.fn.extend({find:function(a){for(var b=this.pushStack("","find",a),d=0,f=0,e=this.length;f
0)for(var j=d;j 0},closest:function(a,b){if(c.isArray(a)){var d=[],f=this[0],e,j= 96 | {},i;if(f&&a.length){e=0;for(var o=a.length;e -1:c(f).is(e)){d.push({selector:i,elem:f});delete j[i]}}f=f.parentNode}}return d}var k=c.expr.match.POS.test(a)?c(a,b||this.context):null;return this.map(function(n,r){for(;r&&r.ownerDocument&&r!==b;){if(k?k.index(r)>-1:c(r).is(a))return r;r=r.parentNode}return null})},index:function(a){if(!a||typeof a=== 97 | "string")return c.inArray(this[0],a?c(a):this.parent().children());return c.inArray(a.jquery?a[0]:a,this)},add:function(a,b){a=typeof a==="string"?c(a,b||this.context):c.makeArray(a);b=c.merge(this.get(),a);return this.pushStack(qa(a[0])||qa(b[0])?b:c.unique(b))},andSelf:function(){return this.add(this.prevObject)}});c.each({parent:function(a){return(a=a.parentNode)&&a.nodeType!==11?a:null},parents:function(a){return c.dir(a,"parentNode")},parentsUntil:function(a,b,d){return c.dir(a,"parentNode", 98 | d)},next:function(a){return c.nth(a,2,"nextSibling")},prev:function(a){return c.nth(a,2,"previousSibling")},nextAll:function(a){return c.dir(a,"nextSibling")},prevAll:function(a){return c.dir(a,"previousSibling")},nextUntil:function(a,b,d){return c.dir(a,"nextSibling",d)},prevUntil:function(a,b,d){return c.dir(a,"previousSibling",d)},siblings:function(a){return c.sibling(a.parentNode.firstChild,a)},children:function(a){return c.sibling(a.firstChild)},contents:function(a){return c.nodeName(a,"iframe")? 99 | a.contentDocument||a.contentWindow.document:c.makeArray(a.childNodes)}},function(a,b){c.fn[a]=function(d,f){var e=c.map(this,b,d);eb.test(a)||(f=d);if(f&&typeof f==="string")e=c.filter(f,e);e=this.length>1?c.unique(e):e;if((this.length>1||gb.test(f))&&fb.test(a))e=e.reverse();return this.pushStack(e,a,R.call(arguments).join(","))}});c.extend({filter:function(a,b,d){if(d)a=":not("+a+")";return c.find.matches(a,b)},dir:function(a,b,d){var f=[];for(a=a[b];a&&a.nodeType!==9&&(d===w||a.nodeType!==1||!c(a).is(d));){a.nodeType=== 100 | 1&&f.push(a);a=a[b]}return f},nth:function(a,b,d){b=b||1;for(var f=0;a;a=a[d])if(a.nodeType===1&&++f===b)break;return a},sibling:function(a,b){for(var d=[];a;a=a.nextSibling)a.nodeType===1&&a!==b&&d.push(a);return d}});var Ja=/ jQuery\d+="(?:\d+|null)"/g,V=/^\s+/,Ka=/(<([\w:]+)[^>]*?)\/>/g,hb=/^(?:area|br|col|embed|hr|img|input|link|meta|param)$/i,La=/<([\w:]+)/,ib=/"+d+">"},F={option:[1,""],legend:[1,""],thead:[1," ","
"],tr:[2,"","
"],td:[3,""],col:[2,"
"," "],area:[1,""],_default:[0,"",""]};F.optgroup=F.option;F.tbody=F.tfoot=F.colgroup=F.caption=F.thead;F.th=F.td;if(!c.support.htmlSerialize)F._default=[1,"div
"," ",""];c.fn.extend({text:function(a){if(c.isFunction(a))return this.each(function(b){var d= 102 | c(this);d.text(a.call(this,b,d.text()))});if(typeof a!=="object"&&a!==w)return this.empty().append((this[0]&&this[0].ownerDocument||s).createTextNode(a));return c.text(this)},wrapAll:function(a){if(c.isFunction(a))return this.each(function(d){c(this).wrapAll(a.call(this,d))});if(this[0]){var b=c(a,this[0].ownerDocument).eq(0).clone(true);this[0].parentNode&&b.insertBefore(this[0]);b.map(function(){for(var d=this;d.firstChild&&d.firstChild.nodeType===1;)d=d.firstChild;return d}).append(this)}return this}, 103 | wrapInner:function(a){if(c.isFunction(a))return this.each(function(b){c(this).wrapInner(a.call(this,b))});return this.each(function(){var b=c(this),d=b.contents();d.length?d.wrapAll(a):b.append(a)})},wrap:function(a){return this.each(function(){c(this).wrapAll(a)})},unwrap:function(){return this.parent().each(function(){c.nodeName(this,"body")||c(this).replaceWith(this.childNodes)}).end()},append:function(){return this.domManip(arguments,true,function(a){this.nodeType===1&&this.appendChild(a)})}, 104 | prepend:function(){return this.domManip(arguments,true,function(a){this.nodeType===1&&this.insertBefore(a,this.firstChild)})},before:function(){if(this[0]&&this[0].parentNode)return this.domManip(arguments,false,function(b){this.parentNode.insertBefore(b,this)});else if(arguments.length){var a=c(arguments[0]);a.push.apply(a,this.toArray());return this.pushStack(a,"before",arguments)}},after:function(){if(this[0]&&this[0].parentNode)return this.domManip(arguments,false,function(b){this.parentNode.insertBefore(b, 105 | this.nextSibling)});else if(arguments.length){var a=this.pushStack(this,"after",arguments);a.push.apply(a,c(arguments[0]).toArray());return a}},remove:function(a,b){for(var d=0,f;(f=this[d])!=null;d++)if(!a||c.filter(a,[f]).length){if(!b&&f.nodeType===1){c.cleanData(f.getElementsByTagName("*"));c.cleanData([f])}f.parentNode&&f.parentNode.removeChild(f)}return this},empty:function(){for(var a=0,b;(b=this[a])!=null;a++)for(b.nodeType===1&&c.cleanData(b.getElementsByTagName("*"));b.firstChild;)b.removeChild(b.firstChild); 106 | return this},clone:function(a){var b=this.map(function(){if(!c.support.noCloneEvent&&!c.isXMLDoc(this)){var d=this.outerHTML,f=this.ownerDocument;if(!d){d=f.createElement("div");d.appendChild(this.cloneNode(true));d=d.innerHTML}return c.clean([d.replace(Ja,"").replace(/=([^="'>\s]+\/)>/g,'="$1">').replace(V,"")],f)[0]}else return this.cloneNode(true)});if(a===true){ra(this,b);ra(this.find("*"),b.find("*"))}return b},html:function(a){if(a===w)return this[0]&&this[0].nodeType===1?this[0].innerHTML.replace(Ja, 107 | ""):null;else if(typeof a==="string"&&!ta.test(a)&&(c.support.leadingWhitespace||!V.test(a))&&!F[(La.exec(a)||["",""])[1].toLowerCase()]){a=a.replace(Ka,Ma);try{for(var b=0,d=this.length;b0||e.cacheable||this.length>1?k.cloneNode(true):k)}o.length&&c.each(o,Qa)}return this}});c.fragments={};c.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(a,b){c.fn[a]=function(d){var f=[];d=c(d);var e=this.length===1&&this[0].parentNode;if(e&&e.nodeType===11&&e.childNodes.length===1&&d.length===1){d[b](this[0]); 111 | return this}else{e=0;for(var j=d.length;e 0?this.clone(true):this).get();c.fn[b].apply(c(d[e]),i);f=f.concat(i)}return this.pushStack(f,a,d.selector)}}});c.extend({clean:function(a,b,d,f){b=b||s;if(typeof b.createElement==="undefined")b=b.ownerDocument||b[0]&&b[0].ownerDocument||s;for(var e=[],j=0,i;(i=a[j])!=null;j++){if(typeof i==="number")i+="";if(i){if(typeof i==="string"&&!jb.test(i))i=b.createTextNode(i);else if(typeof i==="string"){i=i.replace(Ka,Ma);var o=(La.exec(i)||["", 112 | ""])[1].toLowerCase(),k=F[o]||F._default,n=k[0],r=b.createElement("div");for(r.innerHTML=k[1]+i+k[2];n--;)r=r.lastChild;if(!c.support.tbody){n=ib.test(i);o=o==="table"&&!n?r.firstChild&&r.firstChild.childNodes:k[1]===" "&&!n?r.childNodes:[];for(k=o.length-1;k>=0;--k)c.nodeName(o[k],"tbody")&&!o[k].childNodes.length&&o[k].parentNode.removeChild(o[k])}!c.support.leadingWhitespace&&V.test(i)&&r.insertBefore(b.createTextNode(V.exec(i)[0]),r.firstChild);i=r.childNodes}if(i.nodeType)e.push(i);else e= 113 | c.merge(e,i)}}if(d)for(j=0;e[j];j++)if(f&&c.nodeName(e[j],"script")&&(!e[j].type||e[j].type.toLowerCase()==="text/javascript"))f.push(e[j].parentNode?e[j].parentNode.removeChild(e[j]):e[j]);else{e[j].nodeType===1&&e.splice.apply(e,[j+1,0].concat(c.makeArray(e[j].getElementsByTagName("script"))));d.appendChild(e[j])}return e},cleanData:function(a){for(var b,d,f=c.cache,e=c.event.special,j=c.support.deleteExpando,i=0,o;(o=a[i])!=null;i++)if(d=o[c.expando]){b=f[d];if(b.events)for(var k in b.events)e[k]? 114 | c.event.remove(o,k):Ca(o,k,b.handle);if(j)delete o[c.expando];else o.removeAttribute&&o.removeAttribute(c.expando);delete f[d]}}});var kb=/z-?index|font-?weight|opacity|zoom|line-?height/i,Na=/alpha\([^)]*\)/,Oa=/opacity=([^)]*)/,ha=/float/i,ia=/-([a-z])/ig,lb=/([A-Z])/g,mb=/^-?\d+(?:px)?$/i,nb=/^-?\d/,ob={position:"absolute",visibility:"hidden",display:"block"},pb=["Left","Right"],qb=["Top","Bottom"],rb=s.defaultView&&s.defaultView.getComputedStyle,Pa=c.support.cssFloat?"cssFloat":"styleFloat",ja= 115 | function(a,b){return b.toUpperCase()};c.fn.css=function(a,b){return X(this,a,b,true,function(d,f,e){if(e===w)return c.curCSS(d,f);if(typeof e==="number"&&!kb.test(f))e+="px";c.style(d,f,e)})};c.extend({style:function(a,b,d){if(!a||a.nodeType===3||a.nodeType===8)return w;if((b==="width"||b==="height")&&parseFloat(d)<0)d=w;var f=a.style||a,e=d!==w;if(!c.support.opacity&&b==="opacity"){if(e){f.zoom=1;b=parseInt(d,10)+""==="NaN"?"":"alpha(opacity="+d*100+")";a=f.filter||c.curCSS(a,"filter")||"";f.filter= 116 | Na.test(a)?a.replace(Na,b):b}return f.filter&&f.filter.indexOf("opacity=")>=0?parseFloat(Oa.exec(f.filter)[1])/100+"":""}if(ha.test(b))b=Pa;b=b.replace(ia,ja);if(e)f[b]=d;return f[b]},css:function(a,b,d,f){if(b==="width"||b==="height"){var e,j=b==="width"?pb:qb;function i(){e=b==="width"?a.offsetWidth:a.offsetHeight;f!=="border"&&c.each(j,function(){f||(e-=parseFloat(c.curCSS(a,"padding"+this,true))||0);if(f==="margin")e+=parseFloat(c.curCSS(a,"margin"+this,true))||0;else e-=parseFloat(c.curCSS(a, 117 | "border"+this+"Width",true))||0})}a.offsetWidth!==0?i():c.swap(a,ob,i);return Math.max(0,Math.round(e))}return c.curCSS(a,b,d)},curCSS:function(a,b,d){var f,e=a.style;if(!c.support.opacity&&b==="opacity"&&a.currentStyle){f=Oa.test(a.currentStyle.filter||"")?parseFloat(RegExp.$1)/100+"":"";return f===""?"1":f}if(ha.test(b))b=Pa;if(!d&&e&&e[b])f=e[b];else if(rb){if(ha.test(b))b="float";b=b.replace(lb,"-$1").toLowerCase();e=a.ownerDocument.defaultView;if(!e)return null;if(a=e.getComputedStyle(a,null))f= 118 | a.getPropertyValue(b);if(b==="opacity"&&f==="")f="1"}else if(a.currentStyle){d=b.replace(ia,ja);f=a.currentStyle[b]||a.currentStyle[d];if(!mb.test(f)&&nb.test(f)){b=e.left;var j=a.runtimeStyle.left;a.runtimeStyle.left=a.currentStyle.left;e.left=d==="fontSize"?"1em":f||0;f=e.pixelLeft+"px";e.left=b;a.runtimeStyle.left=j}}return f},swap:function(a,b,d){var f={};for(var e in b){f[e]=a.style[e];a.style[e]=b[e]}d.call(a);for(e in b)a.style[e]=f[e]}});if(c.expr&&c.expr.filters){c.expr.filters.hidden=function(a){var b= 119 | a.offsetWidth,d=a.offsetHeight,f=a.nodeName.toLowerCase()==="tr";return b===0&&d===0&&!f?true:b>0&&d>0&&!f?false:c.curCSS(a,"display")==="none"};c.expr.filters.visible=function(a){return!c.expr.filters.hidden(a)}}var sb=J(),tb=/