File: install.rst

package info (click to toggle)
python-jpype 1.5.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 3,984 kB
  • sloc: python: 18,767; cpp: 17,931; java: 8,448; xml: 1,305; makefile: 154; sh: 35
file content (187 lines) | stat: -rw-r--r-- 5,867 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
Installation
============

JPype is available either as a pre-compiled binary for Anaconda, or may be
built from source though various methods.


Binary Install
--------------

JPype can be installed as pre-compiled binary if you are using the `Anaconda
<https://anaconda.org>`_ Python stack. Binaries are available for Linux, OSX,
and windows on conda-forge.

1. Ensure you have installed Anaconda/Miniconda. Instructions can be found
   `here <http://conda.pydata.org/docs/install/quick.html>`__.
2. Install from
   the conda-forge software channel::

    conda install -c conda-forge jpype1


Source Install
--------------

Installing from source requires:

Python
  JPype works CPython 3.5 or later. Both the runtime and the development
  package are required.

Java
  Either the Sun/Oracle JDK/JRE Variant or OpenJDK.

  JPype source distribution includes a copy of the Java JNI header
  and precompiled Java code, thus the Java Development Kit (JDK) is not required.
  JPype has been tested with Java versions from Java 1.8 to Java 13.

C++
  A C++ compiler which matches the ABI used to build CPython.

JDK
  *(Optional)* JPype contains sections of Java code. These sections are
  precompiled in the source distribution, but must be built when installing 
  directly from the git repository.

Once these requirements have been met, one can use pip to build from either the
source distribution or directly from the repository.  Specific requirements from
different achitectures are listed below_.


Build using pip
~~~~~~~~~~~~~~~

JPype may be built and installed with one step using pip.

To install the latest JPype, use: ::

  pip install JPype1

This will install JPype either from source or binary distribution, depending on
your operating system and pip version.

To install from the current github master use: ::

  pip install git+https://github.com/jpype-project/jpype.git

More details on installing from git can be found at `Pip install
<https://pip.pypa.io/en/stable/reference/pip_install/#git>`__.  The git version
does not include a prebuilt jar the JDK is required.


Build and install manually
~~~~~~~~~~~~~~~~~~~~~~~~~~

JPype can be built entirely from source.

**1. Get the JPype source**

The JPype source may be acquired from either 
`github <https://github.com/jpype-project/jpype>`__ or
from `PyPi <http://pypi.python.org/pypi/JPype1>`__. 

**2. Build the source with desired options**

Compile JPype using the included ``setup.py`` script: ::

  python setup.py build

The setup script recognizes several arguments.

--enable-build-jar   Force setup to recreate the jar from scratch. 
--enable-tracing     Build a verison of JPype with full logging to the 
                     console. This can be used to diagnose tricky JNI
                     issues.

After building, JPype can be tested using the test bench. The test
bench requires JDK to build.

**3. Test JPype with (optional):** ::

    python setup.py test

**4. Install JPype with:** ::

    python setup.py install


If it fails...
~~~~~~~~~~~~~~

Most failures happen when setup.py is unable to find the JDK home directory
which shouble be set in the enviroment variable ``JAVA_HOME``.  If this
happens, preform the following steps:

1. Identify the location of your systems JDK installation and explicitly passing
   it to setup.py. ::

     JAVA_HOME=/usr/lib/java/jdk1.8.0/ python setup.py install

2. If that setup.py still fails please create an Issue `on
   github <https://github.com/jpype-project/jpype/issues?state=open>`__ and
   post the relevant logs.


.. _below:

Platform Specific requirements
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

JPype is known to work on Linx, OSX, and Windows.  To make it easier to those
who have not built CPython modules before here are some helpful tips for
different machines.

Debian/Ubuntu
:::::::::::::

Debian/Ubuntu users will have to install ``g++`` and ``python-dev``.
Use:

    sudo apt-get install g++ python-dev python3-dev

Windows
:::::::

CPython modules must be built with the same C++ compiler used to build Python.
The tools listed below work for Python 3.5 to 3.8.  Check with `Python dev guide
<https://devguide.python.org/setup/>`_ for the latest instructions.

1. Install your desired version of Python (3.5 or higher), e.g., `Miniconda
   <https://docs.conda.io/en/latest/miniconda.html#windows-installers>`_ is a good choice for users not yet
   familiar with the language
2. For Python 3 series, Install either 2017 or 2019 Visual Studio.
   `Microsoft Visual Studio 2019 Community Edition
   <https://visualstudio.microsoft.com/downloads/>`_ is known to work.

From the Python developer page: 

   When installing Visual Studio 2019, select the Python development workload and
   the optional Python native development tools component to obtain all of the
   necessary build tools. If you do not already have git installed, you can find
   git for Windows on the Individual components tab of the installer.

When building for windows you must use the Visual Studio developer command
prompt.


Path requirements
-----------------

On certain systems such as Windows 2016 Server, the JDK will not load properly
despite JPype properly locating the JVM library.  The work around for this 
issue is add the JRE bin directory to the system PATH.  Apparently, the 
shared library requires dependencies which are located in the bin directory.
If a JPype fails to load despite having the correct JAVA_HOME and 
system architecture, it may be this issue.


Known Bugs/Limitations
----------------------

-  Java classes outside of a package (in the ``<default>``) cannot be
   imported.
-  Because of lack of JVM support, you cannot shutdown the JVM and then
   restart it.  Nor can you start more than one copy of the JVM.
-  Mixing 64 bit Python with 32 bit Java and vice versa crashes on import 
   of the jpype module.