Files
Pyarmor-Static-Unpack-1shot/pyc_object.h

144 lines
3.4 KiB
C
Raw Normal View History

2009-07-24 08:35:21 +00:00
#ifndef _PYC_OBJECT_H
#define _PYC_OBJECT_H
2009-07-24 21:15:51 +00:00
template <class _Obj>
class PycRef {
public:
PycRef() : m_obj(0) { }
PycRef(_Obj* obj) : m_obj(obj)
{
if (m_obj)
m_obj->addRef();
}
PycRef(const PycRef<_Obj>& obj) : m_obj(obj.m_obj)
{
if (m_obj)
m_obj->addRef();
}
~PycRef<_Obj>()
{
if (m_obj)
m_obj->delRef();
}
2009-07-24 21:15:51 +00:00
PycRef<_Obj>& operator=(_Obj* obj)
{
if (obj)
obj->addRef();
if (m_obj)
m_obj->delRef();
2009-07-24 21:15:51 +00:00
m_obj = obj;
return *this;
}
PycRef<_Obj>& operator=(const PycRef<_Obj>& obj)
{
if (obj.m_obj)
obj.m_obj->addRef();
if (m_obj)
m_obj->delRef();
2009-07-24 21:15:51 +00:00
m_obj = obj.m_obj;
return *this;
}
bool operator==(_Obj* obj) const { return m_obj == obj; }
bool operator==(const PycRef<_Obj>& obj) const { return m_obj == obj.m_obj; }
bool operator!=(_Obj* obj) const { return m_obj != obj; }
bool operator!=(const PycRef<_Obj>& obj) const { return m_obj != obj.m_obj; }
_Obj& operator*() const { return *m_obj; }
_Obj* operator->() const { return m_obj; }
operator _Obj*() const { return m_obj; }
inline int type() const;
2009-07-24 21:15:51 +00:00
/* This is just for coding convenience -- no type checking is done! */
template <class _Cast>
2010-12-18 22:18:32 -08:00
PycRef<_Cast> cast() const { return static_cast<_Cast*>(m_obj); }
2009-07-24 21:15:51 +00:00
bool isIdent(const _Obj* obj) { return m_obj == obj; }
2009-07-24 21:15:51 +00:00
private:
_Obj* m_obj;
};
class PycData;
class PycModule;
2009-07-24 08:35:21 +00:00
/* Please only hold PycObjects inside PycRefs! */
class PycObject {
public:
enum Type {
// From the Python Marshallers
TYPE_NULL = '0',
TYPE_NONE = 'N',
TYPE_FALSE = 'F',
TYPE_TRUE = 'T',
TYPE_STOPITER = 'S',
TYPE_ELLIPSIS = '.',
TYPE_INT = 'i',
TYPE_INT64 = 'I',
TYPE_FLOAT = 'f',
TYPE_BINARY_FLOAT = 'g',
TYPE_COMPLEX = 'x',
TYPE_BINARY_COMPLEX = 'y',
TYPE_LONG = 'l',
TYPE_STRING = 's',
TYPE_INTERNED = 't',
TYPE_STRINGREF = 'R',
TYPE_OBREF = 'r',
2009-07-24 08:35:21 +00:00
TYPE_TUPLE = '(',
TYPE_LIST = '[',
TYPE_DICT = '{',
TYPE_CODE = 'c',
TYPE_CODE2 = 'C', // Used in Python 1.0 - 1.2
TYPE_UNICODE = 'u',
TYPE_UNKNOWN = '?',
TYPE_SET = '<',
TYPE_FROZENSET = '>',
TYPE_ASCII = 'a',
TYPE_ASCII_INTERNED = 'A',
TYPE_SMALL_TUPLE = ')',
TYPE_SHORT_ASCII = 'z',
TYPE_SHORT_ASCII_INTERNED = 'Z',
2009-07-24 08:35:21 +00:00
};
PycObject(int type = TYPE_UNKNOWN) : m_refs(0), m_type(type) { }
virtual ~PycObject() { }
int type() const { return m_type; }
2009-07-24 08:35:21 +00:00
2009-07-24 21:15:51 +00:00
virtual bool isEqual(PycRef<PycObject> obj) const
{ return obj.isIdent(this); }
2009-07-24 21:15:51 +00:00
virtual void load(PycData*, PycModule*) { }
2009-07-24 08:35:21 +00:00
private:
int m_refs;
int m_type;
public:
void addRef() { ++m_refs; }
void delRef() { if (--m_refs == 0) delete this; }
2009-07-24 08:35:21 +00:00
};
template <class _Obj>
int PycRef<_Obj>::type() const
{ return m_obj ? m_obj->type() : PycObject::TYPE_NULL; }
2009-07-24 21:15:51 +00:00
PycRef<PycObject> CreateObject(int type);
PycRef<PycObject> LoadObject(PycData* stream, PycModule* mod);
2009-07-24 08:35:21 +00:00
/* Static Singleton objects */
2009-07-24 21:15:51 +00:00
extern PycRef<PycObject> Pyc_None;
extern PycRef<PycObject> Pyc_Ellipsis;
extern PycRef<PycObject> Pyc_StopIteration;
extern PycRef<PycObject> Pyc_False;
extern PycRef<PycObject> Pyc_True;
2009-07-24 08:35:21 +00:00
#endif