… | |
… | |
977 | { |
977 | { |
978 | CALL_BEGIN (1); |
978 | CALL_BEGIN (1); |
979 | CALL_ARG (name); |
979 | CALL_ARG (name); |
980 | CALL_CALL ("cf::player::find", G_SCALAR); |
980 | CALL_CALL ("cf::player::find", G_SCALAR); |
981 | |
981 | |
982 | player *retval; |
982 | player *retval = 0; |
983 | |
|
|
984 | if (count) |
|
|
985 | sv_to (POPs, retval); |
983 | if (count) sv_to (POPs, retval); |
986 | else |
984 | |
987 | retval = 0; |
985 | CALL_END; |
|
|
986 | |
|
|
987 | return retval; |
|
|
988 | } |
|
|
989 | |
|
|
990 | maptile * |
|
|
991 | find_style (const char *dirname, const char *stylename, int difficulty) |
|
|
992 | { |
|
|
993 | CALL_BEGIN (3); |
|
|
994 | CALL_ARG (dirname); |
|
|
995 | CALL_ARG (stylename); |
|
|
996 | CALL_ARG (difficulty); |
|
|
997 | CALL_CALL ("ext::map_random::find_style", G_SCALAR); |
|
|
998 | |
|
|
999 | maptile *retval = 0; |
|
|
1000 | if (count) sv_to (POPs, retval); |
988 | |
1001 | |
989 | CALL_END; |
1002 | CALL_END; |
990 | |
1003 | |
991 | return retval; |
1004 | return retval; |
992 | } |
1005 | } |
… | |
… | |
997 | CALL_BEGIN (2); |
1010 | CALL_BEGIN (2); |
998 | CALL_ARG (path); |
1011 | CALL_ARG (path); |
999 | CALL_ARG (origin); |
1012 | CALL_ARG (origin); |
1000 | CALL_CALL ("cf::map::find_sync", G_SCALAR); |
1013 | CALL_CALL ("cf::map::find_sync", G_SCALAR); |
1001 | |
1014 | |
1002 | maptile *retval; |
1015 | maptile *retval = 0; |
1003 | |
|
|
1004 | if (count) |
|
|
1005 | sv_to (POPs, retval); |
1016 | if (count) sv_to (POPs, retval); |
1006 | else |
|
|
1007 | retval = 0; |
|
|
1008 | |
1017 | |
1009 | CALL_END; |
1018 | CALL_END; |
1010 | |
1019 | |
1011 | return retval; |
1020 | return retval; |
1012 | } |
1021 | } |
… | |
… | |
1018 | CALL_ARG (path); |
1027 | CALL_ARG (path); |
1019 | CALL_ARG (origin); |
1028 | CALL_ARG (origin); |
1020 | CALL_ARG (load); |
1029 | CALL_ARG (load); |
1021 | CALL_CALL ("cf::map::find_async", G_SCALAR); |
1030 | CALL_CALL ("cf::map::find_async", G_SCALAR); |
1022 | |
1031 | |
1023 | maptile *retval; |
1032 | maptile *retval = 0; |
1024 | |
|
|
1025 | if (count) |
|
|
1026 | sv_to (POPs, retval); |
1033 | if (count) sv_to (POPs, retval); |
1027 | else |
|
|
1028 | retval = 0; |
|
|
1029 | |
1034 | |
1030 | CALL_END; |
1035 | CALL_END; |
1031 | |
1036 | |
1032 | return retval; |
1037 | return retval; |
1033 | } |
1038 | } |
… | |
… | |
1573 | NV floor (NV x) |
1578 | NV floor (NV x) |
1574 | |
1579 | |
1575 | NV ceil (NV x) |
1580 | NV ceil (NV x) |
1576 | |
1581 | |
1577 | NV rndm (...) |
1582 | NV rndm (...) |
|
|
1583 | ALIAS: |
|
|
1584 | rmg_rndm = 1 |
1578 | CODE: |
1585 | CODE: |
|
|
1586 | { |
|
|
1587 | rand_gen &gen = ix ? rmg_rndm : rndm; |
1579 | switch (items) |
1588 | switch (items) |
1580 | { |
1589 | { |
1581 | case 0: RETVAL = rndm (); break; |
1590 | case 0: RETVAL = gen (); break; |
1582 | case 1: RETVAL = rndm (SvUV (ST (0))); break; |
1591 | case 1: RETVAL = gen (SvUV (ST (0))); break; |
1583 | case 2: RETVAL = rndm (SvIV (ST (0)), SvIV (ST (1))); break; |
1592 | case 2: RETVAL = gen (SvIV (ST (0)), SvIV (ST (1))); break; |
1584 | default: croak ("cf::rndm requires none, one or two parameters."); break; |
1593 | default: croak ("cf::rndm requires none, one or two parameters."); break; |
1585 | } |
1594 | } |
|
|
1595 | } |
1586 | OUTPUT: |
1596 | OUTPUT: |
1587 | RETVAL |
1597 | RETVAL |
1588 | |
1598 | |
1589 | NV clamp (NV value, NV min_value, NV max_value) |
1599 | NV clamp (NV value, NV min_value, NV max_value) |
1590 | CODE: |
1600 | CODE: |