Metadata-Version: 2.1
Name: amps-python-client
Version: 5.3.4.3
Summary: AMPS Python Client
Home-page: https://crankuptheamps.com
Maintainer: 60East Technologies, Incorporated
Maintainer-email: support@crankuptheamps.com
License: Commercial/Proprietary :: see LICENSE
Platform: Linux
Platform: Windows
Classifier: License :: Other/Proprietary License
Description-Content-Type: text/markdown
License-File: LICENSE

AMPS Python Client
==================

Introduction
------------

The AMPS Python Client is a Python extension module that makes it easy to connect to AMPS. This client builds upon the AMPS C++ Client and Python/C api to bring high performance AMPS connectivity to Python code.


Prerequisites
-------------

To use the AMPS Python Client, you must have the following software installed and configured on your system:

* Python 2.7 or Python 3.5 and above.
* Python distutils. Most python installations build and include this package by default, but you may run into issues building this extension module if distutils is not functioning properly on your system.
  Python distutils may be packaged in a standalone package named 'python-distutils', or included in 'python-devel.x86_64'. You can also run the setup script available [here](http://peak.telecommunity.com/dist/ez_setup.py).
* C++ compiler. gcc 4.4 or greater on Linux, or a verion of Visual Studio with Mainstream Support from Microsoft (please
  refer to Microsoft product lifecycle policies) on Windows. Note that this must be the same compiler used to build your
  python distribution, else python distutils may be unable to invoke your compiler.


Fedora prerequisites:
1. dnf install redhat-rpm-config
2. dnf install python-devel  # for use with Python2
3. dnf install python3-devel # for use with Python3
4. dnf install gcc-c++

Building From a Git Clone
-------------------------

If you obtained this client by a git clone of the 60East amps-client-python repository, you also need to fetch the correct version of the 
AMPS C++ client submodule. To do this, issue a git submodule command to initialize and update the src/cpp submodule. One easy
way to do this is by issuing the command:

    git submodule update --init

which will initialize and update the submodule in one step. Note that working with submodules in git requires extra care. Visit
[this chapter](http://git-scm.com/book/en/Git-Tools-Submodules) to learn more about git submodules.

Build
-----

This client is distributed as source code and must be compiled before it is used. The build process emits a shared library
(or DLL on Windows) that can be imported into your python application.

### To build on Linux:

1. Run `python setup.py build` from the AMPS Python Client directory to build the client.

   This script uses Python distutils to build the client library. Python distutils provides many additional options for installing the built library into your Python distribution, or
   otherwise controlling the output of the build process. Run `python setup.py --help` to view command help.

2. Check under the `build` directory for `AMPS.so` -- this is the Python extension module. Ensure this library's directory is in your PYTHONPATH.

3. To test, run `python -c "import AMPS"`.  If any errors occur importing the AMPS module, validate that the module built properly, and that the containing directory is in your PYTHONPATH.

### To build on Windows:

1. Use a Visual Studio Command Prompt to create a command prompt where the necessary Visual Studio environment variables are set for command line builds.

2. Add the Python directory (the location of the python.exe interpreter) to your path.
   *Note:* The platform of your python installation must match the target platform for this python module. If you want to
   build a 64-bit module, you must set your PATH to a 64-bit Python installation; for a 32-bit module, you must set it to
   a 32-bit installation. If you'd like to build both, you must do so separately, once with each Python installation.
3. Run `python setup.py build` fom the AMPS Python Client directory to build the client module. Use the `-p win32` option to build a 32-bit client module.
4. Check under the `build` directory for `AMPS.pyd` -- this is the Python extension module. Ensure this library's directory is in your PYTHONPATH.
5. To test, run `python -c "import AMPS"`. If any errors occur importing the AMPS module, validate that the module built properly, and that the containing directory is in your PYTHONPATH.

Installing the Python Binary Wheel
----------------------------------

60East also provides Linux-x86-64 and Windows 64-bit binary wheels built with Python 2.7 and for Python 3.x.
These wheel files are provided on the 60East website.

If your system is not Linux-x86-64, or you are not using Python 2.6, you can generate your own egg by running 'python setup.py bdist_wheel'.

## Installing:

1. Download the wheel file from the 60East client release page.

2. run 'python -m pip install *.whl'.

Troubleshooting Build Problems
------------------------------

Symptom: Python.h not found

Resolution: Update or install python distutils. See the entry on python distutils in the prequisites section for information on installing this package.


For More Information
--------------------

The developer's guide and generated reference documentation for this client are available under the doc/ directory.



