diff --git a/build/doctrees/cgdb.doctree b/build/doctrees/cgdb.doctree new file mode 100644 index 0000000..b0e8e01 Binary files /dev/null and b/build/doctrees/cgdb.doctree differ diff --git a/build/doctrees/cgdb_in_depth.doctree b/build/doctrees/cgdb_in_depth.doctree new file mode 100644 index 0000000..4182751 Binary files /dev/null and b/build/doctrees/cgdb_in_depth.doctree differ diff --git a/build/doctrees/collision.doctree b/build/doctrees/collision.doctree new file mode 100644 index 0000000..4f6b3be Binary files /dev/null and b/build/doctrees/collision.doctree differ diff --git a/build/doctrees/data_files.doctree b/build/doctrees/data_files.doctree new file mode 100644 index 0000000..cf4f959 Binary files /dev/null and b/build/doctrees/data_files.doctree differ diff --git a/build/doctrees/data_files_bodies.doctree b/build/doctrees/data_files_bodies.doctree new file mode 100644 index 0000000..70a8d72 Binary files /dev/null and b/build/doctrees/data_files_bodies.doctree differ diff --git a/build/doctrees/data_files_robots.doctree b/build/doctrees/data_files_robots.doctree new file mode 100644 index 0000000..6ea9134 Binary files /dev/null and b/build/doctrees/data_files_robots.doctree differ diff --git a/build/doctrees/data_files_worlds.doctree b/build/doctrees/data_files_worlds.doctree new file mode 100644 index 0000000..344ff30 Binary files /dev/null and b/build/doctrees/data_files_worlds.doctree differ diff --git a/build/doctrees/dynamics.doctree b/build/doctrees/dynamics.doctree new file mode 100644 index 0000000..07584f6 Binary files /dev/null and b/build/doctrees/dynamics.doctree differ diff --git a/build/doctrees/eigengrasps.doctree b/build/doctrees/eigengrasps.doctree new file mode 100644 index 0000000..0ee32c2 Binary files /dev/null and b/build/doctrees/eigengrasps.doctree differ diff --git a/build/doctrees/environment.pickle b/build/doctrees/environment.pickle new file mode 100644 index 0000000..a5d4d2b Binary files /dev/null and b/build/doctrees/environment.pickle differ diff --git a/build/doctrees/getting_started.doctree b/build/doctrees/getting_started.doctree new file mode 100644 index 0000000..72e64f0 Binary files /dev/null and b/build/doctrees/getting_started.doctree differ diff --git a/build/doctrees/gfo.doctree b/build/doctrees/gfo.doctree new file mode 100644 index 0000000..0876a5f Binary files /dev/null and b/build/doctrees/gfo.doctree differ diff --git a/build/doctrees/grasp_planning.doctree b/build/doctrees/grasp_planning.doctree new file mode 100644 index 0000000..a44205b Binary files /dev/null and b/build/doctrees/grasp_planning.doctree differ diff --git a/build/doctrees/grasp_planning_eg.doctree b/build/doctrees/grasp_planning_eg.doctree new file mode 100644 index 0000000..dc3b464 Binary files /dev/null and b/build/doctrees/grasp_planning_eg.doctree differ diff --git a/build/doctrees/grasp_quality.doctree b/build/doctrees/grasp_quality.doctree new file mode 100644 index 0000000..9e92571 Binary files /dev/null and b/build/doctrees/grasp_quality.doctree differ diff --git a/build/doctrees/hardware.doctree b/build/doctrees/hardware.doctree new file mode 100644 index 0000000..cd26f19 Binary files /dev/null and b/build/doctrees/hardware.doctree differ diff --git a/build/doctrees/index.doctree b/build/doctrees/index.doctree new file mode 100644 index 0000000..d0d4586 Binary files /dev/null and b/build/doctrees/index.doctree differ diff --git a/build/doctrees/installation.doctree b/build/doctrees/installation.doctree new file mode 100644 index 0000000..bca093a Binary files /dev/null and b/build/doctrees/installation.doctree differ diff --git a/build/doctrees/installation_linux.doctree b/build/doctrees/installation_linux.doctree new file mode 100644 index 0000000..8644508 Binary files /dev/null and b/build/doctrees/installation_linux.doctree differ diff --git a/build/doctrees/installation_ros.doctree b/build/doctrees/installation_ros.doctree new file mode 100644 index 0000000..ea2cf0f Binary files /dev/null and b/build/doctrees/installation_ros.doctree differ diff --git a/build/doctrees/installation_windows.doctree b/build/doctrees/installation_windows.doctree new file mode 100644 index 0000000..8c1a501 Binary files /dev/null and b/build/doctrees/installation_windows.doctree differ diff --git a/build/doctrees/intro.doctree b/build/doctrees/intro.doctree new file mode 100644 index 0000000..c1a6f44 Binary files /dev/null and b/build/doctrees/intro.doctree differ diff --git a/build/doctrees/joint_coupling.doctree b/build/doctrees/joint_coupling.doctree new file mode 100644 index 0000000..b1a739a Binary files /dev/null and b/build/doctrees/joint_coupling.doctree differ diff --git a/build/doctrees/matlab.doctree b/build/doctrees/matlab.doctree new file mode 100644 index 0000000..81cb798 Binary files /dev/null and b/build/doctrees/matlab.doctree differ diff --git a/build/doctrees/plugins.doctree b/build/doctrees/plugins.doctree new file mode 100644 index 0000000..9f4db9e Binary files /dev/null and b/build/doctrees/plugins.doctree differ diff --git a/build/doctrees/publications.doctree b/build/doctrees/publications.doctree new file mode 100644 index 0000000..3ea21ea Binary files /dev/null and b/build/doctrees/publications.doctree differ diff --git a/build/doctrees/soft_fingers.doctree b/build/doctrees/soft_fingers.doctree new file mode 100644 index 0000000..950242a Binary files /dev/null and b/build/doctrees/soft_fingers.doctree differ diff --git a/build/html/.buildinfo b/build/html/.buildinfo new file mode 100644 index 0000000..56bf307 --- /dev/null +++ b/build/html/.buildinfo @@ -0,0 +1,4 @@ +# Sphinx build info version 1 +# This file hashes the configuration used when building these files. When it is not found, a full rebuild will be done. +config: 49a35f32485bf25fd9f3631ab9dc84ed +tags: 645f666f9bcd5a90fca523b33c5a78b7 diff --git a/source/_static/arrowTool.jpg b/build/html/_images/arrowTool.jpg similarity index 100% rename from source/_static/arrowTool.jpg rename to build/html/_images/arrowTool.jpg diff --git a/source/_static/collide.jpg b/build/html/_images/collide.jpg similarity index 100% rename from source/_static/collide.jpg rename to build/html/_images/collide.jpg diff --git a/source/_static/dlr_flask.png b/build/html/_images/dlr_flask.png similarity index 100% rename from source/_static/dlr_flask.png rename to build/html/_images/dlr_flask.png diff --git a/source/_static/handTool.jpg b/build/html/_images/handTool.jpg similarity index 100% rename from source/_static/handTool.jpg rename to build/html/_images/handTool.jpg diff --git a/source/_static/materialSelect.jpg b/build/html/_images/materialSelect.jpg similarity index 100% rename from source/_static/materialSelect.jpg rename to build/html/_images/materialSelect.jpg diff --git a/source/_static/rotateTool.jpg b/build/html/_images/rotateTool.jpg similarity index 100% rename from source/_static/rotateTool.jpg rename to build/html/_images/rotateTool.jpg diff --git a/source/_static/seekTool.jpg b/build/html/_images/seekTool.jpg similarity index 100% rename from source/_static/seekTool.jpg rename to build/html/_images/seekTool.jpg diff --git a/source/_static/selectTool.jpg b/build/html/_images/selectTool.jpg similarity index 100% rename from source/_static/selectTool.jpg rename to build/html/_images/selectTool.jpg diff --git a/source/_static/translateTool.jpg b/build/html/_images/translateTool.jpg similarity index 100% rename from source/_static/translateTool.jpg rename to build/html/_images/translateTool.jpg diff --git a/source/_static/viewAllTool.jpg b/build/html/_images/viewAllTool.jpg similarity index 100% rename from source/_static/viewAllTool.jpg rename to build/html/_images/viewAllTool.jpg diff --git a/source/cgdb.rst b/build/html/_sources/cgdb.rst.txt similarity index 100% rename from source/cgdb.rst rename to build/html/_sources/cgdb.rst.txt diff --git a/source/cgdb_in_depth.rst b/build/html/_sources/cgdb_in_depth.rst.txt similarity index 100% rename from source/cgdb_in_depth.rst rename to build/html/_sources/cgdb_in_depth.rst.txt diff --git a/source/collision.rst b/build/html/_sources/collision.rst.txt similarity index 100% rename from source/collision.rst rename to build/html/_sources/collision.rst.txt diff --git a/source/data_files.rst b/build/html/_sources/data_files.rst.txt similarity index 100% rename from source/data_files.rst rename to build/html/_sources/data_files.rst.txt diff --git a/source/data_files_bodies.rst b/build/html/_sources/data_files_bodies.rst.txt similarity index 100% rename from source/data_files_bodies.rst rename to build/html/_sources/data_files_bodies.rst.txt diff --git a/source/data_files_robots.rst b/build/html/_sources/data_files_robots.rst.txt similarity index 100% rename from source/data_files_robots.rst rename to build/html/_sources/data_files_robots.rst.txt diff --git a/source/data_files_worlds.rst b/build/html/_sources/data_files_worlds.rst.txt similarity index 100% rename from source/data_files_worlds.rst rename to build/html/_sources/data_files_worlds.rst.txt diff --git a/source/dynamics.rst b/build/html/_sources/dynamics.rst.txt similarity index 100% rename from source/dynamics.rst rename to build/html/_sources/dynamics.rst.txt diff --git a/source/eigengrasps.rst b/build/html/_sources/eigengrasps.rst.txt similarity index 100% rename from source/eigengrasps.rst rename to build/html/_sources/eigengrasps.rst.txt diff --git a/source/getting_started.rst b/build/html/_sources/getting_started.rst.txt similarity index 100% rename from source/getting_started.rst rename to build/html/_sources/getting_started.rst.txt diff --git a/source/gfo.rst b/build/html/_sources/gfo.rst.txt similarity index 100% rename from source/gfo.rst rename to build/html/_sources/gfo.rst.txt diff --git a/source/grasp_planning.rst b/build/html/_sources/grasp_planning.rst.txt similarity index 100% rename from source/grasp_planning.rst rename to build/html/_sources/grasp_planning.rst.txt diff --git a/source/grasp_planning_eg.rst b/build/html/_sources/grasp_planning_eg.rst.txt similarity index 100% rename from source/grasp_planning_eg.rst rename to build/html/_sources/grasp_planning_eg.rst.txt diff --git a/source/grasp_quality.rst b/build/html/_sources/grasp_quality.rst.txt similarity index 100% rename from source/grasp_quality.rst rename to build/html/_sources/grasp_quality.rst.txt diff --git a/source/hardware.rst b/build/html/_sources/hardware.rst.txt similarity index 100% rename from source/hardware.rst rename to build/html/_sources/hardware.rst.txt diff --git a/source/index.rst b/build/html/_sources/index.rst.txt similarity index 100% rename from source/index.rst rename to build/html/_sources/index.rst.txt diff --git a/source/installation.rst b/build/html/_sources/installation.rst.txt similarity index 100% rename from source/installation.rst rename to build/html/_sources/installation.rst.txt diff --git a/source/installation_linux.rst b/build/html/_sources/installation_linux.rst.txt similarity index 100% rename from source/installation_linux.rst rename to build/html/_sources/installation_linux.rst.txt diff --git a/build/html/_sources/installation_ros.rst.txt b/build/html/_sources/installation_ros.rst.txt new file mode 100644 index 0000000..838c7b6 --- /dev/null +++ b/build/html/_sources/installation_ros.rst.txt @@ -0,0 +1,8 @@ +GraspIt! Installation - Ubuntu Linux with ROS +--------------------------------------------- + +GraspIt! can be integrated into a ros workspace via the graspit-interface package: + +https://github.com/graspit-simulator/graspit_interface + +This is an example of how to write a GraspIt! plugin that serves as interface with ROS, exposing GraspIt! functionality over ROS services or actions. diff --git a/source/installation_windows.rst b/build/html/_sources/installation_windows.rst.txt similarity index 100% rename from source/installation_windows.rst rename to build/html/_sources/installation_windows.rst.txt diff --git a/source/intro.rst b/build/html/_sources/intro.rst.txt similarity index 100% rename from source/intro.rst rename to build/html/_sources/intro.rst.txt diff --git a/source/joint_coupling.rst b/build/html/_sources/joint_coupling.rst.txt similarity index 100% rename from source/joint_coupling.rst rename to build/html/_sources/joint_coupling.rst.txt diff --git a/source/matlab.rst b/build/html/_sources/matlab.rst.txt similarity index 100% rename from source/matlab.rst rename to build/html/_sources/matlab.rst.txt diff --git a/source/plugins.rst b/build/html/_sources/plugins.rst.txt similarity index 100% rename from source/plugins.rst rename to build/html/_sources/plugins.rst.txt diff --git a/source/publications.rst b/build/html/_sources/publications.rst.txt similarity index 100% rename from source/publications.rst rename to build/html/_sources/publications.rst.txt diff --git a/source/soft_fingers.rst b/build/html/_sources/soft_fingers.rst.txt similarity index 100% rename from source/soft_fingers.rst rename to build/html/_sources/soft_fingers.rst.txt diff --git a/build/html/_static/ajax-loader.gif b/build/html/_static/ajax-loader.gif new file mode 100644 index 0000000..61faf8c Binary files /dev/null and b/build/html/_static/ajax-loader.gif differ diff --git a/build/html/_static/arrowTool.jpg b/build/html/_static/arrowTool.jpg new file mode 100644 index 0000000..92d8048 Binary files /dev/null and b/build/html/_static/arrowTool.jpg differ diff --git a/build/html/_static/basic.css b/build/html/_static/basic.css new file mode 100644 index 0000000..6df76b0 --- /dev/null +++ b/build/html/_static/basic.css @@ -0,0 +1,639 @@ +/* + * basic.css + * ~~~~~~~~~ + * + * Sphinx stylesheet -- basic theme. + * + * :copyright: Copyright 2007-2017 by the Sphinx team, see AUTHORS. + * :license: BSD, see LICENSE for details. + * + */ + +/* -- main layout ----------------------------------------------------------- */ + +div.clearer { + clear: both; +} + +/* -- relbar ---------------------------------------------------------------- */ + +div.related { + width: 100%; + font-size: 90%; +} + +div.related h3 { + display: none; +} + +div.related ul { + margin: 0; + padding: 0 0 0 10px; + list-style: none; +} + +div.related li { + display: inline; +} + +div.related li.right { + float: right; + margin-right: 5px; +} + +/* -- sidebar --------------------------------------------------------------- */ + +div.sphinxsidebarwrapper { + padding: 10px 5px 0 10px; +} + +div.sphinxsidebar { + float: left; + width: 230px; + margin-left: -100%; + font-size: 90%; + word-wrap: break-word; + overflow-wrap : break-word; +} + +div.sphinxsidebar ul { + list-style: none; +} + +div.sphinxsidebar ul ul, +div.sphinxsidebar ul.want-points { + margin-left: 20px; + list-style: square; +} + +div.sphinxsidebar ul ul { + margin-top: 0; + margin-bottom: 0; +} + +div.sphinxsidebar form { + margin-top: 10px; +} + +div.sphinxsidebar input { + border: 1px solid #98dbcc; + font-family: sans-serif; + font-size: 1em; +} + +div.sphinxsidebar #searchbox input[type="text"] { + width: 170px; +} + +img { + border: 0; + max-width: 100%; +} + +/* -- search page ----------------------------------------------------------- */ + +ul.search { + margin: 10px 0 0 20px; + padding: 0; +} + +ul.search li { + padding: 5px 0 5px 20px; + background-image: url(file.png); + background-repeat: no-repeat; + background-position: 0 7px; +} + +ul.search li a { + font-weight: bold; +} + +ul.search li div.context { + color: #888; + margin: 2px 0 0 30px; + text-align: left; +} + +ul.keywordmatches li.goodmatch a { + font-weight: bold; +} + +/* -- index page ------------------------------------------------------------ */ + +table.contentstable { + width: 90%; + margin-left: auto; + margin-right: auto; +} + +table.contentstable p.biglink { + line-height: 150%; +} + +a.biglink { + font-size: 1.3em; +} + +span.linkdescr { + font-style: italic; + padding-top: 5px; + font-size: 90%; +} + +/* -- general index --------------------------------------------------------- */ + +table.indextable { + width: 100%; +} + +table.indextable td { + text-align: left; + vertical-align: top; +} + +table.indextable ul { + margin-top: 0; + margin-bottom: 0; + list-style-type: none; +} + +table.indextable > tbody > tr > td > ul { + padding-left: 0em; +} + +table.indextable tr.pcap { + height: 10px; +} + +table.indextable tr.cap { + margin-top: 10px; + background-color: #f2f2f2; +} + +img.toggler { + margin-right: 3px; + margin-top: 3px; + cursor: pointer; +} + +div.modindex-jumpbox { + border-top: 1px solid #ddd; + border-bottom: 1px solid #ddd; + margin: 1em 0 1em 0; + padding: 0.4em; +} + +div.genindex-jumpbox { + border-top: 1px solid #ddd; + border-bottom: 1px solid #ddd; + margin: 1em 0 1em 0; + padding: 0.4em; +} + +/* -- domain module index --------------------------------------------------- */ + +table.modindextable td { + padding: 2px; + border-collapse: collapse; +} + +/* -- general body styles --------------------------------------------------- */ + +div.body p, div.body dd, div.body li, div.body blockquote { + -moz-hyphens: auto; + -ms-hyphens: auto; + -webkit-hyphens: auto; + hyphens: auto; +} + +a.headerlink { + visibility: hidden; +} + +h1:hover > a.headerlink, +h2:hover > a.headerlink, +h3:hover > a.headerlink, +h4:hover > a.headerlink, +h5:hover > a.headerlink, +h6:hover > a.headerlink, +dt:hover > a.headerlink, +caption:hover > a.headerlink, +p.caption:hover > a.headerlink, +div.code-block-caption:hover > a.headerlink { + visibility: visible; +} + +div.body p.caption { + text-align: inherit; +} + +div.body td { + text-align: left; +} + +.first { + margin-top: 0 !important; +} + +p.rubric { + margin-top: 30px; + font-weight: bold; +} + +img.align-left, .figure.align-left, object.align-left { + clear: left; + float: left; + margin-right: 1em; +} + +img.align-right, .figure.align-right, object.align-right { + clear: right; + float: right; + margin-left: 1em; +} + +img.align-center, .figure.align-center, object.align-center { + display: block; + margin-left: auto; + margin-right: auto; +} + +.align-left { + text-align: left; +} + +.align-center { + text-align: center; +} + +.align-right { + text-align: right; +} + +/* -- sidebars -------------------------------------------------------------- */ + +div.sidebar { + margin: 0 0 0.5em 1em; + border: 1px solid #ddb; + padding: 7px 7px 0 7px; + background-color: #ffe; + width: 40%; + float: right; +} + +p.sidebar-title { + font-weight: bold; +} + +/* -- topics ---------------------------------------------------------------- */ + +div.topic { + border: 1px solid #ccc; + padding: 7px 7px 0 7px; + margin: 10px 0 10px 0; +} + +p.topic-title { + font-size: 1.1em; + font-weight: bold; + margin-top: 10px; +} + +/* -- admonitions ----------------------------------------------------------- */ + +div.admonition { + margin-top: 10px; + margin-bottom: 10px; + padding: 7px; +} + +div.admonition dt { + font-weight: bold; +} + +div.admonition dl { + margin-bottom: 0; +} + +p.admonition-title { + margin: 0px 10px 5px 0px; + font-weight: bold; +} + +div.body p.centered { + text-align: center; + margin-top: 25px; +} + +/* -- tables ---------------------------------------------------------------- */ + +table.docutils { + border: 0; + border-collapse: collapse; +} + +table caption span.caption-number { + font-style: italic; +} + +table caption span.caption-text { +} + +table.docutils td, table.docutils th { + padding: 1px 8px 1px 5px; + border-top: 0; + border-left: 0; + border-right: 0; + border-bottom: 1px solid #aaa; +} + +table.footnote td, table.footnote th { + border: 0 !important; +} + +th { + text-align: left; + padding-right: 5px; +} + +table.citation { + border-left: solid 1px gray; + margin-left: 1px; +} + +table.citation td { + border-bottom: none; +} + +/* -- figures --------------------------------------------------------------- */ + +div.figure { + margin: 0.5em; + padding: 0.5em; +} + +div.figure p.caption { + padding: 0.3em; +} + +div.figure p.caption span.caption-number { + font-style: italic; +} + +div.figure p.caption span.caption-text { +} + +/* -- field list styles ----------------------------------------------------- */ + +table.field-list td, table.field-list th { + border: 0 !important; +} + +.field-list ul { + margin: 0; + padding-left: 1em; +} + +.field-list p { + margin: 0; +} + +.field-name { + -moz-hyphens: manual; + -ms-hyphens: manual; + -webkit-hyphens: manual; + hyphens: manual; +} + +/* -- other body styles ----------------------------------------------------- */ + +ol.arabic { + list-style: decimal; +} + +ol.loweralpha { + list-style: lower-alpha; +} + +ol.upperalpha { + list-style: upper-alpha; +} + +ol.lowerroman { + list-style: lower-roman; +} + +ol.upperroman { + list-style: upper-roman; +} + +dl { + margin-bottom: 15px; +} + +dd p { + margin-top: 0px; +} + +dd ul, dd table { + margin-bottom: 10px; +} + +dd { + margin-top: 3px; + margin-bottom: 10px; + margin-left: 30px; +} + +dt:target, .highlighted { + background-color: #fbe54e; +} + +dl.glossary dt { + font-weight: bold; + font-size: 1.1em; +} + +.optional { + font-size: 1.3em; +} + +.sig-paren { + font-size: larger; +} + +.versionmodified { + font-style: italic; +} + +.system-message { + background-color: #fda; + padding: 5px; + border: 3px solid red; +} + +.footnote:target { + background-color: #ffa; +} + +.line-block { + display: block; + margin-top: 1em; + margin-bottom: 1em; +} + +.line-block .line-block { + margin-top: 0; + margin-bottom: 0; + margin-left: 1.5em; +} + +.guilabel, .menuselection { + font-family: sans-serif; +} + +.accelerator { + text-decoration: underline; +} + +.classifier { + font-style: oblique; +} + +abbr, acronym { + border-bottom: dotted 1px; + cursor: help; +} + +/* -- code displays --------------------------------------------------------- */ + +pre { + overflow: auto; + overflow-y: hidden; /* fixes display issues on Chrome browsers */ +} + +span.pre { + -moz-hyphens: none; + -ms-hyphens: none; + -webkit-hyphens: none; + hyphens: none; +} + +td.linenos pre { + padding: 5px 0px; + border: 0; + background-color: transparent; + color: #aaa; +} + +table.highlighttable { + margin-left: 0.5em; +} + +table.highlighttable td { + padding: 0 0.5em 0 0.5em; +} + +div.code-block-caption { + padding: 2px 5px; + font-size: small; +} + +div.code-block-caption code { + background-color: transparent; +} + +div.code-block-caption + div > div.highlight > pre { + margin-top: 0; +} + +div.code-block-caption span.caption-number { + padding: 0.1em 0.3em; + font-style: italic; +} + +div.code-block-caption span.caption-text { +} + +div.literal-block-wrapper { + padding: 1em 1em 0; +} + +div.literal-block-wrapper div.highlight { + margin: 0; +} + +code.descname { + background-color: transparent; + font-weight: bold; + font-size: 1.2em; +} + +code.descclassname { + background-color: transparent; +} + +code.xref, a code { + background-color: transparent; + font-weight: bold; +} + +h1 code, h2 code, h3 code, h4 code, h5 code, h6 code { + background-color: transparent; +} + +.viewcode-link { + float: right; +} + +.viewcode-back { + float: right; + font-family: sans-serif; +} + +div.viewcode-block:target { + margin: -1px -10px; + padding: 0 10px; +} + +/* -- math display ---------------------------------------------------------- */ + +img.math { + vertical-align: middle; +} + +div.body div.math p { + text-align: center; +} + +span.eqno { + float: right; +} + +span.eqno a.headerlink { + position: relative; + left: 0px; + z-index: 1; +} + +div.math:hover a.headerlink { + visibility: visible; +} + +/* -- printout stylesheet --------------------------------------------------- */ + +@media print { + div.document, + div.documentwrapper, + div.bodywrapper { + margin: 0 !important; + width: 100%; + } + + div.sphinxsidebar, + div.related, + div.footer, + #top-link { + display: none; + } +} \ No newline at end of file diff --git a/source/_static/blank.png b/build/html/_static/blank.png similarity index 100% rename from source/_static/blank.png rename to build/html/_static/blank.png diff --git a/source/_static/bodyPropDlg.jpg b/build/html/_static/bodyPropDlg.jpg similarity index 100% rename from source/_static/bodyPropDlg.jpg rename to build/html/_static/bodyPropDlg.jpg diff --git a/build/html/_static/collide.jpg b/build/html/_static/collide.jpg new file mode 100644 index 0000000..90d3c61 Binary files /dev/null and b/build/html/_static/collide.jpg differ diff --git a/build/html/_static/comment-bright.png b/build/html/_static/comment-bright.png new file mode 100644 index 0000000..15e27ed Binary files /dev/null and b/build/html/_static/comment-bright.png differ diff --git a/build/html/_static/comment-close.png b/build/html/_static/comment-close.png new file mode 100644 index 0000000..4d91bcf Binary files /dev/null and b/build/html/_static/comment-close.png differ diff --git a/build/html/_static/comment.png b/build/html/_static/comment.png new file mode 100644 index 0000000..dfbc0cb Binary files /dev/null and b/build/html/_static/comment.png differ diff --git a/source/_themes/sphinx_rtd_theme/static/css/badge_only.css b/build/html/_static/css/badge_only.css similarity index 100% rename from source/_themes/sphinx_rtd_theme/static/css/badge_only.css rename to build/html/_static/css/badge_only.css diff --git a/source/_themes/sphinx_rtd_theme/static/css/badge_only.css.map b/build/html/_static/css/badge_only.css.map similarity index 100% rename from source/_themes/sphinx_rtd_theme/static/css/badge_only.css.map rename to build/html/_static/css/badge_only.css.map diff --git a/source/_themes/sphinx_rtd_theme/static/css/theme.css b/build/html/_static/css/theme.css similarity index 100% rename from source/_themes/sphinx_rtd_theme/static/css/theme.css rename to build/html/_static/css/theme.css diff --git a/source/_themes/sphinx_rtd_theme/static/css/theme.css.map b/build/html/_static/css/theme.css.map similarity index 100% rename from source/_themes/sphinx_rtd_theme/static/css/theme.css.map rename to build/html/_static/css/theme.css.map diff --git a/build/html/_static/dlr_flask.png b/build/html/_static/dlr_flask.png new file mode 100644 index 0000000..b5b97e1 Binary files /dev/null and b/build/html/_static/dlr_flask.png differ diff --git a/build/html/_static/doctools.js b/build/html/_static/doctools.js new file mode 100644 index 0000000..5654977 --- /dev/null +++ b/build/html/_static/doctools.js @@ -0,0 +1,287 @@ +/* + * doctools.js + * ~~~~~~~~~~~ + * + * Sphinx JavaScript utilities for all documentation. + * + * :copyright: Copyright 2007-2017 by the Sphinx team, see AUTHORS. + * :license: BSD, see LICENSE for details. + * + */ + +/** + * select a different prefix for underscore + */ +$u = _.noConflict(); + +/** + * make the code below compatible with browsers without + * an installed firebug like debugger +if (!window.console || !console.firebug) { + var names = ["log", "debug", "info", "warn", "error", "assert", "dir", + "dirxml", "group", "groupEnd", "time", "timeEnd", "count", "trace", + "profile", "profileEnd"]; + window.console = {}; + for (var i = 0; i < names.length; ++i) + window.console[names[i]] = function() {}; +} + */ + +/** + * small helper function to urldecode strings + */ +jQuery.urldecode = function(x) { + return decodeURIComponent(x).replace(/\+/g, ' '); +}; + +/** + * small helper function to urlencode strings + */ +jQuery.urlencode = encodeURIComponent; + +/** + * This function returns the parsed url parameters of the + * current request. Multiple values per key are supported, + * it will always return arrays of strings for the value parts. + */ +jQuery.getQueryParameters = function(s) { + if (typeof s == 'undefined') + s = document.location.search; + var parts = s.substr(s.indexOf('?') + 1).split('&'); + var result = {}; + for (var i = 0; i < parts.length; i++) { + var tmp = parts[i].split('=', 2); + var key = jQuery.urldecode(tmp[0]); + var value = jQuery.urldecode(tmp[1]); + if (key in result) + result[key].push(value); + else + result[key] = [value]; + } + return result; +}; + +/** + * highlight a given string on a jquery object by wrapping it in + * span elements with the given class name. + */ +jQuery.fn.highlightText = function(text, className) { + function highlight(node) { + if (node.nodeType == 3) { + var val = node.nodeValue; + var pos = val.toLowerCase().indexOf(text); + if (pos >= 0 && !jQuery(node.parentNode).hasClass(className)) { + var span = document.createElement("span"); + span.className = className; + span.appendChild(document.createTextNode(val.substr(pos, text.length))); + node.parentNode.insertBefore(span, node.parentNode.insertBefore( + document.createTextNode(val.substr(pos + text.length)), + node.nextSibling)); + node.nodeValue = val.substr(0, pos); + } + } + else if (!jQuery(node).is("button, select, textarea")) { + jQuery.each(node.childNodes, function() { + highlight(this); + }); + } + } + return this.each(function() { + highlight(this); + }); +}; + +/* + * backward compatibility for jQuery.browser + * This will be supported until firefox bug is fixed. + */ +if (!jQuery.browser) { + jQuery.uaMatch = function(ua) { + ua = ua.toLowerCase(); + + var match = /(chrome)[ \/]([\w.]+)/.exec(ua) || + /(webkit)[ \/]([\w.]+)/.exec(ua) || + /(opera)(?:.*version|)[ \/]([\w.]+)/.exec(ua) || + /(msie) ([\w.]+)/.exec(ua) || + ua.indexOf("compatible") < 0 && /(mozilla)(?:.*? rv:([\w.]+)|)/.exec(ua) || + []; + + return { + browser: match[ 1 ] || "", + version: match[ 2 ] || "0" + }; + }; + jQuery.browser = {}; + jQuery.browser[jQuery.uaMatch(navigator.userAgent).browser] = true; +} + +/** + * Small JavaScript module for the documentation. + */ +var Documentation = { + + init : function() { + this.fixFirefoxAnchorBug(); + this.highlightSearchWords(); + this.initIndexTable(); + + }, + + /** + * i18n support + */ + TRANSLATIONS : {}, + PLURAL_EXPR : function(n) { return n == 1 ? 0 : 1; }, + LOCALE : 'unknown', + + // gettext and ngettext don't access this so that the functions + // can safely bound to a different name (_ = Documentation.gettext) + gettext : function(string) { + var translated = Documentation.TRANSLATIONS[string]; + if (typeof translated == 'undefined') + return string; + return (typeof translated == 'string') ? translated : translated[0]; + }, + + ngettext : function(singular, plural, n) { + var translated = Documentation.TRANSLATIONS[singular]; + if (typeof translated == 'undefined') + return (n == 1) ? singular : plural; + return translated[Documentation.PLURALEXPR(n)]; + }, + + addTranslations : function(catalog) { + for (var key in catalog.messages) + this.TRANSLATIONS[key] = catalog.messages[key]; + this.PLURAL_EXPR = new Function('n', 'return +(' + catalog.plural_expr + ')'); + this.LOCALE = catalog.locale; + }, + + /** + * add context elements like header anchor links + */ + addContextElements : function() { + $('div[id] > :header:first').each(function() { + $('\u00B6'). + attr('href', '#' + this.id). + attr('title', _('Permalink to this headline')). + appendTo(this); + }); + $('dt[id]').each(function() { + $('\u00B6'). + attr('href', '#' + this.id). + attr('title', _('Permalink to this definition')). + appendTo(this); + }); + }, + + /** + * workaround a firefox stupidity + * see: https://bugzilla.mozilla.org/show_bug.cgi?id=645075 + */ + fixFirefoxAnchorBug : function() { + if (document.location.hash) + window.setTimeout(function() { + document.location.href += ''; + }, 10); + }, + + /** + * highlight the search words provided in the url in the text + */ + highlightSearchWords : function() { + var params = $.getQueryParameters(); + var terms = (params.highlight) ? params.highlight[0].split(/\s+/) : []; + if (terms.length) { + var body = $('div.body'); + if (!body.length) { + body = $('body'); + } + window.setTimeout(function() { + $.each(terms, function() { + body.highlightText(this.toLowerCase(), 'highlighted'); + }); + }, 10); + $('') + .appendTo($('#searchbox')); + } + }, + + /** + * init the domain index toggle buttons + */ + initIndexTable : function() { + var togglers = $('img.toggler').click(function() { + var src = $(this).attr('src'); + var idnum = $(this).attr('id').substr(7); + $('tr.cg-' + idnum).toggle(); + if (src.substr(-9) == 'minus.png') + $(this).attr('src', src.substr(0, src.length-9) + 'plus.png'); + else + $(this).attr('src', src.substr(0, src.length-8) + 'minus.png'); + }).css('display', ''); + if (DOCUMENTATION_OPTIONS.COLLAPSE_INDEX) { + togglers.click(); + } + }, + + /** + * helper function to hide the search marks again + */ + hideSearchWords : function() { + $('#searchbox .highlight-link').fadeOut(300); + $('span.highlighted').removeClass('highlighted'); + }, + + /** + * make the url absolute + */ + makeURL : function(relativeURL) { + return DOCUMENTATION_OPTIONS.URL_ROOT + '/' + relativeURL; + }, + + /** + * get the current relative url + */ + getCurrentURL : function() { + var path = document.location.pathname; + var parts = path.split(/\//); + $.each(DOCUMENTATION_OPTIONS.URL_ROOT.split(/\//), function() { + if (this == '..') + parts.pop(); + }); + var url = parts.join('/'); + return path.substring(url.lastIndexOf('/') + 1, path.length - 1); + }, + + initOnKeyListeners: function() { + $(document).keyup(function(event) { + var activeElementType = document.activeElement.tagName; + // don't navigate when in search box or textarea + if (activeElementType !== 'TEXTAREA' && activeElementType !== 'INPUT' && activeElementType !== 'SELECT') { + switch (event.keyCode) { + case 37: // left + var prevHref = $('link[rel="prev"]').prop('href'); + if (prevHref) { + window.location.href = prevHref; + return false; + } + case 39: // right + var nextHref = $('link[rel="next"]').prop('href'); + if (nextHref) { + window.location.href = nextHref; + return false; + } + } + } + }); + } +}; + +// quick alias for translations +_ = Documentation.gettext; + +$(document).ready(function() { + Documentation.init(); +}); \ No newline at end of file diff --git a/build/html/_static/down-pressed.png b/build/html/_static/down-pressed.png new file mode 100644 index 0000000..5756c8c Binary files /dev/null and b/build/html/_static/down-pressed.png differ diff --git a/build/html/_static/down.png b/build/html/_static/down.png new file mode 100644 index 0000000..1b3bdad Binary files /dev/null and b/build/html/_static/down.png differ diff --git a/build/html/_static/file.png b/build/html/_static/file.png new file mode 100644 index 0000000..a858a41 Binary files /dev/null and b/build/html/_static/file.png differ diff --git a/source/_themes/sphinx_rtd_theme/static/fonts/FontAwesome.otf b/build/html/_static/fonts/FontAwesome.otf similarity index 100% rename from source/_themes/sphinx_rtd_theme/static/fonts/FontAwesome.otf rename to build/html/_static/fonts/FontAwesome.otf diff --git a/source/_themes/sphinx_rtd_theme/static/fonts/Inconsolata-Bold.ttf b/build/html/_static/fonts/Inconsolata-Bold.ttf similarity index 100% rename from source/_themes/sphinx_rtd_theme/static/fonts/Inconsolata-Bold.ttf rename to build/html/_static/fonts/Inconsolata-Bold.ttf diff --git a/source/_themes/sphinx_rtd_theme/static/fonts/Inconsolata.ttf b/build/html/_static/fonts/Inconsolata.ttf similarity index 100% rename from source/_themes/sphinx_rtd_theme/static/fonts/Inconsolata.ttf rename to build/html/_static/fonts/Inconsolata.ttf diff --git a/source/_themes/sphinx_rtd_theme/static/fonts/Lato-Bold.ttf b/build/html/_static/fonts/Lato-Bold.ttf similarity index 100% rename from source/_themes/sphinx_rtd_theme/static/fonts/Lato-Bold.ttf rename to build/html/_static/fonts/Lato-Bold.ttf diff --git a/source/_themes/sphinx_rtd_theme/static/fonts/Lato-Regular.ttf b/build/html/_static/fonts/Lato-Regular.ttf similarity index 100% rename from source/_themes/sphinx_rtd_theme/static/fonts/Lato-Regular.ttf rename to build/html/_static/fonts/Lato-Regular.ttf diff --git a/source/_themes/sphinx_rtd_theme/static/fonts/RobotoSlab-Bold.ttf b/build/html/_static/fonts/RobotoSlab-Bold.ttf similarity index 100% rename from source/_themes/sphinx_rtd_theme/static/fonts/RobotoSlab-Bold.ttf rename to build/html/_static/fonts/RobotoSlab-Bold.ttf diff --git a/source/_themes/sphinx_rtd_theme/static/fonts/RobotoSlab-Regular.ttf b/build/html/_static/fonts/RobotoSlab-Regular.ttf similarity index 100% rename from source/_themes/sphinx_rtd_theme/static/fonts/RobotoSlab-Regular.ttf rename to build/html/_static/fonts/RobotoSlab-Regular.ttf diff --git a/source/_themes/sphinx_rtd_theme/static/fonts/fontawesome-webfont.eot b/build/html/_static/fonts/fontawesome-webfont.eot similarity index 100% rename from source/_themes/sphinx_rtd_theme/static/fonts/fontawesome-webfont.eot rename to build/html/_static/fonts/fontawesome-webfont.eot diff --git a/source/_themes/sphinx_rtd_theme/static/fonts/fontawesome-webfont.svg b/build/html/_static/fonts/fontawesome-webfont.svg similarity index 100% rename from source/_themes/sphinx_rtd_theme/static/fonts/fontawesome-webfont.svg rename to build/html/_static/fonts/fontawesome-webfont.svg diff --git a/source/_themes/sphinx_rtd_theme/static/fonts/fontawesome-webfont.ttf b/build/html/_static/fonts/fontawesome-webfont.ttf similarity index 100% rename from source/_themes/sphinx_rtd_theme/static/fonts/fontawesome-webfont.ttf rename to build/html/_static/fonts/fontawesome-webfont.ttf diff --git a/source/_themes/sphinx_rtd_theme/static/fonts/fontawesome-webfont.woff b/build/html/_static/fonts/fontawesome-webfont.woff similarity index 100% rename from source/_themes/sphinx_rtd_theme/static/fonts/fontawesome-webfont.woff rename to build/html/_static/fonts/fontawesome-webfont.woff diff --git a/source/_static/gwsProjDlg.jpg b/build/html/_static/gwsProjDlg.jpg similarity index 100% rename from source/_static/gwsProjDlg.jpg rename to build/html/_static/gwsProjDlg.jpg diff --git a/build/html/_static/handTool.jpg b/build/html/_static/handTool.jpg new file mode 100644 index 0000000..3d13e92 Binary files /dev/null and b/build/html/_static/handTool.jpg differ diff --git a/source/_static/handbook.png b/build/html/_static/handbook.png similarity index 100% rename from source/_static/handbook.png rename to build/html/_static/handbook.png diff --git a/source/_static/helpTool.jpg b/build/html/_static/helpTool.jpg similarity index 100% rename from source/_static/helpTool.jpg rename to build/html/_static/helpTool.jpg diff --git a/source/_static/homeTool.jpg b/build/html/_static/homeTool.jpg similarity index 100% rename from source/_static/homeTool.jpg rename to build/html/_static/homeTool.jpg diff --git a/build/html/_static/jquery-3.1.0.js b/build/html/_static/jquery-3.1.0.js new file mode 100644 index 0000000..f2fc274 --- /dev/null +++ b/build/html/_static/jquery-3.1.0.js @@ -0,0 +1,10074 @@ +/*eslint-disable no-unused-vars*/ +/*! + * jQuery JavaScript Library v3.1.0 + * https://jquery.com/ + * + * Includes Sizzle.js + * https://sizzlejs.com/ + * + * Copyright jQuery Foundation and other contributors + * Released under the MIT license + * https://jquery.org/license + * + * Date: 2016-07-07T21:44Z + */ +( function( global, factory ) { + + "use strict"; + + if ( typeof module === "object" && typeof module.exports === "object" ) { + + // For CommonJS and CommonJS-like environments where a proper `window` + // is present, execute the factory and get jQuery. + // For environments that do not have a `window` with a `document` + // (such as Node.js), expose a factory as module.exports. + // This accentuates the need for the creation of a real `window`. + // e.g. var jQuery = require("jquery")(window); + // See ticket #14549 for more info. + module.exports = global.document ? + factory( global, true ) : + function( w ) { + if ( !w.document ) { + throw new Error( "jQuery requires a window with a document" ); + } + return factory( w ); + }; + } else { + factory( global ); + } + +// Pass this if window is not defined yet +} )( typeof window !== "undefined" ? window : this, function( window, noGlobal ) { + +// Edge <= 12 - 13+, Firefox <=18 - 45+, IE 10 - 11, Safari 5.1 - 9+, iOS 6 - 9.1 +// throw exceptions when non-strict code (e.g., ASP.NET 4.5) accesses strict mode +// arguments.callee.caller (trac-13335). But as of jQuery 3.0 (2016), strict mode should be common +// enough that all such attempts are guarded in a try block. +"use strict"; + +var arr = []; + +var document = window.document; + +var getProto = Object.getPrototypeOf; + +var slice = arr.slice; + +var concat = arr.concat; + +var push = arr.push; + +var indexOf = arr.indexOf; + +var class2type = {}; + +var toString = class2type.toString; + +var hasOwn = class2type.hasOwnProperty; + +var fnToString = hasOwn.toString; + +var ObjectFunctionString = fnToString.call( Object ); + +var support = {}; + + + + function DOMEval( code, doc ) { + doc = doc || document; + + var script = doc.createElement( "script" ); + + script.text = code; + doc.head.appendChild( script ).parentNode.removeChild( script ); + } +/* global Symbol */ +// Defining this global in .eslintrc would create a danger of using the global +// unguarded in another place, it seems safer to define global only for this module + + + +var + version = "3.1.0", + + // Define a local copy of jQuery + jQuery = function( selector, context ) { + + // The jQuery object is actually just the init constructor 'enhanced' + // Need init if jQuery is called (just allow error to be thrown if not included) + return new jQuery.fn.init( selector, context ); + }, + + // Support: Android <=4.0 only + // Make sure we trim BOM and NBSP + rtrim = /^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g, + + // Matches dashed string for camelizing + rmsPrefix = /^-ms-/, + rdashAlpha = /-([a-z])/g, + + // Used by jQuery.camelCase as callback to replace() + fcamelCase = function( all, letter ) { + return letter.toUpperCase(); + }; + +jQuery.fn = jQuery.prototype = { + + // The current version of jQuery being used + jquery: version, + + constructor: jQuery, + + // The default length of a jQuery object is 0 + length: 0, + + toArray: function() { + return slice.call( this ); + }, + + // Get the Nth element in the matched element set OR + // Get the whole matched element set as a clean array + get: function( num ) { + return num != null ? + + // Return just the one element from the set + ( num < 0 ? this[ num + this.length ] : this[ num ] ) : + + // Return all the elements in a clean array + slice.call( this ); + }, + + // Take an array of elements and push it onto the stack + // (returning the new matched element set) + pushStack: function( elems ) { + + // Build a new jQuery matched element set + var ret = jQuery.merge( this.constructor(), elems ); + + // Add the old object onto the stack (as a reference) + ret.prevObject = this; + + // Return the newly-formed element set + return ret; + }, + + // Execute a callback for every element in the matched set. + each: function( callback ) { + return jQuery.each( this, callback ); + }, + + map: function( callback ) { + return this.pushStack( jQuery.map( this, function( elem, i ) { + return callback.call( elem, i, elem ); + } ) ); + }, + + slice: function() { + return this.pushStack( slice.apply( this, arguments ) ); + }, + + first: function() { + return this.eq( 0 ); + }, + + last: function() { + return this.eq( -1 ); + }, + + eq: function( i ) { + var len = this.length, + j = +i + ( i < 0 ? len : 0 ); + return this.pushStack( j >= 0 && j < len ? [ this[ j ] ] : [] ); + }, + + end: function() { + return this.prevObject || this.constructor(); + }, + + // For internal use only. + // Behaves like an Array's method, not like a jQuery method. + push: push, + sort: arr.sort, + splice: arr.splice +}; + +jQuery.extend = jQuery.fn.extend = function() { + var options, name, src, copy, copyIsArray, clone, + target = arguments[ 0 ] || {}, + i = 1, + length = arguments.length, + deep = false; + + // Handle a deep copy situation + if ( typeof target === "boolean" ) { + deep = target; + + // Skip the boolean and the target + target = arguments[ i ] || {}; + i++; + } + + // Handle case when target is a string or something (possible in deep copy) + if ( typeof target !== "object" && !jQuery.isFunction( target ) ) { + target = {}; + } + + // Extend jQuery itself if only one argument is passed + if ( i === length ) { + target = this; + i--; + } + + for ( ; i < length; i++ ) { + + // Only deal with non-null/undefined values + if ( ( options = arguments[ i ] ) != null ) { + + // Extend the base object + for ( name in options ) { + src = target[ name ]; + copy = options[ name ]; + + // Prevent never-ending loop + if ( target === copy ) { + continue; + } + + // Recurse if we're merging plain objects or arrays + if ( deep && copy && ( jQuery.isPlainObject( copy ) || + ( copyIsArray = jQuery.isArray( copy ) ) ) ) { + + if ( copyIsArray ) { + copyIsArray = false; + clone = src && jQuery.isArray( src ) ? src : []; + + } else { + clone = src && jQuery.isPlainObject( src ) ? src : {}; + } + + // Never move original objects, clone them + target[ name ] = jQuery.extend( deep, clone, copy ); + + // Don't bring in undefined values + } else if ( copy !== undefined ) { + target[ name ] = copy; + } + } + } + } + + // Return the modified object + return target; +}; + +jQuery.extend( { + + // Unique for each copy of jQuery on the page + expando: "jQuery" + ( version + Math.random() ).replace( /\D/g, "" ), + + // Assume jQuery is ready without the ready module + isReady: true, + + error: function( msg ) { + throw new Error( msg ); + }, + + noop: function() {}, + + isFunction: function( obj ) { + return jQuery.type( obj ) === "function"; + }, + + isArray: Array.isArray, + + isWindow: function( obj ) { + return obj != null && obj === obj.window; + }, + + isNumeric: function( obj ) { + + // As of jQuery 3.0, isNumeric is limited to + // strings and numbers (primitives or objects) + // that can be coerced to finite numbers (gh-2662) + var type = jQuery.type( obj ); + return ( type === "number" || type === "string" ) && + + // parseFloat NaNs numeric-cast false positives ("") + // ...but misinterprets leading-number strings, particularly hex literals ("0x...") + // subtraction forces infinities to NaN + !isNaN( obj - parseFloat( obj ) ); + }, + + isPlainObject: function( obj ) { + var proto, Ctor; + + // Detect obvious negatives + // Use toString instead of jQuery.type to catch host objects + if ( !obj || toString.call( obj ) !== "[object Object]" ) { + return false; + } + + proto = getProto( obj ); + + // Objects with no prototype (e.g., `Object.create( null )`) are plain + if ( !proto ) { + return true; + } + + // Objects with prototype are plain iff they were constructed by a global Object function + Ctor = hasOwn.call( proto, "constructor" ) && proto.constructor; + return typeof Ctor === "function" && fnToString.call( Ctor ) === ObjectFunctionString; + }, + + isEmptyObject: function( obj ) { + + /* eslint-disable no-unused-vars */ + // See https://github.com/eslint/eslint/issues/6125 + var name; + + for ( name in obj ) { + return false; + } + return true; + }, + + type: function( obj ) { + if ( obj == null ) { + return obj + ""; + } + + // Support: Android <=2.3 only (functionish RegExp) + return typeof obj === "object" || typeof obj === "function" ? + class2type[ toString.call( obj ) ] || "object" : + typeof obj; + }, + + // Evaluates a script in a global context + globalEval: function( code ) { + DOMEval( code ); + }, + + // Convert dashed to camelCase; used by the css and data modules + // Support: IE <=9 - 11, Edge 12 - 13 + // Microsoft forgot to hump their vendor prefix (#9572) + camelCase: function( string ) { + return string.replace( rmsPrefix, "ms-" ).replace( rdashAlpha, fcamelCase ); + }, + + nodeName: function( elem, name ) { + return elem.nodeName && elem.nodeName.toLowerCase() === name.toLowerCase(); + }, + + each: function( obj, callback ) { + var length, i = 0; + + if ( isArrayLike( obj ) ) { + length = obj.length; + for ( ; i < length; i++ ) { + if ( callback.call( obj[ i ], i, obj[ i ] ) === false ) { + break; + } + } + } else { + for ( i in obj ) { + if ( callback.call( obj[ i ], i, obj[ i ] ) === false ) { + break; + } + } + } + + return obj; + }, + + // Support: Android <=4.0 only + trim: function( text ) { + return text == null ? + "" : + ( text + "" ).replace( rtrim, "" ); + }, + + // results is for internal usage only + makeArray: function( arr, results ) { + var ret = results || []; + + if ( arr != null ) { + if ( isArrayLike( Object( arr ) ) ) { + jQuery.merge( ret, + typeof arr === "string" ? + [ arr ] : arr + ); + } else { + push.call( ret, arr ); + } + } + + return ret; + }, + + inArray: function( elem, arr, i ) { + return arr == null ? -1 : indexOf.call( arr, elem, i ); + }, + + // Support: Android <=4.0 only, PhantomJS 1 only + // push.apply(_, arraylike) throws on ancient WebKit + merge: function( first, second ) { + var len = +second.length, + j = 0, + i = first.length; + + for ( ; j < len; j++ ) { + first[ i++ ] = second[ j ]; + } + + first.length = i; + + return first; + }, + + grep: function( elems, callback, invert ) { + var callbackInverse, + matches = [], + i = 0, + length = elems.length, + callbackExpect = !invert; + + // Go through the array, only saving the items + // that pass the validator function + for ( ; i < length; i++ ) { + callbackInverse = !callback( elems[ i ], i ); + if ( callbackInverse !== callbackExpect ) { + matches.push( elems[ i ] ); + } + } + + return matches; + }, + + // arg is for internal usage only + map: function( elems, callback, arg ) { + var length, value, + i = 0, + ret = []; + + // Go through the array, translating each of the items to their new values + if ( isArrayLike( elems ) ) { + length = elems.length; + for ( ; i < length; i++ ) { + value = callback( elems[ i ], i, arg ); + + if ( value != null ) { + ret.push( value ); + } + } + + // Go through every key on the object, + } else { + for ( i in elems ) { + value = callback( elems[ i ], i, arg ); + + if ( value != null ) { + ret.push( value ); + } + } + } + + // Flatten any nested arrays + return concat.apply( [], ret ); + }, + + // A global GUID counter for objects + guid: 1, + + // Bind a function to a context, optionally partially applying any + // arguments. + proxy: function( fn, context ) { + var tmp, args, proxy; + + if ( typeof context === "string" ) { + tmp = fn[ context ]; + context = fn; + fn = tmp; + } + + // Quick check to determine if target is callable, in the spec + // this throws a TypeError, but we will just return undefined. + if ( !jQuery.isFunction( fn ) ) { + return undefined; + } + + // Simulated bind + args = slice.call( arguments, 2 ); + proxy = function() { + return fn.apply( context || this, args.concat( slice.call( arguments ) ) ); + }; + + // Set the guid of unique handler to the same of original handler, so it can be removed + proxy.guid = fn.guid = fn.guid || jQuery.guid++; + + return proxy; + }, + + now: Date.now, + + // jQuery.support is not used in Core but other projects attach their + // properties to it so it needs to exist. + support: support +} ); + +if ( typeof Symbol === "function" ) { + jQuery.fn[ Symbol.iterator ] = arr[ Symbol.iterator ]; +} + +// Populate the class2type map +jQuery.each( "Boolean Number String Function Array Date RegExp Object Error Symbol".split( " " ), +function( i, name ) { + class2type[ "[object " + name + "]" ] = name.toLowerCase(); +} ); + +function isArrayLike( obj ) { + + // Support: real iOS 8.2 only (not reproducible in simulator) + // `in` check used to prevent JIT error (gh-2145) + // hasOwn isn't used here due to false negatives + // regarding Nodelist length in IE + var length = !!obj && "length" in obj && obj.length, + type = jQuery.type( obj ); + + if ( type === "function" || jQuery.isWindow( obj ) ) { + return false; + } + + return type === "array" || length === 0 || + typeof length === "number" && length > 0 && ( length - 1 ) in obj; +} +var Sizzle = +/*! + * Sizzle CSS Selector Engine v2.3.0 + * https://sizzlejs.com/ + * + * Copyright jQuery Foundation and other contributors + * Released under the MIT license + * http://jquery.org/license + * + * Date: 2016-01-04 + */ +(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" + 1 * new Date(), + preferredDoc = window.document, + dirruns = 0, + done = 0, + classCache = createCache(), + tokenCache = createCache(), + compilerCache = createCache(), + sortOrder = function( a, b ) { + if ( a === b ) { + hasDuplicate = true; + } + return 0; + }, + + // 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 + // https://jsperf.com/thor-indexof-vs-for/5 + indexOf = function( list, elem ) { + var i = 0, + len = list.length; + for ( ; i < len; i++ ) { + 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 + + // http://www.w3.org/TR/css3-selectors/#whitespace + whitespace = "[\\x20\\t\\r\\n\\f]", + + // http://www.w3.org/TR/CSS21/syndata.html#value-def-identifier + identifier = "(?:\\\\.|[\\w-]|[^\0-\\xa0])+", + + // Attribute selectors: http://www.w3.org/TR/selectors/#attribute-selectors + attributes = "\\[" + whitespace + "*(" + identifier + ")(?:" + whitespace + + // Operator (capture 2) + "*([*^$|!~]?=)" + whitespace + + // "Attribute values must be CSS identifiers [capture 5] or strings [capture 3 or capture 4]" + "*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|(" + identifier + "))|)" + whitespace + + "*\\]", + + pseudos = ":(" + identifier + ")(?:\\((" + + // 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 RegExp( pseudos ), + ridentifier = new RegExp( "^" + identifier + "$" ), + + matchExpr = { + "ID": new RegExp( "^#(" + identifier + ")" ), + "CLASS": new RegExp( "^\\.(" + identifier + ")" ), + "TAG": new RegExp( "^(" + identifier + "|[*])" ), + "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 = /^h\d$/i, + + rnative = /^[^{]+\{\s*\[native \w/, + + // Easily-parseable/retrievable ID or TAG or CLASS selectors + rquickExpr = /^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/, + + rsibling = /[+~]/, + + // 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 ); + }, + + // CSS string/identifier serialization + // https://drafts.csswg.org/cssom/#common-serializing-idioms + rcssescape = /([\0-\x1f\x7f]|^-?\d)|^-$|[^\x80-\uFFFF\w-]/g, + fcssescape = function( ch, asCodePoint ) { + if ( asCodePoint ) { + + // U+0000 NULL becomes U+FFFD REPLACEMENT CHARACTER + if ( ch === "\0" ) { + return "\uFFFD"; + } + + // Control characters and (dependent upon position) numbers get escaped as code points + return ch.slice( 0, -1 ) + "\\" + ch.charCodeAt( ch.length - 1 ).toString( 16 ) + " "; + } + + // Other potentially-special ASCII characters get backslash-escaped + return "\\" + ch; + }, + + // Used for iframes + // See setDocument() + // Removing the function wrapper causes a "Permission Denied" + // error in IE + unloadHandler = function() { + setDocument(); + }, + + disabledAncestor = addCombinator( + function( elem ) { + return elem.disabled === true; + }, + { dir: "parentNode", next: "legend" } + ); + +// 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 = j - 1; + } + }; +} + +function Sizzle( selector, context, results, seed ) { + var m, i, elem, nid, match, groups, newSelector, + newContext = context && context.ownerDocument, + + // nodeType defaults to 9, since context defaults to document + nodeType = context ? context.nodeType : 9; + + results = results || []; + + // Return early from calls with invalid selector or context + if ( typeof selector !== "string" || !selector || + nodeType !== 1 && nodeType !== 9 && nodeType !== 11 ) { + + return results; + } + + // Try to shortcut find operations (as opposed to filters) in HTML documents + if ( !seed ) { + + if ( ( context ? context.ownerDocument || context : preferredDoc ) !== document ) { + setDocument( context ); + } + context = context || document; + + if ( documentIsHTML ) { + + // If the selector is sufficiently simple, try using a "get*By*" DOM method + // (excepting DocumentFragment context, where the methods don't exist) + if ( nodeType !== 11 && (match = rquickExpr.exec( selector )) ) { + + // ID selector + if ( (m = match[1]) ) { + + // Document context + if ( nodeType === 9 ) { + if ( (elem = context.getElementById( m )) ) { + + // Support: IE, Opera, Webkit + // TODO: identify versions + // getElementById can match elements by name instead of ID + if ( elem.id === m ) { + results.push( elem ); + return results; + } + } else { + return results; + } + + // Element context + } else { + + // Support: IE, Opera, Webkit + // TODO: identify versions + // getElementById can match elements by name instead of ID + if ( newContext && (elem = newContext.getElementById( m )) && + contains( context, elem ) && + elem.id === m ) { + + results.push( elem ); + return results; + } + } + + // Type selector + } else if ( match[2] ) { + push.apply( results, context.getElementsByTagName( selector ) ); + return results; + + // Class selector + } else if ( (m = match[3]) && support.getElementsByClassName && + context.getElementsByClassName ) { + + push.apply( results, context.getElementsByClassName( m ) ); + return results; + } + } + + // Take advantage of querySelectorAll + if ( support.qsa && + !compilerCache[ selector + " " ] && + (!rbuggyQSA || !rbuggyQSA.test( selector )) ) { + + if ( nodeType !== 1 ) { + newContext = context; + newSelector = selector; + + // qSA looks outside Element context, which is not what we want + // Thanks to Andrew Dupont for this workaround technique + // Support: IE <=8 + // Exclude object elements + } else if ( context.nodeName.toLowerCase() !== "object" ) { + + // Capture the context ID, setting it first if necessary + if ( (nid = context.getAttribute( "id" )) ) { + nid = nid.replace( rcssescape, fcssescape ); + } else { + context.setAttribute( "id", (nid = expando) ); + } + + // Prefix every selector in the list + groups = tokenize( selector ); + i = groups.length; + while ( i-- ) { + groups[i] = "#" + nid + " " + toSelector( groups[i] ); + } + newSelector = groups.join( "," ); + + // Expand context for sibling selectors + newContext = rsibling.test( selector ) && testContext( context.parentNode ) || + context; + } + + if ( newSelector ) { + try { + push.apply( results, + newContext.querySelectorAll( newSelector ) + ); + return results; + } catch ( qsaError ) { + } finally { + if ( nid === expando ) { + context.removeAttribute( "id" ); + } + } + } + } + } + } + + // All others + return select( selector.replace( rtrim, "$1" ), context, results, seed ); +} + +/** + * 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 cache( key, value ) { + // Use (key + " ") to avoid collision with native prototype properties (see Issue #157) + if ( keys.push( key + " " ) > Expr.cacheLength ) { + // Only keep the most recent entries + delete cache[ keys.shift() ]; + } + return (cache[ key + " " ] = 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 element and returns a boolean result + */ +function assert( fn ) { + var el = document.createElement("fieldset"); + + try { + return !!fn( el ); + } catch (e) { + return false; + } finally { + // Remove from its parent by default + if ( el.parentNode ) { + el.parentNode.removeChild( el ); + } + // release memory in IE + el = 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 addHandle( attrs, handler ) { + var arr = attrs.split("|"), + i = arr.length; + + while ( i-- ) { + Expr.attrHandle[ arr[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 siblingCheck( a, b ) { + var cur = b && a, + diff = cur && a.nodeType === 1 && b.nodeType === 1 && + a.sourceIndex - b.sourceIndex; + + // 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 === b ) { + return -1; + } + } + } + + return a ? 1 : -1; +} + +/** + * Returns a function to use in pseudos for input types + * @param {String} type + */ +function createInputPseudo( type ) { + 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 createButtonPseudo( type ) { + return function( elem ) { + var name = elem.nodeName.toLowerCase(); + return (name === "input" || name === "button") && elem.type === type; + }; +} + +/** + * Returns a function to use in pseudos for :enabled/:disabled + * @param {Boolean} disabled true for :disabled; false for :enabled + */ +function createDisabledPseudo( disabled ) { + // Known :disabled false positives: + // IE: *[disabled]:not(button, input, select, textarea, optgroup, option, menuitem, fieldset) + // not IE: fieldset[disabled] > legend:nth-of-type(n+2) :can-disable + return function( elem ) { + + // Check form elements and option elements for explicit disabling + return "label" in elem && elem.disabled === disabled || + "form" in elem && elem.disabled === disabled || + + // Check non-disabled form elements for fieldset[disabled] ancestors + "form" in elem && elem.disabled === false && ( + // Support: IE6-11+ + // Ancestry is covered for us + elem.isDisabled === disabled || + + // Otherwise, assume any non-