This repository has been archived on 2020-05-25. You can view files and clone it, but cannot push or open issues or pull requests.
tdlib-fork/example/java
levlam 4ebb813907 Set database directory in examples.
GitOrigin-RevId: bbbd31f3a7f044cf12db36bbce21363ee6019cde
2018-02-26 12:41:12 +03:00
..
org/drinkless/tdlib Set database directory in examples. 2018-02-26 12:41:12 +03:00
.gitignore Add Java example. 2018-01-28 13:58:33 +03:00
CMakeLists.txt Return whether Log::set_file_path succeded or not. 2018-01-28 19:38:59 +03:00
README.md Fix some includes and spelling. 2018-01-28 21:13:25 +03:00
td_jni.cpp Fix formatting. 2018-02-02 01:44:51 +03: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/:

cd <path to TDLib sources>
mkdir jnibuild
cd jnibuild
cmake -DCMAKE_BUILD_TYPE=Release -DTD_ENABLE_JNI=ON -DCMAKE_INSTALL_PREFIX:PATH=../example/java/td ..
cmake --build . --target install

If you want to compile TDLib for 64-bit Java on Windows, you will also need to add -G "Visual Studio 14 2015 Win64" option to CMake.

Then you can build this example:

cd <path to TDLib sources>/example/java
mkdir build
cd build
cmake -DCMAKE_BUILD_TYPE=Release -DTd_DIR=<full path to TDLib sources>/example/java/td/lib/cmake/Td -DCMAKE_INSTALL_PREFIX:PATH=.. ..
cmake --build . --target install

Compiled TDLib shared library and Java example after that will be placed in bin/ and Javadoc documentation in docs/.

Now you can run Java example:

cd <path to TDLib sources>/example/java/bin
java -Djava.library.path=. org/drinkless/tdlib/example/Example

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/".

If you get java.lang.UnsatisfiedLinkError with "Can't find dependent libraries", you may also need to copy some dependent shared libraries to bin/.