… | |
… | |
19 | * GNU General Public License for more details. |
19 | * GNU General Public License for more details. |
20 | * |
20 | * |
21 | * You should have received a copy of the GNU General Public License |
21 | * You should have received a copy of the GNU General Public License |
22 | * along with this program; if not, write to the Free Software |
22 | * along with this program; if not, write to the Free Software |
23 | * Foundation, Inc. 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA |
23 | * Foundation, Inc. 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA |
24 | */ |
24 | */ |
25 | |
25 | |
26 | #define PLUGIN_NAME "perl" |
26 | #define PLUGIN_NAME "perl" |
27 | #define PLUGIN_VERSION "cfperl 0.5" |
27 | #define PLUGIN_VERSION "cfperl 0.5" |
28 | |
28 | |
29 | #include <plugin_common.h> |
29 | #include <plugin_common.h> |
… | |
… | |
192 | inline void sv_to (SV *sv, refptr<T> &v) { T *tmp; sv_to (sv, tmp); v = tmp; } |
192 | inline void sv_to (SV *sv, refptr<T> &v) { T *tmp; sv_to (sv, tmp); v = tmp; } |
193 | |
193 | |
194 | template<int N> |
194 | template<int N> |
195 | inline void sv_to (SV *sv, char (&v)[N]) { assign (v, SvPV_nolen (sv)); } |
195 | inline void sv_to (SV *sv, char (&v)[N]) { assign (v, SvPV_nolen (sv)); } |
196 | |
196 | |
|
|
197 | inline void sv_to (SV *sv, rangetype &v) { v = (rangetype) SvIV (sv); } |
|
|
198 | inline void sv_to (SV *sv, bowtype_t &v) { v = (bowtype_t) SvIV (sv); } |
|
|
199 | inline void sv_to (SV *sv, petmode_t &v) { v = (petmode_t) SvIV (sv); } |
|
|
200 | inline void sv_to (SV *sv, usekeytype &v) { v = (usekeytype) SvIV (sv); } |
|
|
201 | inline void sv_to (SV *sv, unapplymode &v) { v = (unapplymode) SvIV (sv); } |
|
|
202 | |
197 | inline void sv_to (SV *sv, UUID &v) |
203 | inline void sv_to (SV *sv, UUID &v) |
198 | { |
204 | { |
199 | unsigned int version; |
205 | unsigned int version; |
200 | |
206 | |
201 | if (2 != sscanf (SvPV_nolen (sv), "<%d.%" SCNx64 ">", &version, &v.seq) || 1 != version) |
207 | if (2 != sscanf (SvPV_nolen (sv), "<%d.%" SCNx64 ">", &version, &v.seq) || 1 != version) |
202 | croak ("unparsable uuid: %s", SvPV_nolen (sv)); |
208 | croak ("unparsable uuid: %s", SvPV_nolen (sv)); |
203 | } |
209 | } |
|
|
210 | |
|
|
211 | inline void sv_to (SV *sv, object::flags_t::reference v) { v = boolSV (sv); } |
204 | |
212 | |
205 | static SV * |
213 | static SV * |
206 | newSVdt_va (va_list &ap, data_type type) |
214 | newSVdt_va (va_list &ap, data_type type) |
207 | { |
215 | { |
208 | SV *sv; |
216 | SV *sv; |
… | |
… | |
361 | |
369 | |
362 | HV *hv = (HV *)SvRV ((SV *)self); |
370 | HV *hv = (HV *)SvRV ((SV *)self); |
363 | |
371 | |
364 | if (SvREFCNT ((SV *)self) == 1 |
372 | if (SvREFCNT ((SV *)self) == 1 |
365 | && SvREFCNT ((SV *)hv) == 1 |
373 | && SvREFCNT ((SV *)hv) == 1 |
366 | && !HvKEYS (hv)) |
374 | && !HvTOTALKEYS (hv)) |
367 | { |
375 | { |
368 | SvREFCNT_dec ((SV *)self); |
376 | SvREFCNT_dec ((SV *)self); |
369 | self = 0; |
377 | self = 0; |
370 | } |
378 | } |
371 | } |
379 | } |
… | |
… | |
1008 | |
1016 | |
1009 | switch (KLASS_OF (event)) |
1017 | switch (KLASS_OF (event)) |
1010 | { |
1018 | { |
1011 | case KLASS_OBJECT: PUSHs (sv_2mortal (newSVdt (DT_OBJECT, op))); break; |
1019 | case KLASS_OBJECT: PUSHs (sv_2mortal (newSVdt (DT_OBJECT, op))); break; |
1012 | case KLASS_PLAYER: PUSHs (sv_2mortal (newSVdt (DT_PLAYER, pl))); break; |
1020 | case KLASS_PLAYER: PUSHs (sv_2mortal (newSVdt (DT_PLAYER, pl))); break; |
1013 | case KLASS_CLIENT: PUSHs (sv_2mortal (newSVdt (DT_CLIENT, pl))); break; |
1021 | case KLASS_CLIENT: PUSHs (sv_2mortal (newSVdt (DT_CLIENT, ns))); break; |
1014 | case KLASS_MAP: PUSHs (sv_2mortal (newSVdt (DT_MAP, map))); break; |
1022 | case KLASS_MAP: PUSHs (sv_2mortal (newSVdt (DT_MAP, map))); break; |
1015 | } |
1023 | } |
1016 | |
1024 | |
1017 | for (;;) |
1025 | for (;;) |
1018 | { |
1026 | { |
… | |
… | |
1410 | const_iv (FLAG_ACTIVATE_ON_RELEASE) |
1418 | const_iv (FLAG_ACTIVATE_ON_RELEASE) |
1411 | const_iv (FLAG_IS_WATER) |
1419 | const_iv (FLAG_IS_WATER) |
1412 | const_iv (FLAG_CONTENT_ON_GEN) |
1420 | const_iv (FLAG_CONTENT_ON_GEN) |
1413 | const_iv (FLAG_IS_A_TEMPLATE) |
1421 | const_iv (FLAG_IS_A_TEMPLATE) |
1414 | const_iv (FLAG_IS_BUILDABLE) |
1422 | const_iv (FLAG_IS_BUILDABLE) |
1415 | const_iv (FLAG_AFK) |
|
|
1416 | |
1423 | |
1417 | const_iv (NDI_BLACK) |
1424 | const_iv (NDI_BLACK) |
1418 | const_iv (NDI_WHITE) |
1425 | const_iv (NDI_WHITE) |
1419 | const_iv (NDI_NAVY) |
1426 | const_iv (NDI_NAVY) |
1420 | const_iv (NDI_RED) |
1427 | const_iv (NDI_RED) |
… | |
… | |
1622 | const_iv (KLASS_OBJECT) |
1629 | const_iv (KLASS_OBJECT) |
1623 | const_iv (KLASS_CLIENT) |
1630 | const_iv (KLASS_CLIENT) |
1624 | const_iv (KLASS_PLAYER) |
1631 | const_iv (KLASS_PLAYER) |
1625 | const_iv (KLASS_MAP) |
1632 | const_iv (KLASS_MAP) |
1626 | |
1633 | |
|
|
1634 | const_iv (CS_QUERY_YESNO) |
|
|
1635 | const_iv (CS_QUERY_SINGLECHAR) |
|
|
1636 | const_iv (CS_QUERY_HIDEINPUT) |
|
|
1637 | |
1627 | const_iv (ST_DEAD) |
1638 | const_iv (ST_DEAD) |
1628 | const_iv (ST_SETUP) |
1639 | const_iv (ST_SETUP) |
1629 | const_iv (ST_PLAYING) |
1640 | const_iv (ST_PLAYING) |
1630 | const_iv (ST_CUSTOM) |
1641 | const_iv (ST_CUSTOM) |
1631 | |
1642 | |
1632 | const_iv (ST_PLAY_AGAIN) |
|
|
1633 | const_iv (ST_ROLL_STAT) |
|
|
1634 | const_iv (ST_CHANGE_CLASS) |
1643 | const_iv (ST_CHANGE_CLASS) |
1635 | const_iv (ST_CONFIRM_QUIT) |
1644 | const_iv (ST_CONFIRM_QUIT) |
1636 | const_iv (ST_CONFIGURE) |
|
|
1637 | const_iv (ST_GET_NAME) |
|
|
1638 | const_iv (ST_GET_PASSWORD) |
|
|
1639 | const_iv (ST_CONFIRM_PASSWORD) |
|
|
1640 | const_iv (ST_GET_PARTY_PASSWORD) |
1645 | const_iv (ST_GET_PARTY_PASSWORD) |
1641 | }; |
1646 | }; |
1642 | |
1647 | |
1643 | for (civ = const_iv + sizeof (const_iv) / sizeof (const_iv [0]); civ-- > const_iv; ) |
1648 | for (civ = const_iv + sizeof (const_iv) / sizeof (const_iv [0]); civ-- > const_iv; ) |
1644 | newCONSTSUB (stash, (char *)civ->name, newSViv (civ->iv)); |
1649 | newCONSTSUB (stash, (char *)civ->name, newSViv (civ->iv)); |
… | |
… | |
1753 | |
1758 | |
1754 | int random_roll (int min, int max, object *op, int goodbad); |
1759 | int random_roll (int min, int max, object *op, int goodbad); |
1755 | |
1760 | |
1756 | const char *cost_string_from_value(uint64 cost, int approx = 0) |
1761 | const char *cost_string_from_value(uint64 cost, int approx = 0) |
1757 | |
1762 | |
1758 | int invoke (int event, ...) |
|
|
1759 | CODE: |
|
|
1760 | if (KLASS_OF (event) != KLASS_GLOBAL) croak ("event class must be GLOBAL"); |
|
|
1761 | AV *av = (AV *)sv_2mortal ((SV *)newAV ()); |
|
|
1762 | for (int i = 1; i < items; i++) av_push (av, SvREFCNT_inc (ST (i))); |
|
|
1763 | RETVAL = INVOKE_((event_type)event, ARG_AV (av)); |
|
|
1764 | OUTPUT: RETVAL |
|
|
1765 | |
|
|
1766 | int |
1763 | int |
1767 | exp_to_level (val64 exp) |
1764 | exp_to_level (val64 exp) |
1768 | CODE: |
1765 | CODE: |
1769 | { |
1766 | { |
1770 | int i = 0; |
1767 | int i = 0; |
… | |
… | |
1809 | CODE: |
1806 | CODE: |
1810 | RETVAL = SvROK (obj) && mg_find (SvRV (obj), PERL_MAGIC_ext); |
1807 | RETVAL = SvROK (obj) && mg_find (SvRV (obj), PERL_MAGIC_ext); |
1811 | OUTPUT: |
1808 | OUTPUT: |
1812 | RETVAL |
1809 | RETVAL |
1813 | |
1810 | |
|
|
1811 | MODULE = cf PACKAGE = cf::global |
|
|
1812 | |
|
|
1813 | int invoke (SV *klass, int event, ...) |
|
|
1814 | CODE: |
|
|
1815 | if (KLASS_OF (event) != KLASS_GLOBAL) croak ("event class must be GLOBAL"); |
|
|
1816 | AV *av = (AV *)sv_2mortal ((SV *)newAV ()); |
|
|
1817 | for (int i = 1; i < items; i++) av_push (av, SvREFCNT_inc (ST (i))); |
|
|
1818 | RETVAL = INVOKE_((event_type)event, ARG_AV (av)); |
|
|
1819 | OUTPUT: RETVAL |
|
|
1820 | |
1814 | MODULE = cf PACKAGE = cf::object PREFIX = cf_object_ |
1821 | MODULE = cf PACKAGE = cf::object PREFIX = cf_object_ |
1815 | |
1822 | |
1816 | INCLUDE: $PERL genacc object ../include/object.h | |
1823 | INCLUDE: $PERL genacc object ../include/object.h | |
1817 | |
1824 | |
1818 | int invoke (object *op, int event, ...) |
1825 | int invoke (object *op, int event, ...) |
… | |
… | |
1836 | RETVAL = object::first; |
1843 | RETVAL = object::first; |
1837 | OUTPUT: RETVAL |
1844 | OUTPUT: RETVAL |
1838 | |
1845 | |
1839 | # missing properties |
1846 | # missing properties |
1840 | |
1847 | |
1841 | int flag (object *op, int flag, int value = 1) |
|
|
1842 | PROTOTYPE: $$;$ |
|
|
1843 | CODE: |
|
|
1844 | RETVAL = QUERY_FLAG (op, flag); |
|
|
1845 | if (items >= 3) |
|
|
1846 | if (value) |
|
|
1847 | SET_FLAG (op, flag); |
|
|
1848 | else |
|
|
1849 | CLEAR_FLAG (op, flag); |
|
|
1850 | OUTPUT: RETVAL |
|
|
1851 | |
|
|
1852 | object *head (object *op) |
1848 | object *head (object *op) |
1853 | PROTOTYPE: $ |
1849 | PROTOTYPE: $ |
1854 | CODE: |
1850 | CODE: |
1855 | RETVAL = op->head ? op->head : op; |
1851 | RETVAL = op->head ? op->head : op; |
1856 | OUTPUT: RETVAL |
1852 | OUTPUT: RETVAL |
… | |
… | |
1866 | PROTOTYPE: $ |
1862 | PROTOTYPE: $ |
1867 | PPCODE: |
1863 | PPCODE: |
1868 | { |
1864 | { |
1869 | object *o; |
1865 | object *o; |
1870 | for (o = obj->inv; o; o = o->below) |
1866 | for (o = obj->inv; o; o = o->below) |
1871 | XPUSHs (sv_2mortal (newSVcfapi (CFAPI_POBJECT, o))); |
1867 | XPUSHs (sv_2mortal (to_sv (o))); |
1872 | } |
1868 | } |
|
|
1869 | |
|
|
1870 | void |
|
|
1871 | set_animation (object *op, int idx) |
|
|
1872 | CODE: |
|
|
1873 | SET_ANIMATION (op, idx); |
|
|
1874 | |
|
|
1875 | void |
|
|
1876 | object::drain_stat () |
|
|
1877 | |
|
|
1878 | void |
|
|
1879 | object::drain_specific_stat (int stat) |
|
|
1880 | |
|
|
1881 | void |
|
|
1882 | object::change_luck (int change) |
|
|
1883 | |
|
|
1884 | void |
|
|
1885 | object::add_statbonus () |
|
|
1886 | |
|
|
1887 | void |
|
|
1888 | object::remove_statbonus () |
1873 | |
1889 | |
1874 | object *find_best_object_match (object *op, const char *match) |
1890 | object *find_best_object_match (object *op, const char *match) |
1875 | |
1891 | |
1876 | object *find_marked_object (object *op) |
1892 | object *find_marked_object (object *op) |
1877 | |
|
|
1878 | int resistance (object *op, int rtype, int newval = 0) |
|
|
1879 | CODE: |
|
|
1880 | if (rtype < 0 || rtype >= NROFATTACKS) |
|
|
1881 | croak ("resistance out of bounds"); |
|
|
1882 | RETVAL = op->resist [rtype]; |
|
|
1883 | if (items >= 3) |
|
|
1884 | op->resist [rtype] = newval; |
|
|
1885 | OUTPUT: RETVAL |
|
|
1886 | |
|
|
1887 | void set_resistance (object *op, int rtype, int val) |
|
|
1888 | CODE: |
|
|
1889 | if (rtype < 0 || rtype >= NROFATTACKS) |
|
|
1890 | op->resist[rtype] = val; |
|
|
1891 | |
1893 | |
1892 | int need_identify (const object *obj); |
1894 | int need_identify (const object *obj); |
1893 | |
1895 | |
1894 | int apply_shop_mat (object *shop_mat, object *op); |
1896 | int apply_shop_mat (object *shop_mat, object *op); |
1895 | |
1897 | |
… | |
… | |
1978 | |
1980 | |
1979 | object *cf_object_insert_in_ob (object *ob, object *where) |
1981 | object *cf_object_insert_in_ob (object *ob, object *where) |
1980 | |
1982 | |
1981 | int cf_object_teleport (object *op, maptile *map, int x, int y) |
1983 | int cf_object_teleport (object *op, maptile *map, int x, int y) |
1982 | |
1984 | |
1983 | void update (object *op, int action) |
1985 | void update_object (object *op, int action) |
1984 | CODE: |
|
|
1985 | update_object (op, action); |
|
|
1986 | |
1986 | |
1987 | object *cf_create_object_by_name (const char *name) |
1987 | object *cf_create_object_by_name (const char *name) |
1988 | |
1988 | |
1989 | void change_exp (object *op, uint64 exp, const char *skill_name = 0, int flag = 0) |
1989 | void change_exp (object *op, uint64 exp, const char *skill_name = 0, int flag = 0) |
1990 | |
1990 | |
… | |
… | |
2002 | |
2002 | |
2003 | void remove_button_link (object *op); |
2003 | void remove_button_link (object *op); |
2004 | |
2004 | |
2005 | |
2005 | |
2006 | MODULE = cf PACKAGE = cf::object PREFIX = cf_ |
2006 | MODULE = cf PACKAGE = cf::object PREFIX = cf_ |
2007 | |
|
|
2008 | void cf_fix_object (object *pl) |
|
|
2009 | ALIAS: fix = 0 |
|
|
2010 | |
2007 | |
2011 | object *cf_insert_ob_in_ob (object *ob, object *where) |
2008 | object *cf_insert_ob_in_ob (object *ob, object *where) |
2012 | |
2009 | |
2013 | # no clean way to get an object from an archetype - stupid idiotic |
2010 | # no clean way to get an object from an archetype - stupid idiotic |
2014 | # dumb kludgy misdesigned plug-in api slowly gets on my nerves. |
2011 | # dumb kludgy misdesigned plug-in api slowly gets on my nerves. |
… | |
… | |
2037 | |
2034 | |
2038 | player *contr (object *op) |
2035 | player *contr (object *op) |
2039 | CODE: |
2036 | CODE: |
2040 | RETVAL = op->contr; |
2037 | RETVAL = op->contr; |
2041 | OUTPUT: RETVAL |
2038 | OUTPUT: RETVAL |
|
|
2039 | |
|
|
2040 | void |
|
|
2041 | object::roll_stats () |
|
|
2042 | |
|
|
2043 | void |
|
|
2044 | object::update_stats () |
|
|
2045 | |
|
|
2046 | void |
|
|
2047 | object::swap_stats (int a, int b) |
2042 | |
2048 | |
2043 | const char *get_ob_key_value (object *op, const char *key) |
2049 | const char *get_ob_key_value (object *op, const char *key) |
2044 | |
2050 | |
2045 | bool set_ob_key_value (object *op, const char *key, const char *value = 0, int add_key = 1) |
2051 | bool set_ob_key_value (object *op, const char *key, const char *value = 0, int add_key = 1) |
2046 | |
2052 | |
… | |
… | |
2081 | player *player (object *op) |
2087 | player *player (object *op) |
2082 | CODE: |
2088 | CODE: |
2083 | RETVAL = op->contr; |
2089 | RETVAL = op->contr; |
2084 | OUTPUT: RETVAL |
2090 | OUTPUT: RETVAL |
2085 | |
2091 | |
|
|
2092 | void check_score (object *op) |
|
|
2093 | |
2086 | void cf_player_message (object *obj, char *txt, int flags = NDI_ORANGE | NDI_UNIQUE) |
2094 | void cf_player_message (object *obj, char *txt, int flags = NDI_ORANGE | NDI_UNIQUE) |
2087 | |
2095 | |
2088 | object *cf_player_send_inventory (object *op) |
2096 | object *cf_player_send_inventory (object *op) |
2089 | |
2097 | |
2090 | char *cf_player_get_ip (object *op) |
2098 | char *cf_player_get_ip (object *op) |
… | |
… | |
2132 | RETVAL = INVOKE_((event_type)event, ARG_PLAYER (pl), ARG_AV (av)); |
2140 | RETVAL = INVOKE_((event_type)event, ARG_PLAYER (pl), ARG_AV (av)); |
2133 | OUTPUT: RETVAL |
2141 | OUTPUT: RETVAL |
2134 | |
2142 | |
2135 | SV *registry (player *pl) |
2143 | SV *registry (player *pl) |
2136 | |
2144 | |
|
|
2145 | player * |
|
|
2146 | create () |
|
|
2147 | CODE: |
|
|
2148 | RETVAL = player::create (); |
|
|
2149 | OUTPUT: |
|
|
2150 | RETVAL |
|
|
2151 | |
|
|
2152 | player * |
|
|
2153 | load (const char *path) |
|
|
2154 | CODE: |
|
|
2155 | RETVAL = player::load (path); |
|
|
2156 | OUTPUT: |
|
|
2157 | RETVAL |
|
|
2158 | |
|
|
2159 | void |
|
|
2160 | player::save (bool final = false) |
|
|
2161 | |
|
|
2162 | void |
|
|
2163 | player::connect (client *ns) |
|
|
2164 | |
|
|
2165 | void |
|
|
2166 | save_stats (player *pl) |
|
|
2167 | CODE: |
|
|
2168 | pl->ob->stats.hp = pl->ob->stats.maxhp; |
|
|
2169 | pl->ob->stats.sp = pl->ob->stats.maxsp; |
|
|
2170 | pl->ob->stats.grace = pl->ob->stats.maxgrace; |
|
|
2171 | pl->orig_stats = pl->ob->stats; |
|
|
2172 | |
2137 | player *cf_player_find (char *name) |
2173 | player *cf_player_find (char *name) |
2138 | PROTOTYPE: $ |
2174 | PROTOTYPE: $ |
2139 | |
2175 | |
2140 | void cf_player_move (player *pl, int dir) |
2176 | void cf_player_move (player *pl, int dir) |
2141 | |
2177 | |
2142 | void play_sound_player_only (player *pl, int soundnum, int x = 0, int y = 0); |
2178 | void play_sound_player_only (player *pl, int soundnum, int x = 0, int y = 0); |
2143 | |
2179 | |
2144 | player *first () |
2180 | player *first () |
2145 | CODE: |
2181 | CODE: |
2146 | RETVAL = first_player; |
2182 | RETVAL = first_player; |
2147 | OUTPUT: RETVAL |
|
|
2148 | |
|
|
2149 | player *next (player *pl) |
|
|
2150 | CODE: |
|
|
2151 | RETVAL = pl->next; |
|
|
2152 | OUTPUT: RETVAL |
2183 | OUTPUT: RETVAL |
2153 | |
2184 | |
2154 | bool |
2185 | bool |
2155 | cell_visible (player *pl, int dx, int dy) |
2186 | cell_visible (player *pl, int dx, int dy) |
2156 | CODE: |
2187 | CODE: |
… | |
… | |
2164 | CODE: |
2195 | CODE: |
2165 | { |
2196 | { |
2166 | STRLEN len; |
2197 | STRLEN len; |
2167 | char *buf = SvPVbyte (packet, len); |
2198 | char *buf = SvPVbyte (packet, len); |
2168 | |
2199 | |
|
|
2200 | if (pl->ns) |
2169 | pl->ns->send_packet (buf, len); |
2201 | pl->ns->send_packet (buf, len); |
2170 | } |
2202 | } |
2171 | |
2203 | |
2172 | int |
2204 | int |
2173 | listening (player *pl, int new_value = -1) |
2205 | listening (player *pl, int new_value = -1) |
2174 | CODE: |
2206 | CODE: |
… | |
… | |
2193 | if (y) sv_to (y, pl->bed_y); |
2225 | if (y) sv_to (y, pl->bed_y); |
2194 | |
2226 | |
2195 | void |
2227 | void |
2196 | list () |
2228 | list () |
2197 | PPCODE: |
2229 | PPCODE: |
2198 | { |
|
|
2199 | player *pl; |
|
|
2200 | for (pl = first_player; pl; pl = pl->next) |
2230 | for (player *pl = first_player; pl; pl = pl->next) |
2201 | XPUSHs (newSVcfapi (CFAPI_PPLAYER, pl)); |
2231 | XPUSHs (sv_2mortal (to_sv (pl))); |
2202 | } |
|
|
2203 | |
2232 | |
2204 | bool |
2233 | bool |
2205 | peaceful (player *pl, bool new_setting = 0) |
2234 | peaceful (player *pl, bool new_setting = 0) |
2206 | PROTOTYPE: $;$ |
2235 | PROTOTYPE: $;$ |
2207 | CODE: |
2236 | CODE: |
… | |
… | |
2469 | RETVAL = INVOKE_((event_type)event, ARG_CLIENT (ns), ARG_AV (av)); |
2498 | RETVAL = INVOKE_((event_type)event, ARG_CLIENT (ns), ARG_AV (av)); |
2470 | OUTPUT: RETVAL |
2499 | OUTPUT: RETVAL |
2471 | |
2500 | |
2472 | SV *registry (client *ns) |
2501 | SV *registry (client *ns) |
2473 | |
2502 | |
|
|
2503 | void |
|
|
2504 | list () |
|
|
2505 | PPCODE: |
|
|
2506 | EXTEND (SP, clients.size ()); |
|
|
2507 | for (sockvec::iterator i = clients.begin (); i != clients.end (); ++i) |
|
|
2508 | PUSHs (sv_2mortal (to_sv (*i))); |
|
|
2509 | |
2474 | client * |
2510 | client * |
2475 | create (int fd, const char *peername) |
2511 | create (int fd, const char *peername) |
2476 | CODE: |
2512 | CODE: |
2477 | RETVAL = client::create (fd, peername); |
2513 | RETVAL = client::create (fd, peername); |
2478 | OUTPUT: |
2514 | OUTPUT: |
2479 | RETVAL |
2515 | RETVAL |
2480 | |
2516 | |
2481 | void |
2517 | void |
|
|
2518 | client::send_packet (SV *packet) |
|
|
2519 | CODE: |
|
|
2520 | { |
|
|
2521 | STRLEN len; |
|
|
2522 | char *buf = SvPVbyte (packet, len); |
|
|
2523 | |
|
|
2524 | THIS->send_packet (buf, len); |
|
|
2525 | } |
|
|
2526 | |
|
|
2527 | void |
2482 | client::destroy () |
2528 | client::destroy () |
2483 | |
2529 | |