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 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108
|
/*****************************************************************************
Copyright 2004 Steve M�nard
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.
*****************************************************************************/
#ifndef _JPCLASS_H_
#define _JPCLASS_H_
/**
* Class to wrap Java Class and provide low-level behavior
*/
class JPClass : public JPClassBase
{
public :
JPClass(const JPTypeName& tname, jclass c);
virtual~ JPClass();
public :
/**
* Called to fully load base classes and members
*/
void postLoad();
HostRef* getStaticAttribute(const string& attr_name);
void setStaticAttribute(const string& attr_name, HostRef* val);
JPObject* newInstance(vector<HostRef*>& args);
JPField* getInstanceField(const string& name);
JPField* getStaticField(const string& name);
JPMethod* getMethod(const string& name);
vector<JPMethod*> getMethods() const
{
vector<JPMethod*> res;
res.reserve(m_Methods.size());
for (map<string, JPMethod*>::const_iterator cur = m_Methods.begin(); cur != m_Methods.end(); cur++)
{
res.push_back(cur->second);
}
return res;
}
jclass getClass()
{
return m_Class;
}
map<string, JPField*>& getStaticFields()
{
return m_StaticFields;
}
map<string, JPField*>& getInstanceFields()
{
return m_InstanceFields;
}
bool isFinal();
bool isAbstract();
bool isInterface()
{
return m_IsInterface;
}
JPClass* getSuperClass();
const vector<JPClass*>& getInterfaces() const;
bool isSubclass(JPClass*);
string describe();
public : // JPType implementation
virtual HostRef* asHostObject(jvalue val);
virtual EMatchType canConvertToJava(HostRef* obj);
virtual jvalue convertToJava(HostRef* obj);
private :
void loadSuperClass();
void loadSuperInterfaces();
void loadFields();
void loadMethods();
void loadConstructors();
jobject buildObjectWrapper(HostRef* obj);
private :
bool m_IsInterface;
JPClass* m_SuperClass;
vector<JPClass*> m_SuperInterfaces;
map<string, JPField*> m_StaticFields;
map<string, JPField*> m_InstanceFields;
map<string, JPMethod*> m_Methods;
JPMethod* m_Constructors;
};
#endif // _JPCLASS_H_
|