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
|
/*****************************************************************************
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
See NOTICE file for details.
*****************************************************************************/
#ifndef _JPTYPE_MANAGER_H_
#define _JPTYPE_MANAGER_H_
/**
* These functions will manage the cache of found type, be it primitive types, class types or the "magic" types.
*/
class JPTypeManager
{
friend class JPContext;
public:
/**
* Initialize the type manager caches
*/
explicit JPTypeManager(JPJavaFrame& frame);
~JPTypeManager() = default;
/**
* Find a class using a native name.
*
* The pointer returned is NOT owned by the caller
*/
JPClass* findClass(jclass cls);
JPClass* findClassByName(const string& str);
JPClass* findClassForObject(jobject obj);
void populateMethod(void* method, jobject obj);
void populateMembers(JPClass* cls);
int interfaceParameterCount(JPClass* cls);
private:
JPContext* m_Context;
JPObjectRef m_JavaTypeManager;
jmethodID m_FindClass;
jmethodID m_FindClassByName;
jmethodID m_FindClassForObject;
jmethodID m_PopulateMethod;
jmethodID m_PopulateMembers;
jmethodID m_InterfaceParameterCount;
} ;
#endif // _JPCLASS_H_
|