2018-01-28 11:58:33 +01:00
# TDLib Java example
To run this example, you will need installed JDK >= 1.6.
For Javadoc documentation generation PHP is needed.
TDLib should be prebuilt for using with Java and installed to local subdirectory `td/` :
```
2018-01-28 19:13:25 +01:00
cd < path to TDLib sources >
2018-01-28 11:58:33 +01:00
mkdir jnibuild
cd jnibuild
cmake -DCMAKE_BUILD_TYPE=Release -DTD_ENABLE_JNI=ON -DCMAKE_INSTALL_PREFIX:PATH=../example/java/td ..
cmake --build . --target install
```
2018-03-13 20:45:00 +01:00
If you want to compile TDLib for 64-bit Java on Windows using MSVC, you will also need to add `-A x64` option to CMake.
2018-01-28 11:58:33 +01:00
Then you can build this example:
```
2018-01-28 19:13:25 +01:00
cd < path to TDLib sources > /example/java
2018-01-28 11:58:33 +01:00
mkdir build
cd build
2018-01-28 19:13:25 +01:00
cmake -DCMAKE_BUILD_TYPE=Release -DTd_DIR=< full path to TDLib sources > /example/java/td/lib/cmake/Td -DCMAKE_INSTALL_PREFIX:PATH=.. ..
2018-01-28 11:58:33 +01:00
cmake --build . --target install
```
2018-03-13 20:45:00 +01:00
Compiled TDLib shared library and Java example after that will be placed in bin/ and Javadoc documentation in `docs/` .
2018-01-28 11:58:33 +01:00
Now you can run Java example:
```
2018-01-28 19:13:25 +01:00
cd < path to TDLib sources > /example/java/bin
2018-01-28 11:58:33 +01:00
java -Djava.library.path=. org/drinkless/tdlib/example/Example
```
2018-01-28 13:43:04 +01:00
If you get "Could NOT find JNI ..." error from CMake, you need to specify to CMake path to the installed JDK, for example, "-DJAVA_HOME=/usr/lib/jvm/java-8-oracle/".
2018-03-13 20:45:00 +01:00
If you get java.lang.UnsatisfiedLinkError with "Can't find dependent libraries", you may also need to copy some dependent shared libraries to `bin/` .