Microsoft Information Protection (MIP) SDK for C++: Reference 1.16
Doxygen-generated documentation for MIP SDK written in C++
Loading...
Searching...
No Matches
android.h
Go to the documentation of this file.
1/*
2 *
3 * Copyright (c) Microsoft Corporation.
4 * All rights reserved.
5 *
6 * This code is licensed under the MIT License.
7 *
8 * Permission is hereby granted, free of charge, to any person obtaining a copy
9 * of this software and associated documentation files(the "Software"), to deal
10 * in the Software without restriction, including without limitation the rights
11 * to use, copy, modify, merge, publish, distribute, sublicense, and / or sell
12 * copies of the Software, and to permit persons to whom the Software is
13 * furnished to do so, subject to the following conditions :
14 *
15 * The above copyright notice and this permission notice shall be included in
16 * all copies or substantial portions of the Software.
17 *
18 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
19 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.IN NO EVENT SHALL THE
21 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
22 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
23 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
24 * THE SOFTWARE.
25 *
26 */
27/**
28 * @brief This files contains android specifics global
29 * functions used to set the android runtime environment.
30 *
31 * @file android.h
32 */
33
34#ifndef API_MIP_ANDROID_H_
35#define API_MIP_ANDROID_H_
36
37#ifdef __ANDROID__
38#include <jni.h>
39#include <string>
40
41#include "mip/mip_export.h"
42#include "mip/mip_namespace.h"
43
44MIP_NAMESPACE_BEGIN
45/**
46 * @brief Sets a global JavaVM pointer to be used for all calls to Android platform API via JNI.
47 * This MUST be done before calling any other public API (on Android only) and must be called from a java thread.
48 *
49 * @param javaVm a pointer the JavaVM object.
50 * @param contextClass the application conext class.
51 * @param contextObject the application object.
52 * @return 0 if successful, returns < 0 error codes.
53 */
54MIP_API int SetJVM(JavaVM* javaVm, jclass contextClass, jobject contextObject);
55/**
56 * @brief Gets the global JavaVM pointer previously set.
57 * @return javaVm a pointer the JavaVM object.
58 */
59MIP_API JavaVM* GetJVM();
60/**
61 * @brief Gets the global application class previously set.
62 * @return the context class previously set.
63 */
64MIP_API jclass GetContextClass();
65/**
66 * @brief Gets the global application object previously set.
67 * @return the context object previously set.
68 */
69MIP_API jobject GetContextObject();
70
71
72MIP_NAMESPACE_END
73
74#endif // __ANDROID__
75#endif // API_MIP_ANDROID_H_
A file export/import macros.
MIP namespace macros.