… | |
… | |
43 | extern sint64 *levels; // the experience table |
43 | extern sint64 *levels; // the experience table |
44 | |
44 | |
45 | typedef object object_ornull; |
45 | typedef object object_ornull; |
46 | typedef maptile maptile_ornull; |
46 | typedef maptile maptile_ornull; |
47 | |
47 | |
|
|
48 | #if IVSIZE >= 8 |
|
|
49 | typedef IV val64; |
|
|
50 | # define newSVval64 newSViv |
|
|
51 | # define SvVAL64 SvIV |
|
|
52 | #else |
48 | typedef double val64; |
53 | typedef double val64; |
49 | #define newSVval64 newSVnv |
54 | # define newSVval64 newSVnv |
50 | #define SvVAL64 SvNV |
55 | # define SvVAL64 SvNV |
|
|
56 | #endif |
51 | |
57 | |
52 | static f_plug_api gethook = cfapi_get_hooks; |
58 | static f_plug_api gethook = cfapi_get_hooks; |
53 | static f_plug_api object_set_property = cfapi_object_set_property; |
59 | static f_plug_api object_set_property = cfapi_object_set_property; |
54 | static f_plug_api object_insert = cfapi_object_insert; |
60 | static f_plug_api object_insert = cfapi_object_insert; |
55 | |
61 | |
… | |
… | |
130 | inline SV *to_sv (unsigned long v) { return newSVuv (v); } |
136 | inline SV *to_sv (unsigned long v) { return newSVuv (v); } |
131 | inline SV *to_sv ( signed long long v) { return newSVval64 (v); } |
137 | inline SV *to_sv ( signed long long v) { return newSVval64 (v); } |
132 | inline SV *to_sv (unsigned long long v) { return newSVval64 (v); } |
138 | inline SV *to_sv (unsigned long long v) { return newSVval64 (v); } |
133 | inline SV *to_sv (float v) { return newSVnv (v); } |
139 | inline SV *to_sv (float v) { return newSVnv (v); } |
134 | inline SV *to_sv (double v) { return newSVnv (v); } |
140 | inline SV *to_sv (double v) { return newSVnv (v); } |
|
|
141 | inline SV *to_sv (client_socket *v) { return newSVattachable (v, "cf::client_socket::wrap"); } |
135 | inline SV *to_sv (player * v) { return newSVattachable (v, "cf::player::wrap"); } |
142 | inline SV *to_sv (player * v) { return newSVattachable (v, "cf::player::wrap"); } |
136 | inline SV *to_sv (object * v) { return newSVattachable (v, v && v->type == PLAYER ? "cf::object::player::wrap" : "cf::object::wrap"); } |
143 | inline SV *to_sv (object * v) { return newSVattachable (v, v && v->type == PLAYER ? "cf::object::player::wrap" : "cf::object::wrap"); } |
137 | inline SV *to_sv (maptile * v) { return newSVattachable (v, "cf::map::wrap"); } |
144 | inline SV *to_sv (maptile * v) { return newSVattachable (v, "cf::map::wrap"); } |
138 | inline SV *to_sv (archetype * v) { return newSVptr (v, "cf::arch::wrap"); } |
145 | inline SV *to_sv (archetype * v) { return newSVptr (v, "cf::arch::wrap"); } |
139 | inline SV *to_sv (partylist * v) { return newSVptr (v, "cf::party::wrap"); } |
146 | inline SV *to_sv (partylist * v) { return newSVptr (v, "cf::party::wrap"); } |
… | |
… | |
148 | inline SV *to_sv (treasurelist * v) { return to_sv (v->name); } |
155 | inline SV *to_sv (treasurelist * v) { return to_sv (v->name); } |
149 | |
156 | |
150 | inline SV *to_sv (UUID v) |
157 | inline SV *to_sv (UUID v) |
151 | { |
158 | { |
152 | char buf[128]; |
159 | char buf[128]; |
153 | snprintf (buf, 128, "<1,%llx>", (unsigned long long)v.seq); |
160 | snprintf (buf, 128, "<1,%" PRIx64 ">", v.seq); |
154 | return newSVpv (buf, 0); |
161 | return newSVpv (buf, 0); |
155 | } |
162 | } |
156 | |
163 | |
157 | inline void sv_to (SV *sv, shstr &v) { v = SvOK (sv) ? SvPV_nolen (sv) : 0; } |
164 | inline void sv_to (SV *sv, shstr &v) { v = SvOK (sv) ? SvPV_nolen (sv) : 0; } |
158 | inline void sv_to (SV *sv, char * &v) { free (v); v = SvOK (sv) ? strdup (SvPV_nolen (sv)) : 0; } //TODO: verify that all simple pointers are strdup-managed |
165 | inline void sv_to (SV *sv, char * &v) { free (v); v = SvOK (sv) ? strdup (SvPV_nolen (sv)) : 0; } |
159 | inline void sv_to (SV *sv, bool &v) { v = SvIV (sv); } |
166 | inline void sv_to (SV *sv, bool &v) { v = SvIV (sv); } |
160 | inline void sv_to (SV *sv, signed char &v) { v = SvIV (sv); } |
167 | inline void sv_to (SV *sv, signed char &v) { v = SvIV (sv); } |
161 | inline void sv_to (SV *sv, unsigned char &v) { v = SvIV (sv); } |
168 | inline void sv_to (SV *sv, unsigned char &v) { v = SvIV (sv); } |
162 | inline void sv_to (SV *sv, signed short &v) { v = SvIV (sv); } |
169 | inline void sv_to (SV *sv, signed short &v) { v = SvIV (sv); } |
163 | inline void sv_to (SV *sv, unsigned short &v) { v = SvIV (sv); } |
170 | inline void sv_to (SV *sv, unsigned short &v) { v = SvIV (sv); } |
… | |
… | |
167 | inline void sv_to (SV *sv, unsigned long &v) { v = SvUV (sv); } |
174 | inline void sv_to (SV *sv, unsigned long &v) { v = SvUV (sv); } |
168 | inline void sv_to (SV *sv, signed long long &v) { v = ( signed long long)SvVAL64 (sv); } |
175 | inline void sv_to (SV *sv, signed long long &v) { v = ( signed long long)SvVAL64 (sv); } |
169 | inline void sv_to (SV *sv, unsigned long long &v) { v = (unsigned long long)SvVAL64 (sv); } |
176 | inline void sv_to (SV *sv, unsigned long long &v) { v = (unsigned long long)SvVAL64 (sv); } |
170 | inline void sv_to (SV *sv, float &v) { v = SvNV (sv); } |
177 | inline void sv_to (SV *sv, float &v) { v = SvNV (sv); } |
171 | inline void sv_to (SV *sv, double &v) { v = SvNV (sv); } |
178 | inline void sv_to (SV *sv, double &v) { v = SvNV (sv); } |
|
|
179 | inline void sv_to (SV *sv, client_socket *&v) { v = (client_socket *)SvPTR_ornull (sv, "cf::client_socket"); } |
172 | inline void sv_to (SV *sv, player * &v) { v = (player *)SvPTR_ornull (sv, "cf::player"); } |
180 | inline void sv_to (SV *sv, player * &v) { v = (player *)SvPTR_ornull (sv, "cf::player"); } |
173 | inline void sv_to (SV *sv, object * &v) { v = (object *)SvPTR_ornull (sv, "cf::object"); } |
181 | inline void sv_to (SV *sv, object * &v) { v = (object *)SvPTR_ornull (sv, "cf::object"); } |
174 | inline void sv_to (SV *sv, archetype * &v) { v = (archetype *)SvPTR_ornull (sv, "cf::arch"); } |
182 | inline void sv_to (SV *sv, archetype * &v) { v = (archetype *)SvPTR_ornull (sv, "cf::arch"); } |
175 | inline void sv_to (SV *sv, maptile * &v) { v = (maptile *)SvPTR_ornull (sv, "cf::map"); } |
183 | inline void sv_to (SV *sv, maptile * &v) { v = (maptile *)SvPTR_ornull (sv, "cf::map"); } |
176 | inline void sv_to (SV *sv, partylist * &v) { v = (partylist *)SvPTR_ornull (sv, "cf::party"); } |
184 | inline void sv_to (SV *sv, partylist * &v) { v = (partylist *)SvPTR_ornull (sv, "cf::party"); } |
… | |
… | |
187 | 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)); } |
188 | |
196 | |
189 | inline void sv_to (SV *sv, UUID &v) |
197 | inline void sv_to (SV *sv, UUID &v) |
190 | { |
198 | { |
191 | unsigned int version; |
199 | unsigned int version; |
192 | unsigned long long seq; |
|
|
193 | |
200 | |
194 | if (2 != sscanf (SvPV_nolen (sv), "<%d.%llx>", &version, &seq) || 1 != version) |
201 | if (2 != sscanf (SvPV_nolen (sv), "<%d.%" SCNx64 ">", &version, &v.seq) || 1 != version) |
195 | croak ("unparsable uuid: %s", SvPV_nolen (sv)); |
202 | croak ("unparsable uuid: %s", SvPV_nolen (sv)); |
196 | |
|
|
197 | v.seq = seq; |
|
|
198 | } |
203 | } |
199 | |
204 | |
200 | static SV * |
205 | static SV * |
201 | newSVdt_va (va_list &ap, data_type type) |
206 | newSVdt_va (va_list &ap, data_type type) |
202 | { |
207 | { |
… | |
… | |
236 | break; |
241 | break; |
237 | |
242 | |
238 | case DT_MAP: |
243 | case DT_MAP: |
239 | // va_arg (object *) when void * is passed is an XSI extension |
244 | // va_arg (object *) when void * is passed is an XSI extension |
240 | 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_socket *)); |
241 | break; |
250 | break; |
242 | |
251 | |
243 | case DT_PLAYER: |
252 | case DT_PLAYER: |
244 | sv = to_sv (va_arg (ap, player *)); |
253 | sv = to_sv (va_arg (ap, player *)); |
245 | break; |
254 | break; |
… | |
… | |
306 | } |
315 | } |
307 | |
316 | |
308 | ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// |
317 | ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// |
309 | |
318 | |
310 | SV * |
319 | SV * |
311 | registry_of (attachable_base *ext) |
320 | registry (attachable_base *ext) |
312 | { |
321 | { |
313 | if (!ext->cb) |
322 | if (!ext->cb) |
314 | ext->cb = newAV (); |
323 | ext->cb = newAV (); |
315 | |
324 | |
316 | return newRV_inc ((SV *)ext->cb); |
325 | return newRV_inc ((SV *)ext->cb); |
… | |
… | |
768 | static CommArray_s rtn_cmd; |
777 | static CommArray_s rtn_cmd; |
769 | |
778 | |
770 | static int |
779 | static int |
771 | runPluginCommand (object *obj, char *params) |
780 | runPluginCommand (object *obj, char *params) |
772 | { |
781 | { |
773 | dSP; |
782 | return -1; |
774 | |
|
|
775 | ENTER; |
|
|
776 | SAVETMPS; |
|
|
777 | |
|
|
778 | PUSHMARK (SP); |
|
|
779 | |
|
|
780 | EXTEND (SP, 3); |
|
|
781 | PUSHs (sv_2mortal (newSVpv (rtn_cmd.name, 0))); |
|
|
782 | PUSHs (sv_2mortal (newSVcfapi (CFAPI_POBJECT, obj))); |
|
|
783 | |
|
|
784 | if (params) |
|
|
785 | PUSHs (sv_2mortal (newSVpv (params, 0))); |
|
|
786 | |
|
|
787 | PUTBACK; |
|
|
788 | int count = call_pv ("cf::inject_command", G_SCALAR | G_EVAL); |
|
|
789 | SPAGAIN; |
|
|
790 | |
|
|
791 | if (SvTRUE (ERRSV)) |
|
|
792 | LOG (llevError, "command '%s' callback evaluation error: %s", rtn_cmd.name, SvPV_nolen (ERRSV)); |
|
|
793 | |
|
|
794 | int returnvalue = count > 0 ? POPi : -1; |
|
|
795 | |
|
|
796 | PUTBACK; |
|
|
797 | FREETMPS; |
|
|
798 | LEAVE; |
|
|
799 | |
|
|
800 | return returnvalue; |
|
|
801 | } |
783 | } |
802 | |
784 | |
803 | extern "C" void *cfperl_getPluginProperty (int *type, ...) |
785 | extern "C" void *cfperl_getPluginProperty (int *type, ...) |
804 | { |
786 | { |
805 | va_list args; |
787 | va_list args; |
… | |
… | |
808 | va_start (args, type); |
790 | va_start (args, type); |
809 | propname = va_arg (args, char *); |
791 | propname = va_arg (args, char *); |
810 | //printf ("Property name: %s\n", propname); |
792 | //printf ("Property name: %s\n", propname); |
811 | |
793 | |
812 | if (!strcmp (propname, "command?")) |
794 | if (!strcmp (propname, "command?")) |
813 | { |
|
|
814 | if (!perl) |
|
|
815 | return NULL; |
795 | return NULL; |
816 | |
796 | else if (!strcmp (propname, "Identification")) |
817 | const char *cmdname = va_arg (args, const char *); |
797 | { |
818 | HV *hv = get_hv ("cf::COMMAND", 1); |
|
|
819 | SV **svp = hv_fetch (hv, cmdname, strlen (cmdname) + 1, 0); |
|
|
820 | |
|
|
821 | va_end (args); |
798 | va_end (args); |
822 | |
799 | return (void *)PLUGIN_NAME; |
823 | if (svp) |
|
|
824 | { |
|
|
825 | // this is totaly broken, should stash it into %COMMAND |
|
|
826 | rtn_cmd.name = cmdname; |
|
|
827 | rtn_cmd.time = SvNV (*svp); |
|
|
828 | rtn_cmd.func = runPluginCommand; |
|
|
829 | |
|
|
830 | return &rtn_cmd; |
|
|
831 | } |
|
|
832 | } |
800 | } |
833 | else if (!strcmp (propname, "Identification")) |
801 | else if (!strcmp (propname, "FullName")) |
834 | { |
802 | { |
835 | va_end (args); |
803 | va_end (args); |
836 | return (void*) PLUGIN_NAME; |
|
|
837 | } |
|
|
838 | else if (!strcmp (propname, "FullName")) |
|
|
839 | { |
|
|
840 | va_end (args); |
|
|
841 | return (void*) PLUGIN_VERSION; |
804 | return (void *)PLUGIN_VERSION; |
842 | } |
805 | } |
843 | else |
806 | else |
844 | va_end (args); |
807 | va_end (args); |
845 | |
808 | |
846 | return NULL; |
809 | return NULL; |
… | |
… | |
871 | PL_exit_flags |= PERL_EXIT_DESTRUCT_END; |
834 | PL_exit_flags |= PERL_EXIT_DESTRUCT_END; |
872 | |
835 | |
873 | char *argv[] = { |
836 | char *argv[] = { |
874 | "", |
837 | "", |
875 | "-e" |
838 | "-e" |
876 | "cf->bootstrap;" |
839 | "use Event;" // required for bootstrap |
|
|
840 | "cf->bootstrap;" // requiored for datadir :*> |
877 | "unshift @INC, cf::datadir ();" |
841 | "unshift @INC, cf::datadir ();" |
878 | "require cf;" |
842 | "require cf;" |
879 | }; |
843 | }; |
880 | |
844 | |
881 | 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)) |
… | |
… | |
944 | object *op; |
908 | object *op; |
945 | player *pl; |
909 | player *pl; |
946 | maptile *map; |
910 | maptile *map; |
947 | |
911 | |
948 | // callback call ordering is: |
912 | // callback call ordering is: |
949 | // 1. per-object callback (NYI) |
913 | // 1. per-object callback |
950 | // 2. per-class object |
914 | // 2. per-class object |
951 | // 2a. per-type callback |
915 | // 3. per-type callback |
952 | // 4. global callbacks |
916 | // 4. global callbacks |
953 | |
917 | |
954 | gather_callbacks (callbacks, cb_global, event); |
918 | gather_callbacks (callbacks, cb_global, event); |
955 | |
919 | |
956 | switch (KLASS_OF (event)) |
920 | switch (KLASS_OF (event)) |
… | |
… | |
1086 | cfperl_result_INT (int idx) |
1050 | cfperl_result_INT (int idx) |
1087 | { |
1051 | { |
1088 | return SvIV (cfperl_result (idx)); |
1052 | return SvIV (cfperl_result (idx)); |
1089 | } |
1053 | } |
1090 | |
1054 | |
|
|
1055 | double |
|
|
1056 | cfperl_result_DOUBLE (int idx) |
|
|
1057 | { |
|
|
1058 | return SvNV (cfperl_result (idx)); |
|
|
1059 | } |
|
|
1060 | |
|
|
1061 | ///////////////////////////////////////////////////////////////////////////// |
|
|
1062 | |
|
|
1063 | struct EventAPI *watcher_base::GEventAPI; |
|
|
1064 | |
|
|
1065 | static void iow_dispatch (pe_event *ev) |
|
|
1066 | { |
|
|
1067 | iow *w = (iow *)ev->ext_data; |
|
|
1068 | w->call (*w, ((pe_ioevent *)ev)->got); |
|
|
1069 | } |
|
|
1070 | |
|
|
1071 | void |
|
|
1072 | iow::alloc () |
|
|
1073 | { |
|
|
1074 | pe = GEventAPI->new_io (0, 0); |
|
|
1075 | |
|
|
1076 | pe->base.callback = (void *)iow_dispatch; |
|
|
1077 | pe->base.ext_data = (void *)this; |
|
|
1078 | |
|
|
1079 | pe->fd = -1; |
|
|
1080 | pe->poll = 0; |
|
|
1081 | } |
|
|
1082 | |
|
|
1083 | iow & |
|
|
1084 | iow::fd (int fd) |
|
|
1085 | { |
|
|
1086 | pe->fd = fd; |
|
|
1087 | |
|
|
1088 | return *this; |
|
|
1089 | } |
|
|
1090 | |
|
|
1091 | int |
|
|
1092 | iow::poll () |
|
|
1093 | { |
|
|
1094 | return pe->poll; |
|
|
1095 | } |
|
|
1096 | |
|
|
1097 | iow & |
|
|
1098 | iow::poll (int events) |
|
|
1099 | { |
|
|
1100 | if (pe->poll != events) |
|
|
1101 | { |
|
|
1102 | if (pe->poll) stop (); |
|
|
1103 | pe->poll = events; |
|
|
1104 | if (pe->poll) start (); |
|
|
1105 | } |
|
|
1106 | |
|
|
1107 | return *this; |
|
|
1108 | } |
|
|
1109 | |
1091 | MODULE = cf PACKAGE = cf PREFIX = cf_ |
1110 | MODULE = cf PACKAGE = cf PREFIX = cf_ |
1092 | |
1111 | |
1093 | BOOT: |
1112 | BOOT: |
1094 | { |
1113 | { |
1095 | HV *stash = gv_stashpv ("cf", 1); |
1114 | HV *stash = gv_stashpv ("cf", 1); |
|
|
1115 | |
|
|
1116 | I_EVENT_API (PACKAGE); |
|
|
1117 | watcher_base::GEventAPI = GEventAPI; |
1096 | |
1118 | |
1097 | newCONSTSUB (stash, "VERSION", newSVpv (VERSION, sizeof (VERSION) - 1)); |
1119 | newCONSTSUB (stash, "VERSION", newSVpv (VERSION, sizeof (VERSION) - 1)); |
1098 | |
1120 | |
1099 | static const struct { |
1121 | static const struct { |
1100 | const char *name; |
1122 | const char *name; |
… | |
… | |
1611 | av_push (event, newSVpv ((char *)eiv->name + eiv->skip, 0)); |
1633 | av_push (event, newSVpv ((char *)eiv->name + eiv->skip, 0)); |
1612 | av_push (event, newSViv (eiv->klass)); |
1634 | av_push (event, newSViv (eiv->klass)); |
1613 | av_store (av, eiv->iv, newRV_noinc ((SV *)event)); |
1635 | av_store (av, eiv->iv, newRV_noinc ((SV *)event)); |
1614 | newCONSTSUB (stash, (char *)eiv->name, newSViv (eiv->iv)); |
1636 | newCONSTSUB (stash, (char *)eiv->name, newSViv (eiv->iv)); |
1615 | } |
1637 | } |
1616 | |
|
|
1617 | //I_EVENT_API (PACKAGE); |
|
|
1618 | } |
1638 | } |
1619 | |
1639 | |
1620 | void _init_vars () |
1640 | void _init_vars () |
1621 | CODE: |
1641 | CODE: |
1622 | cb_global = get_av ("cf::CB_GLOBAL", 1); |
1642 | cb_global = get_av ("cf::CB_GLOBAL", 1); |
1623 | cb_object = get_av ("cf::CB_OBJECT", 1); |
1643 | cb_object = get_av ("cf::CB_OBJECT", 1); |
1624 | cb_player = get_av ("cf::CB_PLAYER", 1); |
1644 | cb_player = get_av ("cf::CB_PLAYER", 1); |
1625 | cb_type = get_av ("cf::CB_TYPE" , 1); |
1645 | cb_type = get_av ("cf::CB_TYPE" , 1); |
1626 | cb_map = get_av ("cf::CB_MAP" , 1); |
1646 | cb_map = get_av ("cf::CB_MAP" , 1); |
1627 | |
1647 | |
1628 | void _global_reattach () |
1648 | void _global_reattach () |
1629 | CODE: |
1649 | CODE: |
1630 | { |
1650 | { |
1631 | // reattach to all attachable objects in the game. |
1651 | // reattach to all attachable objects in the game. |
… | |
… | |
1636 | reattach (map); |
1656 | reattach (map); |
1637 | |
1657 | |
1638 | for (object *op = object::first; op; op = op->next) |
1658 | for (object *op = object::first; op; op = op->next) |
1639 | reattach (op); |
1659 | reattach (op); |
1640 | } |
1660 | } |
|
|
1661 | |
|
|
1662 | bool |
|
|
1663 | add_client_socket (int fd, const char *peername) |
1641 | |
1664 | |
1642 | NV floor (NV x) |
1665 | NV floor (NV x) |
1643 | |
1666 | |
1644 | NV ceil (NV x) |
1667 | NV ceil (NV x) |
1645 | |
1668 | |
… | |
… | |
1693 | } |
1716 | } |
1694 | OUTPUT: RETVAL |
1717 | OUTPUT: RETVAL |
1695 | |
1718 | |
1696 | void _exit (int status = 0) |
1719 | void _exit (int status = 0) |
1697 | |
1720 | |
1698 | int cf_find_animation (char *text) |
1721 | int find_animation (char *text) |
1699 | PROTOTYPE: $ |
1722 | PROTOTYPE: $ |
1700 | |
1723 | |
1701 | int random_roll(int min, int max, object *op, int goodbad); |
1724 | int random_roll (int min, int max, object *op, int goodbad); |
1702 | |
1725 | |
1703 | const char *cost_string_from_value(uint64 cost, int approx = 0) |
1726 | const char *cost_string_from_value(uint64 cost, int approx = 0) |
1704 | |
1727 | |
1705 | int invoke (int event, ...) |
1728 | int invoke (int event, ...) |
1706 | CODE: |
1729 | CODE: |
… | |
… | |
1767 | for (int i = 2; i < items; i++) av_push (av, SvREFCNT_inc (ST (i))); |
1790 | for (int i = 2; i < items; i++) av_push (av, SvREFCNT_inc (ST (i))); |
1768 | RETVAL = INVOKE_((event_type)event, ARG_OBJECT (op), ARG_AV (av)); |
1791 | RETVAL = INVOKE_((event_type)event, ARG_OBJECT (op), ARG_AV (av)); |
1769 | OUTPUT: RETVAL |
1792 | OUTPUT: RETVAL |
1770 | |
1793 | |
1771 | SV *registry (object *op) |
1794 | SV *registry (object *op) |
1772 | CODE: |
|
|
1773 | RETVAL = registry_of (op); |
|
|
1774 | OUTPUT: |
|
|
1775 | RETVAL |
|
|
1776 | |
1795 | |
1777 | void mortals () |
1796 | void mortals () |
1778 | PPCODE: |
1797 | PPCODE: |
1779 | EXTEND (SP, object::mortals.size ()); |
1798 | EXTEND (SP, object::mortals.size ()); |
1780 | for (AUTODECL (i, object::mortals.begin ()); i != object::mortals.end (); ++i) |
1799 | for (AUTODECL (i, object::mortals.begin ()); i != object::mortals.end (); ++i) |
… | |
… | |
1822 | |
1841 | |
1823 | object *find_best_object_match (object *op, const char *match) |
1842 | object *find_best_object_match (object *op, const char *match) |
1824 | |
1843 | |
1825 | object *find_marked_object (object *op) |
1844 | object *find_marked_object (object *op) |
1826 | |
1845 | |
1827 | int cf_object_get_resistance (object *op, int rtype) |
1846 | int resistance (object *op, int rtype, int newval = 0) |
1828 | ALIAS: resistance = 0 |
1847 | CODE: |
|
|
1848 | if (rtype < 0 || rtype >= NROFATTACKS) |
|
|
1849 | croak ("resistance out of bounds"); |
|
|
1850 | RETVAL = op->resist [rtype]; |
|
|
1851 | if (items >= 3) |
|
|
1852 | op->resist [rtype] = newval; |
|
|
1853 | OUTPUT: RETVAL |
|
|
1854 | |
|
|
1855 | void set_resistance (object *op, int rtype, int val) |
|
|
1856 | CODE: |
|
|
1857 | if (rtype < 0 || rtype >= NROFATTACKS) |
|
|
1858 | op->resist[rtype] = val; |
1829 | |
1859 | |
1830 | int need_identify (const object *obj); |
1860 | int need_identify (const object *obj); |
1831 | |
1861 | |
1832 | int apply_shop_mat (object *shop_mat, object *op); |
1862 | int apply_shop_mat (object *shop_mat, object *op); |
1833 | |
1863 | |
… | |
… | |
1835 | CODE: |
1865 | CODE: |
1836 | RETVAL = move_ob (op, dir, originator); |
1866 | RETVAL = move_ob (op, dir, originator); |
1837 | OUTPUT: |
1867 | OUTPUT: |
1838 | RETVAL |
1868 | RETVAL |
1839 | |
1869 | |
1840 | void cf_object_apply (object *op, object *author, int flags = 0) |
1870 | void apply (object *applier, object *applied, int flags = 0) |
|
|
1871 | CODE: |
|
|
1872 | manual_apply (applied, applier, flags); |
1841 | |
1873 | |
1842 | void cf_object_apply_below (object *op) |
1874 | void apply_below (object *op) |
|
|
1875 | CODE: |
|
|
1876 | player_apply_below (op); |
1843 | |
1877 | |
1844 | void cf_object_remove (object *op) |
1878 | void remove (object *op) |
|
|
1879 | CODE: |
|
|
1880 | op->remove (); |
1845 | |
1881 | |
1846 | void cf_object_free (object *op) |
1882 | void destroy (object *op, int recursive = 0) |
|
|
1883 | CODE: |
|
|
1884 | op->destroy (recursive); |
1847 | |
1885 | |
1848 | object *cf_object_present_archname_inside (object *op, char *whatstr) |
1886 | object *cf_object_present_archname_inside (object *op, char *whatstr) |
1849 | |
1887 | |
1850 | int cf_object_transfer (object *op, int x, int y, int r = 0, object_ornull *orig = 0) |
1888 | int cf_object_transfer (object *op, int x, int y, int r = 0, object_ornull *orig = 0) |
1851 | |
1889 | |
1852 | int cf_object_change_map (object *op, int x, int y, maptile *map) |
1890 | int cf_object_change_map (object *op, int x, int y, maptile *map) |
1853 | |
1891 | |
1854 | object *cf_object_clone (object *op, int clonetype = 0) |
1892 | object *clone (object *op, int recursive = 0) |
|
|
1893 | CODE: |
|
|
1894 | if (recursive) |
|
|
1895 | RETVAL = object_create_clone (op); |
|
|
1896 | else |
|
|
1897 | { |
|
|
1898 | RETVAL = object::create (); |
|
|
1899 | op->copy_to (RETVAL); |
|
|
1900 | } |
|
|
1901 | OUTPUT: RETVAL |
1855 | |
1902 | |
1856 | int cf_object_pay_item (object *op, object *buyer) |
1903 | int pay_item (object *op, object *buyer) |
|
|
1904 | CODE: |
|
|
1905 | RETVAL = pay_for_item (op, buyer); |
|
|
1906 | OUTPUT: RETVAL |
1857 | |
1907 | |
1858 | int cf_object_pay_amount (object *op, uint64 amount) |
1908 | int pay_amount (object *op, uint64 amount) |
|
|
1909 | CODE: |
|
|
1910 | RETVAL = pay_for_amount (amount, op); |
|
|
1911 | OUTPUT: RETVAL |
1859 | |
1912 | |
1860 | void pay_player (object *op, uint64 amount) |
1913 | void pay_player (object *op, uint64 amount) |
1861 | |
1914 | |
1862 | val64 pay_player_arch (object *op, const char *arch, uint64 amount) |
1915 | val64 pay_player_arch (object *op, const char *arch, uint64 amount) |
1863 | |
1916 | |
1864 | int cf_object_cast_spell (object *caster, object *ctoo, int dir, object *spell_ob, char *stringarg = 0) |
1917 | int cast_spell (object *op, object *caster, int dir, object *spell_ob, char *stringarg = 0) |
1865 | |
1918 | |
1866 | int cf_object_cast_ability (object *caster, object *ctoo, int dir, object *sp_, char *stringarg = 0) |
1919 | void learn_spell (object *op, object *sp, int special_prayer = 0) |
|
|
1920 | CODE: |
|
|
1921 | do_learn_spell (op, sp, special_prayer); |
1867 | |
1922 | |
1868 | void cf_object_learn_spell (object *op, object *sp) |
|
|
1869 | |
|
|
1870 | void cf_object_forget_spell (object *op, object *sp) |
1923 | void forget_spell (object *op, object *sp) |
|
|
1924 | CODE: |
|
|
1925 | do_forget_spell (op, query_name (sp)); |
1871 | |
1926 | |
1872 | object *cf_object_check_for_spell (object *op, char *spellname) |
1927 | object *check_for_spell (object *op, char *spellname) |
|
|
1928 | CODE: |
|
|
1929 | RETVAL = check_spell_known (op, spellname); |
|
|
1930 | OUTPUT: RETVAL |
1873 | |
1931 | |
1874 | int cf_object_query_money (object *op) |
1932 | int query_money (object *op) |
1875 | ALIAS: money = 0 |
1933 | ALIAS: money = 0 |
1876 | |
1934 | |
1877 | int cf_object_query_cost (object *op, object *who, int flags) |
1935 | int query_cost (object *op, object *who, int flags) |
1878 | ALIAS: cost = 0 |
1936 | ALIAS: cost = 0 |
1879 | |
1937 | |
1880 | void cf_object_activate_rune (object *op , object *victim) |
1938 | void spring_trap (object *op, object *victim) |
1881 | |
1939 | |
1882 | int cf_object_check_trigger (object *op, object *cause) |
1940 | int check_trigger (object *op, object *cause) |
1883 | |
1941 | |
1884 | int cf_object_out_of_map (object *op, int x, int y) |
|
|
1885 | |
|
|
1886 | void cf_object_drop (object *op, object *author) |
1942 | void drop (object *who, object *op) |
1887 | |
1943 | |
1888 | void cf_object_take (object *op, object *author) |
1944 | void pick_up (object *who, object *op) |
1889 | |
1945 | |
1890 | object *cf_object_insert_object (object *op, object *container) |
1946 | object *cf_object_insert_object (object *op, object *container) |
1891 | |
1947 | |
1892 | object *cf_object_insert_in_ob (object *ob, object *where) |
1948 | object *cf_object_insert_in_ob (object *ob, object *where) |
1893 | |
1949 | |
1894 | int cf_object_teleport (object *op, maptile *map, int x, int y) |
1950 | int cf_object_teleport (object *op, maptile *map, int x, int y) |
1895 | |
1951 | |
1896 | void cf_object_update (object *op, int flags) |
1952 | void update (object *op, int action) |
1897 | |
1953 | CODE: |
1898 | void cf_object_pickup (object *op, object *what) |
1954 | update_object (op, action); |
1899 | |
1955 | |
1900 | object *cf_create_object_by_name (const char *name) |
1956 | object *cf_create_object_by_name (const char *name) |
1901 | |
1957 | |
1902 | void change_exp (object *op, uint64 exp, const char *skill_name = 0, int flag = 0) |
1958 | void change_exp (object *op, uint64 exp, const char *skill_name = 0, int flag = 0) |
1903 | |
1959 | |
… | |
… | |
1912 | void use_trigger (object *op); |
1968 | void use_trigger (object *op); |
1913 | |
1969 | |
1914 | void add_button_link (object *button, maptile *map, int connected); |
1970 | void add_button_link (object *button, maptile *map, int connected); |
1915 | |
1971 | |
1916 | void remove_button_link (object *op); |
1972 | void remove_button_link (object *op); |
1917 | |
|
|
1918 | void |
|
|
1919 | cf_object_set_resistance (object *op, int rtype, int val) |
|
|
1920 | CODE: |
|
|
1921 | if (rtype >= 0 && rtype < NROFATTACKS) |
|
|
1922 | op->resist[rtype] = val; |
|
|
1923 | |
1973 | |
1924 | |
1974 | |
1925 | MODULE = cf PACKAGE = cf::object PREFIX = cf_ |
1975 | MODULE = cf PACKAGE = cf::object PREFIX = cf_ |
1926 | |
1976 | |
1927 | void cf_fix_object (object *pl) |
1977 | void cf_fix_object (object *pl) |
… | |
… | |
2037 | int command_banish (object *op, char *params) |
2087 | int command_banish (object *op, char *params) |
2038 | |
2088 | |
2039 | |
2089 | |
2040 | MODULE = cf PACKAGE = cf::player PREFIX = cf_player_ |
2090 | MODULE = cf PACKAGE = cf::player PREFIX = cf_player_ |
2041 | |
2091 | |
2042 | INCLUDE: $PERL genacc player ../include/newserver.h ../include/player.h | |
2092 | INCLUDE: $PERL genacc player ../include/player.h | |
2043 | |
|
|
2044 | char * |
|
|
2045 | client (player *pl) |
|
|
2046 | CODE: |
|
|
2047 | RETVAL = pl->socket.client; |
|
|
2048 | OUTPUT: |
|
|
2049 | RETVAL |
|
|
2050 | |
|
|
2051 | char * |
|
|
2052 | host (player *pl) |
|
|
2053 | CODE: |
|
|
2054 | RETVAL = pl->socket.host; |
|
|
2055 | OUTPUT: |
|
|
2056 | RETVAL |
|
|
2057 | |
2093 | |
2058 | int invoke (player *pl, int event, ...) |
2094 | int invoke (player *pl, int event, ...) |
2059 | CODE: |
2095 | CODE: |
2060 | if (KLASS_OF (event) != KLASS_PLAYER) croak ("event class must be PLAYER"); |
2096 | if (KLASS_OF (event) != KLASS_PLAYER) croak ("event class must be PLAYER"); |
2061 | AV *av = (AV *)sv_2mortal ((SV *)newAV ()); |
2097 | AV *av = (AV *)sv_2mortal ((SV *)newAV ()); |
2062 | for (int i = 2; i < items; i++) av_push (av, SvREFCNT_inc (ST (i))); |
2098 | for (int i = 2; i < items; i++) av_push (av, SvREFCNT_inc (ST (i))); |
2063 | RETVAL = INVOKE_((event_type)event, ARG_PLAYER (pl), ARG_AV (av)); |
2099 | RETVAL = INVOKE_((event_type)event, ARG_PLAYER (pl), ARG_AV (av)); |
2064 | OUTPUT: RETVAL |
2100 | OUTPUT: RETVAL |
2065 | |
2101 | |
2066 | SV *registry (player *pl) |
2102 | SV *registry (player *pl) |
|
|
2103 | |
|
|
2104 | player *cf_player_find (char *name) |
|
|
2105 | PROTOTYPE: $ |
|
|
2106 | |
|
|
2107 | void cf_player_move (player *pl, int dir) |
|
|
2108 | |
|
|
2109 | void play_sound_player_only (player *pl, int soundnum, int x = 0, int y = 0); |
|
|
2110 | |
|
|
2111 | player *first () |
2067 | CODE: |
2112 | CODE: |
2068 | RETVAL = registry_of (pl); |
2113 | RETVAL = first_player; |
|
|
2114 | OUTPUT: RETVAL |
|
|
2115 | |
|
|
2116 | player *next (player *pl) |
|
|
2117 | CODE: |
|
|
2118 | RETVAL = pl->next; |
|
|
2119 | OUTPUT: RETVAL |
|
|
2120 | |
|
|
2121 | bool |
|
|
2122 | cell_visible (player *pl, int dx, int dy) |
|
|
2123 | CODE: |
|
|
2124 | RETVAL = FABS (dx) <= pl->socket->mapx / 2 && FABS (dy) <= pl->socket->mapy / 2 |
|
|
2125 | && !pl->blocked_los [dx + pl->socket->mapx / 2][dy + pl->socket->mapy / 2]; |
2069 | OUTPUT: |
2126 | OUTPUT: |
2070 | RETVAL |
2127 | RETVAL |
2071 | |
2128 | |
2072 | player *cf_player_find (char *name) |
|
|
2073 | PROTOTYPE: $ |
|
|
2074 | |
|
|
2075 | void cf_player_move (player *pl, int dir) |
|
|
2076 | |
|
|
2077 | void play_sound_player_only (player *pl, int soundnum, int x = 0, int y = 0); |
|
|
2078 | |
|
|
2079 | player *first () |
|
|
2080 | CODE: |
|
|
2081 | RETVAL = first_player; |
|
|
2082 | OUTPUT: RETVAL |
|
|
2083 | |
|
|
2084 | player *next (player *pl) |
|
|
2085 | CODE: |
|
|
2086 | RETVAL = pl->next; |
|
|
2087 | OUTPUT: RETVAL |
|
|
2088 | |
|
|
2089 | bool |
|
|
2090 | cell_visible (player *pl, int dx, int dy) |
|
|
2091 | CODE: |
|
|
2092 | RETVAL = FABS (dx) <= pl->socket.mapx / 2 && FABS (dy) <= pl->socket.mapy / 2 |
|
|
2093 | && !pl->blocked_los [dx + pl->socket.mapx / 2][dy + pl->socket.mapy / 2]; |
|
|
2094 | OUTPUT: |
|
|
2095 | RETVAL |
|
|
2096 | |
|
|
2097 | void |
|
|
2098 | buggy_mapscroll (player *pl, int value = 1) |
|
|
2099 | CODE: |
|
|
2100 | pl->socket.buggy_mapscroll = value; |
|
|
2101 | |
|
|
2102 | void |
2129 | void |
2103 | send (player *pl, SV *packet) |
2130 | send (player *pl, SV *packet) |
2104 | CODE: |
2131 | CODE: |
2105 | { |
2132 | { |
2106 | STRLEN len; |
2133 | STRLEN len; |
2107 | char *buf = SvPVbyte (packet, len); |
2134 | char *buf = SvPVbyte (packet, len); |
2108 | |
2135 | |
2109 | Write_String_To_Socket (&pl->socket, buf, len); |
2136 | pl->socket->send_packet (buf, len); |
2110 | } |
2137 | } |
2111 | |
2138 | |
2112 | int |
2139 | int |
2113 | listening (player *pl, int new_value = -1) |
2140 | listening (player *pl, int new_value = -1) |
2114 | CODE: |
2141 | CODE: |
… | |
… | |
2179 | for (int i = 2; i < items; i++) av_push (av, SvREFCNT_inc (ST (i))); |
2206 | for (int i = 2; i < items; i++) av_push (av, SvREFCNT_inc (ST (i))); |
2180 | RETVAL = INVOKE_((event_type)event, ARG_MAP (map), ARG_AV (av)); |
2207 | RETVAL = INVOKE_((event_type)event, ARG_MAP (map), ARG_AV (av)); |
2181 | OUTPUT: RETVAL |
2208 | OUTPUT: RETVAL |
2182 | |
2209 | |
2183 | SV *registry (maptile *map) |
2210 | SV *registry (maptile *map) |
2184 | CODE: |
|
|
2185 | RETVAL = registry_of (map); |
|
|
2186 | OUTPUT: |
|
|
2187 | RETVAL |
|
|
2188 | |
2211 | |
2189 | INCLUDE: $PERL genacc maptile ../include/map.h | |
2212 | INCLUDE: $PERL genacc maptile ../include/map.h | |
2190 | |
2213 | |
2191 | maptile *new (int width, int height) |
2214 | maptile *new (int width, int height) |
2192 | PROTOTYPE: |
2215 | PROTOTYPE: |
… | |
… | |
2200 | void delete_map (maptile *map) |
2223 | void delete_map (maptile *map) |
2201 | |
2224 | |
2202 | void clean_tmp_map (maptile *map) |
2225 | void clean_tmp_map (maptile *map) |
2203 | |
2226 | |
2204 | void play_sound_map (maptile *map, int x, int y, int sound_num) |
2227 | void play_sound_map (maptile *map, int x, int y, int sound_num) |
|
|
2228 | |
|
|
2229 | int out_of_map (maptile *map, int x, int y) |
2205 | |
2230 | |
2206 | maptile *tile_map (maptile *map, unsigned int dir) |
2231 | maptile *tile_map (maptile *map, unsigned int dir) |
2207 | CODE: |
2232 | CODE: |
2208 | RETVAL = dir < 4 ? map->tile_map [dir] : 0; |
2233 | RETVAL = dir < 4 ? map->tile_map [dir] : 0; |
2209 | OUTPUT: |
2234 | OUTPUT: |
… | |
… | |
2393 | |
2418 | |
2394 | MODULE = cf PACKAGE = cf::living |
2419 | MODULE = cf PACKAGE = cf::living |
2395 | |
2420 | |
2396 | INCLUDE: $PERL genacc living ../include/living.h | |
2421 | INCLUDE: $PERL genacc living ../include/living.h | |
2397 | |
2422 | |
|
|
2423 | MODULE = cf PACKAGE = cf::settings |
|
|
2424 | |
|
|
2425 | INCLUDE: $PERL genacc Settings ../include/global.h | |
|
|
2426 | |
|
|
2427 | MODULE = cf PACKAGE = cf::client_socket |
|
|
2428 | |
|
|
2429 | INCLUDE: $PERL genacc client_socket ../include/newserver.h | |
|
|
2430 | |
|
|
2431 | int invoke (client_socket *ns, int event, ...) |
|
|
2432 | CODE: |
|
|
2433 | if (KLASS_OF (event) != KLASS_SOCKET) croak ("event class must be SOCKET"); |
|
|
2434 | AV *av = (AV *)sv_2mortal ((SV *)newAV ()); |
|
|
2435 | for (int i = 2; i < items; i++) av_push (av, SvREFCNT_inc (ST (i))); |
|
|
2436 | RETVAL = INVOKE_((event_type)event, ARG_SOCKET (ns), ARG_AV (av)); |
|
|
2437 | OUTPUT: RETVAL |
|
|
2438 | |
|
|
2439 | SV *registry (client_socket *ns) |
|
|
2440 | |