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

172 lines
3.8 KiB
C
Raw Normal View History

2009-07-24 08:35:21 +00:00
#ifndef _PYC_OBJECT_H
#define _PYC_OBJECT_H
#include <typeinfo>
2009-07-24 21:15:51 +00:00
template <class _Obj>
class PycRef {
public:
2019-10-08 08:42:33 -07:00
PycRef() noexcept : m_obj() { }
2019-10-08 08:42:33 -07:00
PycRef(_Obj* obj) noexcept : m_obj(obj)
{
if (m_obj)
m_obj->addRef();
}
2019-10-08 08:42:33 -07:00
PycRef(const PycRef<_Obj>& obj) noexcept : m_obj(obj.m_obj)
{
if (m_obj)
m_obj->addRef();
}
2019-10-08 08:42:33 -07:00
PycRef(PycRef<_Obj>&& obj) noexcept : m_obj(obj.m_obj)
{
obj.m_obj = nullptr;
}
~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;
}
2019-10-08 08:42:33 -07:00
PycRef<_Obj>& operator=(PycRef<_Obj>&& obj) noexcept
{
m_obj = obj.m_obj;
obj.m_obj = nullptr;
return *this;
}
2009-07-24 21:15:51 +00:00
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
template <class _Cast>
PycRef<_Cast> try_cast() const { return dynamic_cast<_Cast*>(m_obj); }
template <class _Cast>
PycRef<_Cast> cast() const
{
_Cast* result = dynamic_cast<_Cast*>(m_obj);
if (!result)
throw std::bad_cast();
return result;
}
2009-07-24 21:15:51 +00:00
bool isIdent(const _Obj* obj) const { 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;
protected:
2009-07-24 08:35:21 +00:00
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
2019-10-08 08:42:33 -07:00
{
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