Initial project docs and framework.
This commit is contained in:
		
							
								
								
									
										34
									
								
								.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										34
									
								
								.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,34 @@ | ||||
| # Compiled files | ||||
| *.py[co] | ||||
| *.a | ||||
| *.o | ||||
| *.so | ||||
|  | ||||
| # Sphinx | ||||
| _build | ||||
|  | ||||
| # Packages/installer info | ||||
| *.egg | ||||
| *.egg-info | ||||
| dist | ||||
| build | ||||
| eggs | ||||
| parts | ||||
| bin | ||||
| var | ||||
| sdist | ||||
| develop-eggs | ||||
| .installed.cfg | ||||
|  | ||||
| # Other | ||||
| .testrepository | ||||
| .tox | ||||
| .*.swp | ||||
| .coverage | ||||
| cover | ||||
| AUTHORS | ||||
| ChangeLog | ||||
|  | ||||
| # Editor files | ||||
| *~ | ||||
| *.swp | ||||
							
								
								
									
										4
									
								
								.testr.conf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								.testr.conf
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,4 @@ | ||||
| [DEFAULT] | ||||
| test_command=${PYTHON:-python} -m subunit.run discover -t ./ . $LISTOPT $IDOPTION | ||||
| test_id_option=--load-list $IDFILE | ||||
| test_list_option=--list | ||||
							
								
								
									
										17
									
								
								CONTRIBUTING.rst
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								CONTRIBUTING.rst
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,17 @@ | ||||
| If you would like to contribute to the development of OpenStack, | ||||
| you must follow the steps in the "If you're a developer, start here" | ||||
| section of this page: | ||||
|  | ||||
|    http://wiki.openstack.org/HowToContribute | ||||
|  | ||||
| Once those steps have been completed, changes to OpenStack | ||||
| should be submitted for review via the Gerrit tool, following | ||||
| the workflow documented at: | ||||
|  | ||||
|    http://wiki.openstack.org/GerritWorkflow | ||||
|  | ||||
| Pull requests submitted through GitHub will be ignored. | ||||
|  | ||||
| Bugs should be filed on Launchpad, not GitHub: | ||||
|  | ||||
|    https://bugs.launchpad.net/bindep | ||||
							
								
								
									
										176
									
								
								LICENSE
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										176
									
								
								LICENSE
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,176 @@ | ||||
|  | ||||
|                                  Apache License | ||||
|                            Version 2.0, January 2004 | ||||
|                         http://www.apache.org/licenses/ | ||||
|  | ||||
|    TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION | ||||
|  | ||||
|    1. Definitions. | ||||
|  | ||||
|       "License" shall mean the terms and conditions for use, reproduction, | ||||
|       and distribution as defined by Sections 1 through 9 of this document. | ||||
|  | ||||
|       "Licensor" shall mean the copyright owner or entity authorized by | ||||
|       the copyright owner that is granting the License. | ||||
|  | ||||
|       "Legal Entity" shall mean the union of the acting entity and all | ||||
|       other entities that control, are controlled by, or are under common | ||||
|       control with that entity. For the purposes of this definition, | ||||
|       "control" means (i) the power, direct or indirect, to cause the | ||||
|       direction or management of such entity, whether by contract or | ||||
|       otherwise, or (ii) ownership of fifty percent (50%) or more of the | ||||
|       outstanding shares, or (iii) beneficial ownership of such entity. | ||||
|  | ||||
|       "You" (or "Your") shall mean an individual or Legal Entity | ||||
|       exercising permissions granted by this License. | ||||
|  | ||||
|       "Source" form shall mean the preferred form for making modifications, | ||||
|       including but not limited to software source code, documentation | ||||
|       source, and configuration files. | ||||
|  | ||||
|       "Object" form shall mean any form resulting from mechanical | ||||
|       transformation or translation of a Source form, including but | ||||
|       not limited to compiled object code, generated documentation, | ||||
|       and conversions to other media types. | ||||
|  | ||||
|       "Work" shall mean the work of authorship, whether in Source or | ||||
|       Object form, made available under the License, as indicated by a | ||||
|       copyright notice that is included in or attached to the work | ||||
|       (an example is provided in the Appendix below). | ||||
|  | ||||
|       "Derivative Works" shall mean any work, whether in Source or Object | ||||
|       form, that is based on (or derived from) the Work and for which the | ||||
|       editorial revisions, annotations, elaborations, or other modifications | ||||
|       represent, as a whole, an original work of authorship. For the purposes | ||||
|       of this License, Derivative Works shall not include works that remain | ||||
|       separable from, or merely link (or bind by name) to the interfaces of, | ||||
|       the Work and Derivative Works thereof. | ||||
|  | ||||
|       "Contribution" shall mean any work of authorship, including | ||||
|       the original version of the Work and any modifications or additions | ||||
|       to that Work or Derivative Works thereof, that is intentionally | ||||
|       submitted to Licensor for inclusion in the Work by the copyright owner | ||||
|       or by an individual or Legal Entity authorized to submit on behalf of | ||||
|       the copyright owner. For the purposes of this definition, "submitted" | ||||
|       means any form of electronic, verbal, or written communication sent | ||||
|       to the Licensor or its representatives, including but not limited to | ||||
|       communication on electronic mailing lists, source code control systems, | ||||
|       and issue tracking systems that are managed by, or on behalf of, the | ||||
|       Licensor for the purpose of discussing and improving the Work, but | ||||
|       excluding communication that is conspicuously marked or otherwise | ||||
|       designated in writing by the copyright owner as "Not a Contribution." | ||||
|  | ||||
|       "Contributor" shall mean Licensor and any individual or Legal Entity | ||||
|       on behalf of whom a Contribution has been received by Licensor and | ||||
|       subsequently incorporated within the Work. | ||||
|  | ||||
|    2. Grant of Copyright License. Subject to the terms and conditions of | ||||
|       this License, each Contributor hereby grants to You a perpetual, | ||||
|       worldwide, non-exclusive, no-charge, royalty-free, irrevocable | ||||
|       copyright license to reproduce, prepare Derivative Works of, | ||||
|       publicly display, publicly perform, sublicense, and distribute the | ||||
|       Work and such Derivative Works in Source or Object form. | ||||
|  | ||||
|    3. Grant of Patent License. Subject to the terms and conditions of | ||||
|       this License, each Contributor hereby grants to You a perpetual, | ||||
|       worldwide, non-exclusive, no-charge, royalty-free, irrevocable | ||||
|       (except as stated in this section) patent license to make, have made, | ||||
|       use, offer to sell, sell, import, and otherwise transfer the Work, | ||||
|       where such license applies only to those patent claims licensable | ||||
|       by such Contributor that are necessarily infringed by their | ||||
|       Contribution(s) alone or by combination of their Contribution(s) | ||||
|       with the Work to which such Contribution(s) was submitted. If You | ||||
|       institute patent litigation against any entity (including a | ||||
|       cross-claim or counterclaim in a lawsuit) alleging that the Work | ||||
|       or a Contribution incorporated within the Work constitutes direct | ||||
|       or contributory patent infringement, then any patent licenses | ||||
|       granted to You under this License for that Work shall terminate | ||||
|       as of the date such litigation is filed. | ||||
|  | ||||
|    4. Redistribution. You may reproduce and distribute copies of the | ||||
|       Work or Derivative Works thereof in any medium, with or without | ||||
|       modifications, and in Source or Object form, provided that You | ||||
|       meet the following conditions: | ||||
|  | ||||
|       (a) You must give any other recipients of the Work or | ||||
|           Derivative Works a copy of this License; and | ||||
|  | ||||
|       (b) You must cause any modified files to carry prominent notices | ||||
|           stating that You changed the files; and | ||||
|  | ||||
|       (c) You must retain, in the Source form of any Derivative Works | ||||
|           that You distribute, all copyright, patent, trademark, and | ||||
|           attribution notices from the Source form of the Work, | ||||
|           excluding those notices that do not pertain to any part of | ||||
|           the Derivative Works; and | ||||
|  | ||||
|       (d) If the Work includes a "NOTICE" text file as part of its | ||||
|           distribution, then any Derivative Works that You distribute must | ||||
|           include a readable copy of the attribution notices contained | ||||
|           within such NOTICE file, excluding those notices that do not | ||||
|           pertain to any part of the Derivative Works, in at least one | ||||
|           of the following places: within a NOTICE text file distributed | ||||
|           as part of the Derivative Works; within the Source form or | ||||
|           documentation, if provided along with the Derivative Works; or, | ||||
|           within a display generated by the Derivative Works, if and | ||||
|           wherever such third-party notices normally appear. The contents | ||||
|           of the NOTICE file are for informational purposes only and | ||||
|           do not modify the License. You may add Your own attribution | ||||
|           notices within Derivative Works that You distribute, alongside | ||||
|           or as an addendum to the NOTICE text from the Work, provided | ||||
|           that such additional attribution notices cannot be construed | ||||
|           as modifying the License. | ||||
|  | ||||
|       You may add Your own copyright statement to Your modifications and | ||||
|       may provide additional or different license terms and conditions | ||||
|       for use, reproduction, or distribution of Your modifications, or | ||||
|       for any such Derivative Works as a whole, provided Your use, | ||||
|       reproduction, and distribution of the Work otherwise complies with | ||||
|       the conditions stated in this License. | ||||
|  | ||||
|    5. Submission of Contributions. Unless You explicitly state otherwise, | ||||
|       any Contribution intentionally submitted for inclusion in the Work | ||||
|       by You to the Licensor shall be under the terms and conditions of | ||||
|       this License, without any additional terms or conditions. | ||||
|       Notwithstanding the above, nothing herein shall supersede or modify | ||||
|       the terms of any separate license agreement you may have executed | ||||
|       with Licensor regarding such Contributions. | ||||
|  | ||||
|    6. Trademarks. This License does not grant permission to use the trade | ||||
|       names, trademarks, service marks, or product names of the Licensor, | ||||
|       except as required for reasonable and customary use in describing the | ||||
|       origin of the Work and reproducing the content of the NOTICE file. | ||||
|  | ||||
|    7. Disclaimer of Warranty. Unless required by applicable law or | ||||
|       agreed to in writing, Licensor provides the Work (and each | ||||
|       Contributor provides its Contributions) on an "AS IS" BASIS, | ||||
|       WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or | ||||
|       implied, including, without limitation, any warranties or conditions | ||||
|       of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A | ||||
|       PARTICULAR PURPOSE. You are solely responsible for determining the | ||||
|       appropriateness of using or redistributing the Work and assume any | ||||
|       risks associated with Your exercise of permissions under this License. | ||||
|  | ||||
|    8. Limitation of Liability. In no event and under no legal theory, | ||||
|       whether in tort (including negligence), contract, or otherwise, | ||||
|       unless required by applicable law (such as deliberate and grossly | ||||
|       negligent acts) or agreed to in writing, shall any Contributor be | ||||
|       liable to You for damages, including any direct, indirect, special, | ||||
|       incidental, or consequential damages of any character arising as a | ||||
|       result of this License or out of the use or inability to use the | ||||
|       Work (including but not limited to damages for loss of goodwill, | ||||
|       work stoppage, computer failure or malfunction, or any and all | ||||
|       other commercial damages or losses), even if such Contributor | ||||
|       has been advised of the possibility of such damages. | ||||
|  | ||||
|    9. Accepting Warranty or Additional Liability. While redistributing | ||||
|       the Work or Derivative Works thereof, You may choose to offer, | ||||
|       and charge a fee for, acceptance of support, warranty, indemnity, | ||||
|       or other liability obligations and/or rights consistent with this | ||||
|       License. However, in accepting such obligations, You may act only | ||||
|       on Your own behalf and on Your sole responsibility, not on behalf | ||||
|       of any other Contributor, and only if You agree to indemnify, | ||||
|       defend, and hold each Contributor harmless for any liability | ||||
|       incurred by, or claims asserted against, such Contributor by reason | ||||
|       of your accepting any such warranty or additional liability. | ||||
|  | ||||
							
								
								
									
										14
									
								
								MANIFEST.in
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								MANIFEST.in
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | ||||
| include AUTHORS | ||||
| include ChangeLog | ||||
| include CONTRIBUTING.rst | ||||
| include LICENSE | ||||
| include README.rst | ||||
| include other-requirements.txt | ||||
| include requirements.txt | ||||
| include test-requirements.txt | ||||
| include tox.ini | ||||
| recursive-include doc * | ||||
| exclude .gitignore | ||||
| exclude .gitreview | ||||
|  | ||||
| global-exclude *.pyc | ||||
							
								
								
									
										107
									
								
								README.rst
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										107
									
								
								README.rst
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,107 @@ | ||||
| Introduction | ||||
| ============ | ||||
|  | ||||
| Bindep is a tool for checking the presence of binary packages needed to | ||||
| use an application / library. It started life as a way to make it easier to set | ||||
| up a development environment for OpenStack projects. While OpenStack depends | ||||
| heavily on `pip` for installation of Python dependencies, some dependencies are | ||||
| not Python based, and particularly for testing, some dependencies have to be | ||||
| installed before `pip` can be used - such as `virtualenv` and `pip` itself. | ||||
|  | ||||
| Basics | ||||
| ====== | ||||
|  | ||||
| Create a file called ``other-requirements.txt`` and in that list any | ||||
| requirements your application / library has. In your README or INSTALL or | ||||
| other documentation you can tell users to run `bindep` to report on missing | ||||
| dependencies. Users without `bindep` installed can consult the | ||||
| ``other-requirements.txt`` file by hand if they choose, or install `bindep` | ||||
| first and then use it. | ||||
|  | ||||
| Profiles | ||||
| -------- | ||||
|  | ||||
| Profiles can be used to describe different scenarios. For instance, you might | ||||
| have a profile for using PostgreSQL which requires the PostgreSQL client | ||||
| library, a profile for MySQL needing that client library, and a profile for | ||||
| testing which requires both libraries as well as the servers. To select a | ||||
| profile just pass it when running `bindep` - e.g.:: | ||||
|  | ||||
|     $ bindep test | ||||
|  | ||||
| When running bindep a single profile can be chosen by the user, with no | ||||
| explicit selection resulting in the selected profile being ``default``. | ||||
| `bindep` will automatically activate additional profiles representing the | ||||
| platform `bindep` is running under, making it easy to handle platform specific | ||||
| quirks. | ||||
|  | ||||
| The available profiles are inferred by inspecting the requirements file | ||||
| and collating the used profile names. Users can get a report on the  | ||||
| available profiles:: | ||||
|  | ||||
|     $ bindep --profiles | ||||
|  | ||||
|  | ||||
| Writing Requirements Files | ||||
| ========================== | ||||
|  | ||||
| The requirements file ``other-requirements.txt`` lists the dependencies for | ||||
| projects. Where non-ascii characters are needed, they should be UTF8 encoded. | ||||
|  | ||||
| The file is line orientated - each line is a Debian binary package name, an | ||||
| optional profile selector and optional version constraints. (Note - if you are | ||||
| writing an alternative parser, see the Debian policy manual for the parsing | ||||
| rules for packagenames). Debian package names are used as a single source of | ||||
| truth - `bindep` can be taught the mapping onto specific packaging systems. | ||||
| Alternatively, profiles may be used to encode platform specific requirements. | ||||
|  | ||||
| Profiles are used to decide which lines in the requirements file should be | ||||
| considered when checking dependencies. Profile selectors are a list of space | ||||
| separated strings contained in ``[]``. A selector prefixed with ``!`` is a negative | ||||
| selector. For a line in the requirements file to be active: | ||||
|  | ||||
|  * it must not have a negative selector that matches the active profile. | ||||
|  * it must either have no positive selectors, or a positive selector that | ||||
|    matches the active profile. | ||||
|  | ||||
| For instance, the profile selector ``[!qpid]`` will match every profile except | ||||
| ``qpid`` and would be suitable for disabling installation of rabbitmq when qpid | ||||
| is in use. ``[default]`` would match only if the user has not selected a | ||||
| profile (or selected ``default``). ``[default postgresql test]`` would match | ||||
| those three profiles but not ``mysql``. ``[platform:rhel]`` will match only | ||||
| when running in a RHEL linux environment. | ||||
|  | ||||
| Version constraints are a comma separated list of constraints where each | ||||
| constraint is  (== | < | <= | >= | > | ><) VERSION, and the constraints are ANDed | ||||
| together (the same as pip requirements version constraints). | ||||
|  | ||||
| Developing bindep | ||||
| ================= | ||||
|  | ||||
| Either install `bindep` and run ``bindep test`` to check you have the needed | ||||
| tools, or review ``other-requirements.txt`` by hand. | ||||
|  | ||||
| Running Tests | ||||
| ------------- | ||||
|  | ||||
| The testing system is based on a combination of tox and testr. The canonical | ||||
| approach to running tests is to simply run the command `tox`. This will | ||||
| create virtual environments, populate them with depenedencies and run all of | ||||
| the tests that OpenStack CI systems run. Behind the scenes, tox is running | ||||
| `testr run --parallel`, but is set up such that you can supply any additional | ||||
| testr arguments that are needed to tox. For example, you can run: | ||||
| `tox -- --analyze-isolation` to cause tox to tell testr to add | ||||
| --analyze-isolation to its argument list. | ||||
|  | ||||
| It is also possible to run the tests inside of a virtual environment | ||||
| you have created, or it is possible that you have all of the dependencies | ||||
| installed locally already. If you'd like to go this route, the requirements | ||||
| are listed in requirements.txt and the requirements for testing are in | ||||
| test-requirements.txt. Installing them via pip, for instance, is simply:: | ||||
|  | ||||
|   pip install -r requirements.txt -r test-requirements.txt | ||||
|  | ||||
| In you go this route, you can interact with the testr command directly. | ||||
| Running `testr run` will run the entire test suite. `testr run --parallel` | ||||
| will run it in parallel (this is the default incantation tox uses.) More | ||||
| information about testr can be found at: http://wiki.openstack.org/testr | ||||
							
								
								
									
										0
									
								
								bindep/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								bindep/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
								
								
									
										17
									
								
								bindep/main.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								bindep/main.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,17 @@ | ||||
| # Copyright (c) 2013 Hewlett-Packard Development Company, L.P. | ||||
| # | ||||
| # Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| # you may not use this file except in compliance with the License. | ||||
| # You may obtain a copy of the License at | ||||
| # | ||||
| #    http://www.apache.org/licenses/LICENSE-2.0 | ||||
| # | ||||
| # Unless required by applicable law or agreed to in writing, software | ||||
| # distributed under the License is distributed on an "AS IS" BASIS, | ||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or | ||||
| # implied. | ||||
| # See the License for the specific language governing permissions and | ||||
| # limitations under the License. | ||||
|  | ||||
| def main(): | ||||
|     pass | ||||
							
								
								
									
										0
									
								
								bindep/tests/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								bindep/tests/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
								
								
									
										0
									
								
								doc/source/_templates/.placeholder
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								doc/source/_templates/.placeholder
									
									
									
									
									
										Normal file
									
								
							
							
								
								
									
										83
									
								
								doc/source/_theme/layout.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										83
									
								
								doc/source/_theme/layout.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,83 @@ | ||||
| {% extends "basic/layout.html" %} | ||||
| {% set css_files = css_files + ['_static/tweaks.css'] %} | ||||
| {% set script_files = script_files + ['_static/jquery.tweet.js'] %} | ||||
|  | ||||
| {%- macro sidebar() %} | ||||
|       {%- if not embedded %}{% if not theme_nosidebar|tobool %} | ||||
|       <div class="sphinxsidebar"> | ||||
|         <div class="sphinxsidebarwrapper"> | ||||
|           {%- block sidebarlogo %} | ||||
|           {%- if logo %} | ||||
|             <p class="logo"><a href="{{ pathto(master_doc) }}"> | ||||
|               <img class="logo" src="{{ pathto('_static/' + logo, 1) }}" alt="Logo"/> | ||||
|             </a></p> | ||||
|           {%- endif %} | ||||
|           {%- endblock %} | ||||
|           {%- block sidebartoc %} | ||||
|           {%- if display_toc %} | ||||
|             <h3><a href="{{ pathto(master_doc) }}">{{ _('Table Of Contents') }}</a></h3> | ||||
|             {{ toc }} | ||||
|           {%- endif %} | ||||
|           {%- endblock %} | ||||
|           {%- block sidebarrel %} | ||||
|           {%- if prev %} | ||||
|             <h4>{{ _('Previous topic') }}</h4> | ||||
|             <p class="topless"><a href="{{ prev.link|e }}" | ||||
|                                   title="{{ _('previous chapter') }}">{{ prev.title }}</a></p> | ||||
|           {%- endif %} | ||||
|           {%- if next %} | ||||
|             <h4>{{ _('Next topic') }}</h4> | ||||
|             <p class="topless"><a href="{{ next.link|e }}" | ||||
|                                   title="{{ _('next chapter') }}">{{ next.title }}</a></p> | ||||
|           {%- endif %} | ||||
|           {%- endblock %} | ||||
|           {%- block sidebarsourcelink %} | ||||
|           {%- if show_source and has_source and sourcename %} | ||||
|             <h3>{{ _('This Page') }}</h3> | ||||
|             <ul class="this-page-menu"> | ||||
|               <li><a href="{{ pathto('_sources/' + sourcename, true)|e }}" | ||||
|                      rel="nofollow">{{ _('Show Source') }}</a></li> | ||||
|             </ul> | ||||
|           {%- endif %} | ||||
|           {%- endblock %} | ||||
|           {%- if customsidebar %} | ||||
|           {% include customsidebar %} | ||||
|           {%- endif %} | ||||
|           {%- block sidebarsearch %} | ||||
|           {%- if pagename != "search" %} | ||||
|           <div id="searchbox" style="display: none"> | ||||
|             <h3>{{ _('Quick search') }}</h3> | ||||
|               <form class="search" action="{{ pathto('search') }}" method="get"> | ||||
|                 <input type="text" name="q" size="18" /> | ||||
|                 <input type="submit" value="{{ _('Go') }}" /> | ||||
|                 <input type="hidden" name="check_keywords" value="yes" /> | ||||
|                 <input type="hidden" name="area" value="default" /> | ||||
|               </form> | ||||
|               <p class="searchtip" style="font-size: 90%"> | ||||
|               {{ _('Enter search terms or a module, class or function name.') }} | ||||
|               </p> | ||||
|           </div> | ||||
|           <script type="text/javascript">$('#searchbox').show(0);</script> | ||||
|           {%- endif %} | ||||
|           {%- endblock %} | ||||
|         </div> | ||||
|       </div> | ||||
|       {%- endif %}{% endif %} | ||||
| {%- endmacro %} | ||||
|  | ||||
| {% block relbar1 %}{% endblock relbar1 %} | ||||
|  | ||||
| {% block header %} | ||||
|   <div id="header"> | ||||
|     <h1 id="logo"><a href="http://www.openstack.org/">OpenStack</a></h1> | ||||
|     <ul id="navigation"> | ||||
|       <li><a href="http://www.openstack.org/" title="Go to the Home page" class="link">Home</a></li> | ||||
|       <li><a href="http://www.openstack.org/projects/" title="Go to the OpenStack Projects page">Projects</a></li> | ||||
|       <li><a href="http://www.openstack.org/user-stories/" title="Go to the User Stories page" class="link">User Stories</a></li> | ||||
|       <li><a href="http://www.openstack.org/community/" title="Go to the Community page" class="link">Community</a></li> | ||||
|       <li><a href="http://www.openstack.org/blog/" title="Go to the OpenStack Blog">Blog</a></li> | ||||
|       <li><a href="http://wiki.openstack.org/" title="Go to the OpenStack Wiki">Wiki</a></li> | ||||
|       <li><a href="http://docs.openstack.org/" title="Go to OpenStack Documentation" class="current">Documentation</a></li> | ||||
|     </ul> | ||||
|   </div> | ||||
| {% endblock %} | ||||
							
								
								
									
										4
									
								
								doc/source/_theme/theme.conf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								doc/source/_theme/theme.conf
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,4 @@ | ||||
| [theme] | ||||
| inherit = basic | ||||
| stylesheet = nature.css | ||||
| pygments_style = tango | ||||
							
								
								
									
										62
									
								
								doc/source/conf.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										62
									
								
								doc/source/conf.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,62 @@ | ||||
| # -*- coding: utf-8 -*- | ||||
|  | ||||
| import os | ||||
| import sys | ||||
|  | ||||
| sys.path.insert(0, os.path.abspath('../..')) | ||||
| # -- General configuration ---------------------------------------------------- | ||||
|  | ||||
| # Add any Sphinx extension module names here, as strings. They can be | ||||
| # extensions coming with Sphinx (named 'sphinx.ext.*') or your custom ones. | ||||
| extensions = ['sphinx.ext.autodoc', 'sphinx.ext.intersphinx'] | ||||
|  | ||||
| # autodoc generation is a bit aggressive and a nuisance when doing heavy | ||||
| # text edit cycles. | ||||
| # execute "export SPHINX_DEBUG=1" in your terminal to disable | ||||
|  | ||||
| # Add any paths that contain templates here, relative to this directory. | ||||
| templates_path = ['_templates'] | ||||
|  | ||||
| # The suffix of source filenames. | ||||
| source_suffix = '.rst' | ||||
|  | ||||
| # The master toctree document. | ||||
| master_doc = 'index' | ||||
|  | ||||
| # General information about the project. | ||||
| project = 'bindep' | ||||
| copyright = '2013, OpenStack Foundation' | ||||
|  | ||||
| # If true, '()' will be appended to :func: etc. cross-reference text. | ||||
| add_function_parentheses = True | ||||
|  | ||||
| # If true, the current module name will be prepended to all description | ||||
| # unit titles (such as .. function::). | ||||
| add_module_names = True | ||||
|  | ||||
| # The name of the Pygments (syntax highlighting) style to use. | ||||
| pygments_style = 'sphinx' | ||||
|  | ||||
| # -- Options for HTML output -------------------------------------------------- | ||||
|  | ||||
| # The theme to use for HTML and HTML Help pages.  Major themes that come with | ||||
| # Sphinx are currently 'default' and 'sphinxdoc'. | ||||
| html_theme_path = ["."] | ||||
| html_theme = '_theme' | ||||
| html_static_path = ['static'] | ||||
|  | ||||
| # Output file base name for HTML help builder. | ||||
| htmlhelp_basename = '%sdoc' % project | ||||
|  | ||||
| # Grouping the document tree into LaTeX files. List of tuples | ||||
| # (source start file, target name, title, author, documentclass | ||||
| # [howto/manual]). | ||||
| latex_documents = [ | ||||
|     ('index', | ||||
|      '%s.tex' % project, | ||||
|      '%s Documentation' % project, | ||||
|      'OpenStack Foundation', 'manual'), | ||||
| ] | ||||
|  | ||||
| # Example configuration for intersphinx: refer to the Python standard library. | ||||
| intersphinx_mapping = {'http://docs.python.org/': None} | ||||
							
								
								
									
										12
									
								
								doc/source/index.rst
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								doc/source/index.rst
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | ||||
| bindep - Binary dependency management | ||||
| ===================================== | ||||
|  | ||||
| A utility for declaring what dependencies programs have in a programmatic | ||||
| manner. | ||||
|  | ||||
| Indices and tables | ||||
| ================== | ||||
|  | ||||
| * :ref:`genindex` | ||||
| * :ref:`modindex` | ||||
| * :ref:`search` | ||||
							
								
								
									
										416
									
								
								doc/source/static/basic.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										416
									
								
								doc/source/static/basic.css
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,416 @@ | ||||
| /** | ||||
|  * Sphinx stylesheet -- basic theme | ||||
|  * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  */ | ||||
|  | ||||
| /* -- 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%; | ||||
| } | ||||
|  | ||||
| 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; | ||||
| } | ||||
|  | ||||
| img { | ||||
|     border: 0; | ||||
| } | ||||
|  | ||||
| /* -- 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%; | ||||
| } | ||||
|  | ||||
| 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 td { | ||||
|     text-align: left; | ||||
|     vertical-align: top; | ||||
| } | ||||
|  | ||||
| table.indextable dl, table.indextable dd { | ||||
|     margin-top: 0; | ||||
|     margin-bottom: 0; | ||||
| } | ||||
|  | ||||
| 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; | ||||
| } | ||||
|  | ||||
| /* -- general body styles --------------------------------------------------- */ | ||||
|  | ||||
| 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 { | ||||
|     visibility: visible; | ||||
| } | ||||
|  | ||||
| div.body p.caption { | ||||
|     text-align: inherit; | ||||
| } | ||||
|  | ||||
| div.body td { | ||||
|     text-align: left; | ||||
| } | ||||
|  | ||||
| .field-list ul { | ||||
|     padding-left: 1em; | ||||
| } | ||||
|  | ||||
| .first { | ||||
| } | ||||
|  | ||||
| p.rubric { | ||||
|     margin-top: 30px; | ||||
|     font-weight: bold; | ||||
| } | ||||
|  | ||||
| /* -- 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.docutils td, table.docutils th { | ||||
|     padding: 1px 8px 1px 0; | ||||
|     border-top: 0; | ||||
|     border-left: 0; | ||||
|     border-right: 0; | ||||
|     border-bottom: 1px solid #aaa; | ||||
| } | ||||
|  | ||||
| table.field-list td, table.field-list th { | ||||
|     border: 0 !important; | ||||
| } | ||||
|  | ||||
| table.footnote td, table.footnote th { | ||||
|     border: 0 !important; | ||||
| } | ||||
|  | ||||
| th { | ||||
|     text-align: left; | ||||
|     padding-right: 5px; | ||||
| } | ||||
|  | ||||
| /* -- other body styles ----------------------------------------------------- */ | ||||
|  | ||||
| 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, .highlight { | ||||
|     background-color: #fbe54e; | ||||
| } | ||||
|  | ||||
| dl.glossary dt { | ||||
|     font-weight: bold; | ||||
|     font-size: 1.1em; | ||||
| } | ||||
|  | ||||
| .field-list ul { | ||||
|     margin: 0; | ||||
|     padding-left: 1em; | ||||
| } | ||||
|  | ||||
| .field-list p { | ||||
|     margin: 0; | ||||
| } | ||||
|  | ||||
| .refcount { | ||||
|     color: #060; | ||||
| } | ||||
|  | ||||
| .optional { | ||||
|     font-size: 1.3em; | ||||
| } | ||||
|  | ||||
| .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; | ||||
| } | ||||
|  | ||||
| /* -- code displays --------------------------------------------------------- */ | ||||
|  | ||||
| pre { | ||||
|     overflow: auto; | ||||
| } | ||||
|  | ||||
| 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; | ||||
| } | ||||
|  | ||||
| tt.descname { | ||||
|     background-color: transparent; | ||||
|     font-weight: bold; | ||||
|     font-size: 1.2em; | ||||
| } | ||||
|  | ||||
| tt.descclassname { | ||||
|     background-color: transparent; | ||||
| } | ||||
|  | ||||
| tt.xref, a tt { | ||||
|     background-color: transparent; | ||||
|     font-weight: bold; | ||||
| } | ||||
|  | ||||
| h1 tt, h2 tt, h3 tt, h4 tt, h5 tt, h6 tt { | ||||
|     background-color: transparent; | ||||
| } | ||||
|  | ||||
| /* -- math display ---------------------------------------------------------- */ | ||||
|  | ||||
| img.math { | ||||
|     vertical-align: middle; | ||||
| } | ||||
|  | ||||
| div.body div.math p { | ||||
|     text-align: center; | ||||
| } | ||||
|  | ||||
| span.eqno { | ||||
|     float: right; | ||||
| } | ||||
|  | ||||
| /* -- 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; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										230
									
								
								doc/source/static/default.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										230
									
								
								doc/source/static/default.css
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,230 @@ | ||||
| /** | ||||
|  * Sphinx stylesheet -- default theme | ||||
|  * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  */ | ||||
|  | ||||
| @import url("basic.css"); | ||||
|  | ||||
| /* -- page layout ----------------------------------------------------------- */ | ||||
|  | ||||
| body { | ||||
|     font-family: sans-serif; | ||||
|     font-size: 100%; | ||||
|     background-color: #11303d; | ||||
|     color: #000; | ||||
|     margin: 0; | ||||
|     padding: 0; | ||||
| } | ||||
|  | ||||
| div.document { | ||||
|     background-color: #1c4e63; | ||||
| } | ||||
|  | ||||
| div.documentwrapper { | ||||
|     float: left; | ||||
|     width: 100%; | ||||
| } | ||||
|  | ||||
| div.bodywrapper { | ||||
|     margin: 0 0 0 230px; | ||||
| } | ||||
|  | ||||
| div.body { | ||||
|     background-color: #ffffff; | ||||
|     color: #000000; | ||||
|     padding: 0 20px 30px 20px; | ||||
| } | ||||
|  | ||||
| div.footer { | ||||
|     color: #ffffff; | ||||
|     width: 100%; | ||||
|     padding: 9px 0 9px 0; | ||||
|     text-align: center; | ||||
|     font-size: 75%; | ||||
| } | ||||
|  | ||||
| div.footer a { | ||||
|     color: #ffffff; | ||||
|     text-decoration: underline; | ||||
| } | ||||
|  | ||||
| div.related { | ||||
|     background-color: #133f52; | ||||
|     line-height: 30px; | ||||
|     color: #ffffff; | ||||
| } | ||||
|  | ||||
| div.related a { | ||||
|     color: #ffffff; | ||||
| } | ||||
|  | ||||
| div.sphinxsidebar { | ||||
| } | ||||
|  | ||||
| div.sphinxsidebar h3 { | ||||
|     font-family: 'Trebuchet MS', sans-serif; | ||||
|     color: #ffffff; | ||||
|     font-size: 1.4em; | ||||
|     font-weight: normal; | ||||
|     margin: 0; | ||||
|     padding: 0; | ||||
| } | ||||
|  | ||||
| div.sphinxsidebar h3 a { | ||||
|     color: #ffffff; | ||||
| } | ||||
|  | ||||
| div.sphinxsidebar h4 { | ||||
|     font-family: 'Trebuchet MS', sans-serif; | ||||
|     color: #ffffff; | ||||
|     font-size: 1.3em; | ||||
|     font-weight: normal; | ||||
|     margin: 5px 0 0 0; | ||||
|     padding: 0; | ||||
| } | ||||
|  | ||||
| div.sphinxsidebar p { | ||||
|     color: #ffffff; | ||||
| } | ||||
|  | ||||
| div.sphinxsidebar p.topless { | ||||
|     margin: 5px 10px 10px 10px; | ||||
| } | ||||
|  | ||||
| div.sphinxsidebar ul { | ||||
|     margin: 10px; | ||||
|     padding: 0; | ||||
|     color: #ffffff; | ||||
| } | ||||
|  | ||||
| div.sphinxsidebar a { | ||||
|     color: #98dbcc; | ||||
| } | ||||
|  | ||||
| div.sphinxsidebar input { | ||||
|     border: 1px solid #98dbcc; | ||||
|     font-family: sans-serif; | ||||
|     font-size: 1em; | ||||
| } | ||||
|  | ||||
| /* -- body styles ----------------------------------------------------------- */ | ||||
|  | ||||
| a { | ||||
|     color: #355f7c; | ||||
|     text-decoration: none; | ||||
| } | ||||
|  | ||||
| a:hover { | ||||
|     text-decoration: underline; | ||||
| } | ||||
|  | ||||
| div.body p, div.body dd, div.body li { | ||||
|     text-align: left; | ||||
|     line-height: 130%; | ||||
| } | ||||
|  | ||||
| div.body h1, | ||||
| div.body h2, | ||||
| div.body h3, | ||||
| div.body h4, | ||||
| div.body h5, | ||||
| div.body h6 { | ||||
|     font-family: 'Trebuchet MS', sans-serif; | ||||
|     background-color: #f2f2f2; | ||||
|     font-weight: normal; | ||||
|     color: #20435c; | ||||
|     border-bottom: 1px solid #ccc; | ||||
|     margin: 20px -20px 10px -20px; | ||||
|     padding: 3px 0 3px 10px; | ||||
| } | ||||
|  | ||||
| div.body h1 { margin-top: 0; font-size: 200%; } | ||||
| div.body h2 { font-size: 160%; } | ||||
| div.body h3 { font-size: 140%; } | ||||
| div.body h4 { font-size: 120%; } | ||||
| div.body h5 { font-size: 110%; } | ||||
| div.body h6 { font-size: 100%; } | ||||
|  | ||||
| a.headerlink { | ||||
|     color: #c60f0f; | ||||
|     font-size: 0.8em; | ||||
|     padding: 0 4px 0 4px; | ||||
|     text-decoration: none; | ||||
| } | ||||
|  | ||||
| a.headerlink:hover { | ||||
|     background-color: #c60f0f; | ||||
|     color: white; | ||||
| } | ||||
|  | ||||
| div.body p, div.body dd, div.body li { | ||||
|     text-align: left; | ||||
|     line-height: 130%; | ||||
| } | ||||
|  | ||||
| div.admonition p.admonition-title + p { | ||||
|     display: inline; | ||||
| } | ||||
|  | ||||
| div.admonition p { | ||||
|     margin-bottom: 5px; | ||||
| } | ||||
|  | ||||
| div.admonition pre { | ||||
|     margin-bottom: 5px; | ||||
| } | ||||
|  | ||||
| div.admonition ul, div.admonition ol { | ||||
|     margin-bottom: 5px; | ||||
| } | ||||
|  | ||||
| div.note { | ||||
|     background-color: #eee; | ||||
|     border: 1px solid #ccc; | ||||
| } | ||||
|  | ||||
| div.seealso { | ||||
|     background-color: #ffc; | ||||
|     border: 1px solid #ff6; | ||||
| } | ||||
|  | ||||
| div.topic { | ||||
|     background-color: #eee; | ||||
| } | ||||
|  | ||||
| div.warning { | ||||
|     background-color: #ffe4e4; | ||||
|     border: 1px solid #f66; | ||||
| } | ||||
|  | ||||
| p.admonition-title { | ||||
|     display: inline; | ||||
| } | ||||
|  | ||||
| p.admonition-title:after { | ||||
|     content: ":"; | ||||
| } | ||||
|  | ||||
| pre { | ||||
|     padding: 5px; | ||||
|     background-color: #eeffcc; | ||||
|     color: #333333; | ||||
|     line-height: 120%; | ||||
|     border: 1px solid #ac9; | ||||
|     border-left: none; | ||||
|     border-right: none; | ||||
| } | ||||
|  | ||||
| tt { | ||||
|     background-color: #ecf0f3; | ||||
|     padding: 0 1px 0 1px; | ||||
|     font-size: 0.95em; | ||||
| } | ||||
|  | ||||
| .warning tt { | ||||
|     background: #efc2c2; | ||||
| } | ||||
|  | ||||
| .note tt { | ||||
|     background: #d6d6d6; | ||||
| } | ||||
							
								
								
									
										
											BIN
										
									
								
								doc/source/static/header-line.gif
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								doc/source/static/header-line.gif
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 48 B | 
							
								
								
									
										
											BIN
										
									
								
								doc/source/static/header_bg.jpg
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								doc/source/static/header_bg.jpg
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 3.7 KiB | 
							
								
								
									
										154
									
								
								doc/source/static/jquery.tweet.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										154
									
								
								doc/source/static/jquery.tweet.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,154 @@ | ||||
| (function($) { | ||||
|  | ||||
|   $.fn.tweet = function(o){ | ||||
|     var s = { | ||||
|       username: ["seaofclouds"],              // [string]   required, unless you want to display our tweets. :) it can be an array, just do ["username1","username2","etc"] | ||||
|       list: null,                              //[string]   optional name of list belonging to username | ||||
|       avatar_size: null,                      // [integer]  height and width of avatar if displayed (48px max) | ||||
|       count: 3,                               // [integer]  how many tweets to display? | ||||
|       intro_text: null,                       // [string]   do you want text BEFORE your your tweets? | ||||
|       outro_text: null,                       // [string]   do you want text AFTER your tweets? | ||||
|       join_text:  null,                       // [string]   optional text in between date and tweet, try setting to "auto" | ||||
|       auto_join_text_default: "i said,",      // [string]   auto text for non verb: "i said" bullocks | ||||
|       auto_join_text_ed: "i",                 // [string]   auto text for past tense: "i" surfed | ||||
|       auto_join_text_ing: "i am",             // [string]   auto tense for present tense: "i was" surfing | ||||
|       auto_join_text_reply: "i replied to",   // [string]   auto tense for replies: "i replied to" @someone "with" | ||||
|       auto_join_text_url: "i was looking at", // [string]   auto tense for urls: "i was looking at" http:... | ||||
|       loading_text: null,                     // [string]   optional loading text, displayed while tweets load | ||||
|       query: null                             // [string]   optional search query | ||||
|     }; | ||||
|  | ||||
|     if(o) $.extend(s, o); | ||||
|  | ||||
|     $.fn.extend({ | ||||
|       linkUrl: function() { | ||||
|         var returning = []; | ||||
|         var regexp = /((ftp|http|https):\/\/(\w+:{0,1}\w*@)?(\S+)(:[0-9]+)?(\/|\/([\w#!:.?+=&%@!\-\/]))?)/gi; | ||||
|         this.each(function() { | ||||
|           returning.push(this.replace(regexp,"<a href=\"$1\">$1</a>")); | ||||
|         }); | ||||
|         return $(returning); | ||||
|       }, | ||||
|       linkUser: function() { | ||||
|         var returning = []; | ||||
|         var regexp = /[\@]+([A-Za-z0-9-_]+)/gi; | ||||
|         this.each(function() { | ||||
|           returning.push(this.replace(regexp,"<a href=\"http://twitter.com/$1\">@$1</a>")); | ||||
|         }); | ||||
|         return $(returning); | ||||
|       }, | ||||
|       linkHash: function() { | ||||
|         var returning = []; | ||||
|         var regexp = / [\#]+([A-Za-z0-9-_]+)/gi; | ||||
|         this.each(function() { | ||||
|           returning.push(this.replace(regexp, ' <a href="http://search.twitter.com/search?q=&tag=$1&lang=all&from='+s.username.join("%2BOR%2B")+'">#$1</a>')); | ||||
|         }); | ||||
|         return $(returning); | ||||
|       }, | ||||
|       capAwesome: function() { | ||||
|         var returning = []; | ||||
|         this.each(function() { | ||||
|           returning.push(this.replace(/\b(awesome)\b/gi, '<span class="awesome">$1</span>')); | ||||
|         }); | ||||
|         return $(returning); | ||||
|       }, | ||||
|       capEpic: function() { | ||||
|         var returning = []; | ||||
|         this.each(function() { | ||||
|           returning.push(this.replace(/\b(epic)\b/gi, '<span class="epic">$1</span>')); | ||||
|         }); | ||||
|         return $(returning); | ||||
|       }, | ||||
|       makeHeart: function() { | ||||
|         var returning = []; | ||||
|         this.each(function() { | ||||
|           returning.push(this.replace(/(<)+[3]/gi, "<tt class='heart'>♥</tt>")); | ||||
|         }); | ||||
|         return $(returning); | ||||
|       } | ||||
|     }); | ||||
|  | ||||
|     function relative_time(time_value) { | ||||
|       var parsed_date = Date.parse(time_value); | ||||
|       var relative_to = (arguments.length > 1) ? arguments[1] : new Date(); | ||||
|       var delta = parseInt((relative_to.getTime() - parsed_date) / 1000); | ||||
|       var pluralize = function (singular, n) { | ||||
|         return '' + n + ' ' + singular + (n == 1 ? '' : 's'); | ||||
|       }; | ||||
|       if(delta < 60) { | ||||
|       return 'less than a minute ago'; | ||||
|       } else if(delta < (45*60)) { | ||||
|       return 'about ' + pluralize("minute", parseInt(delta / 60)) + ' ago'; | ||||
|       } else if(delta < (24*60*60)) { | ||||
|       return 'about ' + pluralize("hour", parseInt(delta / 3600)) + ' ago'; | ||||
|       } else { | ||||
|       return 'about ' + pluralize("day", parseInt(delta / 86400)) + ' ago'; | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     function build_url() { | ||||
|       var proto = ('https:' == document.location.protocol ? 'https:' : 'http:'); | ||||
|       if (s.list) { | ||||
|         return proto+"//api.twitter.com/1/"+s.username[0]+"/lists/"+s.list+"/statuses.json?per_page="+s.count+"&callback=?"; | ||||
|       } else if (s.query == null && s.username.length == 1) { | ||||
|         return proto+'//twitter.com/status/user_timeline/'+s.username[0]+'.json?count='+s.count+'&callback=?'; | ||||
|       } else { | ||||
|         var query = (s.query || 'from:'+s.username.join('%20OR%20from:')); | ||||
|         return proto+'//search.twitter.com/search.json?&q='+query+'&rpp='+s.count+'&callback=?'; | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     return this.each(function(){ | ||||
|       var list = $('<ul class="tweet_list">').appendTo(this); | ||||
|       var intro = '<p class="tweet_intro">'+s.intro_text+'</p>'; | ||||
|       var outro = '<p class="tweet_outro">'+s.outro_text+'</p>'; | ||||
|       var loading = $('<p class="loading">'+s.loading_text+'</p>'); | ||||
|  | ||||
|       if(typeof(s.username) == "string"){ | ||||
|         s.username = [s.username]; | ||||
|       } | ||||
|  | ||||
|       if (s.loading_text) $(this).append(loading); | ||||
|       $.getJSON(build_url(), function(data){ | ||||
|         if (s.loading_text) loading.remove(); | ||||
|         if (s.intro_text) list.before(intro); | ||||
|         $.each((data.results || data), function(i,item){ | ||||
|           // auto join text based on verb tense and content | ||||
|           if (s.join_text == "auto") { | ||||
|             if (item.text.match(/^(@([A-Za-z0-9-_]+)) .*/i)) { | ||||
|               var join_text = s.auto_join_text_reply; | ||||
|             } else if (item.text.match(/(^\w+:\/\/[A-Za-z0-9-_]+\.[A-Za-z0-9-_:%&\?\/.=]+) .*/i)) { | ||||
|               var join_text = s.auto_join_text_url; | ||||
|             } else if (item.text.match(/^((\w+ed)|just) .*/im)) { | ||||
|               var join_text = s.auto_join_text_ed; | ||||
|             } else if (item.text.match(/^(\w*ing) .*/i)) { | ||||
|               var join_text = s.auto_join_text_ing; | ||||
|             } else { | ||||
|               var join_text = s.auto_join_text_default; | ||||
|             } | ||||
|           } else { | ||||
|             var join_text = s.join_text; | ||||
|           }; | ||||
|  | ||||
|           var from_user = item.from_user || item.user.screen_name; | ||||
|           var profile_image_url = item.profile_image_url || item.user.profile_image_url; | ||||
|           var join_template = '<span class="tweet_join"> '+join_text+' </span>'; | ||||
|           var join = ((s.join_text) ? join_template : ' '); | ||||
|           var avatar_template = '<a class="tweet_avatar" href="http://twitter.com/'+from_user+'"><img src="'+profile_image_url+'" height="'+s.avatar_size+'" width="'+s.avatar_size+'" alt="'+from_user+'\'s avatar" title="'+from_user+'\'s avatar" border="0"/></a>'; | ||||
|           var avatar = (s.avatar_size ? avatar_template : ''); | ||||
|           var date = '<a href="http://twitter.com/'+from_user+'/statuses/'+item.id+'" title="view tweet on twitter">'+relative_time(item.created_at)+'</a>'; | ||||
|           var text = '<span class="tweet_text">' +$([item.text]).linkUrl().linkUser().linkHash().makeHeart().capAwesome().capEpic()[0]+ '</span>'; | ||||
|  | ||||
|           // until we create a template option, arrange the items below to alter a tweet's display. | ||||
|           list.append('<li>' + avatar + date + join + text + '</li>'); | ||||
|  | ||||
|           list.children('li:first').addClass('tweet_first'); | ||||
|           list.children('li:odd').addClass('tweet_even'); | ||||
|           list.children('li:even').addClass('tweet_odd'); | ||||
|         }); | ||||
|         if (s.outro_text) list.after(outro); | ||||
|       }); | ||||
|  | ||||
|     }); | ||||
|   }; | ||||
| })(jQuery); | ||||
							
								
								
									
										245
									
								
								doc/source/static/nature.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										245
									
								
								doc/source/static/nature.css
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,245 @@ | ||||
| /* | ||||
|  * nature.css_t | ||||
|  * ~~~~~~~~~~~~ | ||||
|  * | ||||
|  * Sphinx stylesheet -- nature theme. | ||||
|  * | ||||
|  * :copyright: Copyright 2007-2011 by the Sphinx team, see AUTHORS. | ||||
|  * :license: BSD, see LICENSE for details. | ||||
|  * | ||||
|  */ | ||||
|   | ||||
| @import url("basic.css"); | ||||
|   | ||||
| /* -- page layout ----------------------------------------------------------- */ | ||||
|   | ||||
| body { | ||||
|     font-family: Arial, sans-serif; | ||||
|     font-size: 100%; | ||||
|     background-color: #111; | ||||
|     color: #555; | ||||
|     margin: 0; | ||||
|     padding: 0; | ||||
| } | ||||
|  | ||||
| div.documentwrapper { | ||||
|     float: left; | ||||
|     width: 100%; | ||||
| } | ||||
|  | ||||
| div.bodywrapper { | ||||
|     margin: 0 0 0 {{ theme_sidebarwidth|toint }}px; | ||||
| } | ||||
|  | ||||
| hr { | ||||
|     border: 1px solid #B1B4B6; | ||||
| } | ||||
|   | ||||
| div.document { | ||||
|     background-color: #eee; | ||||
| } | ||||
|   | ||||
| div.body { | ||||
|     background-color: #ffffff; | ||||
|     color: #3E4349; | ||||
|     padding: 0 30px 30px 30px; | ||||
|     font-size: 0.9em; | ||||
| } | ||||
|   | ||||
| div.footer { | ||||
|     color: #555; | ||||
|     width: 100%; | ||||
|     padding: 13px 0; | ||||
|     text-align: center; | ||||
|     font-size: 75%; | ||||
| } | ||||
|   | ||||
| div.footer a { | ||||
|     color: #444; | ||||
|     text-decoration: underline; | ||||
| } | ||||
|   | ||||
| div.related { | ||||
|     background-color: #6BA81E; | ||||
|     line-height: 32px; | ||||
|     color: #fff; | ||||
|     text-shadow: 0px 1px 0 #444; | ||||
|     font-size: 0.9em; | ||||
| } | ||||
|   | ||||
| div.related a { | ||||
|     color: #E2F3CC; | ||||
| } | ||||
|   | ||||
| div.sphinxsidebar { | ||||
|     font-size: 0.75em; | ||||
|     line-height: 1.5em; | ||||
| } | ||||
|  | ||||
| div.sphinxsidebarwrapper{ | ||||
|     padding: 20px 0; | ||||
| } | ||||
|   | ||||
| div.sphinxsidebar h3, | ||||
| div.sphinxsidebar h4 { | ||||
|     font-family: Arial, sans-serif; | ||||
|     color: #222; | ||||
|     font-size: 1.2em; | ||||
|     font-weight: normal; | ||||
|     margin: 0; | ||||
|     padding: 5px 10px; | ||||
|     background-color: #ddd; | ||||
|     text-shadow: 1px 1px 0 white | ||||
| } | ||||
|  | ||||
| div.sphinxsidebar h4{ | ||||
|     font-size: 1.1em; | ||||
| } | ||||
|   | ||||
| div.sphinxsidebar h3 a { | ||||
|     color: #444; | ||||
| } | ||||
|   | ||||
|   | ||||
| div.sphinxsidebar p { | ||||
|     color: #888; | ||||
|     padding: 5px 20px; | ||||
| } | ||||
|   | ||||
| div.sphinxsidebar p.topless { | ||||
| } | ||||
|   | ||||
| div.sphinxsidebar ul { | ||||
|     margin: 10px 20px; | ||||
|     padding: 0; | ||||
|     color: #000; | ||||
| } | ||||
|   | ||||
| div.sphinxsidebar a { | ||||
|     color: #444; | ||||
| } | ||||
|   | ||||
| div.sphinxsidebar input { | ||||
|     border: 1px solid #ccc; | ||||
|     font-family: sans-serif; | ||||
|     font-size: 1em; | ||||
| } | ||||
|  | ||||
| div.sphinxsidebar input[type=text]{ | ||||
|     margin-left: 20px; | ||||
| } | ||||
|   | ||||
| /* -- body styles ----------------------------------------------------------- */ | ||||
|   | ||||
| a { | ||||
|     color: #005B81; | ||||
|     text-decoration: none; | ||||
| } | ||||
|   | ||||
| a:hover { | ||||
|     color: #E32E00; | ||||
|     text-decoration: underline; | ||||
| } | ||||
|   | ||||
| div.body h1, | ||||
| div.body h2, | ||||
| div.body h3, | ||||
| div.body h4, | ||||
| div.body h5, | ||||
| div.body h6 { | ||||
|     font-family: Arial, sans-serif; | ||||
|     background-color: #BED4EB; | ||||
|     font-weight: normal; | ||||
|     color: #212224; | ||||
|     margin: 30px 0px 10px 0px; | ||||
|     padding: 5px 0 5px 10px; | ||||
|     text-shadow: 0px 1px 0 white | ||||
| } | ||||
|   | ||||
| div.body h1 { border-top: 20px solid white; margin-top: 0; font-size: 200%; } | ||||
| div.body h2 { font-size: 150%; background-color: #C8D5E3; } | ||||
| div.body h3 { font-size: 120%; background-color: #D8DEE3; } | ||||
| div.body h4 { font-size: 110%; background-color: #D8DEE3; } | ||||
| div.body h5 { font-size: 100%; background-color: #D8DEE3; } | ||||
| div.body h6 { font-size: 100%; background-color: #D8DEE3; } | ||||
|   | ||||
| a.headerlink { | ||||
|     color: #c60f0f; | ||||
|     font-size: 0.8em; | ||||
|     padding: 0 4px 0 4px; | ||||
|     text-decoration: none; | ||||
| } | ||||
|   | ||||
| a.headerlink:hover { | ||||
|     background-color: #c60f0f; | ||||
|     color: white; | ||||
| } | ||||
|   | ||||
| div.body p, div.body dd, div.body li { | ||||
|     line-height: 1.5em; | ||||
| } | ||||
|   | ||||
| div.admonition p.admonition-title + p { | ||||
|     display: inline; | ||||
| } | ||||
|  | ||||
| div.highlight{ | ||||
|     background-color: white; | ||||
| } | ||||
|  | ||||
| div.note { | ||||
|     background-color: #eee; | ||||
|     border: 1px solid #ccc; | ||||
| } | ||||
|   | ||||
| div.seealso { | ||||
|     background-color: #ffc; | ||||
|     border: 1px solid #ff6; | ||||
| } | ||||
|   | ||||
| div.topic { | ||||
|     background-color: #eee; | ||||
| } | ||||
|   | ||||
| div.warning { | ||||
|     background-color: #ffe4e4; | ||||
|     border: 1px solid #f66; | ||||
| } | ||||
|   | ||||
| p.admonition-title { | ||||
|     display: inline; | ||||
| } | ||||
|   | ||||
| p.admonition-title:after { | ||||
|     content: ":"; | ||||
| } | ||||
|   | ||||
| pre { | ||||
|     padding: 10px; | ||||
|     background-color: White; | ||||
|     color: #222; | ||||
|     line-height: 1.2em; | ||||
|     border: 1px solid #C6C9CB; | ||||
|     font-size: 1.1em; | ||||
|     margin: 1.5em 0 1.5em 0; | ||||
|     -webkit-box-shadow: 1px 1px 1px #d8d8d8; | ||||
|     -moz-box-shadow: 1px 1px 1px #d8d8d8; | ||||
| } | ||||
|   | ||||
| tt { | ||||
|     background-color: #ecf0f3; | ||||
|     color: #222; | ||||
|     /* padding: 1px 2px; */ | ||||
|     font-size: 1.1em; | ||||
|     font-family: monospace; | ||||
| } | ||||
|  | ||||
| .viewcode-back { | ||||
|     font-family: Arial, sans-serif; | ||||
| } | ||||
|  | ||||
| div.viewcode-block:target { | ||||
|     background-color: #f4debf; | ||||
|     border-top: 1px solid #ac9; | ||||
|     border-bottom: 1px solid #ac9; | ||||
| } | ||||
							
								
								
									
										
											BIN
										
									
								
								doc/source/static/openstack_logo.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								doc/source/static/openstack_logo.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 3.6 KiB | 
							
								
								
									
										94
									
								
								doc/source/static/tweaks.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										94
									
								
								doc/source/static/tweaks.css
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,94 @@ | ||||
| body { | ||||
|   background: #fff url(../_static/header_bg.jpg) top left no-repeat; | ||||
| } | ||||
|  | ||||
| #header { | ||||
|   width: 950px; | ||||
|   margin: 0 auto; | ||||
|   height: 102px; | ||||
| } | ||||
|  | ||||
| #header h1#logo { | ||||
|   background: url(../_static/openstack_logo.png) top left no-repeat; | ||||
|   display: block; | ||||
|   float: left; | ||||
|   text-indent: -9999px; | ||||
|   width: 175px; | ||||
|   height: 55px; | ||||
| } | ||||
|  | ||||
| #navigation { | ||||
|   background: url(../_static/header-line.gif) repeat-x 0 bottom; | ||||
|   display: block; | ||||
|   float: left; | ||||
|   margin: 27px 0 0 25px; | ||||
|   padding: 0; | ||||
| } | ||||
|  | ||||
| #navigation li{ | ||||
|   float: left; | ||||
|   display: block; | ||||
|   margin-right: 25px; | ||||
| } | ||||
|  | ||||
| #navigation li a { | ||||
|   display: block; | ||||
|   font-weight: normal; | ||||
|   text-decoration: none; | ||||
|   background-position: 50% 0; | ||||
|   padding: 20px 0 5px; | ||||
|   color: #353535; | ||||
|   font-size: 14px; | ||||
| } | ||||
|  | ||||
| #navigation li a.current, #navigation li a.section { | ||||
|   border-bottom: 3px solid #cf2f19; | ||||
|   color: #cf2f19; | ||||
| } | ||||
|  | ||||
| div.related { | ||||
|   background-color: #cde2f8; | ||||
|   border: 1px solid #b0d3f8; | ||||
| } | ||||
|  | ||||
| div.related a { | ||||
|   color: #4078ba; | ||||
|   text-shadow: none; | ||||
| } | ||||
|  | ||||
| div.sphinxsidebarwrapper { | ||||
|   padding-top: 0; | ||||
| } | ||||
|  | ||||
| pre { | ||||
|   color: #555; | ||||
| } | ||||
|  | ||||
| div.documentwrapper h1, div.documentwrapper h2, div.documentwrapper h3, div.documentwrapper h4, div.documentwrapper h5, div.documentwrapper h6 { | ||||
|   font-family: 'PT Sans', sans-serif !important; | ||||
|   color: #264D69; | ||||
|   border-bottom: 1px dotted #C5E2EA; | ||||
|   padding: 0; | ||||
|   background: none; | ||||
|   padding-bottom: 5px; | ||||
| } | ||||
|  | ||||
| div.documentwrapper h3 { | ||||
|   color: #CF2F19; | ||||
| } | ||||
|  | ||||
| a.headerlink { | ||||
|   color: #fff !important; | ||||
|   margin-left: 5px; | ||||
|   background: #CF2F19 !important; | ||||
| } | ||||
|  | ||||
| div.body { | ||||
|   margin-top: -25px; | ||||
|   margin-left: 230px; | ||||
| } | ||||
|  | ||||
| div.document { | ||||
|   width: 960px; | ||||
|   margin: 0 auto; | ||||
| } | ||||
							
								
								
									
										2
									
								
								other-requirements.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								other-requirements.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,2 @@ | ||||
| python-virtualenv [test] | ||||
| python-tox [test] | ||||
							
								
								
									
										2
									
								
								requirements.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								requirements.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,2 @@ | ||||
| d2to1>=0.2.10,<0.3 | ||||
| pbr | ||||
							
								
								
									
										32
									
								
								setup.cfg
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								setup.cfg
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | ||||
| [metadata] | ||||
| name = bindep | ||||
| author = OpenStack | ||||
| author-email = openstack-dev@lists.openstack.org | ||||
| summary = Binary dependency utility | ||||
| description-file = | ||||
|     README.rst | ||||
| home-page = http://pypi.python.org/pypi/bindep | ||||
| classifier =  | ||||
|     Development Status :: 4 - Beta | ||||
|         Environment :: Console | ||||
|         Environment :: OpenStack | ||||
|         Intended Audience :: Developers | ||||
|         Intended Audience :: Information Technology | ||||
|         License :: OSI Approved :: Apache Software License | ||||
|         Operating System :: OS Independent | ||||
|         Programming Language :: Python | ||||
|  | ||||
| [files] | ||||
| packages = | ||||
|     bindep | ||||
|  | ||||
| [global] | ||||
| setup-hooks = | ||||
|     pbr.hooks.setup_hook | ||||
|  | ||||
| [pbr] | ||||
| warnerrors = True | ||||
|  | ||||
| [entry_points] | ||||
| console_scripts = | ||||
|     bindep = bindep.main:main | ||||
							
								
								
									
										22
									
								
								setup.py
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										22
									
								
								setup.py
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,22 @@ | ||||
| #!/usr/bin/env python | ||||
| # Copyright (c) 2013 Hewlett-Packard Development Company, L.P. | ||||
| # | ||||
| # Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| # you may not use this file except in compliance with the License. | ||||
| # You may obtain a copy of the License at | ||||
| # | ||||
| #    http://www.apache.org/licenses/LICENSE-2.0 | ||||
| # | ||||
| # Unless required by applicable law or agreed to in writing, software | ||||
| # distributed under the License is distributed on an "AS IS" BASIS, | ||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or | ||||
| # implied. | ||||
| # See the License for the specific language governing permissions and | ||||
| # limitations under the License. | ||||
|  | ||||
| import setuptools | ||||
|  | ||||
| setuptools.setup( | ||||
|     setup_requires=['d2to1>=0.2.10,<0.3', 'pbr'], | ||||
|     d2to1=True, | ||||
| ) | ||||
							
								
								
									
										8
									
								
								test-requirements.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								test-requirements.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | ||||
| coverage>=3.6 | ||||
| discover | ||||
| fixtures>=0.3.12 | ||||
| flake8 | ||||
| python-subunit | ||||
| sphinx>=1.1.2 | ||||
| testrepository>=0.0.13 | ||||
| testtools>=0.9.27 | ||||
							
								
								
									
										34
									
								
								tox.ini
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										34
									
								
								tox.ini
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,34 @@ | ||||
| [tox] | ||||
| envlist = py26,py27,pep8 | ||||
|  | ||||
| [testenv] | ||||
| setenv = VIRTUAL_ENV={envdir} | ||||
|          LANG=en_US.UTF-8 | ||||
|          LANGUAGE=en_US:en | ||||
|          LC_ALL=C | ||||
| deps = -r{toxinidir}/requirements.txt | ||||
|        -r{toxinidir}/test-requirements.txt | ||||
| commands = | ||||
|   python setup.py testr --slowest --testr-args='{posargs}' | ||||
|  | ||||
| [tox:jenkins] | ||||
| sitepackages = True | ||||
| downloadcache = ~/cache/pip | ||||
|  | ||||
| [testenv:pep8] | ||||
| deps = -r{toxinidir}/requirements.txt | ||||
|        -r{toxinidir}/test-requirements.txt | ||||
|        hacking | ||||
| commands = flake8 | ||||
|  | ||||
| [testenv:cover] | ||||
| setenv = VIRTUAL_ENV={envdir} | ||||
| commands = | ||||
|   python setup.py testr --coverage | ||||
|  | ||||
| [testenv:venv] | ||||
| commands = {posargs} | ||||
|  | ||||
| [flake8] | ||||
| exclude = .venv,.tox,dist,doc,*.egg,build | ||||
| show-source = true | ||||
		Reference in New Issue
	
	Block a user
	 Robert Collins
					Robert Collins