Metadata-Version: 2.1
Name: gravitybee
Version: 0.1.11
Summary: Generate standalone python applications.
Home-page: https://github.com/YakDriver/gravitybee
Author: YakDriver
Author-email: projects@plus3it.com
License: Apache Software License 2.0
Platform: Linux
Platform: Windows
Platform: Darwin
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: Apache Software License
Classifier: Operating System :: MacOS :: MacOS X
Classifier: Operating System :: POSIX :: Linux
Classifier: Operating System :: Microsoft :: Windows
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.5
Classifier: Programming Language :: Python :: 3.6
Classifier: Programming Language :: Python :: Implementation :: CPython
Classifier: Programming Language :: Python :: Implementation :: PyPy
Classifier: Topic :: Utilities
Requires-Dist: distlib
Requires-Dist: setuptools
Requires-Dist: click
Requires-Dist: pyinstaller
Requires-Dist: pyppyn

==========
GravityBee
==========

.. image:: https://img.shields.io/github/license/YakDriver/gravitybee.svg
    :target: ./LICENSE
    :alt: License
.. image:: https://travis-ci.org/YakDriver/gravitybee.svg?branch=master
    :target: http://travis-ci.org/YakDriver/gravitybee
    :alt: Build Status
.. image:: https://img.shields.io/pypi/pyversions/gravitybee.svg
    :target: https://pypi.python.org/pypi/gravitybee
    :alt: Python Version Compatibility
.. image:: https://img.shields.io/pypi/v/gravitybee.svg
    :target: https://pypi.python.org/pypi/gravitybee
    :alt: Version

GravityBee helps you generate standalone applications for Windows,
Mac, and Linux from your Python applications.

GravityBee is targeted at Python
programs that are already packaged in the standard setuptools
way.

These are some benefits of a GravityBee standalone application:

* You end up with one file that contains everything.
* Your users do not need Python or any packages installed.
* You build separate natively executable applications for each of
  your target platforms.

GravityBee depends on `Pyppyn <https://github.com/YakDriver/pyppyn>`_ and
`PyInstaller <http://www.pyinstaller.org>`_ and is subject to their limitations.

To Build A Standalone Application
=================================

Step 1 - Install
----------------

You must install the application you wish to build (e.g.,
``yoursuperapp``), as well as GravityBee.

.. code-block:: bash

    $ pip install yoursuperapp gravitybee

The process will also work fine if you're installing from a local
version of your app.

.. code-block:: bash

    $ cd yoursuperapp
    $ ls setup*
    setup.cfg            setup.py
    $ pip install --editable .
    $ pip install gravitybee

Step 2 - Provide (or gather) information
----------------------------------------

GravityBee will assume all necessary information when run. However,
you may wish to override the assumed
values. You can provide values either through environment variables
or command line flags. If both are
provided, command line flags take precedence.

Options:

================  ==================    ==========================================
ENV VAR           CL Options            Desciption
================  ==================    ==========================================
GB_APP_NAME       --app-name, -a        The name that will appear as part of the
                                        final standalone application name.
                                        *Default:* ``name`` *from setup.py and/or
                                        setup.cfg.*
GB_PKG_NAME       --pkg-name, -n        The package name for the application you are
                                        building.
                                        *Default: First value in* ``packages`` *from
                                        setup.py and/or setup.cfg,
                                        or if not found, the value from --app-name.*
GB_SCRIPT         --script, -s          The path to the application file installed by
                                        ``pip`` when you installed
                                        your application. Depending on your
                                        configuration, this may be determined by
                                        ``options.entry_points.console_scripts`` from
                                        ``setup.py`` and/or ``setup.cfg``.
                                        *Default:* ``$VIRTUAL_ENV/bin/app_name``
GB_SRC_DIR        --src-dir, -d         The relative path of the package containing
                                        your application.
                                        *Default:* ``.``
GB_PKG_DIR        --pkg-dir, -p         The relative or absolute path of the package
                                        containing your application.
                                        This directory must contain a ``setup.py`` file.
                                        *Default:* ``.``
GB_VERBOSE        --verbose, -v         Verbose mode.
GB_EXTRA_DATA     --extra-data, -e      Relative to package directory, any extra
                                        directories or files that need
                                        to be included, that wouldn't normally be
                                        included as Python code. Can be used multiple
                                        times.
                                        *Default: None*
GB_WORK_DIR       --work-dir, -w        Directory for use by GravityBee to build
                                        application. Cannot be an existing
                                        directory as it will be deleted if the clean
                                        option is used.
                                        *Default:* ``gb_workdir_<uuid>``
GB_CLEAN          --clean, -c           Whether to clean up the work directory after
                                        the build. If used, GravityBee will copy the
                                        built standalone application to the current
                                        directory before deleting.
                                        *Default: Not*
GB_NAME_FORMAT    --name-format, -f     Format to be used in naming the standalone
                                        application. Must include
                                        {an}, {v}, {os}, {m}
                                        for app name, version, os, and machine
                                        type respectively.
                                        *Default:* ``{an}-{v}-standalone-{os}-{m}``
GB_NO_FILE        --no-file             Do not write the output files (see below).
                                        If the ``--sha`` flag is used to
                                        write a
                                        hash to a file, that file will still be
                                        written regardless.
                                        *Default: Will write
                                        files*
GB_SHA            --sha                 Where to put SHA256
                                        hash for generated file.
                                        Valid options are ``file``
                                        (create a separate file with
                                        hash), or ``info`` (only
                                        include the hash in the file
                                        info output). *Default:* ``info``
================  ==================    ==========================================




If you are using environment variables, you could set them up like this.

.. code-block:: bash

    $ export GB_APP_NAME=coolapp
    $ export GB_PKG_NAME=coolapp
    $ export GB_SCRIPT=/usr/var/python/etc/coolapp


Step 3 - Generate
-----------------

Creating the standalone application is easy now.

.. code-block:: bash

    $ gravitybee

If you are not using environment variables, you can combine steps 2 and 3.

.. code-block:: bash

    $ gravitybee --app-name coolapp --script /usr/var/python/etc/coolapp --pkg-dir coolapp

Output Files
------------

If the ``--no-file`` flag is not used, GravityBee will create output
files. These include:

* **gravitybee-files.json**: A JSON file that contains information
  about the standalone application generated by GravityBee including
  ``filename``, ``path``, ``mime-type``, and ``label`` as a list of
  dicts.
* **gravitybee-info.json**: A JSON file that contains information
  extracted
  about the application including ``app_name``, ``app_version``,
  ``console_script``,
  ``script_path``, ``pkg_dir``, ``src_dir``, ``name_format``,
  ``clean``, ``work_dir``,
  ``created_file``, ``created_path``, and ``extra_data``.
* **gravitybee-environs.sh**: A shell file that can be sourced on
  POSIX platforms
  to create environment variables with GravityBee information. Each
  is prefixed
  with ``GB_ENV_``.
* **gravitybee-environs.bat**: A batch file that can be used to
  create environment variables with GravityBee information on
  Windows. Each
  environ is prefixed with ``GB_ENV_``.


The Test Example
----------------

Here is the file/package structure of the included
`test application <https://github.com/YakDriver/gravitybee/tree/dev/tests/gbtestapp>`_.

.. code-block:: bash

    gbtestapp
    |-- setup.py
    |-- setup.cfg
    >-- src
    |   >-- gbtestapp
    |       |-- __init__.py
    |       |-- cli.py
    |       >-- gbextradata
    |           |-- __init__.py
    |           |-- data_file.txt

You would build the application as follows. Since the application
package is under the ``src`` directory, you need to let GravityBee
know. Also, since we need to include the ``data_file.txt`` file,
we'll use the ``--extradata`` option to include the containing
directory (``gbextradata``).

.. code-block:: bash

    $ cd gbtestapp
    $ gravitybee --src-dir src --extra-data gbextradata --verbose --clean


From Python Example
-------------------

Using GravityBee from a Python script is also possible. Using the
sample test app, here's some example code.

.. code-block:: python

    import gravitybee

    args = gravitybee.Arguments(
        src_dir="src",
        extra_data=["gbextradata"],
        verbose=True,
        pkg_dir=os.path.join("tests", "gbtestapp"),
        clean=True
    )

    pg = gravitybee.PackageGenerator(args)
    pg.generate()

    # show path (and name) of standalone app
    print("The standalone app: ", pg.created_path)


Attribution
===========

The idea for GravityBee's core functionality comes from `Nicholas Chammas <https://github.com/nchammas>`_
and his project `flintrock <https://github.com/nchammas/flintrock>`_. Huge thanks to Nicholas!


Contribute
==========

GravityBee is hosted on `GitHub <http://github.com/YakDriver/gravitybee>`_ and is an open source project that welcomes contributions of all kinds from the community.

For more information about contributing, see `the contributor guidelines <https://github.com/YakDriver/gravitybee/CONTRIBUTING.rst>`_.



CHANGE LOG
==========

0.1.11 - 2018.05.24
-------------------
* [ENHANCEMENT] Create a SHA256 hash for the generated standalone
  file and include hash with file information and optionally in
  a separate file (using --sha flag).
* [ENHANCEMENT] Change names of environment variables produced
  with output scripts to be prefixed with GB_ENV so that the
  environs do not collide with environs consumed by GravityBee.
* [ENHANCEMENT] Provide a convenience cleanup Bash script to
  remove GravityBee output files (e.g., json and generated
  executables).
* [ENHANCEMENT] Cleanup code with more constants.

0.1.10 - 2018.05.21
-------------------
* [ENHANCEMENT] Provide two additional output files for importing
  GravityBee information into the environment on POSIX and Windows
  platforms.

0.1.9 - 2018.05.14
------------------
* [ENHANCEMENT] Output file with run info in json format for easy
  consumption by other tools.

0.1.8 - 2018.05.11
------------------
* [ENHANCEMENT] In non-verbose mode, allow for supressing stdout and
  stderr from pyinstaller, which can be sizeable.
* [ENHANCEMENT] Change name of ``gravitybee.file`` to
  ``gravitybee-files.json``.

0.1.7 - 2018.05.11
------------------
* [BUG FIX] Fix exit code (was returning True).
* [ENHANCEMENT] Automatically find console script installed by
  setuptools on Windows and Linux and variety of places.

0.1.6 - 2018.05.03
------------------
* [ENHANCEMENT] Follow format prescribed by satsuki for output
  file (potential for multiple files).

0.1.5 - 2018.05.01
------------------
* [ENHANCEMENT] Add mime-type and label to .json formatted file
  information stored in gravitybee.file.

0.1.3 - 2018.05.01
------------------
* [ENHANCEMENT] Create gravitybee.file with name of standalone
  application.

0.1.2 - 2018.04.27
------------------
* [ENHANCEMENT] Provide standalone file and path.
* [BUG FIX] Path bug.

0.1.1 - 2018.04.26
------------------
* [BUG FIX] Many bug fixes.

0.1.0 - 2018.04.20
------------------
* Initial release!


