Integrate the SDK

Update time: 2023/03/23 08:41:42

From NIM SKD v8.4.0, the directory of the SDK is adjusted. Cmake manages the C++ wrapper layer. Depending on the situation, appropriate modifications may be required when accessing the C++ encapsulation layer.

cpp├─bin
├─include
├─lib
└─wrapper
  • bin/lib stores the dynamic library files of the NIM SDK in the C language. Package the required modules when you release your app. Files with the lib extension are the symbolic link file of the dynamic library in Windows.
    • (lib)nim(.dll|.so|.dylib): instant messaging
    • (lib)nim_chatroom(.dll|.so|.dylib): chat room
    • (lib)nim_qchat(.dll|.so|.dylib): Qchat
    • (lib)h_available(.dll|.so|.dylib): Highly-availability module, dependent by the previous three modules
    • (lib)nim_tools_http(.dll|.so|.dylib): HTTP utility library
    • nim_audio.dll: audio decoding library that only supports Windows
    • nrtc.dll: audio and video call library that only supports Windows
    • node-nim.node: NIM SDK Node encapsulation layer, used for access in the Electron and Node.js environments.
    • Other (system) dependencies, such as msvcp120.dll, and msvcr120.dll.
  • The include directory stores the header files of the NIM C SDK.
  • wrapper directory stores the source code of the C++ wrapper layer (including header files).

C implementation

If you want to integrate the NIM SDK with a pure C interface, you can complete the following steps.

  1. Add the include folder in the search path of header files.
  2. Add the lib directory as the search path for dependency libraries.
  3. Add the static library file under the lib directory as an additional dependency library of your existing project.

C implementation

Integrate the SDK using CMake

If your original project is managed based on CMake, you can complete the following steps.

  1. Add the wrapper directory as a subdirectory using the ADD_SUBDIRECTORY command.

  2. Use the INCLUDE_DIRECTORIES method to add the include and wrapper folders as search paths of header files.

  3. Use TARGET_LINK_LIBRARIES to add link libraries as needed. Libraries:

    • nim_cpp_wrapper: NIM C++ library wrapper.
    • nim_chatroom_cpp_wrapper: Chatroom C++ library wrapper.
    • nim_wrapper_util: The utility library of NIM and Chatroom C++ library wrapper.
    • nim_tools_cpp_wrapper: the C++ library wrapper of NIM HTTP component.
    • nim_qchat_cpp_wrapper: the C++ library wrapper of NIM QChat.

Conventional methods (Visual Studio, Qt, and Xcode)

To access the C++ wrapper layer using the conventional method, you must generate the binary file of the C++ wrapper layer. Based on the runtime library and platform tool set of your project, generate the binary file of the wrapper layer. The following configurations are provided for your to generate the C++ wrapper layer in different situations. You only need to select one of the options that suit your project configuration.

Use CMake GUI

  1. Use the CMake GUI tool to open the C++ wrapper layer folder and configure the generated cache directory.

  2. After clicking the Configure button, you will be prompted to configure the project. You can see the figure below to configure your project.

  3. Clicking the Finish button to initialize the project.

  4. Configure the option to generate the project file on the interface, and then click the Generate button to generate the project file.

    See the following configuration:

    You can choose whether to generate a dynamic library or a static library by configuring BUILD_SHARED_LIBS. By default, a static library is generated. The CMAKE_INSTALL_PREFIX option determines the export directory of the C++ header files and library files, which can be specified as the root directory of the SDK.

  5. Click the Open Project button to open the project.

  6. Right-click INSTALL in the opened project.

    After the generation is complete, the header files and library files of the C++ wrapper layer will be automatically copied to the include and lib directories under the root directory of the SDK.

    Install configuration: "Debug"
    Installing: E:/nim-sdk/lib/nim_wrapper_util_d.lib
    Installing: E:/nim-sdk/lib/nim_cpp_wrapper_d.lib
    Installing: E:/nim-sdk/lib/nim_chatroom_cpp_wrapper_d.lib
    Installing: E:/nim-sdk/lib/nim_tools_cpp_wrapper_d.lib
    Installing: E:/nim-sdk/include/nim_chatroom_cpp_wrapper
    Installing: E:/nim-sdk/include/nim_chatroom_cpp_wrapper/api
    Installing: E:/nim-sdk/include/nim_chatroom_cpp_wrapper/api/nim_chatroom_cpp.h
    .......
    Installing: E:/nim-sdk/include/nim_cpp_wrapper
    Installing: E:/nim-sdk/include/nim_cpp_wrapper/api
    .......
    
  7. In the project, add the include directory as the search path of header files, add the lib directory to the search path of library files of your project, and link the specified library file.

Take Visual Studio as an example:

  • Search path of header files, right click Properties -> C/C++ -> General, "AdditionalInclude Directories".
  • Search path of library files, right click Properties -> Linker -> General, "AdditionalLibrary Directories"
  • Link the library file. right click Properties -> Linker -> Input -> Additional LibraryDirectories.

If you upgrade from the SDK earlier than v8.4.0 to SDK v8.4.0, you must change theinclude path of the original header file from the original nim_sdk to the includedirectory.

Use the command line tool

In most cases, you must automate the compilation step in the CI integration phase, you can use the command line to generate the C++ wrapper layer code:

bash# Create a new build folder in the SDK directory to cache the temporary files generated when compiling the C++ wrapper layer
md build && cd build
# Generate a project file, you can specify different parameters to determine the properties of the generated project file
# Add -DCMAKE_CXX_FLAGS_DEBUG=/MTd -DCMAKE_CXX_FLAGS_RELEASE=/MT to generate a MTd/MT project
# Add -DBUILD_SHARED_LIBS=ON to generate a dynamic library project
# Add -G"Visual Studio 15 2017 Win64" to generate a VS2017 64-bit project
# Add -G"Visual Studio 14 2015" to generate a VS2015 project
# Add -T"v141_xp" to generate projects that support Windows XP
cmake ../wrapper
# Compile project files and export header files and library files
# The --build parameter describes the project to be compiled in the current directory
# The --config parameter specifies whether you want to compile the Release or Debug version of the library file
# The --target indicates the specified target you want to compile, use install here. Pay attention to the casing of `install` under macOS
cmake --build . --config Debug --target install

Teamwork and CI integration

DO NOT directly reference the project files generated by CMake into the project, because CMake uses the absolute path to write into the project configuration file (.vcxproj). The project files you generate on your own device cannot be used on other computers.

Use a custom script to always execute CMake before compilation to generate and compile the project to obtain the required binary during Continuous integration (CI) or when collaborating with other teammates.

You can also upload the generated .dll and .lib to your code version control system. Although this is convenient, uploading binary files to the version control system every time the SDK is updated will increase the size of the repository.

If your project is already managed based on CMake, you only need to use the wrapper as a dependency of your project, and no additional configuration is required.

Was this page helpful?
Yes
No
  • C implementation
  • C implementation
  • Integrate the SDK using CMake
  • Conventional methods (Visual Studio, Qt, and Xcode)
  • Teamwork and CI integration