--- deliantra/server/include/cfperl.h 2007/07/01 05:00:18 1.81 +++ deliantra/server/include/cfperl.h 2007/08/06 10:54:12 1.86 @@ -91,6 +91,7 @@ void cfperl_cleanup (int make_core); void cfperl_make_book (object *book, int level); void cfperl_send_msg (client *ns, int color, const char *type, const char *msg); +int cfperl_can_merge (object *ob1, object *ob2); ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// @@ -155,7 +156,7 @@ ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// INTERFACE_CLASS (attachable) -struct attachable +struct attachable : refcnt_base { static MGVTBL vtbl; @@ -166,14 +167,9 @@ F_DESTROYED = 0x01, F_DEBUG_TRACE = 0x02, }; - - // object is delete'd after the refcount reaches 0 int ACC (RW, flags); - mutable int ACC (RW, refcnt); - - MTH void refcnt_inc () const { ++refcnt; } - MTH void refcnt_dec () const { --refcnt; } + // object is delete'd after the refcount reaches 0 MTH int refcnt_cnt () const; // check wether the object has died and destroy MTH void refcnt_chk () { if (expect_false (refcnt <= 0)) do_check (); } @@ -202,16 +198,17 @@ void optimise (); // possibly save some memory by destroying unneeded data attachable () - : flags (0), refcnt (0), self (0), cb (0), attach (0) + : flags (0), self (0), cb (0), attach (0) { } attachable (const attachable &src) - : flags (0), refcnt (0), self (0), cb (0), attach (src.attach) + : flags (0), self (0), cb (0), attach (src.attach) { } - virtual ~attachable (); + // set a custom key to the given value, or delete it if value = 0 + void set_key (const char *key, const char *value = 0); attachable &operator =(const attachable &src); @@ -232,6 +229,9 @@ // the method that does the real destroy work virtual void do_destroy (); + + // destructor is protected, should not be called by anybody + virtual ~attachable (); }; // the global object is a pseudo object that cares for the global events @@ -413,6 +413,7 @@ void get (uint32 &i) { i = get_sint64 (); } void get (sint64 &i) { i = get_sint64 (); } + void parse_warn (const char *msg); bool parse_error (const char *type = 0, const char *name = 0, bool skip = true); };