ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/deliantra/server/server/cfperl.xs
(Generate patch)

Comparing deliantra/server/server/cfperl.xs (file contents):
Revision 1.74 by root, Mon Dec 11 23:35:37 2006 UTC vs.
Revision 1.85 by root, Sat Dec 16 03:08:26 2006 UTC

136inline SV *to_sv (unsigned long v) { return newSVuv (v); } 136inline SV *to_sv (unsigned long v) { return newSVuv (v); }
137inline SV *to_sv ( signed long long v) { return newSVval64 (v); } 137inline SV *to_sv ( signed long long v) { return newSVval64 (v); }
138inline SV *to_sv (unsigned long long v) { return newSVval64 (v); } 138inline SV *to_sv (unsigned long long v) { return newSVval64 (v); }
139inline SV *to_sv (float v) { return newSVnv (v); } 139inline SV *to_sv (float v) { return newSVnv (v); }
140inline SV *to_sv (double v) { return newSVnv (v); } 140inline SV *to_sv (double v) { return newSVnv (v); }
141inline SV *to_sv (client * v) { return newSVattachable (v, "cf::client::wrap"); }
141inline SV *to_sv (player * v) { return newSVattachable (v, "cf::player::wrap"); } 142inline SV *to_sv (player * v) { return newSVattachable (v, "cf::player::wrap"); }
142inline SV *to_sv (object * v) { return newSVattachable (v, v && v->type == PLAYER ? "cf::object::player::wrap" : "cf::object::wrap"); } 143inline SV *to_sv (object * v) { return newSVattachable (v, v && v->type == PLAYER ? "cf::object::player::wrap" : "cf::object::wrap"); }
143inline SV *to_sv (maptile * v) { return newSVattachable (v, "cf::map::wrap"); } 144inline SV *to_sv (maptile * v) { return newSVattachable (v, "cf::map::wrap"); }
144inline SV *to_sv (archetype * v) { return newSVptr (v, "cf::arch::wrap"); } 145inline SV *to_sv (archetype * v) { return newSVptr (v, "cf::arch::wrap"); }
145inline SV *to_sv (partylist * v) { return newSVptr (v, "cf::party::wrap"); } 146inline SV *to_sv (partylist * v) { return newSVptr (v, "cf::party::wrap"); }
173inline void sv_to (SV *sv, unsigned long &v) { v = SvUV (sv); } 174inline void sv_to (SV *sv, unsigned long &v) { v = SvUV (sv); }
174inline void sv_to (SV *sv, signed long long &v) { v = ( signed long long)SvVAL64 (sv); } 175inline void sv_to (SV *sv, signed long long &v) { v = ( signed long long)SvVAL64 (sv); }
175inline void sv_to (SV *sv, unsigned long long &v) { v = (unsigned long long)SvVAL64 (sv); } 176inline void sv_to (SV *sv, unsigned long long &v) { v = (unsigned long long)SvVAL64 (sv); }
176inline void sv_to (SV *sv, float &v) { v = SvNV (sv); } 177inline void sv_to (SV *sv, float &v) { v = SvNV (sv); }
177inline void sv_to (SV *sv, double &v) { v = SvNV (sv); } 178inline void sv_to (SV *sv, double &v) { v = SvNV (sv); }
179inline void sv_to (SV *sv, client * &v) { v = (client *)SvPTR_ornull (sv, "cf::client"); }
178inline void sv_to (SV *sv, player * &v) { v = (player *)SvPTR_ornull (sv, "cf::player"); } 180inline void sv_to (SV *sv, player * &v) { v = (player *)SvPTR_ornull (sv, "cf::player"); }
179inline void sv_to (SV *sv, object * &v) { v = (object *)SvPTR_ornull (sv, "cf::object"); } 181inline void sv_to (SV *sv, object * &v) { v = (object *)SvPTR_ornull (sv, "cf::object"); }
180inline void sv_to (SV *sv, archetype * &v) { v = (archetype *)SvPTR_ornull (sv, "cf::arch"); } 182inline void sv_to (SV *sv, archetype * &v) { v = (archetype *)SvPTR_ornull (sv, "cf::arch"); }
181inline void sv_to (SV *sv, maptile * &v) { v = (maptile *)SvPTR_ornull (sv, "cf::map"); } 183inline void sv_to (SV *sv, maptile * &v) { v = (maptile *)SvPTR_ornull (sv, "cf::map"); }
182inline void sv_to (SV *sv, partylist * &v) { v = (partylist *)SvPTR_ornull (sv, "cf::party"); } 184inline void sv_to (SV *sv, partylist * &v) { v = (partylist *)SvPTR_ornull (sv, "cf::party"); }
239 break; 241 break;
240 242
241 case DT_MAP: 243 case DT_MAP:
242 // va_arg (object *) when void * is passed is an XSI extension 244 // va_arg (object *) when void * is passed is an XSI extension
243 sv = to_sv (va_arg (ap, maptile *)); 245 sv = to_sv (va_arg (ap, maptile *));
246 break;
247
248 case DT_SOCKET:
249 sv = to_sv (va_arg (ap, client *));
244 break; 250 break;
245 251
246 case DT_PLAYER: 252 case DT_PLAYER:
247 sv = to_sv (va_arg (ap, player *)); 253 sv = to_sv (va_arg (ap, player *));
248 break; 254 break;
309} 315}
310 316
311////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// 317//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
312 318
313SV * 319SV *
314registry_of (attachable_base *ext) 320registry (attachable_base *ext)
315{ 321{
316 if (!ext->cb) 322 if (!ext->cb)
317 ext->cb = newAV (); 323 ext->cb = newAV ();
318 324
319 return newRV_inc ((SV *)ext->cb); 325 return newRV_inc ((SV *)ext->cb);
828 PL_exit_flags |= PERL_EXIT_DESTRUCT_END; 834 PL_exit_flags |= PERL_EXIT_DESTRUCT_END;
829 835
830 char *argv[] = { 836 char *argv[] = {
831 "", 837 "",
832 "-e" 838 "-e"
833 "cf->bootstrap;" 839 "use Event;" // required for bootstrap
840 "cf->bootstrap;" // required for datadir :*>
834 "unshift @INC, cf::datadir ();" 841 "unshift @INC, cf::datadir ();"
835 "require cf;" 842 "require cf;"
836 }; 843 };
837 844
838 if (perl_parse (perl, xs_init, 2, argv, (char **)NULL) || perl_run (perl)) 845 if (perl_parse (perl, xs_init, 2, argv, (char **)NULL) || perl_run (perl))
1049cfperl_result_DOUBLE (int idx) 1056cfperl_result_DOUBLE (int idx)
1050{ 1057{
1051 return SvNV (cfperl_result (idx)); 1058 return SvNV (cfperl_result (idx));
1052} 1059}
1053 1060
1061/////////////////////////////////////////////////////////////////////////////
1062
1063struct EventAPI *watcher_base::GEventAPI;
1064
1065static void iw_dispatch (pe_event *ev)
1066{
1067 iw *w = (iw *)ev->ext_data;
1068 w->call (*w);
1069}
1070
1071void
1072iw::alloc ()
1073{
1074 pe = GEventAPI->new_idle (0, 0);
1075
1076 pe->base.callback = (void *)iw_dispatch;
1077 pe->base.ext_data = (void *)this;
1078}
1079
1080static void iow_dispatch (pe_event *ev)
1081{
1082 iow *w = (iow *)ev->ext_data;
1083 w->call (*w, ((pe_ioevent *)ev)->got);
1084}
1085
1086void
1087iow::alloc ()
1088{
1089 pe = GEventAPI->new_io (0, 0);
1090
1091 pe->base.callback = (void *)iow_dispatch;
1092 pe->base.ext_data = (void *)this;
1093
1094 pe->fd = -1;
1095 pe->poll = 0;
1096}
1097
1098void
1099iow::fd (int fd)
1100{
1101 pe->fd = fd;
1102}
1103
1104int
1105iow::poll ()
1106{
1107 return pe->poll;
1108}
1109
1110void
1111iow::poll (int events)
1112{
1113 if (pe->poll != events)
1114 {
1115 if (pe->poll) stop ();
1116 pe->poll = events;
1117 if (pe->poll) start ();
1118 }
1119}
1120
1054MODULE = cf PACKAGE = cf PREFIX = cf_ 1121MODULE = cf PACKAGE = cf PREFIX = cf_
1055 1122
1056BOOT: 1123BOOT:
1057{ 1124{
1058 HV *stash = gv_stashpv ("cf", 1); 1125 HV *stash = gv_stashpv ("cf", 1);
1126
1127 I_EVENT_API (PACKAGE);
1128 watcher_base::GEventAPI = GEventAPI;
1059 1129
1060 newCONSTSUB (stash, "VERSION", newSVpv (VERSION, sizeof (VERSION) - 1)); 1130 newCONSTSUB (stash, "VERSION", newSVpv (VERSION, sizeof (VERSION) - 1));
1061 1131
1062 static const struct { 1132 static const struct {
1063 const char *name; 1133 const char *name;
1574 av_push (event, newSVpv ((char *)eiv->name + eiv->skip, 0)); 1644 av_push (event, newSVpv ((char *)eiv->name + eiv->skip, 0));
1575 av_push (event, newSViv (eiv->klass)); 1645 av_push (event, newSViv (eiv->klass));
1576 av_store (av, eiv->iv, newRV_noinc ((SV *)event)); 1646 av_store (av, eiv->iv, newRV_noinc ((SV *)event));
1577 newCONSTSUB (stash, (char *)eiv->name, newSViv (eiv->iv)); 1647 newCONSTSUB (stash, (char *)eiv->name, newSViv (eiv->iv));
1578 } 1648 }
1579
1580 //I_EVENT_API (PACKAGE);
1581} 1649}
1582 1650
1583void _init_vars () 1651void _init_vars ()
1584 CODE: 1652 CODE:
1585 cb_global = get_av ("cf::CB_GLOBAL", 1); 1653 cb_global = get_av ("cf::CB_GLOBAL", 1);
1599 reattach (map); 1667 reattach (map);
1600 1668
1601 for (object *op = object::first; op; op = op->next) 1669 for (object *op = object::first; op; op = op->next)
1602 reattach (op); 1670 reattach (op);
1603} 1671}
1672
1673bool
1674add_client (int fd, const char *peername)
1604 1675
1605NV floor (NV x) 1676NV floor (NV x)
1606 1677
1607NV ceil (NV x) 1678NV ceil (NV x)
1608 1679
1730 for (int i = 2; i < items; i++) av_push (av, SvREFCNT_inc (ST (i))); 1801 for (int i = 2; i < items; i++) av_push (av, SvREFCNT_inc (ST (i)));
1731 RETVAL = INVOKE_((event_type)event, ARG_OBJECT (op), ARG_AV (av)); 1802 RETVAL = INVOKE_((event_type)event, ARG_OBJECT (op), ARG_AV (av));
1732 OUTPUT: RETVAL 1803 OUTPUT: RETVAL
1733 1804
1734SV *registry (object *op) 1805SV *registry (object *op)
1735 CODE:
1736 RETVAL = registry_of (op);
1737 OUTPUT:
1738 RETVAL
1739 1806
1740void mortals () 1807void mortals ()
1741 PPCODE: 1808 PPCODE:
1742 EXTEND (SP, object::mortals.size ()); 1809 EXTEND (SP, object::mortals.size ());
1743 for (AUTODECL (i, object::mortals.begin ()); i != object::mortals.end (); ++i) 1810 for (AUTODECL (i, object::mortals.begin ()); i != object::mortals.end (); ++i)
1838 if (recursive) 1905 if (recursive)
1839 RETVAL = object_create_clone (op); 1906 RETVAL = object_create_clone (op);
1840 else 1907 else
1841 { 1908 {
1842 RETVAL = object::create (); 1909 RETVAL = object::create ();
1843 copy_object (op, RETVAL); 1910 op->copy_to (RETVAL);
1844 } 1911 }
1845 OUTPUT: RETVAL 1912 OUTPUT: RETVAL
1846 1913
1847int pay_item (object *op, object *buyer) 1914int pay_item (object *op, object *buyer)
1848 CODE: 1915 CODE:
2031int command_banish (object *op, char *params) 2098int command_banish (object *op, char *params)
2032 2099
2033 2100
2034MODULE = cf PACKAGE = cf::player PREFIX = cf_player_ 2101MODULE = cf PACKAGE = cf::player PREFIX = cf_player_
2035 2102
2036INCLUDE: $PERL genacc player ../include/newserver.h ../include/player.h | 2103INCLUDE: $PERL genacc player ../include/player.h |
2037
2038char *
2039client (player *pl)
2040 CODE:
2041 RETVAL = pl->socket.client;
2042 OUTPUT:
2043 RETVAL
2044
2045char *
2046host (player *pl)
2047 CODE:
2048 RETVAL = pl->socket.host;
2049 OUTPUT:
2050 RETVAL
2051 2104
2052int invoke (player *pl, int event, ...) 2105int invoke (player *pl, int event, ...)
2053 CODE: 2106 CODE:
2054 if (KLASS_OF (event) != KLASS_PLAYER) croak ("event class must be PLAYER"); 2107 if (KLASS_OF (event) != KLASS_PLAYER) croak ("event class must be PLAYER");
2055 AV *av = (AV *)sv_2mortal ((SV *)newAV ()); 2108 AV *av = (AV *)sv_2mortal ((SV *)newAV ());
2056 for (int i = 2; i < items; i++) av_push (av, SvREFCNT_inc (ST (i))); 2109 for (int i = 2; i < items; i++) av_push (av, SvREFCNT_inc (ST (i)));
2057 RETVAL = INVOKE_((event_type)event, ARG_PLAYER (pl), ARG_AV (av)); 2110 RETVAL = INVOKE_((event_type)event, ARG_PLAYER (pl), ARG_AV (av));
2058 OUTPUT: RETVAL 2111 OUTPUT: RETVAL
2059 2112
2060SV *registry (player *pl) 2113SV *registry (player *pl)
2114
2115player *cf_player_find (char *name)
2116 PROTOTYPE: $
2117
2118void cf_player_move (player *pl, int dir)
2119
2120void play_sound_player_only (player *pl, int soundnum, int x = 0, int y = 0);
2121
2122player *first ()
2061 CODE: 2123 CODE:
2062 RETVAL = registry_of (pl); 2124 RETVAL = first_player;
2125 OUTPUT: RETVAL
2126
2127player *next (player *pl)
2128 CODE:
2129 RETVAL = pl->next;
2130 OUTPUT: RETVAL
2131
2132bool
2133cell_visible (player *pl, int dx, int dy)
2134 CODE:
2135 RETVAL = FABS (dx) <= pl->socket->mapx / 2 && FABS (dy) <= pl->socket->mapy / 2
2136 && !pl->blocked_los [dx + pl->socket->mapx / 2][dy + pl->socket->mapy / 2];
2063 OUTPUT: 2137 OUTPUT:
2064 RETVAL 2138 RETVAL
2065 2139
2066player *cf_player_find (char *name)
2067 PROTOTYPE: $
2068
2069void cf_player_move (player *pl, int dir)
2070
2071void play_sound_player_only (player *pl, int soundnum, int x = 0, int y = 0);
2072
2073player *first ()
2074 CODE:
2075 RETVAL = first_player;
2076 OUTPUT: RETVAL
2077
2078player *next (player *pl)
2079 CODE:
2080 RETVAL = pl->next;
2081 OUTPUT: RETVAL
2082
2083bool
2084cell_visible (player *pl, int dx, int dy)
2085 CODE:
2086 RETVAL = FABS (dx) <= pl->socket.mapx / 2 && FABS (dy) <= pl->socket.mapy / 2
2087 && !pl->blocked_los [dx + pl->socket.mapx / 2][dy + pl->socket.mapy / 2];
2088 OUTPUT:
2089 RETVAL
2090
2091void
2092buggy_mapscroll (player *pl, int value = 1)
2093 CODE:
2094 pl->socket.buggy_mapscroll = value;
2095
2096void 2140void
2097send (player *pl, SV *packet) 2141send (player *pl, SV *packet)
2098 CODE: 2142 CODE:
2099{ 2143{
2100 STRLEN len; 2144 STRLEN len;
2101 char *buf = SvPVbyte (packet, len); 2145 char *buf = SvPVbyte (packet, len);
2102 2146
2103 Write_String_To_Socket (&pl->socket, buf, len); 2147 pl->socket->send_packet (buf, len);
2104} 2148}
2105 2149
2106int 2150int
2107listening (player *pl, int new_value = -1) 2151listening (player *pl, int new_value = -1)
2108 CODE: 2152 CODE:
2173 for (int i = 2; i < items; i++) av_push (av, SvREFCNT_inc (ST (i))); 2217 for (int i = 2; i < items; i++) av_push (av, SvREFCNT_inc (ST (i)));
2174 RETVAL = INVOKE_((event_type)event, ARG_MAP (map), ARG_AV (av)); 2218 RETVAL = INVOKE_((event_type)event, ARG_MAP (map), ARG_AV (av));
2175 OUTPUT: RETVAL 2219 OUTPUT: RETVAL
2176 2220
2177SV *registry (maptile *map) 2221SV *registry (maptile *map)
2178 CODE:
2179 RETVAL = registry_of (map);
2180 OUTPUT:
2181 RETVAL
2182 2222
2183INCLUDE: $PERL genacc maptile ../include/map.h | 2223INCLUDE: $PERL genacc maptile ../include/map.h |
2184 2224
2185maptile *new (int width, int height) 2225maptile *new (int width, int height)
2186 PROTOTYPE: 2226 PROTOTYPE:
2389 2429
2390MODULE = cf PACKAGE = cf::living 2430MODULE = cf PACKAGE = cf::living
2391 2431
2392INCLUDE: $PERL genacc living ../include/living.h | 2432INCLUDE: $PERL genacc living ../include/living.h |
2393 2433
2434MODULE = cf PACKAGE = cf::settings
2435
2436INCLUDE: $PERL genacc Settings ../include/global.h |
2437
2438MODULE = cf PACKAGE = cf::client
2439
2440INCLUDE: $PERL genacc client ../include/client.h |
2441
2442int invoke (client *ns, int event, ...)
2443 CODE:
2444 if (KLASS_OF (event) != KLASS_SOCKET) croak ("event class must be SOCKET");
2445 AV *av = (AV *)sv_2mortal ((SV *)newAV ());
2446 for (int i = 2; i < items; i++) av_push (av, SvREFCNT_inc (ST (i)));
2447 RETVAL = INVOKE_((event_type)event, ARG_SOCKET (ns), ARG_AV (av));
2448 OUTPUT: RETVAL
2449
2450SV *registry (client *ns)
2451

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines