summaryrefslogtreecommitdiff
path: root/servergreps/hercules/20141016/src/char.c
diff options
context:
space:
mode:
Diffstat (limited to 'servergreps/hercules/20141016/src/char.c')
-rw-r--r--servergreps/hercules/20141016/src/char.c16364
1 files changed, 0 insertions, 16364 deletions
diff --git a/servergreps/hercules/20141016/src/char.c b/servergreps/hercules/20141016/src/char.c
deleted file mode 100644
index cde0244..0000000
--- a/servergreps/hercules/20141016/src/char.c
+++ /dev/null
@@ -1,16364 +0,0 @@
-# 1 "../../../server-code/src/char/char.c"
-# 1 "<built-in>"
-# 1 "<command-line>"
-# 1 "/usr/include/stdc-predef.h" 1 3 4
-# 1 "<command-line>" 2
-# 1 "../../../server-code/src/char/char.c"
-# 23 "../../../server-code/src/char/char.c"
-# 1 "../../../server-code/src/config/core.h" 1
-# 90 "../../../server-code/src/config/core.h"
-# 1 "../../../server-code/src/config/./renewal.h" 1
-# 91 "../../../server-code/src/config/core.h" 2
-# 1 "../../../server-code/src/config/./secure.h" 1
-# 92 "../../../server-code/src/config/core.h" 2
-# 1 "../../../server-code/src/config/./classes/general.h" 1
-# 93 "../../../server-code/src/config/core.h" 2
-
-
-
-
-# 1 "../../../server-code/src/config/./const.h" 1
-# 62 "../../../server-code/src/config/./const.h"
- typedef short defType;
-# 98 "../../../server-code/src/config/core.h" 2
-# 24 "../../../server-code/src/char/char.c" 2
-# 1 "../../../server-code/src/char/char.h" 1
-# 24 "../../../server-code/src/char/char.h"
-# 1 "../../../server-code/src/common/hercules.h" 1
-# 24 "../../../server-code/src/common/hercules.h"
-# 1 "../../../server-code/src/common/cbasetypes.h" 1
-# 116 "../../../server-code/src/common/cbasetypes.h"
-# 1 "/usr/include/inttypes.h" 1 3 4
-# 25 "/usr/include/inttypes.h" 3 4
-# 1 "/usr/include/features.h" 1 3 4
-# 361 "/usr/include/features.h" 3 4
-# 1 "/usr/include/x86_64-linux-gnu/sys/cdefs.h" 1 3 4
-# 410 "/usr/include/x86_64-linux-gnu/sys/cdefs.h" 3 4
-# 1 "/usr/include/x86_64-linux-gnu/bits/wordsize.h" 1 3 4
-# 411 "/usr/include/x86_64-linux-gnu/sys/cdefs.h" 2 3 4
-# 362 "/usr/include/features.h" 2 3 4
-# 385 "/usr/include/features.h" 3 4
-# 1 "/usr/include/x86_64-linux-gnu/gnu/stubs.h" 1 3 4
-# 10 "/usr/include/x86_64-linux-gnu/gnu/stubs.h" 3 4
-# 1 "/usr/include/x86_64-linux-gnu/gnu/stubs-64.h" 1 3 4
-# 11 "/usr/include/x86_64-linux-gnu/gnu/stubs.h" 2 3 4
-# 386 "/usr/include/features.h" 2 3 4
-# 26 "/usr/include/inttypes.h" 2 3 4
-
-# 1 "/usr/lib/gcc/x86_64-linux-gnu/5/include/stdint.h" 1 3 4
-# 9 "/usr/lib/gcc/x86_64-linux-gnu/5/include/stdint.h" 3 4
-# 1 "/usr/include/stdint.h" 1 3 4
-# 26 "/usr/include/stdint.h" 3 4
-# 1 "/usr/include/x86_64-linux-gnu/bits/wchar.h" 1 3 4
-# 27 "/usr/include/stdint.h" 2 3 4
-# 1 "/usr/include/x86_64-linux-gnu/bits/wordsize.h" 1 3 4
-# 28 "/usr/include/stdint.h" 2 3 4
-# 36 "/usr/include/stdint.h" 3 4
-
-# 36 "/usr/include/stdint.h" 3 4
-typedef signed char int8_t;
-typedef short int int16_t;
-typedef int int32_t;
-
-typedef long int int64_t;
-
-
-
-
-
-
-
-typedef unsigned char uint8_t;
-typedef unsigned short int uint16_t;
-
-typedef unsigned int uint32_t;
-
-
-
-typedef unsigned long int uint64_t;
-# 65 "/usr/include/stdint.h" 3 4
-typedef signed char int_least8_t;
-typedef short int int_least16_t;
-typedef int int_least32_t;
-
-typedef long int int_least64_t;
-
-
-
-
-
-
-typedef unsigned char uint_least8_t;
-typedef unsigned short int uint_least16_t;
-typedef unsigned int uint_least32_t;
-
-typedef unsigned long int uint_least64_t;
-# 90 "/usr/include/stdint.h" 3 4
-typedef signed char int_fast8_t;
-
-typedef long int int_fast16_t;
-typedef long int int_fast32_t;
-typedef long int int_fast64_t;
-# 103 "/usr/include/stdint.h" 3 4
-typedef unsigned char uint_fast8_t;
-
-typedef unsigned long int uint_fast16_t;
-typedef unsigned long int uint_fast32_t;
-typedef unsigned long int uint_fast64_t;
-# 119 "/usr/include/stdint.h" 3 4
-typedef long int intptr_t;
-
-
-typedef unsigned long int uintptr_t;
-# 134 "/usr/include/stdint.h" 3 4
-typedef long int intmax_t;
-typedef unsigned long int uintmax_t;
-# 10 "/usr/lib/gcc/x86_64-linux-gnu/5/include/stdint.h" 2 3 4
-# 28 "/usr/include/inttypes.h" 2 3 4
-
-
-
-
-
-
-typedef int __gwchar_t;
-# 266 "/usr/include/inttypes.h" 3 4
-
-
-
-
-
-typedef struct
- {
- long int quot;
- long int rem;
- } imaxdiv_t;
-# 290 "/usr/include/inttypes.h" 3 4
-extern intmax_t imaxabs (intmax_t __n) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__const__));
-
-
-extern imaxdiv_t imaxdiv (intmax_t __numer, intmax_t __denom)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__const__));
-
-
-extern intmax_t strtoimax (const char *__restrict __nptr,
- char **__restrict __endptr, int __base) __attribute__ ((__nothrow__ , __leaf__));
-
-
-extern uintmax_t strtoumax (const char *__restrict __nptr,
- char ** __restrict __endptr, int __base) __attribute__ ((__nothrow__ , __leaf__));
-
-
-extern intmax_t wcstoimax (const __gwchar_t *__restrict __nptr,
- __gwchar_t **__restrict __endptr, int __base)
- __attribute__ ((__nothrow__ , __leaf__));
-
-
-extern uintmax_t wcstoumax (const __gwchar_t *__restrict __nptr,
- __gwchar_t ** __restrict __endptr, int __base)
- __attribute__ ((__nothrow__ , __leaf__));
-# 432 "/usr/include/inttypes.h" 3 4
-
-# 117 "../../../server-code/src/common/cbasetypes.h" 2
-
-# 1 "/usr/lib/gcc/x86_64-linux-gnu/5/include-fixed/limits.h" 1 3 4
-# 34 "/usr/lib/gcc/x86_64-linux-gnu/5/include-fixed/limits.h" 3 4
-# 1 "/usr/lib/gcc/x86_64-linux-gnu/5/include-fixed/syslimits.h" 1 3 4
-
-
-
-
-
-
-# 1 "/usr/lib/gcc/x86_64-linux-gnu/5/include-fixed/limits.h" 1 3 4
-# 168 "/usr/lib/gcc/x86_64-linux-gnu/5/include-fixed/limits.h" 3 4
-# 1 "/usr/include/limits.h" 1 3 4
-# 143 "/usr/include/limits.h" 3 4
-# 1 "/usr/include/x86_64-linux-gnu/bits/posix1_lim.h" 1 3 4
-# 160 "/usr/include/x86_64-linux-gnu/bits/posix1_lim.h" 3 4
-# 1 "/usr/include/x86_64-linux-gnu/bits/local_lim.h" 1 3 4
-# 38 "/usr/include/x86_64-linux-gnu/bits/local_lim.h" 3 4
-# 1 "/usr/include/linux/limits.h" 1 3 4
-# 39 "/usr/include/x86_64-linux-gnu/bits/local_lim.h" 2 3 4
-# 161 "/usr/include/x86_64-linux-gnu/bits/posix1_lim.h" 2 3 4
-# 144 "/usr/include/limits.h" 2 3 4
-
-
-
-# 1 "/usr/include/x86_64-linux-gnu/bits/posix2_lim.h" 1 3 4
-# 148 "/usr/include/limits.h" 2 3 4
-# 169 "/usr/lib/gcc/x86_64-linux-gnu/5/include-fixed/limits.h" 2 3 4
-# 8 "/usr/lib/gcc/x86_64-linux-gnu/5/include-fixed/syslimits.h" 2 3 4
-# 35 "/usr/lib/gcc/x86_64-linux-gnu/5/include-fixed/limits.h" 2 3 4
-# 119 "../../../server-code/src/common/cbasetypes.h" 2
-# 1 "/usr/include/time.h" 1 3 4
-# 29 "/usr/include/time.h" 3 4
-
-
-
-
-
-
-
-
-# 1 "/usr/lib/gcc/x86_64-linux-gnu/5/include/stddef.h" 1 3 4
-# 216 "/usr/lib/gcc/x86_64-linux-gnu/5/include/stddef.h" 3 4
-typedef long unsigned int size_t;
-# 38 "/usr/include/time.h" 2 3 4
-
-
-
-# 1 "/usr/include/x86_64-linux-gnu/bits/time.h" 1 3 4
-# 42 "/usr/include/time.h" 2 3 4
-# 55 "/usr/include/time.h" 3 4
-# 1 "/usr/include/x86_64-linux-gnu/bits/types.h" 1 3 4
-# 27 "/usr/include/x86_64-linux-gnu/bits/types.h" 3 4
-# 1 "/usr/include/x86_64-linux-gnu/bits/wordsize.h" 1 3 4
-# 28 "/usr/include/x86_64-linux-gnu/bits/types.h" 2 3 4
-
-
-typedef unsigned char __u_char;
-typedef unsigned short int __u_short;
-typedef unsigned int __u_int;
-typedef unsigned long int __u_long;
-
-
-typedef signed char __int8_t;
-typedef unsigned char __uint8_t;
-typedef signed short int __int16_t;
-typedef unsigned short int __uint16_t;
-typedef signed int __int32_t;
-typedef unsigned int __uint32_t;
-
-typedef signed long int __int64_t;
-typedef unsigned long int __uint64_t;
-
-
-
-
-
-
-
-typedef long int __quad_t;
-typedef unsigned long int __u_quad_t;
-# 121 "/usr/include/x86_64-linux-gnu/bits/types.h" 3 4
-# 1 "/usr/include/x86_64-linux-gnu/bits/typesizes.h" 1 3 4
-# 122 "/usr/include/x86_64-linux-gnu/bits/types.h" 2 3 4
-
-
-typedef unsigned long int __dev_t;
-typedef unsigned int __uid_t;
-typedef unsigned int __gid_t;
-typedef unsigned long int __ino_t;
-typedef unsigned long int __ino64_t;
-typedef unsigned int __mode_t;
-typedef unsigned long int __nlink_t;
-typedef long int __off_t;
-typedef long int __off64_t;
-typedef int __pid_t;
-typedef struct { int __val[2]; } __fsid_t;
-typedef long int __clock_t;
-typedef unsigned long int __rlim_t;
-typedef unsigned long int __rlim64_t;
-typedef unsigned int __id_t;
-typedef long int __time_t;
-typedef unsigned int __useconds_t;
-typedef long int __suseconds_t;
-
-typedef int __daddr_t;
-typedef int __key_t;
-
-
-typedef int __clockid_t;
-
-
-typedef void * __timer_t;
-
-
-typedef long int __blksize_t;
-
-
-
-
-typedef long int __blkcnt_t;
-typedef long int __blkcnt64_t;
-
-
-typedef unsigned long int __fsblkcnt_t;
-typedef unsigned long int __fsblkcnt64_t;
-
-
-typedef unsigned long int __fsfilcnt_t;
-typedef unsigned long int __fsfilcnt64_t;
-
-
-typedef long int __fsword_t;
-
-typedef long int __ssize_t;
-
-
-typedef long int __syscall_slong_t;
-
-typedef unsigned long int __syscall_ulong_t;
-
-
-
-typedef __off64_t __loff_t;
-typedef __quad_t *__qaddr_t;
-typedef char *__caddr_t;
-
-
-typedef long int __intptr_t;
-
-
-typedef unsigned int __socklen_t;
-# 56 "/usr/include/time.h" 2 3 4
-
-
-
-typedef __clock_t clock_t;
-
-
-
-# 73 "/usr/include/time.h" 3 4
-
-
-typedef __time_t time_t;
-
-
-
-# 91 "/usr/include/time.h" 3 4
-typedef __clockid_t clockid_t;
-# 103 "/usr/include/time.h" 3 4
-typedef __timer_t timer_t;
-# 120 "/usr/include/time.h" 3 4
-struct timespec
- {
- __time_t tv_sec;
- __syscall_slong_t tv_nsec;
- };
-
-
-
-
-
-
-
-
-struct tm
-{
- int tm_sec;
- int tm_min;
- int tm_hour;
- int tm_mday;
- int tm_mon;
- int tm_year;
- int tm_wday;
- int tm_yday;
- int tm_isdst;
-
-
- long int tm_gmtoff;
- const char *tm_zone;
-
-
-
-
-};
-
-
-
-
-
-
-
-
-struct itimerspec
- {
- struct timespec it_interval;
- struct timespec it_value;
- };
-
-
-struct sigevent;
-
-
-
-
-
-typedef __pid_t pid_t;
-# 186 "/usr/include/time.h" 3 4
-
-
-
-extern clock_t clock (void) __attribute__ ((__nothrow__ , __leaf__));
-
-
-extern time_t time (time_t *__timer) __attribute__ ((__nothrow__ , __leaf__));
-
-
-extern double difftime (time_t __time1, time_t __time0)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__const__));
-
-
-extern time_t mktime (struct tm *__tp) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-
-extern size_t strftime (char *__restrict __s, size_t __maxsize,
- const char *__restrict __format,
- const struct tm *__restrict __tp) __attribute__ ((__nothrow__ , __leaf__));
-
-# 221 "/usr/include/time.h" 3 4
-# 1 "/usr/include/xlocale.h" 1 3 4
-# 27 "/usr/include/xlocale.h" 3 4
-typedef struct __locale_struct
-{
-
- struct __locale_data *__locales[13];
-
-
- const unsigned short int *__ctype_b;
- const int *__ctype_tolower;
- const int *__ctype_toupper;
-
-
- const char *__names[13];
-} *__locale_t;
-
-
-typedef __locale_t locale_t;
-# 222 "/usr/include/time.h" 2 3 4
-
-extern size_t strftime_l (char *__restrict __s, size_t __maxsize,
- const char *__restrict __format,
- const struct tm *__restrict __tp,
- __locale_t __loc) __attribute__ ((__nothrow__ , __leaf__));
-# 236 "/usr/include/time.h" 3 4
-
-
-
-extern struct tm *gmtime (const time_t *__timer) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-extern struct tm *localtime (const time_t *__timer) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-
-extern struct tm *gmtime_r (const time_t *__restrict __timer,
- struct tm *__restrict __tp) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-extern struct tm *localtime_r (const time_t *__restrict __timer,
- struct tm *__restrict __tp) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-
-extern char *asctime (const struct tm *__tp) __attribute__ ((__nothrow__ , __leaf__));
-
-
-extern char *ctime (const time_t *__timer) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-
-
-
-extern char *asctime_r (const struct tm *__restrict __tp,
- char *__restrict __buf) __attribute__ ((__nothrow__ , __leaf__));
-
-
-extern char *ctime_r (const time_t *__restrict __timer,
- char *__restrict __buf) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-extern char *__tzname[2];
-extern int __daylight;
-extern long int __timezone;
-
-
-
-
-extern char *tzname[2];
-
-
-
-extern void tzset (void) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-extern int daylight;
-extern long int timezone;
-
-
-
-
-
-extern int stime (const time_t *__when) __attribute__ ((__nothrow__ , __leaf__));
-# 319 "/usr/include/time.h" 3 4
-extern time_t timegm (struct tm *__tp) __attribute__ ((__nothrow__ , __leaf__));
-
-
-extern time_t timelocal (struct tm *__tp) __attribute__ ((__nothrow__ , __leaf__));
-
-
-extern int dysize (int __year) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__const__));
-# 334 "/usr/include/time.h" 3 4
-extern int nanosleep (const struct timespec *__requested_time,
- struct timespec *__remaining);
-
-
-
-extern int clock_getres (clockid_t __clock_id, struct timespec *__res) __attribute__ ((__nothrow__ , __leaf__));
-
-
-extern int clock_gettime (clockid_t __clock_id, struct timespec *__tp) __attribute__ ((__nothrow__ , __leaf__));
-
-
-extern int clock_settime (clockid_t __clock_id, const struct timespec *__tp)
- __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-
-
-extern int clock_nanosleep (clockid_t __clock_id, int __flags,
- const struct timespec *__req,
- struct timespec *__rem);
-
-
-extern int clock_getcpuclockid (pid_t __pid, clockid_t *__clock_id) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-extern int timer_create (clockid_t __clock_id,
- struct sigevent *__restrict __evp,
- timer_t *__restrict __timerid) __attribute__ ((__nothrow__ , __leaf__));
-
-
-extern int timer_delete (timer_t __timerid) __attribute__ ((__nothrow__ , __leaf__));
-
-
-extern int timer_settime (timer_t __timerid, int __flags,
- const struct itimerspec *__restrict __value,
- struct itimerspec *__restrict __ovalue) __attribute__ ((__nothrow__ , __leaf__));
-
-
-extern int timer_gettime (timer_t __timerid, struct itimerspec *__value)
- __attribute__ ((__nothrow__ , __leaf__));
-
-
-extern int timer_getoverrun (timer_t __timerid) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-
-extern int timespec_get (struct timespec *__ts, int __base)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-# 430 "/usr/include/time.h" 3 4
-
-# 120 "../../../server-code/src/common/cbasetypes.h" 2
-# 140 "../../../server-code/src/common/cbasetypes.h"
-
-# 140 "../../../server-code/src/common/cbasetypes.h"
-typedef int8_t int8;
-typedef int16_t int16;
-typedef int32_t int32;
-typedef int64_t int64;
-
-typedef int8_t sint8;
-typedef int16_t sint16;
-typedef int32_t sint32;
-typedef int64_t sint64;
-
-typedef uint8_t uint8;
-typedef uint16_t uint16;
-typedef uint32_t uint32;
-typedef uint64_t uint64;
-# 196 "../../../server-code/src/common/cbasetypes.h"
-typedef long int ppint;
-typedef long int ppint8;
-typedef long int ppint16;
-typedef long int ppint32;
-
-typedef unsigned long int ppuint;
-typedef unsigned long int ppuint8;
-typedef unsigned long int ppuint16;
-typedef unsigned long int ppuint32;
-
-
-
-
-
-# 1 "/usr/lib/gcc/x86_64-linux-gnu/5/include/stddef.h" 1 3 4
-# 149 "/usr/lib/gcc/x86_64-linux-gnu/5/include/stddef.h" 3 4
-
-# 149 "/usr/lib/gcc/x86_64-linux-gnu/5/include/stddef.h" 3 4
-typedef long int ptrdiff_t;
-# 328 "/usr/lib/gcc/x86_64-linux-gnu/5/include/stddef.h" 3 4
-typedef int wchar_t;
-# 426 "/usr/lib/gcc/x86_64-linux-gnu/5/include/stddef.h" 3 4
-typedef struct {
- long long __max_align_ll __attribute__((__aligned__(__alignof__(long long))));
- long double __max_align_ld __attribute__((__aligned__(__alignof__(long double))));
-} max_align_t;
-# 211 "../../../server-code/src/common/cbasetypes.h" 2
-# 227 "../../../server-code/src/common/cbasetypes.h"
-
-# 227 "../../../server-code/src/common/cbasetypes.h"
-typedef intptr_t intptr;
-typedef uintptr_t uintptr;
-
-
-
-
-
-
-
- typedef int64 sysint;
- typedef uint64 usysint;
-# 305 "../../../server-code/src/common/cbasetypes.h"
-# 1 "/usr/lib/gcc/x86_64-linux-gnu/5/include/stdbool.h" 1 3 4
-# 306 "../../../server-code/src/common/cbasetypes.h" 2
-# 395 "../../../server-code/src/common/cbasetypes.h"
-# 1 "/usr/include/ctype.h" 1 3 4
-# 28 "/usr/include/ctype.h" 3 4
-
-# 39 "/usr/include/ctype.h" 3 4
-# 1 "/usr/include/endian.h" 1 3 4
-# 36 "/usr/include/endian.h" 3 4
-# 1 "/usr/include/x86_64-linux-gnu/bits/endian.h" 1 3 4
-# 37 "/usr/include/endian.h" 2 3 4
-# 60 "/usr/include/endian.h" 3 4
-# 1 "/usr/include/x86_64-linux-gnu/bits/byteswap.h" 1 3 4
-# 28 "/usr/include/x86_64-linux-gnu/bits/byteswap.h" 3 4
-# 1 "/usr/include/x86_64-linux-gnu/bits/wordsize.h" 1 3 4
-# 29 "/usr/include/x86_64-linux-gnu/bits/byteswap.h" 2 3 4
-
-
-
-
-
-
-# 1 "/usr/include/x86_64-linux-gnu/bits/byteswap-16.h" 1 3 4
-# 36 "/usr/include/x86_64-linux-gnu/bits/byteswap.h" 2 3 4
-# 44 "/usr/include/x86_64-linux-gnu/bits/byteswap.h" 3 4
-
-# 44 "/usr/include/x86_64-linux-gnu/bits/byteswap.h" 3 4
-static __inline unsigned int
-__bswap_32 (unsigned int __bsx)
-{
- return __builtin_bswap32 (__bsx);
-}
-# 108 "/usr/include/x86_64-linux-gnu/bits/byteswap.h" 3 4
-static __inline __uint64_t
-__bswap_64 (__uint64_t __bsx)
-{
- return __builtin_bswap64 (__bsx);
-}
-# 61 "/usr/include/endian.h" 2 3 4
-# 40 "/usr/include/ctype.h" 2 3 4
-
-
-
-
-
-
-enum
-{
- _ISupper = ((0) < 8 ? ((1 << (0)) << 8) : ((1 << (0)) >> 8)),
- _ISlower = ((1) < 8 ? ((1 << (1)) << 8) : ((1 << (1)) >> 8)),
- _ISalpha = ((2) < 8 ? ((1 << (2)) << 8) : ((1 << (2)) >> 8)),
- _ISdigit = ((3) < 8 ? ((1 << (3)) << 8) : ((1 << (3)) >> 8)),
- _ISxdigit = ((4) < 8 ? ((1 << (4)) << 8) : ((1 << (4)) >> 8)),
- _ISspace = ((5) < 8 ? ((1 << (5)) << 8) : ((1 << (5)) >> 8)),
- _ISprint = ((6) < 8 ? ((1 << (6)) << 8) : ((1 << (6)) >> 8)),
- _ISgraph = ((7) < 8 ? ((1 << (7)) << 8) : ((1 << (7)) >> 8)),
- _ISblank = ((8) < 8 ? ((1 << (8)) << 8) : ((1 << (8)) >> 8)),
- _IScntrl = ((9) < 8 ? ((1 << (9)) << 8) : ((1 << (9)) >> 8)),
- _ISpunct = ((10) < 8 ? ((1 << (10)) << 8) : ((1 << (10)) >> 8)),
- _ISalnum = ((11) < 8 ? ((1 << (11)) << 8) : ((1 << (11)) >> 8))
-};
-# 79 "/usr/include/ctype.h" 3 4
-extern const unsigned short int **__ctype_b_loc (void)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__const__));
-extern const __int32_t **__ctype_tolower_loc (void)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__const__));
-extern const __int32_t **__ctype_toupper_loc (void)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__const__));
-# 104 "/usr/include/ctype.h" 3 4
-
-
-
-
-
-
-extern int isalnum (int) __attribute__ ((__nothrow__ , __leaf__));
-extern int isalpha (int) __attribute__ ((__nothrow__ , __leaf__));
-extern int iscntrl (int) __attribute__ ((__nothrow__ , __leaf__));
-extern int isdigit (int) __attribute__ ((__nothrow__ , __leaf__));
-extern int islower (int) __attribute__ ((__nothrow__ , __leaf__));
-extern int isgraph (int) __attribute__ ((__nothrow__ , __leaf__));
-extern int isprint (int) __attribute__ ((__nothrow__ , __leaf__));
-extern int ispunct (int) __attribute__ ((__nothrow__ , __leaf__));
-extern int isspace (int) __attribute__ ((__nothrow__ , __leaf__));
-extern int isupper (int) __attribute__ ((__nothrow__ , __leaf__));
-extern int isxdigit (int) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-extern int tolower (int __c) __attribute__ ((__nothrow__ , __leaf__));
-
-
-extern int toupper (int __c) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-
-
-
-
-extern int isblank (int) __attribute__ ((__nothrow__ , __leaf__));
-
-
-# 150 "/usr/include/ctype.h" 3 4
-extern int isascii (int __c) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-extern int toascii (int __c) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-extern int _toupper (int) __attribute__ ((__nothrow__ , __leaf__));
-extern int _tolower (int) __attribute__ ((__nothrow__ , __leaf__));
-# 271 "/usr/include/ctype.h" 3 4
-extern int isalnum_l (int, __locale_t) __attribute__ ((__nothrow__ , __leaf__));
-extern int isalpha_l (int, __locale_t) __attribute__ ((__nothrow__ , __leaf__));
-extern int iscntrl_l (int, __locale_t) __attribute__ ((__nothrow__ , __leaf__));
-extern int isdigit_l (int, __locale_t) __attribute__ ((__nothrow__ , __leaf__));
-extern int islower_l (int, __locale_t) __attribute__ ((__nothrow__ , __leaf__));
-extern int isgraph_l (int, __locale_t) __attribute__ ((__nothrow__ , __leaf__));
-extern int isprint_l (int, __locale_t) __attribute__ ((__nothrow__ , __leaf__));
-extern int ispunct_l (int, __locale_t) __attribute__ ((__nothrow__ , __leaf__));
-extern int isspace_l (int, __locale_t) __attribute__ ((__nothrow__ , __leaf__));
-extern int isupper_l (int, __locale_t) __attribute__ ((__nothrow__ , __leaf__));
-extern int isxdigit_l (int, __locale_t) __attribute__ ((__nothrow__ , __leaf__));
-
-extern int isblank_l (int, __locale_t) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-extern int __tolower_l (int __c, __locale_t __l) __attribute__ ((__nothrow__ , __leaf__));
-extern int tolower_l (int __c, __locale_t __l) __attribute__ ((__nothrow__ , __leaf__));
-
-
-extern int __toupper_l (int __c, __locale_t __l) __attribute__ ((__nothrow__ , __leaf__));
-extern int toupper_l (int __c, __locale_t __l) __attribute__ ((__nothrow__ , __leaf__));
-# 347 "/usr/include/ctype.h" 3 4
-
-# 396 "../../../server-code/src/common/cbasetypes.h" 2
-# 417 "../../../server-code/src/common/cbasetypes.h"
-# 1 "/usr/lib/gcc/x86_64-linux-gnu/5/include/stdarg.h" 1 3 4
-# 40 "/usr/lib/gcc/x86_64-linux-gnu/5/include/stdarg.h" 3 4
-typedef __builtin_va_list __gnuc_va_list;
-# 98 "/usr/lib/gcc/x86_64-linux-gnu/5/include/stdarg.h" 3 4
-typedef __gnuc_va_list va_list;
-# 418 "../../../server-code/src/common/cbasetypes.h" 2
-# 25 "../../../server-code/src/common/hercules.h" 2
-# 25 "../../../server-code/src/char/char.h" 2
-# 1 "../../../server-code/src/common/core.h" 1
-# 25 "../../../server-code/src/common/core.h"
-# 1 "../../../server-code/src/common/db.h" 1
-# 90 "../../../server-code/src/common/db.h"
-
-# 90 "../../../server-code/src/common/db.h"
-enum DBReleaseOption {
- DB_RELEASE_NOTHING = 0x0,
- DB_RELEASE_KEY = 0x1,
- DB_RELEASE_DATA = 0x2,
- DB_RELEASE_BOTH = DB_RELEASE_KEY|DB_RELEASE_DATA,
-};
-# 117 "../../../server-code/src/common/db.h"
-enum DBType {
- DB_INT,
- DB_UINT,
- DB_STRING,
- DB_ISTRING,
- DB_INT64,
- DB_UINT64,
-};
-# 148 "../../../server-code/src/common/db.h"
-enum DBOptions {
- DB_OPT_BASE = 0x00,
- DB_OPT_DUP_KEY = 0x01,
- DB_OPT_RELEASE_KEY = 0x02,
- DB_OPT_RELEASE_DATA = 0x04,
- DB_OPT_RELEASE_BOTH = DB_OPT_RELEASE_KEY|DB_OPT_RELEASE_DATA,
- DB_OPT_ALLOW_NULL_KEY = 0x08,
- DB_OPT_ALLOW_NULL_DATA = 0x10,
-};
-# 169 "../../../server-code/src/common/db.h"
-union DBKey {
- int i;
- unsigned int ui;
- const char *str;
- char *mutstr;
- int64 i64;
- uint64 ui64;
-};
-# 186 "../../../server-code/src/common/db.h"
-enum DBDataType {
- DB_DATA_INT,
- DB_DATA_UINT,
- DB_DATA_PTR,
-};
-# 201 "../../../server-code/src/common/db.h"
-struct DBData {
- enum DBDataType type;
- union {
- int i;
- unsigned int ui;
- void *ptr;
- } u;
-};
-# 220 "../../../server-code/src/common/db.h"
-typedef struct DBData (*DBCreateData)(union DBKey key, va_list args);
-# 237 "../../../server-code/src/common/db.h"
-typedef int (*DBApply)(union DBKey key, struct DBData *data, va_list args);
-# 250 "../../../server-code/src/common/db.h"
-typedef int (*DBMatcher)(union DBKey key, struct DBData data, va_list args);
-# 264 "../../../server-code/src/common/db.h"
-typedef int (*DBComparator)(union DBKey key1, union DBKey key2, unsigned short maxlen);
-# 276 "../../../server-code/src/common/db.h"
-typedef uint64 (*DBHasher)(union DBKey key, unsigned short maxlen);
-# 290 "../../../server-code/src/common/db.h"
-typedef void (*DBReleaser)(union DBKey key, struct DBData data, enum DBReleaseOption which);
-# 304 "../../../server-code/src/common/db.h"
-struct DBIterator {
-# 314 "../../../server-code/src/common/db.h"
- struct DBData *(*first)(struct DBIterator *self, union DBKey *out_key);
-# 325 "../../../server-code/src/common/db.h"
- struct DBData *(*last)(struct DBIterator *self, union DBKey *out_key);
-# 336 "../../../server-code/src/common/db.h"
- struct DBData *(*next)(struct DBIterator *self, union DBKey *out_key);
-# 347 "../../../server-code/src/common/db.h"
- struct DBData *(*prev)(struct DBIterator *self, union DBKey *out_key);
-# 357 "../../../server-code/src/common/db.h"
-
-# 357 "../../../server-code/src/common/db.h" 3 4
-_Bool
-# 357 "../../../server-code/src/common/db.h"
- (*exists)(struct DBIterator *self);
-# 372 "../../../server-code/src/common/db.h"
- int (*remove)(struct DBIterator *self, struct DBData *out_data);
-
-
-
-
-
-
- void (*destroy)(struct DBIterator *self);
-
-};
-
-
-
-
-
-
-
-struct DBMap {
-# 400 "../../../server-code/src/common/db.h"
- struct DBIterator *(*iterator)(struct DBMap *self);
-# 409 "../../../server-code/src/common/db.h"
-
-# 409 "../../../server-code/src/common/db.h" 3 4
-_Bool
-# 409 "../../../server-code/src/common/db.h"
- (*exists)(struct DBMap *self, union DBKey key);
-# 418 "../../../server-code/src/common/db.h"
- struct DBData *(*get)(struct DBMap *self, union DBKey key);
-# 438 "../../../server-code/src/common/db.h"
- unsigned int (*getall)(struct DBMap *self, struct DBData **buf, unsigned int max, DBMatcher match, ...);
-# 456 "../../../server-code/src/common/db.h"
- unsigned int (*vgetall)(struct DBMap *self, struct DBData **buf, unsigned int max, DBMatcher match, va_list args);
-# 472 "../../../server-code/src/common/db.h"
- struct DBData *(*ensure)(struct DBMap *self, union DBKey key, DBCreateData create, ...);
-# 486 "../../../server-code/src/common/db.h"
- struct DBData *(*vensure)(struct DBMap *self, union DBKey key, DBCreateData create, va_list args);
-# 499 "../../../server-code/src/common/db.h"
- int (*put)(struct DBMap *self, union DBKey key, struct DBData data, struct DBData *out_data);
-# 511 "../../../server-code/src/common/db.h"
- int (*remove)(struct DBMap *self, union DBKey key, struct DBData *out_data);
-# 525 "../../../server-code/src/common/db.h"
- int (*foreach)(struct DBMap *self, DBApply func, ...);
-# 537 "../../../server-code/src/common/db.h"
- int (*vforeach)(struct DBMap *self, DBApply func, va_list args);
-# 553 "../../../server-code/src/common/db.h"
- int (*clear)(struct DBMap *self, DBApply func, ...);
-# 567 "../../../server-code/src/common/db.h"
- int (*vclear)(struct DBMap *self, DBApply func, va_list args);
-# 584 "../../../server-code/src/common/db.h"
- int (*destroy)(struct DBMap *self, DBApply func, ...);
-# 599 "../../../server-code/src/common/db.h"
- int (*vdestroy)(struct DBMap *self, DBApply func, va_list args);
-
-
-
-
-
-
-
- unsigned int (*size)(struct DBMap *self);
-
-
-
-
-
-
-
- enum DBType (*type)(struct DBMap *self);
-
-
-
-
-
-
-
- enum DBOptions (*options)(struct DBMap *self);
-
-};
-# 745 "../../../server-code/src/common/db.h"
-struct db_interface {
-# 758 "../../../server-code/src/common/db.h"
-enum DBOptions (*fix_options) (enum DBType type, enum DBOptions options);
-# 768 "../../../server-code/src/common/db.h"
-DBComparator (*default_cmp) (enum DBType type);
-# 778 "../../../server-code/src/common/db.h"
-DBHasher (*default_hash) (enum DBType type);
-# 797 "../../../server-code/src/common/db.h"
-DBReleaser (*default_release) (enum DBType type, enum DBOptions options);
-# 808 "../../../server-code/src/common/db.h"
-DBReleaser (*custom_release) (enum DBReleaseOption which);
-# 834 "../../../server-code/src/common/db.h"
-struct DBMap *(*alloc) (const char *file, const char *func, int line, enum DBType type, enum DBOptions options, unsigned short maxlen);
-
-
-
-
-
-
-
-union DBKey (*i2key) (int key);
-
-
-
-
-
-
-
-union DBKey (*ui2key) (unsigned int key);
-
-
-
-
-
-
-
-union DBKey (*str2key) (const char *key);
-
-
-
-
-
-
-
-union DBKey (*i642key) (int64 key);
-
-
-
-
-
-
-
-union DBKey (*ui642key) (uint64 key);
-
-
-
-
-
-
-
-struct DBData (*i2data) (int data);
-
-
-
-
-
-
-
-struct DBData (*ui2data) (unsigned int data);
-
-
-
-
-
-
-
-struct DBData (*ptr2data) (void *data);
-# 907 "../../../server-code/src/common/db.h"
-int (*data2i) (struct DBData *data);
-# 916 "../../../server-code/src/common/db.h"
-unsigned int (*data2ui) (struct DBData *data);
-# 925 "../../../server-code/src/common/db.h"
-void* (*data2ptr) (struct DBData *data);
-
-
-
-
-
-
-void (*init) (void);
-
-
-
-
-
-
-
-void (*final) (void);
-};
-
-
-struct linkdb_node {
- struct linkdb_node *next;
- struct linkdb_node *prev;
- void *key;
- void *data;
-};
-
-typedef void (*LinkDBFunc)(void* key, void* data, va_list args);
-
-
-void linkdb_insert (struct linkdb_node** head, void *key, void* data);
-void linkdb_replace (struct linkdb_node** head, void *key, void* data);
-void* linkdb_search (struct linkdb_node** head, void *key);
-void* linkdb_erase (struct linkdb_node** head, void *key);
-void linkdb_final (struct linkdb_node** head);
-void linkdb_vforeach(struct linkdb_node** head, LinkDBFunc func, va_list ap);
-void linkdb_foreach (struct linkdb_node** head, LinkDBFunc func, ...);
-
-void db_defaults(void);
-
-
-extern struct db_interface *DB;
-# 26 "../../../server-code/src/common/core.h" 2
-# 34 "../../../server-code/src/common/core.h"
-enum server_types {
- SERVER_TYPE_UNKNOWN = 0x0,
- SERVER_TYPE_LOGIN = 0x1,
- SERVER_TYPE_CHAR = 0x2,
- SERVER_TYPE_MAP = 0x4,
-};
-
-
-enum E_CORE_ST {
- CORE_ST_STOP = 0,
- CORE_ST_RUN,
- CORE_ST_LAST
-};
-
-
-enum cmdline_options {
- CMDLINE_OPT_NORMAL = 0x0,
- CMDLINE_OPT_PARAM = 0x1,
- CMDLINE_OPT_SILENT = 0x2,
- CMDLINE_OPT_PREINIT = 0x4,
-};
-typedef
-# 55 "../../../server-code/src/common/core.h" 3 4
- _Bool
-# 55 "../../../server-code/src/common/core.h"
- (*CmdlineExecFunc)(const char *name, const char *params);
-struct CmdlineArgData {
- unsigned int pluginID;
- unsigned int options;
- char *name;
- char shortname;
- CmdlineExecFunc func;
- char *help;
-};
-
-struct cmdline_interface {
- struct { int _max_; int _len_; struct CmdlineArgData *_data_; } args_data;
-
- void (*init) (void);
- void (*final) (void);
-
-# 70 "../../../server-code/src/common/core.h" 3 4
-_Bool
-# 70 "../../../server-code/src/common/core.h"
- (*arg_add) (unsigned int pluginID, const char *name, char shortname, CmdlineExecFunc func, const char *help, unsigned int options);
- int (*exec) (int argc, char **argv, unsigned int options);
-
-# 72 "../../../server-code/src/common/core.h" 3 4
-_Bool
-# 72 "../../../server-code/src/common/core.h"
- (*arg_next_value) (const char *name, int current_arg, int argc);
- const char *(*arg_source) (struct CmdlineArgData *arg);
-};
-
-struct core_interface {
- int arg_c;
- char **arg_v;
-
- int runflag;
- char *server_name;
- enum server_types server_type;
-
-
-
- void (*shutdown_callback)(void);
-};
-
-
-
-
-
-
-extern void cmdline_args_init_local(void);
-extern int do_init(int,char**);
-extern void set_server_type(void);
-extern void do_abort(void);
-extern int do_final(void);
-
-
-
-
-
-
-
-void cmdline_defaults(void);
-
-
-extern struct core_interface *core;
-extern struct cmdline_interface *cmdline;
-# 26 "../../../server-code/src/char/char.h" 2
-
-# 1 "../../../server-code/src/common/mmo.h" 1
-# 225 "../../../server-code/src/common/mmo.h"
-struct hplugin_data_store;
-
-enum item_types {
- IT_HEALING = 0,
- IT_UNKNOWN,
- IT_USABLE,
- IT_ETC,
- IT_WEAPON,
- IT_ARMOR,
- IT_CARD,
- IT_PETEGG,
- IT_PETARMOR,
- IT_UNKNOWN2,
- IT_AMMO,
- IT_DELAYCONSUME,
- IT_CASH = 18,
- IT_MAX
-};
-
-
-
-
-enum quest_state {
- Q_INACTIVE,
- Q_ACTIVE,
- Q_COMPLETE,
-};
-
-
-struct quest {
- int quest_id;
- unsigned int time;
- int count[3];
- enum quest_state state;
-};
-
-struct item {
- int id;
- short nameid;
- short amount;
- unsigned int equip;
- char identify;
- char refine;
- char attribute;
- short card[4];
- unsigned int expire_time;
- char favorite;
- unsigned char bound;
- uint64 unique_id;
-};
-
-
-enum equip_pos {
- EQP_NONE = 0x000000,
- EQP_HEAD_LOW = 0x000001,
- EQP_HEAD_MID = 0x000200,
- EQP_HEAD_TOP = 0x000100,
- EQP_HAND_R = 0x000002,
- EQP_HAND_L = 0x000020,
- EQP_ARMOR = 0x000010,
- EQP_SHOES = 0x000040,
- EQP_GARMENT = 0x000004,
- EQP_ACC_L = 0x000008,
- EQP_ACC_R = 0x000080,
- EQP_COSTUME_HEAD_TOP = 0x000400,
- EQP_COSTUME_HEAD_MID = 0x000800,
- EQP_COSTUME_HEAD_LOW = 0x001000,
- EQP_COSTUME_GARMENT = 0x002000,
-
- EQP_AMMO = 0x008000,
- EQP_SHADOW_ARMOR = 0x010000,
- EQP_SHADOW_WEAPON = 0x020000,
- EQP_SHADOW_SHIELD = 0x040000,
- EQP_SHADOW_SHOES = 0x080000,
- EQP_SHADOW_ACC_R = 0x100000,
- EQP_SHADOW_ACC_L = 0x200000,
-};
-
-struct point {
- unsigned short map;
- short x,y;
-};
-
-enum e_skill_flag
-{
- SKILL_FLAG_PERMANENT,
- SKILL_FLAG_TEMPORARY,
- SKILL_FLAG_PLAGIARIZED,
- SKILL_FLAG_UNUSED,
- SKILL_FLAG_PERM_GRANTED,
-
-
- SKILL_FLAG_REPLACED_LV_0,
-};
-
-enum e_mmo_charstatus_opt {
- OPT_NONE = 0x0,
- OPT_SHOW_EQUIP = 0x1,
- OPT_ALLOW_PARTY = 0x2,
-};
-
-enum e_item_bound_type {
- IBT_NONE = 0x0,
- IBT_MIN = 0x1,
- IBT_ACCOUNT = 0x1,
- IBT_GUILD = 0x2,
- IBT_PARTY = 0x3,
- IBT_CHARACTER = 0x4,
- IBT_MAX = 0x4,
-};
-
-enum {
- OPTION_NOTHING = 0x00000000,
- OPTION_SIGHT = 0x00000001,
- OPTION_HIDE = 0x00000002,
- OPTION_CLOAK = 0x00000004,
- OPTION_FALCON = 0x00000010,
- OPTION_RIDING = 0x00000020,
- OPTION_INVISIBLE = 0x00000040,
- OPTION_ORCISH = 0x00000800,
- OPTION_WEDDING = 0x00001000,
- OPTION_RUWACH = 0x00002000,
- OPTION_CHASEWALK = 0x00004000,
- OPTION_FLYING = 0x00008000,
- OPTION_XMAS = 0x00010000,
- OPTION_TRANSFORM = 0x00020000,
- OPTION_SUMMER = 0x00040000,
- OPTION_DRAGON1 = 0x00080000,
- OPTION_WUG = 0x00100000,
- OPTION_WUGRIDER = 0x00200000,
- OPTION_MADOGEAR = 0x00400000,
- OPTION_DRAGON2 = 0x00800000,
- OPTION_DRAGON3 = 0x01000000,
- OPTION_DRAGON4 = 0x02000000,
- OPTION_DRAGON5 = 0x04000000,
- OPTION_HANBOK = 0x08000000,
- OPTION_OKTOBERFEST = 0x10000000,
-# 372 "../../../server-code/src/common/mmo.h"
- OPTION_DRAGON = OPTION_DRAGON1|OPTION_DRAGON2|OPTION_DRAGON3|OPTION_DRAGON4|OPTION_DRAGON5,
- OPTION_COSTUME = OPTION_WEDDING|OPTION_XMAS|OPTION_SUMMER|OPTION_HANBOK|OPTION_OKTOBERFEST,
-};
-
-struct s_skill {
- unsigned short id;
- unsigned char lv;
- unsigned char flag;
-};
-
-struct script_reg_state {
- unsigned int type : 1;
- unsigned int update : 1;
-};
-
-struct script_reg_num {
- struct script_reg_state flag;
- int value;
-};
-
-struct script_reg_str {
- struct script_reg_state flag;
- char *value;
-};
-
-
-struct status_change_data {
- unsigned short type;
- int val1, val2, val3, val4;
- int tick;
-};
-
-struct storage_data {
- int storage_amount;
- struct item items[600];
-};
-
-struct guild_storage {
- int dirty;
- int guild_id;
- short storage_status;
- short storage_amount;
- struct item items[600];
- unsigned short lock;
-};
-
-struct s_pet {
- int account_id;
- int char_id;
- int pet_id;
- short class_;
- short level;
- short egg_id;
- short equip;
- short intimate;
- short hungry;
- char name[(23 + 1)];
- char rename_flag;
- char incubate;
-};
-
-struct s_homunculus {
- char name[(23 + 1)];
- int hom_id;
- int char_id;
- short class_;
- short prev_class;
- int hp,max_hp,sp,max_sp;
- unsigned int intimacy;
- short hunger;
- struct s_skill hskill[43];
- short skillpts;
- short level;
- unsigned int exp;
- short rename_flag;
- short vaporize;
- int str;
- int agi;
- int vit;
- int int_;
- int dex;
- int luk;
-
- int str_value;
- int agi_value;
- int vit_value;
- int int_value;
- int dex_value;
- int luk_value;
-
- int8 spiritball;
-};
-
-struct s_mercenary {
- int mercenary_id;
- int char_id;
- short class_;
- int hp, sp;
- unsigned int kill_count;
- unsigned int life_time;
-};
-
-struct s_elemental {
- int elemental_id;
- int char_id;
- short class_;
- uint32 mode;
- int hp, sp, max_hp, max_sp, matk, atk, atk2;
- short hit, flee, amotion, def, mdef;
- int life_time;
-};
-
-struct s_friend {
- int account_id;
- int char_id;
- char name[(23 + 1)];
-};
-
-struct hotkey {
-
- unsigned int id;
- unsigned short lv;
- unsigned char type;
-
-
-
-};
-
-struct mmo_charstatus {
- int char_id;
- int account_id;
- int partner_id;
- int father;
- int mother;
- int child;
-
- unsigned int base_exp,job_exp;
- int zeny;
- int bank_vault;
-
- short class_;
- unsigned int status_point,skill_point;
- int hp,max_hp,sp,max_sp;
- unsigned int option;
- short manner;
- unsigned char karma;
- short hair,hair_color,clothes_color,body;
- int party_id,guild_id,pet_id,hom_id,mer_id,ele_id;
- int fame;
-
-
- int arch_faith, arch_calls;
- int spear_faith, spear_calls;
- int sword_faith, sword_calls;
-
- short weapon;
- short shield;
- short head_top,head_mid,head_bottom;
- short robe;
-
- char name[(23 + 1)];
- unsigned int base_level,job_level;
- short str,agi,vit,int_,dex,luk;
- unsigned char slot,sex;
-
- uint32 mapip;
- uint16 mapport;
-
- struct point last_point,save_point,memo_point[3];
- struct item inventory[100],cart[100];
- struct storage_data storage;
- struct s_skill skill[1478];
-
- struct s_friend friends[40];
-
- struct hotkey hotkeys[38];
-
-
-# 549 "../../../server-code/src/common/mmo.h" 3 4
-_Bool
-# 549 "../../../server-code/src/common/mmo.h"
- show_equip, allow_party;
- unsigned short rename;
- unsigned short slotchange;
-
- time_t delete_date;
-
-
- unsigned short mod_exp,mod_drop,mod_death;
-
- unsigned char font;
-
- uint32 uniqueitem_counter;
-
- unsigned char hotkey_rowshift;
-};
-
-typedef enum mail_status {
- MAIL_NEW,
- MAIL_UNREAD,
- MAIL_READ,
-} mail_status;
-
-struct mail_message {
- int id;
- int send_id;
- char send_name[(23 + 1)];
- int dest_id;
- char dest_name[(23 + 1)];
- char title[40];
- char body[200];
-
- mail_status status;
- time_t timestamp;
-
- int zeny;
- struct item item;
-};
-
-struct mail_data {
- short amount;
-
-# 589 "../../../server-code/src/common/mmo.h" 3 4
-_Bool
-# 589 "../../../server-code/src/common/mmo.h"
- full;
- short unchecked, unread;
- struct mail_message msg[30];
-};
-
-struct auction_data {
- unsigned int auction_id;
- int seller_id;
- char seller_name[(23 + 1)];
- int buyer_id;
- char buyer_name[(23 + 1)];
-
- struct item item;
-
- char item_name[50];
- short type;
-
- unsigned short hours;
- int price, buynow;
- time_t timestamp;
- int auction_end_timer;
-};
-
-struct party_member {
- int account_id;
- int char_id;
- char name[(23 + 1)];
- unsigned short class_;
- unsigned short map;
- unsigned short lv;
- unsigned leader : 1,
- online : 1;
-};
-
-struct party {
- int party_id;
- char name[(23 + 1)];
- unsigned char count;
- unsigned exp : 1,
- item : 2;
- struct party_member member[12];
-};
-
-struct map_session_data;
-struct guild_member {
- int account_id, char_id;
- short hair,hair_color,gender,class_,lv;
- uint64 exp;
- int exp_payper;
- short online,position;
- char name[(23 + 1)];
- struct map_session_data *sd;
- unsigned char modified;
-};
-
-struct guild_position {
- char name[(23 + 1)];
- int mode;
- int exp_mode;
- unsigned char modified;
-};
-
-struct guild_alliance {
- int opposition;
- int guild_id;
- char name[(23 + 1)];
-};
-
-struct guild_expulsion {
- char name[(23 + 1)];
- char mes[40];
- int account_id;
-};
-
-struct guild_skill {
- int id,lv;
-};
-
-struct channel_data;
-struct guild {
- int guild_id;
- short guild_lv, connect_member, max_member, average_lv;
- uint64 exp;
- unsigned int next_exp;
- int skill_point;
- char name[(23 + 1)],master[(23 + 1)];
- struct guild_member member[(16 +10*6)];
- struct guild_position position[20];
- char mes1[60],mes2[120];
- int emblem_len,emblem_id;
- char emblem_data[2048];
- struct guild_alliance alliance[16];
- struct guild_expulsion expulsion[32];
- struct guild_skill skill[15];
-
-
- unsigned short save_flag;
-
- short *instance;
- unsigned short instances;
-
- struct channel_data *channel;
- struct hplugin_data_store *hdata;
-};
-
-struct guild_castle {
- int castle_id;
- int mapindex;
- char castle_name[(23 + 1)];
- char castle_event[(23 + 1)];
- int guild_id;
- int economy;
- int defense;
- int triggerE;
- int triggerD;
- int nextTime;
- int payTime;
- int createTime;
- int visibleC;
- struct {
- unsigned visible : 1;
- int id;
- } guardian[8];
- int* temp_guardians;
- int temp_guardians_max;
-};
-
-struct fame_list {
- int id;
- int fame;
- char name[(23 + 1)];
-};
-
-enum fame_list_type {
- RANKTYPE_BLACKSMITH = 0,
- RANKTYPE_ALCHEMIST = 1,
- RANKTYPE_TAEKWON = 2,
- RANKTYPE_PK = 3,
-};
-
-
-
-
-
-
-enum guild_basic_info {
- GBI_EXP = 1,
- GBI_GUILDLV,
- GBI_SKILLPOINT,
-
-
-
-
-
- GBI_SKILLLV,
-};
-
-enum {
- GMI_POSITION = 0,
- GMI_EXP,
- GMI_HAIR,
- GMI_HAIR_COLOR,
- GMI_GENDER,
- GMI_CLASS,
- GMI_LEVEL,
-};
-
-enum guild_permission {
- GPERM_INVITE = 0x01,
- GPERM_EXPEL = 0x10,
- GPERM_ALL = GPERM_INVITE|GPERM_EXPEL,
- GPERM_MASK = GPERM_ALL,
-};
-
-enum {
- GD_SKILLBASE=10000,
- GD_APPROVAL=10000,
- GD_KAFRACONTRACT=10001,
- GD_GUARDRESEARCH=10002,
- GD_GUARDUP=10003,
- GD_EXTENSION=10004,
- GD_GLORYGUILD=10005,
- GD_LEADERSHIP=10006,
- GD_GLORYWOUNDS=10007,
- GD_SOULCOLD=10008,
- GD_HAWKEYES=10009,
- GD_BATTLEORDER=10010,
- GD_REGENERATION=10011,
- GD_RESTORE=10012,
- GD_EMERGENCYCALL=10013,
- GD_DEVELOPMENT=10014,
- GD_MAX,
-};
-
-
-enum {
- JOB_NOVICE,
- JOB_SWORDMAN,
- JOB_MAGE,
- JOB_ARCHER,
- JOB_ACOLYTE,
- JOB_MERCHANT,
- JOB_THIEF,
- JOB_KNIGHT,
- JOB_PRIEST,
- JOB_WIZARD,
- JOB_BLACKSMITH,
- JOB_HUNTER,
- JOB_ASSASSIN,
- JOB_KNIGHT2,
- JOB_CRUSADER,
- JOB_MONK,
- JOB_SAGE,
- JOB_ROGUE,
- JOB_ALCHEMIST,
- JOB_BARD,
- JOB_DANCER,
- JOB_CRUSADER2,
- JOB_WEDDING,
- JOB_SUPER_NOVICE,
- JOB_GUNSLINGER,
- JOB_NINJA,
- JOB_XMAS,
- JOB_SUMMER,
- JOB_MAX_BASIC,
-
- JOB_NOVICE_HIGH = 4001,
- JOB_SWORDMAN_HIGH,
- JOB_MAGE_HIGH,
- JOB_ARCHER_HIGH,
- JOB_ACOLYTE_HIGH,
- JOB_MERCHANT_HIGH,
- JOB_THIEF_HIGH,
- JOB_LORD_KNIGHT,
- JOB_HIGH_PRIEST,
- JOB_HIGH_WIZARD,
- JOB_WHITESMITH,
- JOB_SNIPER,
- JOB_ASSASSIN_CROSS,
- JOB_LORD_KNIGHT2,
- JOB_PALADIN,
- JOB_CHAMPION,
- JOB_PROFESSOR,
- JOB_STALKER,
- JOB_CREATOR,
- JOB_CLOWN,
- JOB_GYPSY,
- JOB_PALADIN2,
-
- JOB_BABY,
- JOB_BABY_SWORDMAN,
- JOB_BABY_MAGE,
- JOB_BABY_ARCHER,
- JOB_BABY_ACOLYTE,
- JOB_BABY_MERCHANT,
- JOB_BABY_THIEF,
- JOB_BABY_KNIGHT,
- JOB_BABY_PRIEST,
- JOB_BABY_WIZARD,
- JOB_BABY_BLACKSMITH,
- JOB_BABY_HUNTER,
- JOB_BABY_ASSASSIN,
- JOB_BABY_KNIGHT2,
- JOB_BABY_CRUSADER,
- JOB_BABY_MONK,
- JOB_BABY_SAGE,
- JOB_BABY_ROGUE,
- JOB_BABY_ALCHEMIST,
- JOB_BABY_BARD,
- JOB_BABY_DANCER,
- JOB_BABY_CRUSADER2,
- JOB_SUPER_BABY,
-
- JOB_TAEKWON,
- JOB_STAR_GLADIATOR,
- JOB_STAR_GLADIATOR2,
- JOB_SOUL_LINKER,
-
- JOB_GANGSI,
- JOB_DEATH_KNIGHT,
- JOB_DARK_COLLECTOR,
-
- JOB_RUNE_KNIGHT = 4054,
- JOB_WARLOCK,
- JOB_RANGER,
- JOB_ARCH_BISHOP,
- JOB_MECHANIC,
- JOB_GUILLOTINE_CROSS,
-
- JOB_RUNE_KNIGHT_T,
- JOB_WARLOCK_T,
- JOB_RANGER_T,
- JOB_ARCH_BISHOP_T,
- JOB_MECHANIC_T,
- JOB_GUILLOTINE_CROSS_T,
-
- JOB_ROYAL_GUARD,
- JOB_SORCERER,
- JOB_MINSTREL,
- JOB_WANDERER,
- JOB_SURA,
- JOB_GENETIC,
- JOB_SHADOW_CHASER,
-
- JOB_ROYAL_GUARD_T,
- JOB_SORCERER_T,
- JOB_MINSTREL_T,
- JOB_WANDERER_T,
- JOB_SURA_T,
- JOB_GENETIC_T,
- JOB_SHADOW_CHASER_T,
-
- JOB_RUNE_KNIGHT2,
- JOB_RUNE_KNIGHT_T2,
- JOB_ROYAL_GUARD2,
- JOB_ROYAL_GUARD_T2,
- JOB_RANGER2,
- JOB_RANGER_T2,
- JOB_MECHANIC2,
- JOB_MECHANIC_T2,
-
- JOB_BABY_RUNE = 4096,
- JOB_BABY_WARLOCK,
- JOB_BABY_RANGER,
- JOB_BABY_BISHOP,
- JOB_BABY_MECHANIC,
- JOB_BABY_CROSS,
-
- JOB_BABY_GUARD,
- JOB_BABY_SORCERER,
- JOB_BABY_MINSTREL,
- JOB_BABY_WANDERER,
- JOB_BABY_SURA,
- JOB_BABY_GENETIC,
- JOB_BABY_CHASER,
-
- JOB_BABY_RUNE2,
- JOB_BABY_GUARD2,
- JOB_BABY_RANGER2,
- JOB_BABY_MECHANIC2,
-
- JOB_SUPER_NOVICE_E = 4190,
- JOB_SUPER_BABY_E,
-
- JOB_KAGEROU = 4211,
- JOB_OBORO,
- JOB_REBELLION = 4215,
-
- JOB_MAX,
-};
-
-
-
-
-enum {
- SEX_FEMALE = 0,
- SEX_MALE,
- SEX_SERVER
-};
-
-enum weapon_type {
- W_FIST,
- W_DAGGER,
- W_1HSWORD,
- W_2HSWORD,
- W_1HSPEAR,
- W_2HSPEAR,
- W_1HAXE,
- W_2HAXE,
- W_MACE,
- W_2HMACE,
- W_STAFF,
- W_BOW,
- W_KNUCKLE,
- W_MUSICAL,
- W_WHIP,
- W_BOOK,
- W_KATAR,
- W_REVOLVER,
- W_RIFLE,
- W_GATLING,
- W_SHOTGUN,
- W_GRENADE,
- W_HUUMA,
- W_2HSTAFF,
- MAX_SINGLE_WEAPON_TYPE,
-
- W_DOUBLE_DD,
- W_DOUBLE_SS,
- W_DOUBLE_AA,
- W_DOUBLE_DS,
- W_DOUBLE_DA,
- W_DOUBLE_SA,
- MAX_WEAPON_TYPE,
-};
-
-enum ammo_type {
- A_ARROW = 1,
- A_DAGGER,
- A_BULLET,
- A_SHELL,
- A_GRENADE,
- A_SHURIKEN,
- A_KUNAI,
- A_CANNONBALL,
- A_THROWWEAPON,
-};
-
-enum e_char_server_type {
- CST_NORMAL = 0,
- CST_MAINTENANCE = 1,
- CST_OVER18 = 2,
- CST_PAYING = 3,
- CST_F2P = 4,
-};
-
-enum e_pc_reg_loading {
- PRL_NONE = 0x0,
- PRL_CHAR = 0x1,
- PRL_ACCL = 0x2,
- PRL_ACCG = 0x4,
- PRL_ALL = 0xFF,
-};
-
-
-
-
-enum zh_char_ask_name_type {
- CHAR_ASK_NAME_BLOCK = 1,
- CHAR_ASK_NAME_BAN = 2,
- CHAR_ASK_NAME_UNBLOCK = 3,
- CHAR_ASK_NAME_UNBAN = 4,
- CHAR_ASK_NAME_CHANGESEX = 5,
- CHAR_ASK_NAME_CHARBAN = 6,
- CHAR_ASK_NAME_CHARUNBAN = 7,
- CHAR_ASK_NAME_CHANGECHARSEX = 8,
-};
-
-
-
-
-enum hz_char_ask_name_answer {
- CHAR_ASK_NAME_ANS_DONE = 0,
- CHAR_ASK_NAME_ANS_NOTFOUND = 1,
- CHAR_ASK_NAME_ANS_GMLOW = 2,
- CHAR_ASK_NAME_ANS_OFFLINE = 3,
-};
-# 28 "../../../server-code/src/char/char.h" 2
-
-enum E_CHARSERVER_ST {
- CHARSERVER_ST_RUNNING = CORE_ST_LAST,
- CHARSERVER_ST_SHUTDOWN,
- CHARSERVER_ST_LAST
-};
-
-struct char_session_data {
-
-# 36 "../../../server-code/src/char/char.h" 3 4
-_Bool
-# 36 "../../../server-code/src/char/char.h"
- auth;
- int account_id, login_id1, login_id2, sex;
- int found_char[9];
- time_t unban_time[9];
- char email[40];
- time_t expiration_time;
- int group_id;
- uint8 char_slots;
- uint32 version;
- uint8 clienttype;
- char pincode[4+1];
- uint32 pincode_seed;
- uint16 pincode_try;
- uint32 pincode_change;
- char new_name[(23 + 1)];
- char birthdate[10+1];
-};
-
-struct online_char_data {
- int account_id;
- int char_id;
- int fd;
- int waiting_disconnect;
- short server;
- int pincode_enable;
-};
-
-struct mmo_map_server {
- int fd;
- uint32 ip;
- uint16 port;
- int users;
- struct { int _max_; int _len_; uint16 *_data_; } maps;
-};
-
-
-
-
-
-enum inventory_table_type {
- TABLE_INVENTORY,
- TABLE_CART,
- TABLE_STORAGE,
- TABLE_GUILD_STORAGE,
-};
-
-struct char_auth_node {
- int account_id;
- int char_id;
- uint32 login_id1;
- uint32 login_id2;
- uint32 ip;
- int sex;
- time_t expiration_time;
- int group_id;
- unsigned changing_mapservers : 1;
-};
-
-
-
-
-struct char_interface {
- struct mmo_map_server server[2];
- int login_fd;
- int char_fd;
- struct DBMap *online_char_db;
- struct DBMap *char_db_;
- char userid[(23 + 1)];
- char passwd[(23 + 1)];
- char server_name[20];
- uint32 ip;
- uint16 port;
- int server_type;
- int new_display;
-
- char *CHAR_CONF_NAME;
- char *NET_CONF_NAME;
- char *SQL_CONF_NAME;
- char *INTER_CONF_NAME;
-
- int (*waiting_disconnect) (int tid, int64 tick, int id, intptr_t data);
- int (*delete_char_sql) (int char_id);
- struct DBData (*create_online_char_data) (union DBKey key, va_list args);
- void (*set_account_online) (int account_id);
- void (*set_account_offline) (int account_id);
- void (*set_char_charselect) (int account_id);
- void (*set_char_online) (int map_id, int char_id, int account_id);
- void (*set_char_offline) (int char_id, int account_id);
- int (*db_setoffline) (union DBKey key, struct DBData *data, va_list ap);
- int (*db_kickoffline) (union DBKey key, struct DBData *data, va_list ap);
- void (*set_login_all_offline) (void);
- void (*set_all_offline) (int id);
- void (*set_all_offline_sql) (void);
- struct DBData (*create_charstatus) (union DBKey key, va_list args);
- int (*mmo_char_tosql) (int char_id, struct mmo_charstatus* p);
- int (*memitemdata_to_sql) (const struct item items[], int max, int id, int tableswitch);
- int (*mmo_gender) (const struct char_session_data *sd, const struct mmo_charstatus *p, char sex);
- int (*mmo_chars_fromsql) (struct char_session_data* sd, uint8* buf);
- int (*mmo_char_fromsql) (int char_id, struct mmo_charstatus* p,
-# 134 "../../../server-code/src/char/char.h" 3 4
- _Bool
-# 134 "../../../server-code/src/char/char.h"
- load_everything);
- int (*mmo_char_sql_init) (void);
-
-# 136 "../../../server-code/src/char/char.h" 3 4
-_Bool
-# 136 "../../../server-code/src/char/char.h"
- (*char_slotchange) (struct char_session_data *sd, int fd, unsigned short from, unsigned short to);
- int (*rename_char_sql) (struct char_session_data *sd, int char_id);
- int (*check_char_name) (char * name, char * esc_name);
- int (*make_new_char_sql) (struct char_session_data *sd, const char *name_, int str, int agi, int vit, int int_, int dex, int luk, int slot, int hair_color, int hair_style);
- int (*divorce_char_sql) (int partner_id1, int partner_id2);
- int (*count_users) (void);
- int (*mmo_char_tobuf) (uint8* buffer, struct mmo_charstatus* p);
- void (*mmo_char_send099d) (int fd, struct char_session_data *sd);
- void (*mmo_char_send_ban_list) (int fd, struct char_session_data *sd);
- void (*mmo_char_send_slots_info) (int fd, struct char_session_data* sd);
- int (*mmo_char_send_characters) (int fd, struct char_session_data* sd);
- int (*char_married) (int pl1, int pl2);
- int (*char_child) (int parent_id, int child_id);
- int (*char_family) (int cid1, int cid2, int cid3);
- void (*disconnect_player) (int account_id);
- void (*authfail_fd) (int fd, int type);
- void (*request_account_data) (int account_id);
- void (*auth_ok) (int fd, struct char_session_data *sd);
- void (*ping_login_server) (int fd);
- int (*parse_fromlogin_connection_state) (int fd);
- void (*auth_error) (int fd, unsigned char flag);
- void (*parse_fromlogin_auth_state) (int fd);
- void (*parse_fromlogin_account_data) (int fd);
- void (*parse_fromlogin_login_pong) (int fd);
- void (*changesex) (int account_id, int sex);
- int (*parse_fromlogin_changesex_reply) (int fd);
- void (*parse_fromlogin_account_reg2) (int fd);
- void (*parse_fromlogin_ban) (int fd);
- void (*parse_fromlogin_kick) (int fd);
- void (*update_ip) (int fd);
- void (*parse_fromlogin_update_ip) (int fd);
- void (*parse_fromlogin_accinfo2_failed) (int fd);
- void (*parse_fromlogin_accinfo2_ok) (int fd);
- int (*parse_fromlogin) (int fd);
- int (*request_accreg2) (int account_id, int char_id);
- void (*global_accreg_to_login_start) (int account_id, int char_id);
- void (*global_accreg_to_login_send) (void);
- void (*global_accreg_to_login_add) (const char *key, unsigned int index, intptr_t val,
-# 173 "../../../server-code/src/char/char.h" 3 4
- _Bool
-# 173 "../../../server-code/src/char/char.h"
- is_string);
- void (*read_fame_list) (void);
- int (*send_fame_list) (int fd);
- void (*update_fame_list) (int type, int index, int fame);
- int (*loadName) (int char_id, char* name);
- void (*parse_frommap_datasync) (int fd);
- void (*parse_frommap_skillid2idx) (int fd);
- void (*map_received_ok) (int fd);
- void (*send_maps) (int fd, int id, int j);
- void (*parse_frommap_map_names) (int fd, int id);
- void (*send_scdata) (int fd, int aid, int cid);
- void (*parse_frommap_request_scdata) (int fd);
- void (*parse_frommap_set_users_count) (int fd, int id);
- void (*parse_frommap_set_users) (int fd, int id);
- void (*save_character_ack) (int fd, int aid, int cid);
- void (*parse_frommap_save_character) (int fd, int id);
- void (*select_ack) (int fd, int account_id, uint8 flag);
- void (*parse_frommap_char_select_req) (int fd);
- void (*change_map_server_ack) (int fd, const uint8 *data,
-# 191 "../../../server-code/src/char/char.h" 3 4
- _Bool
-# 191 "../../../server-code/src/char/char.h"
- ok);
- void (*parse_frommap_change_map_server) (int fd);
- void (*parse_frommap_remove_friend) (int fd);
- void (*char_name_ack) (int fd, int char_id);
- void (*parse_frommap_char_name_request) (int fd);
- void (*parse_frommap_change_email) (int fd);
- void (*ban) (int account_id, int char_id, time_t *unban_time, short year, short month, short day, short hour, short minute, short second);
- void (*unban) (int char_id, int *result);
- void (*ask_name_ack) (int fd, int acc, const char* name, int type, int result);
- int (*changecharsex) (int char_id, int sex);
- void (*parse_frommap_change_account) (int fd);
- void (*parse_frommap_fame_list) (int fd);
- void (*parse_frommap_divorce_char) (int fd);
- void (*parse_frommap_ragsrvinfo) (int fd);
- void (*parse_frommap_set_char_offline) (int fd);
- void (*parse_frommap_set_all_offline) (int fd, int id);
- void (*parse_frommap_set_char_online) (int fd, int id);
- void (*parse_frommap_build_fame_list) (int fd);
- void (*parse_frommap_save_status_change_data) (int fd);
- void (*send_pong) (int fd);
- void (*parse_frommap_ping) (int fd);
- void (*map_auth_ok) (int fd, int account_id, struct char_auth_node* node, struct mmo_charstatus* cd);
- void (*map_auth_failed) (int fd, int account_id, int char_id, int login_id1, char sex, uint32 ip);
- void (*parse_frommap_auth_request) (int fd, int id);
- void (*parse_frommap_update_ip) (int fd, int id);
- void (*parse_frommap_request_stats_report) (int fd);
- void (*parse_frommap_scdata_update) (int fd);
- void (*parse_frommap_scdata_delete) (int fd);
- int (*parse_frommap) (int fd);
- int (*search_mapserver) (unsigned short map, uint32 ip, uint16 port);
- int (*mapif_init) (int fd);
- uint32 (*lan_subnet_check) (uint32 ip);
- void (*delete2_ack) (int fd, int char_id, uint32 result, time_t delete_date);
- void (*delete2_accept_actual_ack) (int fd, int char_id, uint32 result);
- void (*delete2_accept_ack) (int fd, int char_id, uint32 result);
- void (*delete2_cancel_ack) (int fd, int char_id, uint32 result);
- void (*delete2_req) (int fd, struct char_session_data* sd);
- void (*delete2_accept) (int fd, struct char_session_data* sd);
- void (*delete2_cancel) (int fd, struct char_session_data* sd);
- void (*send_account_id) (int fd, int account_id);
- void (*parse_char_connect) (int fd, struct char_session_data* sd, uint32 ipl);
- void (*send_map_info) (int fd, int i, uint32 subnet_map_ip, struct mmo_charstatus *cd);
- void (*send_wait_char_server) (int fd);
- int (*search_default_maps_mapserver) (struct mmo_charstatus *cd);
- void (*parse_char_select) (int fd, struct char_session_data* sd, uint32 ipl);
- void (*creation_failed) (int fd, int result);
- void (*creation_ok) (int fd, struct mmo_charstatus *char_dat);
- void (*parse_char_create_new_char) (int fd, struct char_session_data* sd);
- void (*delete_char_failed) (int fd, int flag);
- void (*delete_char_ok) (int fd);
- void (*parse_char_delete_char) (int fd, struct char_session_data* sd, unsigned short cmd);
- void (*parse_char_ping) (int fd);
- void (*allow_rename) (int fd, int flag);
- void (*parse_char_rename_char) (int fd, struct char_session_data* sd);
- void (*parse_char_rename_char2) (int fd, struct char_session_data* sd);
- void (*rename_char_ack) (int fd, int flag);
- void (*parse_char_rename_char_confirm) (int fd, struct char_session_data* sd);
- void (*captcha_notsupported) (int fd);
- void (*parse_char_request_captcha) (int fd);
- void (*parse_char_check_captcha) (int fd);
- void (*parse_char_delete2_req) (int fd, struct char_session_data* sd);
- void (*parse_char_delete2_accept) (int fd, struct char_session_data* sd);
- void (*parse_char_delete2_cancel) (int fd, struct char_session_data* sd);
- void (*login_map_server_ack) (int fd, uint8 flag);
- void (*parse_char_login_map_server) (int fd, uint32 ipl);
- void (*parse_char_pincode_check) (int fd, struct char_session_data* sd);
- void (*parse_char_pincode_window) (int fd, struct char_session_data* sd);
- void (*parse_char_pincode_change) (int fd, struct char_session_data* sd);
- void (*parse_char_pincode_first_pin) (int fd, struct char_session_data* sd);
- void (*parse_char_request_chars) (int fd, struct char_session_data* sd);
- void (*change_character_slot_ack) (int fd,
-# 261 "../../../server-code/src/char/char.h" 3 4
- _Bool
-# 261 "../../../server-code/src/char/char.h"
- ret);
- void (*parse_char_move_character) (int fd, struct char_session_data* sd);
- int (*parse_char_unknown_packet) (int fd, uint32 ipl);
- int (*parse_char) (int fd);
- int (*broadcast_user_count) (int tid, int64 tick, int id, intptr_t data);
- int (*send_accounts_tologin_sub) (union DBKey key, struct DBData *data, va_list ap);
- int (*send_accounts_tologin) (int tid, int64 tick, int id, intptr_t data);
- int (*check_connect_login_server) (int tid, int64 tick, int id, intptr_t data);
- int (*online_data_cleanup_sub) (union DBKey key, struct DBData *data, va_list ap);
- int (*online_data_cleanup) (int tid, int64 tick, int id, intptr_t data);
- void (*sql_config_read) (const char* cfgName);
- void (*config_dispatch) (char *w1, char *w2);
- int (*config_read) (const char* cfgName);
-};
-
-
-extern int char_name_option;
-extern char char_name_letters[];
-extern
-# 279 "../../../server-code/src/char/char.h" 3 4
- _Bool
-# 279 "../../../server-code/src/char/char.h"
- char_gm_read;
-extern int autosave_interval;
-extern int save_log;
-extern char db_path[];
-extern char char_db[256];
-extern char scdata_db[256];
-extern char cart_db[256];
-extern char inventory_db[256];
-extern char charlog_db[256];
-extern char storage_db[256];
-extern char interlog_db[256];
-extern char skill_db[256];
-extern char memo_db[256];
-extern char guild_db[256];
-extern char guild_alliance_db[256];
-extern char guild_castle_db[256];
-extern char guild_expulsion_db[256];
-extern char guild_member_db[256];
-extern char guild_position_db[256];
-extern char guild_skill_db[256];
-extern char guild_storage_db[256];
-extern char party_db[256];
-extern char pet_db[256];
-extern char mail_db[256];
-extern char auction_db[256];
-extern char quest_db[256];
-extern char homunculus_db[256];
-extern char skill_homunculus_db[256];
-extern char mercenary_db[256];
-extern char mercenary_owner_db[256];
-extern char ragsrvinfo_db[256];
-extern char elemental_db[256];
-extern char acc_reg_num_db[32];
-extern char acc_reg_str_db[32];
-extern char char_reg_str_db[32];
-extern char char_reg_num_db[32];
-
-extern int guild_exp_rate;
-extern int log_inter;
-
-void char_load_defaults(void);
-void char_defaults(void);
-
-
-extern struct char_interface *chr;
-# 25 "../../../server-code/src/char/char.c" 2
-
-# 1 "../../../server-code/src/char/HPMchar.h" 1
-# 28 "../../../server-code/src/char/HPMchar.h"
-# 1 "../../../server-code/src/common/HPM.h" 1
-# 29 "../../../server-code/src/common/HPM.h"
-# 1 "../../../server-code/src/common/HPMi.h" 1
-# 24 "../../../server-code/src/common/HPMi.h"
-# 1 "../../../server-code/src/common/console.h" 1
-# 25 "../../../server-code/src/common/console.h"
-# 1 "../../../server-code/src/common/mutex.h" 1
-# 26 "../../../server-code/src/common/mutex.h"
-typedef struct ramutex ramutex;
-typedef struct racond racond;
-
-
-
-
-
-
-
-ramutex *ramutex_create(void);
-
-
-
-
-
-
-void ramutex_destroy(ramutex *m);
-
-
-
-
-
-
-void ramutex_lock(ramutex *m);
-# 58 "../../../server-code/src/common/mutex.h"
-
-# 58 "../../../server-code/src/common/mutex.h" 3 4
-_Bool
-# 58 "../../../server-code/src/common/mutex.h"
- ramutex_trylock(ramutex *m);
-
-
-
-
-
-
-void ramutex_unlock(ramutex *m);
-
-
-
-
-
-
-
-racond *racond_create(void);
-
-
-
-
-
-
-void racond_destroy(racond *c);
-# 89 "../../../server-code/src/common/mutex.h"
-void racond_wait(racond *c, ramutex *m, sysint timeout_ticks);
-# 99 "../../../server-code/src/common/mutex.h"
-void racond_signal(racond *c);
-# 108 "../../../server-code/src/common/mutex.h"
-void racond_broadcast(racond *c);
-# 26 "../../../server-code/src/common/console.h" 2
-# 1 "../../../server-code/src/common/spinlock.h" 1
-# 31 "../../../server-code/src/common/spinlock.h"
-# 1 "../../../server-code/src/common/atomic.h" 1
-# 110 "../../../server-code/src/common/atomic.h"
-static __attribute__((always_inline)) inline int64 InterlockedExchangeAdd64(volatile int64 *addend, int64 increment){
- return __sync_fetch_and_add(addend, increment);
-}
-
-static __attribute__((always_inline)) inline int32 InterlockedExchangeAdd(volatile int32 *addend, int32 increment){
- return __sync_fetch_and_add(addend, increment);
-}
-
-static __attribute__((always_inline)) inline int64 InterlockedIncrement64(volatile int64 *addend){
- return __sync_add_and_fetch(addend, 1);
-}
-
-static __attribute__((always_inline)) inline int32 InterlockedIncrement(volatile int32 *addend){
- return __sync_add_and_fetch(addend, 1);
-}
-
-static __attribute__((always_inline)) inline int64 InterlockedDecrement64(volatile int64 *addend){
- return __sync_sub_and_fetch(addend, 1);
-}
-
-static __attribute__((always_inline)) inline int32 InterlockedDecrement(volatile int32 *addend){
- return __sync_sub_and_fetch(addend, 1);
-}
-
-static __attribute__((always_inline)) inline int64 InterlockedCompareExchange64(volatile int64 *dest, int64 exch, int64 cmp){
- return __sync_val_compare_and_swap(dest, cmp, exch);
-}
-
-static __attribute__((always_inline)) inline int32 InterlockedCompareExchange(volatile int32 *dest, int32 exch, int32 cmp){
- return __sync_val_compare_and_swap(dest, cmp, exch);
-}
-
-static __attribute__((always_inline)) inline int64 InterlockedExchange64(volatile int64 *target, int64 val){
- return __sync_lock_test_and_set(target, val);
-}
-
-static __attribute__((always_inline)) inline int32 InterlockedExchange(volatile int32 *target, int32 val){
- return __sync_lock_test_and_set(target, val);
-}
-# 32 "../../../server-code/src/common/spinlock.h" 2
-
-# 1 "../../../server-code/src/common/thread.h" 1
-# 26 "../../../server-code/src/common/thread.h"
-typedef struct rAthread rAthread;
-typedef void* (*rAthreadProc)(void*);
-
-typedef enum RATHREAD_PRIO {
- RAT_PRIO_LOW = 0,
- RAT_PRIO_NORMAL,
- RAT_PRIO_HIGH
-} RATHREAD_PRIO;
-# 45 "../../../server-code/src/common/thread.h"
-rAthread *rathread_create(rAthreadProc entryPoint, void *param);
-# 58 "../../../server-code/src/common/thread.h"
-rAthread *rathread_createEx(rAthreadProc entryPoint, void *param, size_t szStack, RATHREAD_PRIO prio);
-# 68 "../../../server-code/src/common/thread.h"
-void rathread_destroy(rAthread *handle);
-# 79 "../../../server-code/src/common/thread.h"
-rAthread *rathread_self(void);
-# 90 "../../../server-code/src/common/thread.h"
-int rathread_get_tid(void);
-# 101 "../../../server-code/src/common/thread.h"
-
-# 101 "../../../server-code/src/common/thread.h" 3 4
-_Bool
-# 101 "../../../server-code/src/common/thread.h"
- rathread_wait(rAthread *handle, void **out_exitCode);
-# 110 "../../../server-code/src/common/thread.h"
-void rathread_prio_set(rAthread *handle, RATHREAD_PRIO prio);
-
-
-
-
-
-
-
-RATHREAD_PRIO rathread_prio_get(rAthread *handle);
-# 128 "../../../server-code/src/common/thread.h"
-void rathread_yield(void);
-
-void rathread_init(void);
-void rathread_final(void);
-# 34 "../../../server-code/src/common/spinlock.h" 2
-# 47 "../../../server-code/src/common/spinlock.h"
-typedef struct SPIN_LOCK{
- volatile int32 lock;
- volatile int32 nest;
-
- volatile int32 sync_lock;
-} __attribute__((aligned(64))) SPIN_LOCK;
-
-
-
-
-static __attribute__((always_inline)) inline void InitializeSpinLock(SPIN_LOCK *lck){
- lck->lock = 0;
- lck->nest = 0;
- lck->sync_lock = 0;
-}
-
-static __attribute__((always_inline)) inline void FinalizeSpinLock(SPIN_LOCK *lck){
- return;
-}
-
-
-
-
-
-static __attribute__((always_inline)) inline void EnterSpinLock(SPIN_LOCK *lck){
- int tid = rathread_get_tid();
-
-
-
- do { if(InterlockedCompareExchange((&lck->sync_lock), 1, 0) == 0) break; rathread_yield(); } while( 1);
- if(InterlockedCompareExchange(&lck->lock, tid, tid) == tid){
- InterlockedIncrement(&lck->nest);
- do { InterlockedExchange((&lck->sync_lock), 0); } while(0);
- return;
- }
-
- do { InterlockedExchange((&lck->sync_lock), 0); } while(0);
-
-
- while(1){
- if(InterlockedCompareExchange(&lck->lock, tid, 0) == 0){
- InterlockedIncrement(&lck->nest);
- return;
- }
- rathread_yield();
- }
-
-}
-
-
-static __attribute__((always_inline)) inline void LeaveSpinLock(SPIN_LOCK *lck){
- int tid = rathread_get_tid();
-
- do { if(InterlockedCompareExchange((&lck->sync_lock), 1, 0) == 0) break; rathread_yield(); } while( 1);
-
- if(InterlockedCompareExchange(&lck->lock, tid, tid) == tid){
- if(InterlockedDecrement(&lck->nest) == 0)
- InterlockedExchange(&lck->lock, 0);
- }
-
- do { InterlockedExchange((&lck->sync_lock), 0); } while(0);
-}
-# 27 "../../../server-code/src/common/console.h" 2
-
-
-
-struct Sql;
-# 41 "../../../server-code/src/common/console.h"
-typedef void (*CParseFunc)(char *line);
-# 56 "../../../server-code/src/common/console.h"
-enum CONSOLE_PARSE_ENTRY_TYPE {
- CPET_UNKNOWN,
- CPET_FUNCTION,
- CPET_CATEGORY,
-};
-
-struct CParseEntry {
- char cmd[20];
- int type;
- union {
- CParseFunc func;
- struct { int _max_; int _len_; struct CParseEntry * *_data_; } children;
- } u;
-};
-
-struct console_input_interface {
-
-
- SPIN_LOCK ptlock;
- rAthread *pthread;
- volatile int32 ptstate;
- ramutex *ptmutex;
- racond *ptcond;
-
- struct { int _max_; int _len_; struct CParseEntry * *_data_; } command_list;
- struct { int _max_; int _len_; struct CParseEntry * *_data_; } commands;
-
- struct Sql *SQL;
-
- void (*parse_init) (void);
- void (*parse_final) (void);
- int (*parse_timer) (int tid, int64 tick, int id, intptr_t data);
- void *(*pthread_main) (void *x);
- void (*parse) (char* line);
- void (*parse_sub) (char* line);
- int (*key_pressed) (void);
- void (*load_defaults) (void);
- void (*parse_list_subs) (struct CParseEntry *cmd, unsigned char depth);
- void (*addCommand) (char *name, CParseFunc func);
- void (*setSQL) (struct Sql *SQL_handle);
-
-
-
-};
-
-struct console_interface {
- void (*init) (void);
- void (*final) (void);
- void (*display_title) (void);
- void (*display_gplnotice) (void);
-
- struct console_input_interface *input;
-};
-
-
-void console_defaults(void);
-
-
-extern struct console_interface *console;
-# 25 "../../../server-code/src/common/HPMi.h" 2
-
-# 1 "../../../server-code/src/common/showmsg.h" 1
-# 29 "../../../server-code/src/common/showmsg.h"
-struct config_setting_t;
-# 89 "../../../server-code/src/common/showmsg.h"
-enum msg_type {
- MSG_NONE,
- MSG_STATUS,
- MSG_SQL,
- MSG_INFORMATION,
- MSG_NOTICE,
- MSG_WARNING,
- MSG_DEBUG,
- MSG_ERROR,
- MSG_FATALERROR
-};
-
-struct showmsg_interface {
-
-# 102 "../../../server-code/src/common/showmsg.h" 3 4
-_Bool
-# 102 "../../../server-code/src/common/showmsg.h"
- stdout_with_ansisequence;
- int silent;
- int console_log;
- char timestamp_format[20];
-
- void (*init) (void);
- void (*final) (void);
-
- void (*clearScreen) (void);
- int (*showMessageV) (const char *string, va_list ap);
-
- void (*showMessage) (const char *, ...) __attribute__((format(printf, 1, 2)));
- void (*showStatus) (const char *, ...) __attribute__((format(printf, 1, 2)));
- void (*showSQL) (const char *, ...) __attribute__((format(printf, 1, 2)));
- void (*showInfo) (const char *, ...) __attribute__((format(printf, 1, 2)));
- void (*showNotice) (const char *, ...) __attribute__((format(printf, 1, 2)));
- void (*showWarning) (const char *, ...) __attribute__((format(printf, 1, 2)));
- void (*showDebug) (const char *, ...) __attribute__((format(printf, 1, 2)));
- void (*showError) (const char *, ...) __attribute__((format(printf, 1, 2)));
- void (*showFatalError) (const char *, ...) __attribute__((format(printf, 1, 2)));
- void (*showConfigWarning) (struct config_setting_t *config, const char *string, ...) __attribute__((format(printf, 2, 3)));
-};
-# 140 "../../../server-code/src/common/showmsg.h"
-void showmsg_defaults(void);
-
-
-extern struct showmsg_interface *showmsg;
-# 27 "../../../server-code/src/common/HPMi.h" 2
-
-struct Sql;
-struct script_state;
-struct AtCommandInfo;
-struct socket_data;
-struct map_session_data;
-struct hplugin_data_store;
-
-
-
-
-struct hplugin_info {
- char* name;
- enum server_types type;
- char* version;
- char* req_version;
-};
-
-struct s_HPMDataCheck {
- char *name;
- unsigned int size;
- int type;
-};
-
-
-
-enum hp_event_types {
- HPET_INIT,
- HPET_FINAL,
- HPET_READY,
- HPET_POST_FINAL,
- HPET_PRE_INIT,
- HPET_MAX,
-};
-
-enum HPluginPacketHookingPoints {
- hpClif_Parse,
- hpChrif_Parse,
- hpParse_FromMap,
- hpParse_FromLogin,
- hpParse_Char,
- hpParse_FromChar,
- hpParse_Login,
-
- hpPHP_MAX,
-};
-
-enum HPluginHookType {
- HOOK_TYPE_PRE,
- HOOK_TYPE_POST,
-};
-
-
-
-
-enum HPluginDataTypes {
- HPDT_UNKNOWN,
- HPDT_SESSION,
- HPDT_MSD,
- HPDT_NPCD,
- HPDT_MAP,
- HPDT_INSTANCE,
- HPDT_GUILD,
- HPDT_PARTY,
- HPDT_MOBDB,
- HPDT_MOBDATA,
- HPDT_ITEMDATA,
- HPDT_BGDATA,
- HPDT_AUTOTRADE_VEND,
-};
-
-
-enum HPluginConfType {
- HPCT_BATTLE,
- HPCT_LOGIN,
- HPCT_CHAR,
- HPCT_CHAR_INTER,
- HPCT_MAP_INTER,
- HPCT_LOG,
- HPCT_SCRIPT,
- HPCT_MAX,
-};
-# 220 "../../../server-code/src/common/HPMi.h"
-struct HPMi_interface {
-
- unsigned int pid;
-
- void (*event[HPET_MAX]) (void);
-
-# 225 "../../../server-code/src/common/HPMi.h" 3 4
-_Bool
-# 225 "../../../server-code/src/common/HPMi.h"
- (*addCommand) (char *name,
-# 225 "../../../server-code/src/common/HPMi.h" 3 4
- _Bool
-# 225 "../../../server-code/src/common/HPMi.h"
- (*func)(const int fd, struct map_session_data* sd, const char* command, const char* message,struct AtCommandInfo *info));
-
-# 226 "../../../server-code/src/common/HPMi.h" 3 4
-_Bool
-# 226 "../../../server-code/src/common/HPMi.h"
- (*addScript) (char *name, char *args,
-# 226 "../../../server-code/src/common/HPMi.h" 3 4
- _Bool
-# 226 "../../../server-code/src/common/HPMi.h"
- (*func)(struct script_state *st),
-# 226 "../../../server-code/src/common/HPMi.h" 3 4
- _Bool
-# 226 "../../../server-code/src/common/HPMi.h"
- isDeprecated);
- void (*addCPCommand) (char *name, CParseFunc func);
-
- void (*addToHPData) (enum HPluginDataTypes type, uint32 pluginID, struct hplugin_data_store **storeptr, void *data, uint32 classid,
-# 229 "../../../server-code/src/common/HPMi.h" 3 4
- _Bool
-# 229 "../../../server-code/src/common/HPMi.h"
- autofree);
- void *(*getFromHPData) (enum HPluginDataTypes type, uint32 pluginID, struct hplugin_data_store *store, uint32 classid);
- void (*removeFromHPData) (enum HPluginDataTypes type, uint32 pluginID, struct hplugin_data_store *store, uint32 classid);
-
-
-# 233 "../../../server-code/src/common/HPMi.h" 3 4
-_Bool
-# 233 "../../../server-code/src/common/HPMi.h"
- (*addPacket) (unsigned short cmd, unsigned short length, void (*receive)(int fd), unsigned int point, unsigned int pluginID);
-
-
-# 235 "../../../server-code/src/common/HPMi.h" 3 4
-_Bool
-# 235 "../../../server-code/src/common/HPMi.h"
- (*AddHook) (enum HPluginHookType type, const char *target, void *hook, unsigned int pID);
- void (*HookStop) (const char *func, unsigned int pID);
-
-# 237 "../../../server-code/src/common/HPMi.h" 3 4
-_Bool
-# 237 "../../../server-code/src/common/HPMi.h"
- (*HookStopped) (void);
-
-
-# 239 "../../../server-code/src/common/HPMi.h" 3 4
-_Bool
-# 239 "../../../server-code/src/common/HPMi.h"
- (*addArg) (unsigned int pluginID, char *name,
-# 239 "../../../server-code/src/common/HPMi.h" 3 4
- _Bool
-# 239 "../../../server-code/src/common/HPMi.h"
- has_param, CmdlineExecFunc func, const char *help);
-
-
-# 241 "../../../server-code/src/common/HPMi.h" 3 4
-_Bool
-# 241 "../../../server-code/src/common/HPMi.h"
- (*addConf) (unsigned int pluginID, enum HPluginConfType type, char *name, void (*parse_func) (const char *key, const char *val), int (*return_func) (const char *key));
-
- void (*addPCGPermission) (unsigned int pluginID, char *name, unsigned int *mask);
-
- struct Sql *sql_handle;
-};
-# 30 "../../../server-code/src/common/HPM.h" 2
-# 44 "../../../server-code/src/common/HPM.h"
-# 1 "/usr/include/dlfcn.h" 1 3 4
-# 24 "/usr/include/dlfcn.h" 3 4
-# 1 "/usr/lib/gcc/x86_64-linux-gnu/5/include/stddef.h" 1 3 4
-# 25 "/usr/include/dlfcn.h" 2 3 4
-
-
-# 1 "/usr/include/x86_64-linux-gnu/bits/dlfcn.h" 1 3 4
-# 28 "/usr/include/dlfcn.h" 2 3 4
-# 52 "/usr/include/dlfcn.h" 3 4
-
-
-
-
-
-# 56 "/usr/include/dlfcn.h" 3 4
-extern void *dlopen (const char *__file, int __mode) __attribute__ ((__nothrow__));
-
-
-
-extern int dlclose (void *__handle) __attribute__ ((__nothrow__)) __attribute__ ((__nonnull__ (1)));
-
-
-
-extern void *dlsym (void *__restrict __handle,
- const char *__restrict __name) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (2)));
-# 82 "/usr/include/dlfcn.h" 3 4
-extern char *dlerror (void) __attribute__ ((__nothrow__ , __leaf__));
-# 188 "/usr/include/dlfcn.h" 3 4
-
-# 45 "../../../server-code/src/common/HPM.h" 2
-# 64 "../../../server-code/src/common/HPM.h"
-# 1 "/usr/include/string.h" 1 3 4
-# 27 "/usr/include/string.h" 3 4
-
-
-
-
-
-# 1 "/usr/lib/gcc/x86_64-linux-gnu/5/include/stddef.h" 1 3 4
-# 33 "/usr/include/string.h" 2 3 4
-
-
-
-
-
-
-
-
-
-extern void *memcpy (void *__restrict __dest, const void *__restrict __src,
- size_t __n) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1, 2)));
-
-
-extern void *memmove (void *__dest, const void *__src, size_t __n)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1, 2)));
-
-
-
-
-
-
-extern void *memccpy (void *__restrict __dest, const void *__restrict __src,
- int __c, size_t __n)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1, 2)));
-
-
-
-
-
-extern void *memset (void *__s, int __c, size_t __n) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-
-
-extern int memcmp (const void *__s1, const void *__s2, size_t __n)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__pure__)) __attribute__ ((__nonnull__ (1, 2)));
-# 92 "/usr/include/string.h" 3 4
-extern void *memchr (const void *__s, int __c, size_t __n)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__pure__)) __attribute__ ((__nonnull__ (1)));
-
-
-# 123 "/usr/include/string.h" 3 4
-
-
-extern char *strcpy (char *__restrict __dest, const char *__restrict __src)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1, 2)));
-
-extern char *strncpy (char *__restrict __dest,
- const char *__restrict __src, size_t __n)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1, 2)));
-
-
-extern char *strcat (char *__restrict __dest, const char *__restrict __src)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1, 2)));
-
-extern char *strncat (char *__restrict __dest, const char *__restrict __src,
- size_t __n) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1, 2)));
-
-
-extern int strcmp (const char *__s1, const char *__s2)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__pure__)) __attribute__ ((__nonnull__ (1, 2)));
-
-extern int strncmp (const char *__s1, const char *__s2, size_t __n)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__pure__)) __attribute__ ((__nonnull__ (1, 2)));
-
-
-extern int strcoll (const char *__s1, const char *__s2)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__pure__)) __attribute__ ((__nonnull__ (1, 2)));
-
-extern size_t strxfrm (char *__restrict __dest,
- const char *__restrict __src, size_t __n)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (2)));
-
-# 162 "/usr/include/string.h" 3 4
-extern int strcoll_l (const char *__s1, const char *__s2, __locale_t __l)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__pure__)) __attribute__ ((__nonnull__ (1, 2, 3)));
-
-extern size_t strxfrm_l (char *__dest, const char *__src, size_t __n,
- __locale_t __l) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (2, 4)));
-
-
-
-
-extern char *strdup (const char *__s)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__malloc__)) __attribute__ ((__nonnull__ (1)));
-
-
-
-
-
-
-extern char *strndup (const char *__string, size_t __n)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__malloc__)) __attribute__ ((__nonnull__ (1)));
-# 206 "/usr/include/string.h" 3 4
-
-# 231 "/usr/include/string.h" 3 4
-extern char *strchr (const char *__s, int __c)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__pure__)) __attribute__ ((__nonnull__ (1)));
-# 258 "/usr/include/string.h" 3 4
-extern char *strrchr (const char *__s, int __c)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__pure__)) __attribute__ ((__nonnull__ (1)));
-
-
-# 277 "/usr/include/string.h" 3 4
-
-
-
-extern size_t strcspn (const char *__s, const char *__reject)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__pure__)) __attribute__ ((__nonnull__ (1, 2)));
-
-
-extern size_t strspn (const char *__s, const char *__accept)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__pure__)) __attribute__ ((__nonnull__ (1, 2)));
-# 310 "/usr/include/string.h" 3 4
-extern char *strpbrk (const char *__s, const char *__accept)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__pure__)) __attribute__ ((__nonnull__ (1, 2)));
-# 337 "/usr/include/string.h" 3 4
-extern char *strstr (const char *__haystack, const char *__needle)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__pure__)) __attribute__ ((__nonnull__ (1, 2)));
-
-
-
-
-extern char *strtok (char *__restrict __s, const char *__restrict __delim)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (2)));
-
-
-
-
-extern char *__strtok_r (char *__restrict __s,
- const char *__restrict __delim,
- char **__restrict __save_ptr)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (2, 3)));
-
-extern char *strtok_r (char *__restrict __s, const char *__restrict __delim,
- char **__restrict __save_ptr)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (2, 3)));
-# 392 "/usr/include/string.h" 3 4
-
-
-extern size_t strlen (const char *__s)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__pure__)) __attribute__ ((__nonnull__ (1)));
-
-
-
-
-
-extern size_t strnlen (const char *__string, size_t __maxlen)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__pure__)) __attribute__ ((__nonnull__ (1)));
-
-
-
-
-
-extern char *strerror (int __errnum) __attribute__ ((__nothrow__ , __leaf__));
-
-# 422 "/usr/include/string.h" 3 4
-extern int strerror_r (int __errnum, char *__buf, size_t __buflen) __asm__ ("" "__xpg_strerror_r") __attribute__ ((__nothrow__ , __leaf__))
-
- __attribute__ ((__nonnull__ (2)));
-# 440 "/usr/include/string.h" 3 4
-extern char *strerror_l (int __errnum, __locale_t __l) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-
-extern void __bzero (void *__s, size_t __n) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-
-
-
-extern void bcopy (const void *__src, void *__dest, size_t __n)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1, 2)));
-
-
-extern void bzero (void *__s, size_t __n) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-
-
-extern int bcmp (const void *__s1, const void *__s2, size_t __n)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__pure__)) __attribute__ ((__nonnull__ (1, 2)));
-# 484 "/usr/include/string.h" 3 4
-extern char *index (const char *__s, int __c)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__pure__)) __attribute__ ((__nonnull__ (1)));
-# 512 "/usr/include/string.h" 3 4
-extern char *rindex (const char *__s, int __c)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__pure__)) __attribute__ ((__nonnull__ (1)));
-
-
-
-
-extern int ffs (int __i) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__const__));
-# 529 "/usr/include/string.h" 3 4
-extern int strcasecmp (const char *__s1, const char *__s2)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__pure__)) __attribute__ ((__nonnull__ (1, 2)));
-
-
-extern int strncasecmp (const char *__s1, const char *__s2, size_t __n)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__pure__)) __attribute__ ((__nonnull__ (1, 2)));
-# 552 "/usr/include/string.h" 3 4
-extern char *strsep (char **__restrict __stringp,
- const char *__restrict __delim)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1, 2)));
-
-
-
-
-extern char *strsignal (int __sig) __attribute__ ((__nothrow__ , __leaf__));
-
-
-extern char *__stpcpy (char *__restrict __dest, const char *__restrict __src)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1, 2)));
-extern char *stpcpy (char *__restrict __dest, const char *__restrict __src)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1, 2)));
-
-
-
-extern char *__stpncpy (char *__restrict __dest,
- const char *__restrict __src, size_t __n)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1, 2)));
-extern char *stpncpy (char *__restrict __dest,
- const char *__restrict __src, size_t __n)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1, 2)));
-# 639 "/usr/include/string.h" 3 4
-
-# 65 "../../../server-code/src/common/HPM.h" 2
-
-
-
-
-# 68 "../../../server-code/src/common/HPM.h"
-struct hplugin {
- void * dll;
- unsigned int idx;
- char *filename;
- struct hplugin_info *info;
- struct HPMi_interface *hpi;
-};
-
-
-
-
-struct hpm_symbol {
- const char *name;
- void *ptr;
-};
-
-
-
-
-struct hplugin_data_entry {
- uint32 pluginID;
- uint32 classid;
- struct {
- unsigned int free : 1;
- } flag;
- void *data;
-};
-
-
-
-
-struct hplugin_data_store {
- enum HPluginDataTypes type;
- struct { int _max_; int _len_; struct hplugin_data_entry * *_data_; } entries;
-};
-
-struct HPluginPacket {
- unsigned int pluginID;
- unsigned short cmd;
- short len;
- void (*receive) (int fd);
-};
-
-struct HPMFileNameCache {
- const char *addr;
- char *name;
-};
-
-
-struct HPConfListenStorage {
- unsigned int pluginID;
- char key[40];
- void (*parse_func) (const char *key, const char *val);
- int (*return_func) (const char *key);
-};
-
-
-struct HPM_interface {
-
- unsigned int version[2];
-
-# 128 "../../../server-code/src/common/HPM.h" 3 4
-_Bool
-# 128 "../../../server-code/src/common/HPM.h"
- off;
-
-# 129 "../../../server-code/src/common/HPM.h" 3 4
-_Bool
-# 129 "../../../server-code/src/common/HPM.h"
- hooking;
-
-
-# 131 "../../../server-code/src/common/HPM.h" 3 4
-_Bool
-# 131 "../../../server-code/src/common/HPM.h"
- force_return;
-
- struct { int _max_; int _len_; struct hplugin * *_data_; } plugins;
- struct { int _max_; int _len_; struct hpm_symbol * *_data_; } symbols;
-
- struct { int _max_; int _len_; struct HPluginPacket *_data_; } packets[hpPHP_MAX];
-
- struct {
-
- int count;
- struct HPMFileNameCache *data;
- } filenames;
-
- struct { int _max_; int _len_; struct HPConfListenStorage *_data_; } config_listeners[HPCT_MAX];
-
- struct { int _max_; int _len_; char * *_data_; } cmdline_load_plugins;
-
- void (*init) (void);
- void (*final) (void);
- struct hplugin * (*create) (void);
- struct hplugin * (*load) (const char* filename);
- void (*unload) (struct hplugin* plugin);
-
-# 153 "../../../server-code/src/common/HPM.h" 3 4
-_Bool
-# 153 "../../../server-code/src/common/HPM.h"
- (*exists) (const char *filename);
-
-# 154 "../../../server-code/src/common/HPM.h" 3 4
-_Bool
-# 154 "../../../server-code/src/common/HPM.h"
- (*iscompatible) (char* version);
- void (*event) (enum hp_event_types type);
- void *(*import_symbol) (char *name, unsigned int pID);
- void (*share) (void *value, const char *name);
- void (*config_read) (void);
- char *(*pid2name) (unsigned int pid);
- unsigned char (*parse_packets) (int fd, int packet_id, enum HPluginPacketHookingPoints point);
- void (*load_sub) (struct hplugin *plugin);
-
-# 162 "../../../server-code/src/common/HPM.h" 3 4
-_Bool
-# 162 "../../../server-code/src/common/HPM.h"
- (*addhook_sub) (enum HPluginHookType type, const char *target, void *hook, unsigned int pID);
-
-
-# 164 "../../../server-code/src/common/HPM.h" 3 4
-_Bool
-# 164 "../../../server-code/src/common/HPM.h"
- (*parseConf) (const char *w1, const char *w2, enum HPluginConfType point);
-
-# 165 "../../../server-code/src/common/HPM.h" 3 4
-_Bool
-# 165 "../../../server-code/src/common/HPM.h"
- (*getBattleConf) (const char* w1, int *value);
-
-
-# 167 "../../../server-code/src/common/HPM.h" 3 4
-_Bool
-# 167 "../../../server-code/src/common/HPM.h"
- (*DataCheck) (struct s_HPMDataCheck *src, unsigned int size, int version, char *name);
- void (*datacheck_init) (const struct s_HPMDataCheck *src, unsigned int length, int version);
- void (*datacheck_final) (void);
-
- void (*data_store_create) (struct hplugin_data_store **storeptr, enum HPluginDataTypes type);
- void (*data_store_destroy) (struct hplugin_data_store **storeptr);
-
-# 173 "../../../server-code/src/common/HPM.h" 3 4
-_Bool
-# 173 "../../../server-code/src/common/HPM.h"
- (*data_store_validate) (enum HPluginDataTypes type, struct hplugin_data_store **storeptr,
-# 173 "../../../server-code/src/common/HPM.h" 3 4
- _Bool
-# 173 "../../../server-code/src/common/HPM.h"
- initialize);
-
-
-# 175 "../../../server-code/src/common/HPM.h" 3 4
-_Bool
-# 175 "../../../server-code/src/common/HPM.h"
- (*data_store_validate_sub) (enum HPluginDataTypes type, struct hplugin_data_store **storeptr,
-# 175 "../../../server-code/src/common/HPM.h" 3 4
- _Bool
-# 175 "../../../server-code/src/common/HPM.h"
- initialize);
-};
-
-
-# 178 "../../../server-code/src/common/HPM.h" 3 4
-_Bool
-# 178 "../../../server-code/src/common/HPM.h"
-cmdline_arg_loadplugin (const char *name, const char *params);
-
-extern struct HPM_interface *HPM;
-
-void hpm_defaults(void);
-# 29 "../../../server-code/src/char/HPMchar.h" 2
-
-struct hplugin;
-
-
-# 32 "../../../server-code/src/char/HPMchar.h" 3 4
-_Bool
-# 32 "../../../server-code/src/char/HPMchar.h"
- HPM_char_data_store_validate(enum HPluginDataTypes type, struct hplugin_data_store **storeptr,
-# 32 "../../../server-code/src/char/HPMchar.h" 3 4
- _Bool
-# 32 "../../../server-code/src/char/HPMchar.h"
- initialize);
-
-void HPM_char_plugin_load_sub(struct hplugin *plugin);
-
-void HPM_char_do_final(void);
-
-void HPM_char_do_init(void);
-# 27 "../../../server-code/src/char/char.c" 2
-# 1 "../../../server-code/src/char/geoip.h" 1
-# 29 "../../../server-code/src/char/geoip.h"
-struct s_geoip {
- unsigned char *cache;
-
-# 31 "../../../server-code/src/char/geoip.h" 3 4
-_Bool
-# 31 "../../../server-code/src/char/geoip.h"
- active;
-};
-
-
-
-
-
-struct geoip_interface {
- struct s_geoip *data;
- const char* (*getcountry) (uint32 ipnum);
- void (*final) (
-# 41 "../../../server-code/src/char/geoip.h" 3 4
- _Bool
-# 41 "../../../server-code/src/char/geoip.h"
- shutdown);
- void (*init) (void);
-};
-
-
-void geoip_defaults(void);
-
-
-extern struct geoip_interface *geoip;
-# 28 "../../../server-code/src/char/char.c" 2
-# 1 "../../../server-code/src/char/int_auction.h" 1
-# 28 "../../../server-code/src/char/int_auction.h"
-struct DBMap;
-
-
-
-
-struct inter_auction_interface {
- struct DBMap *db;
- int (*count) (int char_id,
-# 35 "../../../server-code/src/char/int_auction.h" 3 4
- _Bool
-# 35 "../../../server-code/src/char/int_auction.h"
- buy);
- void (*save) (struct auction_data *auction);
- unsigned int (*create) (struct auction_data *auction);
- int (*end_timer) (int tid, int64 tick, int id, intptr_t data);
- void (*delete_) (struct auction_data *auction);
- void (*fromsql) (void);
- int (*parse_frommap) (int fd);
- int (*sql_init) (void);
- void (*sql_final) (void);
-};
-
-
-void inter_auction_defaults(void);
-
-
-extern struct inter_auction_interface *inter_auction;
-# 29 "../../../server-code/src/char/char.c" 2
-# 1 "../../../server-code/src/char/int_elemental.h" 1
-# 29 "../../../server-code/src/char/int_elemental.h"
-struct inter_elemental_interface {
- void (*sql_init) (void);
- void (*sql_final) (void);
- int (*parse_frommap) (int fd);
-};
-
-
-void inter_elemental_defaults(void);
-
-
-extern struct inter_elemental_interface *inter_elemental;
-# 30 "../../../server-code/src/char/char.c" 2
-# 1 "../../../server-code/src/char/int_guild.h" 1
-# 27 "../../../server-code/src/char/int_guild.h"
-enum {
- GS_BASIC = 0x0001,
- GS_MEMBER = 0x0002,
- GS_POSITION = 0x0004,
- GS_ALLIANCE = 0x0008,
- GS_EXPULSION = 0x0010,
- GS_SKILL = 0x0020,
- GS_EMBLEM = 0x0040,
- GS_CONNECT = 0x0080,
- GS_LEVEL = 0x0100,
- GS_MES = 0x0200,
- GS_MASK = 0x03FF,
- GS_BASIC_MASK = (GS_BASIC | GS_EMBLEM | GS_CONNECT | GS_LEVEL | GS_MES),
- GS_REMOVE = 0x8000,
-};
-
-
-
-
-struct inter_guild_interface {
- struct DBMap *guild_db;
- struct DBMap *castle_db;
- unsigned int exp[50];
-
- int (*save_timer) (int tid, int64 tick, int id, intptr_t data);
- int (*removemember_tosql) (int account_id, int char_id);
- int (*tosql) (struct guild *g, int flag);
- struct guild* (*fromsql) (int guild_id);
- int (*castle_tosql) (struct guild_castle *gc);
- struct guild_castle* (*castle_fromsql) (int castle_id);
-
-# 57 "../../../server-code/src/char/int_guild.h" 3 4
-_Bool
-# 57 "../../../server-code/src/char/int_guild.h"
- (*exp_parse_row) (char* split[], int column, int current);
- int (*CharOnline) (int char_id, int guild_id);
- int (*CharOffline) (int char_id, int guild_id);
- int (*sql_init) (void);
- int (*db_final) (union DBKey key, struct DBData *data, va_list ap);
- void (*sql_final) (void);
- int (*search_guildname) (const char *str);
-
-# 64 "../../../server-code/src/char/int_guild.h" 3 4
-_Bool
-# 64 "../../../server-code/src/char/int_guild.h"
- (*check_empty) (struct guild *g);
- unsigned int (*nextexp) (int level);
- int (*checkskill) (struct guild *g, int id);
- int (*calcinfo) (struct guild *g);
- int (*sex_changed) (int guild_id, int account_id, int char_id, short gender);
- int (*charname_changed) (int guild_id, int account_id, int char_id, char *name);
- int (*parse_frommap) (int fd);
- int (*leave) (int guild_id, int account_id, int char_id);
- int (*broken) (int guild_id);
-};
-
-
-void inter_guild_defaults(void);
-
-
-extern struct inter_guild_interface *inter_guild;
-# 31 "../../../server-code/src/char/char.c" 2
-# 1 "../../../server-code/src/char/int_homun.h" 1
-# 29 "../../../server-code/src/char/int_homun.h"
-struct inter_homunculus_interface {
- int (*sql_init) (void);
- void (*sql_final) (void);
- int (*parse_frommap) (int fd);
-};
-
-
-void inter_homunculus_defaults(void);
-
-
-extern struct inter_homunculus_interface *inter_homunculus;
-# 32 "../../../server-code/src/char/char.c" 2
-# 1 "../../../server-code/src/char/int_mail.h" 1
-# 26 "../../../server-code/src/char/int_mail.h"
-struct item;
-struct mail_data;
-struct mail_message;
-
-
-
-
-struct inter_mail_interface {
- int (*sql_init) (void);
- void (*sql_final) (void);
- int (*parse_frommap) (int fd);
- int (*fromsql) (int char_id, struct mail_data* md);
- int (*savemessage) (struct mail_message* msg);
-
-# 39 "../../../server-code/src/char/int_mail.h" 3 4
-_Bool
-# 39 "../../../server-code/src/char/int_mail.h"
- (*loadmessage) (int mail_id, struct mail_message* msg);
-
-# 40 "../../../server-code/src/char/int_mail.h" 3 4
-_Bool
-# 40 "../../../server-code/src/char/int_mail.h"
- (*DeleteAttach) (int mail_id);
- void (*sendmail) (int send_id, const char* send_name, int dest_id, const char* dest_name, const char* title, const char* body, int zeny, struct item *item);
-};
-
-
-void inter_mail_defaults(void);
-
-
-extern struct inter_mail_interface *inter_mail;
-# 33 "../../../server-code/src/char/char.c" 2
-# 1 "../../../server-code/src/char/int_mercenary.h" 1
-# 26 "../../../server-code/src/char/int_mercenary.h"
-struct mmo_charstatus;
-
-
-
-
-struct inter_mercenary_interface {
-
-# 32 "../../../server-code/src/char/int_mercenary.h" 3 4
-_Bool
-# 32 "../../../server-code/src/char/int_mercenary.h"
- (*owner_fromsql) (int char_id, struct mmo_charstatus *status);
-
-# 33 "../../../server-code/src/char/int_mercenary.h" 3 4
-_Bool
-# 33 "../../../server-code/src/char/int_mercenary.h"
- (*owner_tosql) (int char_id, struct mmo_charstatus *status);
-
-# 34 "../../../server-code/src/char/int_mercenary.h" 3 4
-_Bool
-# 34 "../../../server-code/src/char/int_mercenary.h"
- (*owner_delete) (int char_id);
- int (*sql_init) (void);
- void (*sql_final) (void);
- int (*parse_frommap) (int fd);
-};
-
-
-void inter_mercenary_defaults(void);
-
-
-extern struct inter_mercenary_interface *inter_mercenary;
-# 34 "../../../server-code/src/char/char.c" 2
-# 1 "../../../server-code/src/char/int_party.h" 1
-# 28 "../../../server-code/src/char/int_party.h"
-struct DBMap;
-
-
-enum {
- PS_CREATE = 0x01,
- PS_BASIC = 0x02,
- PS_LEADER = 0x04,
- PS_ADDMEMBER = 0x08,
- PS_DELMEMBER = 0x10,
- PS_BREAK = 0x20,
-};
-
-struct party_data {
- struct party party;
- unsigned int min_lv, max_lv;
- int family;
- unsigned char size;
-};
-
-
-
-
-struct inter_party_interface {
- struct party_data *pt;
- struct DBMap *db;
- int (*check_lv) (struct party_data *p);
- void (*calc_state) (struct party_data *p);
- int (*tosql) (struct party *p, int flag, int index);
- struct party_data* (*fromsql) (int party_id);
- int (*sql_init) (void);
- void (*sql_final) (void);
- struct party_data* (*search_partyname) (const char *str);
- int (*check_exp_share) (struct party_data *p);
- int (*check_empty) (struct party_data *p);
- int (*parse_frommap) (int fd);
- int (*leave) (int party_id,int account_id, int char_id);
- int (*CharOnline) (int char_id, int party_id);
- int (*CharOffline) (int char_id, int party_id);
-};
-
-
-void inter_party_defaults(void);
-
-
-extern struct inter_party_interface *inter_party;
-# 35 "../../../server-code/src/char/char.c" 2
-# 1 "../../../server-code/src/char/int_pet.h" 1
-# 26 "../../../server-code/src/char/int_pet.h"
-struct s_pet;
-
-
-
-
-struct inter_pet_interface {
- struct s_pet *pt;
- int (*tosql) (const struct s_pet *p);
- int (*fromsql) (int pet_id, struct s_pet* p);
- int (*sql_init) (void);
- void (*sql_final) (void);
- int (*delete_) (int pet_id);
- int (*parse_frommap) (int fd);
-};
-
-
-void inter_pet_defaults(void);
-
-
-extern struct inter_pet_interface *inter_pet;
-# 36 "../../../server-code/src/char/char.c" 2
-# 1 "../../../server-code/src/char/int_quest.h" 1
-# 29 "../../../server-code/src/char/int_quest.h"
-struct inter_quest_interface {
- int (*parse_frommap) (int fd);
-};
-
-
-void inter_quest_defaults(void);
-
-
-extern struct inter_quest_interface *inter_quest;
-# 37 "../../../server-code/src/char/char.c" 2
-# 1 "../../../server-code/src/char/int_storage.h" 1
-# 26 "../../../server-code/src/char/int_storage.h"
-struct storage_data;
-struct guild_storage;
-
-
-
-
-struct inter_storage_interface {
- int (*tosql) (int account_id, struct storage_data* p);
- int (*fromsql) (int account_id, struct storage_data* p);
- int (*guild_storage_tosql) (int guild_id, const struct guild_storage *p);
- int (*guild_storage_fromsql) (int guild_id, struct guild_storage* p);
- int (*sql_init) (void);
- void (*sql_final) (void);
- int (*delete_) (int account_id);
- int (*guild_storage_delete) (int guild_id);
- int (*parse_frommap) (int fd);
-};
-
-
-void inter_storage_defaults(void);
-
-
-extern struct inter_storage_interface *inter_storage;
-# 38 "../../../server-code/src/char/char.c" 2
-# 1 "../../../server-code/src/char/inter.h" 1
-# 30 "../../../server-code/src/char/inter.h"
-struct Sql;
-
-
-
-
-struct inter_interface {
- struct Sql *sql_handle;
- const char* (*msg_txt) (int msg_number);
-
-# 38 "../../../server-code/src/char/inter.h" 3 4
-_Bool
-# 38 "../../../server-code/src/char/inter.h"
- (*msg_config_read) (const char *cfg_name,
-# 38 "../../../server-code/src/char/inter.h" 3 4
- _Bool
-# 38 "../../../server-code/src/char/inter.h"
- allow_override);
- void (*do_final_msg) (void);
- const char* (*job_name) (int class_);
- void (*vmsg_to_fd) (int fd, int u_fd, int aid, char* msg, va_list ap);
- void (*msg_to_fd) (int fd, int u_fd, int aid, char *msg, ...) __attribute__((format(printf, 4, 5)));
- void (*savereg) (int account_id, int char_id, const char *key, unsigned int index, intptr_t val,
-# 43 "../../../server-code/src/char/inter.h" 3 4
- _Bool
-# 43 "../../../server-code/src/char/inter.h"
- is_string);
- int (*accreg_fromsql) (int account_id,int char_id, int fd, int type);
- int (*config_read) (const char* cfgName);
- int (*vlog) (char* fmt, va_list ap);
- int (*log) (char* fmt, ...);
- int (*init_sql) (const char *file);
- int (*mapif_init) (int fd);
- int (*check_ttl_wisdata_sub) (union DBKey key, struct DBData *data, va_list ap);
- int (*check_ttl_wisdata) (void);
- int (*check_length) (int fd, int length);
- int (*parse_frommap) (int fd);
- void (*final) (void);
-};
-
-
-extern unsigned int party_share_level;
-
-void inter_defaults(void);
-
-
-extern struct inter_interface *inter;
-# 39 "../../../server-code/src/char/char.c" 2
-# 1 "../../../server-code/src/char/loginif.h" 1
-# 26 "../../../server-code/src/char/loginif.h"
-struct char_session_data;
-
-
-
-
-struct loginif_interface {
- void (*init) (void);
- void (*final) (void);
- void (*reset) (void);
- void (*check_shutdown) (void);
- void (*on_disconnect) (void);
- void (*on_ready) (void);
- void (*block_account) (int account_id, int flag);
- void (*ban_account) (int account_id, short year, short month, short day, short hour, short minute, short second);
- void (*unban_account) (int account_id);
- void (*changesex) (int account_id);
- void (*auth) (int fd, struct char_session_data* sd, uint32 ipl);
- void (*send_users_count) (int users);
- void (*connect_to_server) (void);
-};
-
-
-void loginif_defaults(void);
-
-
-extern struct loginif_interface *loginif;
-# 40 "../../../server-code/src/char/char.c" 2
-# 1 "../../../server-code/src/char/mapif.h" 1
-# 26 "../../../server-code/src/char/mapif.h"
-struct WisData;
-
-
-
-
-struct mapif_interface {
- void (*ban) (int id, unsigned int flag, int status);
- void (*server_init) (int id);
- void (*server_destroy) (int id);
- void (*server_reset) (int id);
- void (*on_disconnect) (int id);
- void (*on_parse_accinfo) (int account_id, int u_fd, int u_aid, int u_group, int map_fd);
- void (*char_ban) (int char_id, time_t timestamp);
- int (*sendall) (const unsigned char *buf, unsigned int len);
- int (*sendallwos) (int sfd, unsigned char *buf, unsigned int len);
- int (*send) (int fd, unsigned char *buf, unsigned int len);
- void (*send_users_count) (int users);
- void (*auction_message) (int char_id, unsigned char result);
- void (*auction_sendlist) (int fd, int char_id, short count, short pages, unsigned char *buf);
- void (*parse_auction_requestlist) (int fd);
- void (*auction_register) (int fd, struct auction_data *auction);
- void (*parse_auction_register) (int fd);
- void (*auction_cancel) (int fd, int char_id, unsigned char result);
- void (*parse_auction_cancel) (int fd);
- void (*auction_close) (int fd, int char_id, unsigned char result);
- void (*parse_auction_close) (int fd);
- void (*auction_bid) (int fd, int char_id, int bid, unsigned char result);
- void (*parse_auction_bid) (int fd);
-
-# 54 "../../../server-code/src/char/mapif.h" 3 4
-_Bool
-# 54 "../../../server-code/src/char/mapif.h"
- (*elemental_create) (struct s_elemental *ele);
-
-# 55 "../../../server-code/src/char/mapif.h" 3 4
-_Bool
-# 55 "../../../server-code/src/char/mapif.h"
- (*elemental_save) (const struct s_elemental *ele);
-
-# 56 "../../../server-code/src/char/mapif.h" 3 4
-_Bool
-# 56 "../../../server-code/src/char/mapif.h"
- (*elemental_load) (int ele_id, int char_id, struct s_elemental *ele);
-
-# 57 "../../../server-code/src/char/mapif.h" 3 4
-_Bool
-# 57 "../../../server-code/src/char/mapif.h"
- (*elemental_delete) (int ele_id);
- void (*elemental_send) (int fd, struct s_elemental *ele, unsigned char flag);
- void (*parse_elemental_create) (int fd, const struct s_elemental *ele);
- void (*parse_elemental_load) (int fd, int ele_id, int char_id);
- void (*elemental_deleted) (int fd, unsigned char flag);
- void (*parse_elemental_delete) (int fd, int ele_id);
- void (*elemental_saved) (int fd, unsigned char flag);
- void (*parse_elemental_save) (int fd, const struct s_elemental *ele);
- int (*guild_created) (int fd, int account_id, struct guild *g);
- int (*guild_noinfo) (int fd, int guild_id);
- int (*guild_info) (int fd, struct guild *g);
- int (*guild_memberadded) (int fd, int guild_id, int account_id, int char_id, int flag);
- int (*guild_withdraw) (int guild_id, int account_id, int char_id, int flag, const char *name, const char *mes);
- int (*guild_memberinfoshort) (struct guild *g, int idx);
- int (*guild_broken) (int guild_id, int flag);
- int (*guild_message) (int guild_id, int account_id, const char *mes, int len, int sfd);
- int (*guild_basicinfochanged) (int guild_id, int type, const void *data, int len);
- int (*guild_memberinfochanged) (int guild_id, int account_id, int char_id, int type, const void *data, int len);
- int (*guild_skillupack) (int guild_id, uint16 skill_id, int account_id);
- int (*guild_alliance) (int guild_id1, int guild_id2, int account_id1, int account_id2, int flag, const char *name1, const char *name2);
- int (*guild_position) (struct guild *g, int idx);
- int (*guild_notice) (struct guild *g);
- int (*guild_emblem) (struct guild *g);
- int (*guild_master_changed) (struct guild *g, int aid, int cid);
- int (*guild_castle_dataload) (int fd, int sz, const int *castle_ids);
- int (*parse_CreateGuild) (int fd, int account_id, const char *name, const struct guild_member *master);
- int (*parse_GuildInfo) (int fd, int guild_id);
- int (*parse_GuildAddMember) (int fd, int guild_id, const struct guild_member *m);
- int (*parse_GuildLeave) (int fd, int guild_id, int account_id, int char_id, int flag, const char *mes);
- int (*parse_GuildChangeMemberInfoShort) (int fd, int guild_id, int account_id, int char_id, int online, int lv, int class_);
- int (*parse_BreakGuild) (int fd, int guild_id);
- int (*parse_GuildMessage) (int fd, int guild_id, int account_id, const char *mes, int len);
- int (*parse_GuildBasicInfoChange) (int fd, int guild_id, int type, const void *data, int len);
- int (*parse_GuildMemberInfoChange) (int fd, int guild_id, int account_id, int char_id, int type, const char *data, int len);
- int (*parse_GuildPosition) (int fd, int guild_id, int idx, const struct guild_position *p);
- int (*parse_GuildSkillUp) (int fd, int guild_id, uint16 skill_id, int account_id, int max);
- int (*parse_GuildDeleteAlliance) (struct guild *g, int guild_id, int account_id1, int account_id2, int flag);
- int (*parse_GuildAlliance) (int fd, int guild_id1, int guild_id2, int account_id1, int account_id2, int flag);
- int (*parse_GuildNotice) (int fd, int guild_id, const char *mes1, const char *mes2);
- int (*parse_GuildEmblem) (int fd, int len, int guild_id, int dummy, const char *data);
- int (*parse_GuildCastleDataLoad) (int fd, int len, const int *castle_ids);
- int (*parse_GuildCastleDataSave) (int fd, int castle_id, int index, int value);
- int (*parse_GuildMasterChange) (int fd, int guild_id, const char* name, int len);
- void (*homunculus_created) (int fd, int account_id, const struct s_homunculus *sh, unsigned char flag);
- void (*homunculus_deleted) (int fd, int flag);
- void (*homunculus_loaded) (int fd, int account_id, struct s_homunculus *hd);
- void (*homunculus_saved) (int fd, int account_id,
-# 103 "../../../server-code/src/char/mapif.h" 3 4
- _Bool
-# 103 "../../../server-code/src/char/mapif.h"
- flag);
- void (*homunculus_renamed) (int fd, int account_id, int char_id, unsigned char flag, const char *name);
-
-# 105 "../../../server-code/src/char/mapif.h" 3 4
-_Bool
-# 105 "../../../server-code/src/char/mapif.h"
- (*homunculus_create) (struct s_homunculus *hd);
-
-# 106 "../../../server-code/src/char/mapif.h" 3 4
-_Bool
-# 106 "../../../server-code/src/char/mapif.h"
- (*homunculus_save) (const struct s_homunculus *hd);
-
-# 107 "../../../server-code/src/char/mapif.h" 3 4
-_Bool
-# 107 "../../../server-code/src/char/mapif.h"
- (*homunculus_load) (int homun_id, struct s_homunculus* hd);
-
-# 108 "../../../server-code/src/char/mapif.h" 3 4
-_Bool
-# 108 "../../../server-code/src/char/mapif.h"
- (*homunculus_delete) (int homun_id);
-
-# 109 "../../../server-code/src/char/mapif.h" 3 4
-_Bool
-# 109 "../../../server-code/src/char/mapif.h"
- (*homunculus_rename) (const char *name);
- void (*parse_homunculus_create) (int fd, int len, int account_id, const struct s_homunculus *phd);
- void (*parse_homunculus_delete) (int fd, int homun_id);
- void (*parse_homunculus_load) (int fd, int account_id, int homun_id);
- void (*parse_homunculus_save) (int fd, int len, int account_id, const struct s_homunculus *phd);
- void (*parse_homunculus_rename) (int fd, int account_id, int char_id, const char *name);
- void (*mail_sendinbox) (int fd, int char_id, unsigned char flag, struct mail_data *md);
- void (*parse_mail_requestinbox) (int fd);
- void (*parse_mail_read) (int fd);
- void (*mail_sendattach) (int fd, int char_id, struct mail_message *msg);
- void (*mail_getattach) (int fd, int char_id, int mail_id);
- void (*parse_mail_getattach) (int fd);
- void (*mail_delete) (int fd, int char_id, int mail_id,
-# 121 "../../../server-code/src/char/mapif.h" 3 4
- _Bool
-# 121 "../../../server-code/src/char/mapif.h"
- failed);
- void (*parse_mail_delete) (int fd);
- void (*mail_new) (struct mail_message *msg);
- void (*mail_return) (int fd, int char_id, int mail_id, int new_mail);
- void (*parse_mail_return) (int fd);
- void (*mail_send) (int fd, struct mail_message* msg);
- void (*parse_mail_send) (int fd);
-
-# 128 "../../../server-code/src/char/mapif.h" 3 4
-_Bool
-# 128 "../../../server-code/src/char/mapif.h"
- (*mercenary_create) (struct s_mercenary *merc);
-
-# 129 "../../../server-code/src/char/mapif.h" 3 4
-_Bool
-# 129 "../../../server-code/src/char/mapif.h"
- (*mercenary_save) (const struct s_mercenary *merc);
-
-# 130 "../../../server-code/src/char/mapif.h" 3 4
-_Bool
-# 130 "../../../server-code/src/char/mapif.h"
- (*mercenary_load) (int merc_id, int char_id, struct s_mercenary *merc);
-
-# 131 "../../../server-code/src/char/mapif.h" 3 4
-_Bool
-# 131 "../../../server-code/src/char/mapif.h"
- (*mercenary_delete) (int merc_id);
- void (*mercenary_send) (int fd, struct s_mercenary *merc, unsigned char flag);
- void (*parse_mercenary_create) (int fd, const struct s_mercenary *merc);
- void (*parse_mercenary_load) (int fd, int merc_id, int char_id);
- void (*mercenary_deleted) (int fd, unsigned char flag);
- void (*parse_mercenary_delete) (int fd, int merc_id);
- void (*mercenary_saved) (int fd, unsigned char flag);
- void (*parse_mercenary_save) (int fd, const struct s_mercenary *merc);
- int (*party_created) (int fd, int account_id, int char_id, struct party *p);
- void (*party_noinfo) (int fd, int party_id, int char_id);
- void (*party_info) (int fd, struct party* p, int char_id);
- int (*party_memberadded) (int fd, int party_id, int account_id, int char_id, int flag);
- int (*party_optionchanged) (int fd, struct party *p, int account_id, int flag);
- int (*party_withdraw) (int party_id,int account_id, int char_id);
- int (*party_membermoved) (struct party *p, int idx);
- int (*party_broken) (int party_id, int flag);
- int (*party_message) (int party_id, int account_id, const char *mes, int len, int sfd);
- int (*parse_CreateParty) (int fd, const char *name, int item, int item2, const struct party_member *leader);
- void (*parse_PartyInfo) (int fd, int party_id, int char_id);
- int (*parse_PartyAddMember) (int fd, int party_id, const struct party_member *member);
- int (*parse_PartyChangeOption) (int fd,int party_id,int account_id,int exp,int item);
- int (*parse_PartyLeave) (int fd, int party_id, int account_id, int char_id);
- int (*parse_PartyChangeMap) (int fd, int party_id, int account_id, int char_id, unsigned short map, int online, unsigned int lv);
- int (*parse_BreakParty) (int fd, int party_id);
- int (*parse_PartyMessage) (int fd, int party_id, int account_id, const char *mes, int len);
- int (*parse_PartyLeaderChange) (int fd, int party_id, int account_id, int char_id);
- int (*pet_created) (int fd, int account_id, struct s_pet *p);
- int (*pet_info) (int fd, int account_id, struct s_pet *p);
- int (*pet_noinfo) (int fd, int account_id);
- int (*save_pet_ack) (int fd, int account_id, int flag);
- int (*delete_pet_ack) (int fd, int flag);
- int (*create_pet) (int fd, int account_id, int char_id, short pet_class, short pet_lv, short pet_egg_id,
- short pet_equip, short intimate, short hungry, char rename_flag, char incubate, const char *pet_name);
- int (*load_pet) (int fd, int account_id, int char_id, int pet_id);
- int (*save_pet) (int fd, int account_id, const struct s_pet *data);
- int (*delete_pet) (int fd, int pet_id);
- int (*parse_CreatePet) (int fd);
- int (*parse_LoadPet) (int fd);
- int (*parse_SavePet) (int fd);
- int (*parse_DeletePet) (int fd);
- struct quest *(*quests_fromsql) (int char_id, int *count);
-
-# 172 "../../../server-code/src/char/mapif.h" 3 4
-_Bool
-# 172 "../../../server-code/src/char/mapif.h"
- (*quest_delete) (int char_id, int quest_id);
-
-# 173 "../../../server-code/src/char/mapif.h" 3 4
-_Bool
-# 173 "../../../server-code/src/char/mapif.h"
- (*quest_add) (int char_id, struct quest qd);
-
-# 174 "../../../server-code/src/char/mapif.h" 3 4
-_Bool
-# 174 "../../../server-code/src/char/mapif.h"
- (*quest_update) (int char_id, struct quest qd);
- void (*quest_save_ack) (int fd, int char_id,
-# 175 "../../../server-code/src/char/mapif.h" 3 4
- _Bool
-# 175 "../../../server-code/src/char/mapif.h"
- success);
- int (*parse_quest_save) (int fd);
- void (*send_quests) (int fd, int char_id, struct quest *tmp_questlog, int num_quests);
- int (*parse_quest_load) (int fd);
- int (*load_guild_storage) (int fd, int account_id, int guild_id, char flag);
- int (*save_guild_storage_ack) (int fd, int account_id, int guild_id, int fail);
- int (*parse_LoadGuildStorage) (int fd);
- int (*parse_SaveGuildStorage) (int fd);
- int (*itembound_ack) (int fd, int aid, int guild_id);
- int (*parse_ItemBoundRetrieve_sub) (int fd);
- void (*parse_ItemBoundRetrieve) (int fd);
- void (*parse_accinfo) (int fd);
- void (*parse_accinfo2) (
-# 187 "../../../server-code/src/char/mapif.h" 3 4
- _Bool
-# 187 "../../../server-code/src/char/mapif.h"
- success, int map_fd, int u_fd, int u_aid, int account_id, const char *userid, const char *user_pass,
- const char *email, const char *last_ip, const char *lastlogin, const char *pin_code, const char *birthdate, int group_id, int logincount, int state);
- int (*broadcast) (const unsigned char *mes, int len, unsigned int fontColor, short fontType, short fontSize, short fontAlign, short fontY, int sfd);
- int (*wis_message) (struct WisData *wd);
- void (*wis_response) (int fd, const unsigned char *src, int flag);
- int (*wis_end) (struct WisData *wd, int flag);
- int (*account_reg_reply) (int fd,int account_id,int char_id, int type);
- int (*disconnectplayer) (int fd, int account_id, int char_id, int reason);
- int (*parse_broadcast) (int fd);
- int (*parse_WisRequest) (int fd);
- int (*parse_WisReply) (int fd);
- int (*parse_WisToGM) (int fd);
- int (*parse_Registry) (int fd);
- int (*parse_RegistryRequest) (int fd);
- void (*namechange_ack) (int fd, int account_id, int char_id, int type, int flag, const char *name);
- int (*parse_NameChangeRequest) (int fd);
-};
-
-
-void mapif_defaults(void);
-
-
-extern struct mapif_interface *mapif;
-# 41 "../../../server-code/src/char/char.c" 2
-# 1 "../../../server-code/src/char/pincode.h" 1
-# 26 "../../../server-code/src/char/pincode.h"
-struct char_session_data;
-
-enum PincodeResponseCode {
- PINCODE_OK = 0,
- PINCODE_ASK = 1,
- PINCODE_NOTSET = 2,
- PINCODE_EXPIRED = 3,
- PINCODE_UNUSED = 7,
- PINCODE_WRONG = 8,
-};
-
-
-
-
-struct pincode_interface {
-
- int enabled;
- int changetime;
- int maxtry;
- int charselect;
- unsigned int multiplier;
- unsigned int baseSeed;
-
- void (*handle) (int fd, struct char_session_data* sd);
- void (*decrypt) (unsigned int userSeed, char* pin);
- void (*error) (int account_id);
- void (*update) (int account_id, char* pin);
- void (*sendstate) (int fd, struct char_session_data* sd, uint16 state);
- void (*setnew) (int fd, struct char_session_data* sd);
- void (*change) (int fd, struct char_session_data* sd);
- int (*compare) (int fd, struct char_session_data* sd, char* pin);
- void (*check) (int fd, struct char_session_data* sd);
-
-# 58 "../../../server-code/src/char/pincode.h" 3 4
-_Bool
-# 58 "../../../server-code/src/char/pincode.h"
- (*config_read) (char *w1, char *w2);
-};
-
-
-void pincode_defaults(void);
-
-
-extern struct pincode_interface *pincode;
-# 42 "../../../server-code/src/char/char.c" 2
-
-
-
-
-
-
-# 1 "../../../server-code/src/common/memmgr.h" 1
-# 80 "../../../server-code/src/common/memmgr.h"
-struct malloc_interface {
- void (*init) (void);
- void (*final) (void);
-
- void* (*malloc)(size_t size, const char *file, int line, const char *func);
- void* (*calloc)(size_t num, size_t size, const char *file, int line, const char *func);
- void* (*realloc)(void *p, size_t size, const char *file, int line, const char *func);
- void* (*reallocz)(void *p, size_t size, const char *file, int line, const char *func);
- char* (*astrdup)(const char *p, const char *file, int line, const char *func);
- char *(*astrndup)(const char *p, size_t size, const char *file, int line, const char *func);
- void (*free)(void *p, const char *file, int line, const char *func);
-
- void (*memory_check)(void);
-
-# 93 "../../../server-code/src/common/memmgr.h" 3 4
-_Bool
-# 93 "../../../server-code/src/common/memmgr.h"
- (*verify_ptr)(void* ptr);
- size_t (*usage) (void);
-
- void (*post_shutdown) (void);
- void (*init_messages) (void);
-};
-
-
-void malloc_defaults(void);
-
-void memmgr_report(int extra);
-
-
-extern struct malloc_interface *iMalloc;
-# 49 "../../../server-code/src/char/char.c" 2
-# 1 "../../../server-code/src/common/mapindex.h" 1
-# 28 "../../../server-code/src/common/mapindex.h"
-struct DBMap;
-# 84 "../../../server-code/src/common/mapindex.h"
-struct mapindex_interface {
- char config_file[80];
-
- struct DBMap *db;
-
- int num;
-
- char *default_map;
-
- int default_x;
-
- int default_y;
-
- struct {
- char name[(11 + 1)];
- } list[2000];
-
- int (*init) (void);
- void (*final) (void);
-
- int (*addmap) (int index, const char* name);
- void (*removemap) (int index);
- const char* (*getmapname) (const char* string, char* output);
-
-
- const char* (*getmapname_ext) (const char* string, char* output);
-
- unsigned short (*name2id) (const char*);
- const char * (*id2name) (uint16 id, const char *file, int line, const char *func);
-
-# 113 "../../../server-code/src/common/mapindex.h" 3 4
-_Bool
-# 113 "../../../server-code/src/common/mapindex.h"
- (*check_default) (void);
-};
-
-
-void mapindex_defaults(void);
-
-
-extern struct mapindex_interface *mapindex;
-# 50 "../../../server-code/src/char/char.c" 2
-
-# 1 "../../../server-code/src/common/nullpo.h" 1
-# 40 "../../../server-code/src/common/nullpo.h"
-# 1 "/usr/include/assert.h" 1 3 4
-# 66 "/usr/include/assert.h" 3 4
-
-
-
-
-# 69 "/usr/include/assert.h" 3 4
-extern void __assert_fail (const char *__assertion, const char *__file,
- unsigned int __line, const char *__function)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__noreturn__));
-
-
-extern void __assert_perror_fail (int __errnum, const char *__file,
- unsigned int __line, const char *__function)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__noreturn__));
-
-
-
-
-extern void __assert (const char *__assertion, const char *__file, int __line)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__noreturn__));
-
-
-
-# 41 "../../../server-code/src/common/nullpo.h" 2
-# 155 "../../../server-code/src/common/nullpo.h"
-
-# 155 "../../../server-code/src/common/nullpo.h"
-struct nullpo_interface {
- void (*assert_report) (const char *file, int line, const char *func, const char *targetname, const char *title);
-};
-
-
-void nullpo_defaults(void);
-
-
-extern struct nullpo_interface *nullpo;
-# 52 "../../../server-code/src/char/char.c" 2
-
-# 1 "../../../server-code/src/common/socket.h" 1
-# 54 "../../../server-code/src/char/char.c" 2
-# 1 "../../../server-code/src/common/strlib.h" 1
-# 54 "../../../server-code/src/common/strlib.h"
-typedef enum e_svopt {
-
- SV_NOESCAPE_NOTERMINATE = 0,
-
- SV_ESCAPE_C = 1,
-
- SV_TERMINATE_LF = 2,
- SV_TERMINATE_CRLF = 4,
- SV_TERMINATE_CR = 8,
-
- SV_KEEP_TERMINATOR = 16
-} e_svopt;
-
-
-
-
-
-
-struct s_svstate {
- const char* str;
- int len;
- int off;
- int start;
- int end;
- enum e_svopt opt;
- char delim;
-
-# 80 "../../../server-code/src/common/strlib.h" 3 4
-_Bool
-# 80 "../../../server-code/src/common/strlib.h"
- done;
-};
-
-
-
-struct StringBuf {
- char *buf_;
- char *ptr_;
- unsigned int max_;
-};
-typedef struct StringBuf StringBuf;
-
-struct strlib_interface {
- char *(*jstrescape) (char* pt);
- char *(*jstrescapecpy) (char* pt, const char* spt);
- int (*jmemescapecpy) (char* pt, const char* spt, int size);
- int (*remove_control_chars_) (char* str);
- char *(*trim_) (char* str);
- char *(*normalize_name_) (char* str,const char* delims);
- const char *(*stristr_) (const char *haystack, const char *needle);
-
-
- size_t (*strnlen_) (const char* string, size_t maxlen);
-
-
- char * (*strtok_r_) (char *s1, const char *s2, char **lasts);
-
- int (*e_mail_check_) (char* email);
- int (*config_switch_) (const char* str);
-
-
- char *(*safestrncpy_) (char* dst, const char* src, size_t n);
-
-
- size_t (*safestrnlen_) (const char* string, size_t maxlen);
-
-
-
-
- int (*safesnprintf_) (char *buf, size_t sz, const char *fmt, ...) __attribute__((format(printf, 3, 4)));
-
-
-
- int (*strline_) (const char* str, size_t pos);
-
-
-
-
-
-# 128 "../../../server-code/src/common/strlib.h" 3 4
-_Bool
-# 128 "../../../server-code/src/common/strlib.h"
- (*bin2hex_) (char* output, unsigned char* input, size_t count);
-};
-
-struct stringbuf_interface {
- StringBuf* (*Malloc) (void);
- void (*Init) (StringBuf* self);
- int (*Printf) (StringBuf *self, const char *fmt, ...) __attribute__((format(printf, 2, 3)));
- int (*Vprintf) (StringBuf* self, const char* fmt, va_list args);
- int (*Append) (StringBuf* self, const StringBuf *sbuf);
- int (*AppendStr) (StringBuf* self, const char* str);
- int (*Length) (StringBuf* self);
- char* (*Value) (StringBuf* self);
- void (*Clear) (StringBuf* self);
- void (*Destroy) (StringBuf* self);
- void (*Free) (StringBuf* self);
-};
-
-struct sv_interface {
-
-
-
-
-
- int (*parse_next) (struct s_svstate* svstate);
-
-
-
-
-
-
- int (*parse) (const char* str, int len, int startoff, char delim, int* out_pos, int npos, enum e_svopt opt);
-
-
-
-
-
-
-
- int (*split) (char* str, int len, int startoff, char delim, char** out_fields, int nfields, enum e_svopt opt);
-
-
-
-
- size_t (*escape_c) (char* out_dest, const char* src, size_t len, const char* escapes);
-
-
-
-
- size_t (*unescape_c) (char* out_dest, const char* src, size_t len);
-
-
- const char* (*skip_escaped_c) (const char* p);
-
-
-
-
-
-# 184 "../../../server-code/src/common/strlib.h" 3 4
-_Bool
-# 184 "../../../server-code/src/common/strlib.h"
- (*readdb) (const char* directory, const char* filename, char delim, int mincols, int maxcols, int maxrows,
-# 184 "../../../server-code/src/common/strlib.h" 3 4
- _Bool
-# 184 "../../../server-code/src/common/strlib.h"
- (*parseproc)(char* fields[], int columns, int current));
-};
-
-
-void strlib_defaults(void);
-
-
-extern struct strlib_interface *strlib;
-extern struct stringbuf_interface *StrBuf;
-extern struct sv_interface *sv;
-# 55 "../../../server-code/src/char/char.c" 2
-# 1 "../../../server-code/src/common/sql.h" 1
-# 40 "../../../server-code/src/common/sql.h"
-enum SqlDataType {
- SQLDT_NULL,
-
- SQLDT_INT8,
- SQLDT_INT16,
- SQLDT_INT32,
- SQLDT_INT64,
- SQLDT_UINT8,
- SQLDT_UINT16,
- SQLDT_UINT32,
- SQLDT_UINT64,
-
- SQLDT_CHAR,
- SQLDT_SHORT,
- SQLDT_INT,
- SQLDT_LONG,
- SQLDT_LONGLONG,
- SQLDT_UCHAR,
- SQLDT_USHORT,
- SQLDT_UINT,
- SQLDT_ULONG,
- SQLDT_ULONGLONG,
-
- SQLDT_FLOAT,
- SQLDT_DOUBLE,
-
- SQLDT_STRING,
- SQLDT_ENUM,
-
-
- SQLDT_BLOB,
- SQLDT_LASTID
-};
-
-struct Sql;
-struct SqlStmt;
-
-struct sql_interface {
-
-
-
- int (*Connect) (struct Sql *self, const char *user, const char *passwd, const char *host, uint16 port, const char *db);
-
-
-
- int (*GetTimeout) (struct Sql *self, uint32 *out_timeout);
-
-
-
- int (*GetColumnNames) (struct Sql *self, const char *table, char *out_buf, size_t buf_len, char sep);
-
-
-
- int (*SetEncoding) (struct Sql *self, const char *encoding);
-
-
-
- int (*Ping) (struct Sql *self);
-
-
-
-
- size_t (*EscapeString) (struct Sql *self, char *out_to, const char *from);
-
-
-
-
- size_t (*EscapeStringLen) (struct Sql *self, char *out_to, const char *from, size_t from_len);
-
-
-
-
-
- int (*Query) (struct Sql *self, const char *query, ...) __attribute__((format(printf, 2, 3)));
-
-
-
-
-
- int (*QueryV) (struct Sql *self, const char *query, va_list args);
-
-
-
-
-
- int (*QueryStr) (struct Sql *self, const char *query);
-
-
-
- uint64 (*LastInsertId) (struct Sql *self);
-
-
-
- uint32 (*NumColumns) (struct Sql *self);
-
-
-
- uint64 (*NumRows) (struct Sql *self);
-
-
-
-
- int (*NextRow) (struct Sql *self);
-
-
-
-
- int (*GetData) (struct Sql *self, size_t col, char **out_buf, size_t *out_len);
-
- void (*FreeResult) (struct Sql *self);
-
- void (*ShowDebug_) (struct Sql *self, const char *debug_file, const unsigned long debug_line);
-
- void (*Free) (struct Sql *self);
-
- struct Sql *(*Malloc) (void);
-# 179 "../../../server-code/src/common/sql.h"
- struct SqlStmt* (*StmtMalloc)(struct Sql *sql);
-
-
-
-
-
-
- int (*StmtPrepare) (struct SqlStmt *self, const char *query, ...) __attribute__((format(printf, 2, 3)));
-
-
-
-
-
-
- int (*StmtPrepareV)(struct SqlStmt *self, const char *query, va_list args);
-
-
-
-
-
-
- int (*StmtPrepareStr)(struct SqlStmt *self, const char *query);
-
-
-
-
- size_t (*StmtNumParams)(struct SqlStmt *self);
-
-
-
-
-
-
- int (*StmtBindParam)(struct SqlStmt *self, size_t idx, enum SqlDataType buffer_type, const void *buffer, size_t buffer_len);
-
-
-
-
-
- int (*StmtExecute)(struct SqlStmt *self);
-
-
-
-
- uint64 (*StmtLastInsertId)(struct SqlStmt *self);
-
-
-
-
- size_t (*StmtNumColumns)(struct SqlStmt *self);
-
-
-
-
-
-
-
- int (*StmtBindColumn)(struct SqlStmt *self, size_t idx, enum SqlDataType buffer_type, void *buffer, size_t buffer_len, uint32 *out_length, int8 *out_is_null);
-
-
-
-
- uint64 (*StmtNumRows)(struct SqlStmt *self);
-
-
-
-
-
- int (*StmtNextRow)(struct SqlStmt *self);
-
-
- void (*StmtFreeResult)(struct SqlStmt *self);
-
-
- void (*StmtFree)(struct SqlStmt *self);
-
- void (*StmtShowDebug_)(struct SqlStmt *self, const char *debug_file, const unsigned long debug_line);
-
-};
-
-
-void sql_defaults(void);
-
-void Sql_Init(void);
-
-void Sql_HerculesUpdateCheck(struct Sql *self);
-void Sql_HerculesUpdateSkip(struct Sql *self, const char *filename);
-
-
-extern struct sql_interface *SQL;
-# 56 "../../../server-code/src/char/char.c" 2
-# 1 "../../../server-code/src/common/timer.h" 1
-# 32 "../../../server-code/src/common/timer.h"
-enum {
- TIMER_ONCE_AUTODEL = 0x01,
- TIMER_INTERVAL = 0x02,
- TIMER_REMOVE_HEAP = 0x10,
-};
-
-
-
-typedef int (*TimerFunc)(int tid, int64 tick, int id, intptr_t data);
-
-struct TimerData {
- int64 tick;
- TimerFunc func;
- unsigned char type;
- int interval;
-
-
- int id;
- intptr_t data;
-};
-
-
-
-
-
-
-
-struct timer_interface {
-
-
- int64 (*gettick) (void);
- int64 (*gettick_nocache) (void);
-
- int (*add) (int64 tick, TimerFunc func, int id, intptr_t data);
- int (*add_interval) (int64 tick, TimerFunc func, int id, intptr_t data, int interval);
- const struct TimerData *(*get) (int tid);
- int (*delete) (int tid, TimerFunc func);
-
- int64 (*addtick) (int tid, int64 tick);
- int64 (*settick) (int tid, int64 tick);
-
- int (*add_func_list) (TimerFunc func, char* name);
-
- unsigned long (*get_uptime) (void);
-
- int (*perform) (int64 tick);
- void (*init) (void);
- void (*final) (void);
-};
-
-
-void timer_defaults(void);
-
-
-extern struct timer_interface *timer;
-# 57 "../../../server-code/src/char/char.c" 2
-# 1 "../../../server-code/src/common/utils.h" 1
-# 26 "../../../server-code/src/common/utils.h"
-# 1 "/usr/include/stdio.h" 1 3 4
-# 29 "/usr/include/stdio.h" 3 4
-
-
-
-
-# 1 "/usr/lib/gcc/x86_64-linux-gnu/5/include/stddef.h" 1 3 4
-# 34 "/usr/include/stdio.h" 2 3 4
-# 44 "/usr/include/stdio.h" 3 4
-
-# 44 "/usr/include/stdio.h" 3 4
-struct _IO_FILE;
-
-
-
-typedef struct _IO_FILE FILE;
-
-
-
-
-
-# 64 "/usr/include/stdio.h" 3 4
-typedef struct _IO_FILE __FILE;
-# 74 "/usr/include/stdio.h" 3 4
-# 1 "/usr/include/libio.h" 1 3 4
-# 31 "/usr/include/libio.h" 3 4
-# 1 "/usr/include/_G_config.h" 1 3 4
-# 15 "/usr/include/_G_config.h" 3 4
-# 1 "/usr/lib/gcc/x86_64-linux-gnu/5/include/stddef.h" 1 3 4
-# 16 "/usr/include/_G_config.h" 2 3 4
-
-
-
-
-# 1 "/usr/include/wchar.h" 1 3 4
-# 82 "/usr/include/wchar.h" 3 4
-typedef struct
-{
- int __count;
- union
- {
-
- unsigned int __wch;
-
-
-
- char __wchb[4];
- } __value;
-} __mbstate_t;
-# 21 "/usr/include/_G_config.h" 2 3 4
-typedef struct
-{
- __off_t __pos;
- __mbstate_t __state;
-} _G_fpos_t;
-typedef struct
-{
- __off64_t __pos;
- __mbstate_t __state;
-} _G_fpos64_t;
-# 32 "/usr/include/libio.h" 2 3 4
-# 144 "/usr/include/libio.h" 3 4
-struct _IO_jump_t; struct _IO_FILE;
-
-
-
-
-
-typedef void _IO_lock_t;
-
-
-
-
-
-struct _IO_marker {
- struct _IO_marker *_next;
- struct _IO_FILE *_sbuf;
-
-
-
- int _pos;
-# 173 "/usr/include/libio.h" 3 4
-};
-
-
-enum __codecvt_result
-{
- __codecvt_ok,
- __codecvt_partial,
- __codecvt_error,
- __codecvt_noconv
-};
-# 241 "/usr/include/libio.h" 3 4
-struct _IO_FILE {
- int _flags;
-
-
-
-
- char* _IO_read_ptr;
- char* _IO_read_end;
- char* _IO_read_base;
- char* _IO_write_base;
- char* _IO_write_ptr;
- char* _IO_write_end;
- char* _IO_buf_base;
- char* _IO_buf_end;
-
- char *_IO_save_base;
- char *_IO_backup_base;
- char *_IO_save_end;
-
- struct _IO_marker *_markers;
-
- struct _IO_FILE *_chain;
-
- int _fileno;
-
-
-
- int _flags2;
-
- __off_t _old_offset;
-
-
-
- unsigned short _cur_column;
- signed char _vtable_offset;
- char _shortbuf[1];
-
-
-
- _IO_lock_t *_lock;
-# 289 "/usr/include/libio.h" 3 4
- __off64_t _offset;
-# 298 "/usr/include/libio.h" 3 4
- void *__pad1;
- void *__pad2;
- void *__pad3;
- void *__pad4;
- size_t __pad5;
-
- int _mode;
-
- char _unused2[15 * sizeof (int) - 4 * sizeof (void *) - sizeof (size_t)];
-
-};
-
-
-typedef struct _IO_FILE _IO_FILE;
-
-
-struct _IO_FILE_plus;
-
-extern struct _IO_FILE_plus _IO_2_1_stdin_;
-extern struct _IO_FILE_plus _IO_2_1_stdout_;
-extern struct _IO_FILE_plus _IO_2_1_stderr_;
-# 334 "/usr/include/libio.h" 3 4
-typedef __ssize_t __io_read_fn (void *__cookie, char *__buf, size_t __nbytes);
-
-
-
-
-
-
-
-typedef __ssize_t __io_write_fn (void *__cookie, const char *__buf,
- size_t __n);
-
-
-
-
-
-
-
-typedef int __io_seek_fn (void *__cookie, __off64_t *__pos, int __w);
-
-
-typedef int __io_close_fn (void *__cookie);
-# 386 "/usr/include/libio.h" 3 4
-extern int __underflow (_IO_FILE *);
-extern int __uflow (_IO_FILE *);
-extern int __overflow (_IO_FILE *, int);
-# 430 "/usr/include/libio.h" 3 4
-extern int _IO_getc (_IO_FILE *__fp);
-extern int _IO_putc (int __c, _IO_FILE *__fp);
-extern int _IO_feof (_IO_FILE *__fp) __attribute__ ((__nothrow__ , __leaf__));
-extern int _IO_ferror (_IO_FILE *__fp) __attribute__ ((__nothrow__ , __leaf__));
-
-extern int _IO_peekc_locked (_IO_FILE *__fp);
-
-
-
-
-
-extern void _IO_flockfile (_IO_FILE *) __attribute__ ((__nothrow__ , __leaf__));
-extern void _IO_funlockfile (_IO_FILE *) __attribute__ ((__nothrow__ , __leaf__));
-extern int _IO_ftrylockfile (_IO_FILE *) __attribute__ ((__nothrow__ , __leaf__));
-# 460 "/usr/include/libio.h" 3 4
-extern int _IO_vfscanf (_IO_FILE * __restrict, const char * __restrict,
- __gnuc_va_list, int *__restrict);
-extern int _IO_vfprintf (_IO_FILE *__restrict, const char *__restrict,
- __gnuc_va_list);
-extern __ssize_t _IO_padn (_IO_FILE *, int, __ssize_t);
-extern size_t _IO_sgetn (_IO_FILE *, void *, size_t);
-
-extern __off64_t _IO_seekoff (_IO_FILE *, __off64_t, int, int);
-extern __off64_t _IO_seekpos (_IO_FILE *, __off64_t, int);
-
-extern void _IO_free_backup_area (_IO_FILE *) __attribute__ ((__nothrow__ , __leaf__));
-# 75 "/usr/include/stdio.h" 2 3 4
-# 90 "/usr/include/stdio.h" 3 4
-typedef __off_t off_t;
-# 102 "/usr/include/stdio.h" 3 4
-typedef __ssize_t ssize_t;
-
-
-
-
-
-
-
-typedef _G_fpos_t fpos_t;
-
-
-
-
-# 164 "/usr/include/stdio.h" 3 4
-# 1 "/usr/include/x86_64-linux-gnu/bits/stdio_lim.h" 1 3 4
-# 165 "/usr/include/stdio.h" 2 3 4
-
-
-
-extern struct _IO_FILE *stdin;
-extern struct _IO_FILE *stdout;
-extern struct _IO_FILE *stderr;
-
-
-
-
-
-
-
-extern int remove (const char *__filename) __attribute__ ((__nothrow__ , __leaf__));
-
-extern int rename (const char *__old, const char *__new) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-extern int renameat (int __oldfd, const char *__old, int __newfd,
- const char *__new) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-
-
-
-
-extern FILE *tmpfile (void) ;
-# 209 "/usr/include/stdio.h" 3 4
-extern char *tmpnam (char *__s) __attribute__ ((__nothrow__ , __leaf__)) ;
-
-
-
-
-
-extern char *tmpnam_r (char *__s) __attribute__ ((__nothrow__ , __leaf__)) ;
-# 227 "/usr/include/stdio.h" 3 4
-extern char *tempnam (const char *__dir, const char *__pfx)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__malloc__)) ;
-
-
-
-
-
-
-
-
-extern int fclose (FILE *__stream);
-
-
-
-
-extern int fflush (FILE *__stream);
-
-# 252 "/usr/include/stdio.h" 3 4
-extern int fflush_unlocked (FILE *__stream);
-# 266 "/usr/include/stdio.h" 3 4
-
-
-
-
-
-
-extern FILE *fopen (const char *__restrict __filename,
- const char *__restrict __modes) ;
-
-
-
-
-extern FILE *freopen (const char *__restrict __filename,
- const char *__restrict __modes,
- FILE *__restrict __stream) ;
-# 295 "/usr/include/stdio.h" 3 4
-
-# 306 "/usr/include/stdio.h" 3 4
-extern FILE *fdopen (int __fd, const char *__modes) __attribute__ ((__nothrow__ , __leaf__)) ;
-# 319 "/usr/include/stdio.h" 3 4
-extern FILE *fmemopen (void *__s, size_t __len, const char *__modes)
- __attribute__ ((__nothrow__ , __leaf__)) ;
-
-
-
-
-extern FILE *open_memstream (char **__bufloc, size_t *__sizeloc) __attribute__ ((__nothrow__ , __leaf__)) ;
-
-
-
-
-
-
-extern void setbuf (FILE *__restrict __stream, char *__restrict __buf) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-extern int setvbuf (FILE *__restrict __stream, char *__restrict __buf,
- int __modes, size_t __n) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-
-extern void setbuffer (FILE *__restrict __stream, char *__restrict __buf,
- size_t __size) __attribute__ ((__nothrow__ , __leaf__));
-
-
-extern void setlinebuf (FILE *__stream) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-
-
-
-
-extern int fprintf (FILE *__restrict __stream,
- const char *__restrict __format, ...);
-
-
-
-
-extern int printf (const char *__restrict __format, ...);
-
-extern int sprintf (char *__restrict __s,
- const char *__restrict __format, ...) __attribute__ ((__nothrow__));
-
-
-
-
-
-extern int vfprintf (FILE *__restrict __s, const char *__restrict __format,
- __gnuc_va_list __arg);
-
-
-
-
-extern int vprintf (const char *__restrict __format, __gnuc_va_list __arg);
-
-extern int vsprintf (char *__restrict __s, const char *__restrict __format,
- __gnuc_va_list __arg) __attribute__ ((__nothrow__));
-
-
-
-
-
-extern int snprintf (char *__restrict __s, size_t __maxlen,
- const char *__restrict __format, ...)
- __attribute__ ((__nothrow__)) __attribute__ ((__format__ (__printf__, 3, 4)));
-
-extern int vsnprintf (char *__restrict __s, size_t __maxlen,
- const char *__restrict __format, __gnuc_va_list __arg)
- __attribute__ ((__nothrow__)) __attribute__ ((__format__ (__printf__, 3, 0)));
-
-# 412 "/usr/include/stdio.h" 3 4
-extern int vdprintf (int __fd, const char *__restrict __fmt,
- __gnuc_va_list __arg)
- __attribute__ ((__format__ (__printf__, 2, 0)));
-extern int dprintf (int __fd, const char *__restrict __fmt, ...)
- __attribute__ ((__format__ (__printf__, 2, 3)));
-
-
-
-
-
-
-
-
-extern int fscanf (FILE *__restrict __stream,
- const char *__restrict __format, ...) ;
-
-
-
-
-extern int scanf (const char *__restrict __format, ...) ;
-
-extern int sscanf (const char *__restrict __s,
- const char *__restrict __format, ...) __attribute__ ((__nothrow__ , __leaf__));
-# 443 "/usr/include/stdio.h" 3 4
-extern int fscanf (FILE *__restrict __stream, const char *__restrict __format, ...) __asm__ ("" "__isoc99_fscanf")
-
- ;
-extern int scanf (const char *__restrict __format, ...) __asm__ ("" "__isoc99_scanf")
- ;
-extern int sscanf (const char *__restrict __s, const char *__restrict __format, ...) __asm__ ("" "__isoc99_sscanf") __attribute__ ((__nothrow__ , __leaf__))
-
- ;
-# 463 "/usr/include/stdio.h" 3 4
-
-
-
-
-
-
-
-
-extern int vfscanf (FILE *__restrict __s, const char *__restrict __format,
- __gnuc_va_list __arg)
- __attribute__ ((__format__ (__scanf__, 2, 0))) ;
-
-
-
-
-
-extern int vscanf (const char *__restrict __format, __gnuc_va_list __arg)
- __attribute__ ((__format__ (__scanf__, 1, 0))) ;
-
-
-extern int vsscanf (const char *__restrict __s,
- const char *__restrict __format, __gnuc_va_list __arg)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__format__ (__scanf__, 2, 0)));
-# 494 "/usr/include/stdio.h" 3 4
-extern int vfscanf (FILE *__restrict __s, const char *__restrict __format, __gnuc_va_list __arg) __asm__ ("" "__isoc99_vfscanf")
-
-
-
- __attribute__ ((__format__ (__scanf__, 2, 0))) ;
-extern int vscanf (const char *__restrict __format, __gnuc_va_list __arg) __asm__ ("" "__isoc99_vscanf")
-
- __attribute__ ((__format__ (__scanf__, 1, 0))) ;
-extern int vsscanf (const char *__restrict __s, const char *__restrict __format, __gnuc_va_list __arg) __asm__ ("" "__isoc99_vsscanf") __attribute__ ((__nothrow__ , __leaf__))
-
-
-
- __attribute__ ((__format__ (__scanf__, 2, 0)));
-# 522 "/usr/include/stdio.h" 3 4
-
-
-
-
-
-
-
-
-
-extern int fgetc (FILE *__stream);
-extern int getc (FILE *__stream);
-
-
-
-
-
-extern int getchar (void);
-
-# 550 "/usr/include/stdio.h" 3 4
-extern int getc_unlocked (FILE *__stream);
-extern int getchar_unlocked (void);
-# 561 "/usr/include/stdio.h" 3 4
-extern int fgetc_unlocked (FILE *__stream);
-
-
-
-
-
-
-
-
-
-
-
-extern int fputc (int __c, FILE *__stream);
-extern int putc (int __c, FILE *__stream);
-
-
-
-
-
-extern int putchar (int __c);
-
-# 594 "/usr/include/stdio.h" 3 4
-extern int fputc_unlocked (int __c, FILE *__stream);
-
-
-
-
-
-
-
-extern int putc_unlocked (int __c, FILE *__stream);
-extern int putchar_unlocked (int __c);
-
-
-
-
-
-
-extern int getw (FILE *__stream);
-
-
-extern int putw (int __w, FILE *__stream);
-
-
-
-
-
-
-
-
-extern char *fgets (char *__restrict __s, int __n, FILE *__restrict __stream)
- ;
-# 640 "/usr/include/stdio.h" 3 4
-
-# 665 "/usr/include/stdio.h" 3 4
-extern __ssize_t __getdelim (char **__restrict __lineptr,
- size_t *__restrict __n, int __delimiter,
- FILE *__restrict __stream) ;
-extern __ssize_t getdelim (char **__restrict __lineptr,
- size_t *__restrict __n, int __delimiter,
- FILE *__restrict __stream) ;
-
-
-
-
-
-
-
-extern __ssize_t getline (char **__restrict __lineptr,
- size_t *__restrict __n,
- FILE *__restrict __stream) ;
-
-
-
-
-
-
-
-
-extern int fputs (const char *__restrict __s, FILE *__restrict __stream);
-
-
-
-
-
-extern int puts (const char *__s);
-
-
-
-
-
-
-extern int ungetc (int __c, FILE *__stream);
-
-
-
-
-
-
-extern size_t fread (void *__restrict __ptr, size_t __size,
- size_t __n, FILE *__restrict __stream) ;
-
-
-
-
-extern size_t fwrite (const void *__restrict __ptr, size_t __size,
- size_t __n, FILE *__restrict __s);
-
-# 737 "/usr/include/stdio.h" 3 4
-extern size_t fread_unlocked (void *__restrict __ptr, size_t __size,
- size_t __n, FILE *__restrict __stream) ;
-extern size_t fwrite_unlocked (const void *__restrict __ptr, size_t __size,
- size_t __n, FILE *__restrict __stream);
-
-
-
-
-
-
-
-
-extern int fseek (FILE *__stream, long int __off, int __whence);
-
-
-
-
-extern long int ftell (FILE *__stream) ;
-
-
-
-
-extern void rewind (FILE *__stream);
-
-# 773 "/usr/include/stdio.h" 3 4
-extern int fseeko (FILE *__stream, __off_t __off, int __whence);
-
-
-
-
-extern __off_t ftello (FILE *__stream) ;
-# 792 "/usr/include/stdio.h" 3 4
-
-
-
-
-
-
-extern int fgetpos (FILE *__restrict __stream, fpos_t *__restrict __pos);
-
-
-
-
-extern int fsetpos (FILE *__stream, const fpos_t *__pos);
-# 815 "/usr/include/stdio.h" 3 4
-
-# 824 "/usr/include/stdio.h" 3 4
-
-
-extern void clearerr (FILE *__stream) __attribute__ ((__nothrow__ , __leaf__));
-
-extern int feof (FILE *__stream) __attribute__ ((__nothrow__ , __leaf__)) ;
-
-extern int ferror (FILE *__stream) __attribute__ ((__nothrow__ , __leaf__)) ;
-
-
-
-
-extern void clearerr_unlocked (FILE *__stream) __attribute__ ((__nothrow__ , __leaf__));
-extern int feof_unlocked (FILE *__stream) __attribute__ ((__nothrow__ , __leaf__)) ;
-extern int ferror_unlocked (FILE *__stream) __attribute__ ((__nothrow__ , __leaf__)) ;
-
-
-
-
-
-
-
-
-extern void perror (const char *__s);
-
-
-
-
-
-
-# 1 "/usr/include/x86_64-linux-gnu/bits/sys_errlist.h" 1 3 4
-# 26 "/usr/include/x86_64-linux-gnu/bits/sys_errlist.h" 3 4
-extern int sys_nerr;
-extern const char *const sys_errlist[];
-# 854 "/usr/include/stdio.h" 2 3 4
-
-
-
-
-extern int fileno (FILE *__stream) __attribute__ ((__nothrow__ , __leaf__)) ;
-
-
-
-
-extern int fileno_unlocked (FILE *__stream) __attribute__ ((__nothrow__ , __leaf__)) ;
-# 872 "/usr/include/stdio.h" 3 4
-extern FILE *popen (const char *__command, const char *__modes) ;
-
-
-
-
-
-extern int pclose (FILE *__stream);
-
-
-
-
-
-extern char *ctermid (char *__s) __attribute__ ((__nothrow__ , __leaf__));
-# 912 "/usr/include/stdio.h" 3 4
-extern void flockfile (FILE *__stream) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-extern int ftrylockfile (FILE *__stream) __attribute__ ((__nothrow__ , __leaf__)) ;
-
-
-extern void funlockfile (FILE *__stream) __attribute__ ((__nothrow__ , __leaf__));
-# 942 "/usr/include/stdio.h" 3 4
-
-# 27 "../../../server-code/src/common/utils.h" 2
-
-# 1 "/usr/include/unistd.h" 1 3 4
-# 27 "/usr/include/unistd.h" 3 4
-
-# 205 "/usr/include/unistd.h" 3 4
-# 1 "/usr/include/x86_64-linux-gnu/bits/posix_opt.h" 1 3 4
-# 206 "/usr/include/unistd.h" 2 3 4
-
-
-
-# 1 "/usr/include/x86_64-linux-gnu/bits/environments.h" 1 3 4
-# 22 "/usr/include/x86_64-linux-gnu/bits/environments.h" 3 4
-# 1 "/usr/include/x86_64-linux-gnu/bits/wordsize.h" 1 3 4
-# 23 "/usr/include/x86_64-linux-gnu/bits/environments.h" 2 3 4
-# 210 "/usr/include/unistd.h" 2 3 4
-# 229 "/usr/include/unistd.h" 3 4
-# 1 "/usr/lib/gcc/x86_64-linux-gnu/5/include/stddef.h" 1 3 4
-# 230 "/usr/include/unistd.h" 2 3 4
-
-
-
-
-
-typedef __gid_t gid_t;
-
-
-
-
-typedef __uid_t uid_t;
-# 258 "/usr/include/unistd.h" 3 4
-typedef __useconds_t useconds_t;
-# 277 "/usr/include/unistd.h" 3 4
-typedef __socklen_t socklen_t;
-# 290 "/usr/include/unistd.h" 3 4
-extern int access (const char *__name, int __type) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-# 307 "/usr/include/unistd.h" 3 4
-extern int faccessat (int __fd, const char *__file, int __type, int __flag)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (2))) ;
-# 337 "/usr/include/unistd.h" 3 4
-extern __off_t lseek (int __fd, __off_t __offset, int __whence) __attribute__ ((__nothrow__ , __leaf__));
-# 356 "/usr/include/unistd.h" 3 4
-extern int close (int __fd);
-
-
-
-
-
-
-extern ssize_t read (int __fd, void *__buf, size_t __nbytes) ;
-
-
-
-
-
-extern ssize_t write (int __fd, const void *__buf, size_t __n) ;
-# 379 "/usr/include/unistd.h" 3 4
-extern ssize_t pread (int __fd, void *__buf, size_t __nbytes,
- __off_t __offset) ;
-
-
-
-
-
-
-extern ssize_t pwrite (int __fd, const void *__buf, size_t __n,
- __off_t __offset) ;
-# 420 "/usr/include/unistd.h" 3 4
-extern int pipe (int __pipedes[2]) __attribute__ ((__nothrow__ , __leaf__)) ;
-# 435 "/usr/include/unistd.h" 3 4
-extern unsigned int alarm (unsigned int __seconds) __attribute__ ((__nothrow__ , __leaf__));
-# 447 "/usr/include/unistd.h" 3 4
-extern unsigned int sleep (unsigned int __seconds);
-
-
-
-
-
-
-
-extern __useconds_t ualarm (__useconds_t __value, __useconds_t __interval)
- __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-
-
-extern int usleep (__useconds_t __useconds);
-# 472 "/usr/include/unistd.h" 3 4
-extern int pause (void);
-
-
-
-extern int chown (const char *__file, __uid_t __owner, __gid_t __group)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1))) ;
-
-
-
-extern int fchown (int __fd, __uid_t __owner, __gid_t __group) __attribute__ ((__nothrow__ , __leaf__)) ;
-
-
-
-
-extern int lchown (const char *__file, __uid_t __owner, __gid_t __group)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1))) ;
-
-
-
-
-
-
-extern int fchownat (int __fd, const char *__file, __uid_t __owner,
- __gid_t __group, int __flag)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (2))) ;
-
-
-
-extern int chdir (const char *__path) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1))) ;
-
-
-
-extern int fchdir (int __fd) __attribute__ ((__nothrow__ , __leaf__)) ;
-# 514 "/usr/include/unistd.h" 3 4
-extern char *getcwd (char *__buf, size_t __size) __attribute__ ((__nothrow__ , __leaf__)) ;
-# 528 "/usr/include/unistd.h" 3 4
-extern char *getwd (char *__buf)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1))) __attribute__ ((__deprecated__)) ;
-
-
-
-
-extern int dup (int __fd) __attribute__ ((__nothrow__ , __leaf__)) ;
-
-
-extern int dup2 (int __fd, int __fd2) __attribute__ ((__nothrow__ , __leaf__));
-# 546 "/usr/include/unistd.h" 3 4
-extern char **__environ;
-
-
-
-
-
-
-
-extern int execve (const char *__path, char *const __argv[],
- char *const __envp[]) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1, 2)));
-
-
-
-
-extern int fexecve (int __fd, char *const __argv[], char *const __envp[])
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (2)));
-
-
-
-
-extern int execv (const char *__path, char *const __argv[])
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1, 2)));
-
-
-
-extern int execle (const char *__path, const char *__arg, ...)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1, 2)));
-
-
-
-extern int execl (const char *__path, const char *__arg, ...)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1, 2)));
-
-
-
-extern int execvp (const char *__file, char *const __argv[])
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1, 2)));
-
-
-
-
-extern int execlp (const char *__file, const char *__arg, ...)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1, 2)));
-# 601 "/usr/include/unistd.h" 3 4
-extern int nice (int __inc) __attribute__ ((__nothrow__ , __leaf__)) ;
-
-
-
-
-extern void _exit (int __status) __attribute__ ((__noreturn__));
-
-
-
-
-
-# 1 "/usr/include/x86_64-linux-gnu/bits/confname.h" 1 3 4
-# 24 "/usr/include/x86_64-linux-gnu/bits/confname.h" 3 4
-enum
- {
- _PC_LINK_MAX,
-
- _PC_MAX_CANON,
-
- _PC_MAX_INPUT,
-
- _PC_NAME_MAX,
-
- _PC_PATH_MAX,
-
- _PC_PIPE_BUF,
-
- _PC_CHOWN_RESTRICTED,
-
- _PC_NO_TRUNC,
-
- _PC_VDISABLE,
-
- _PC_SYNC_IO,
-
- _PC_ASYNC_IO,
-
- _PC_PRIO_IO,
-
- _PC_SOCK_MAXBUF,
-
- _PC_FILESIZEBITS,
-
- _PC_REC_INCR_XFER_SIZE,
-
- _PC_REC_MAX_XFER_SIZE,
-
- _PC_REC_MIN_XFER_SIZE,
-
- _PC_REC_XFER_ALIGN,
-
- _PC_ALLOC_SIZE_MIN,
-
- _PC_SYMLINK_MAX,
-
- _PC_2_SYMLINKS
-
- };
-
-
-enum
- {
- _SC_ARG_MAX,
-
- _SC_CHILD_MAX,
-
- _SC_CLK_TCK,
-
- _SC_NGROUPS_MAX,
-
- _SC_OPEN_MAX,
-
- _SC_STREAM_MAX,
-
- _SC_TZNAME_MAX,
-
- _SC_JOB_CONTROL,
-
- _SC_SAVED_IDS,
-
- _SC_REALTIME_SIGNALS,
-
- _SC_PRIORITY_SCHEDULING,
-
- _SC_TIMERS,
-
- _SC_ASYNCHRONOUS_IO,
-
- _SC_PRIORITIZED_IO,
-
- _SC_SYNCHRONIZED_IO,
-
- _SC_FSYNC,
-
- _SC_MAPPED_FILES,
-
- _SC_MEMLOCK,
-
- _SC_MEMLOCK_RANGE,
-
- _SC_MEMORY_PROTECTION,
-
- _SC_MESSAGE_PASSING,
-
- _SC_SEMAPHORES,
-
- _SC_SHARED_MEMORY_OBJECTS,
-
- _SC_AIO_LISTIO_MAX,
-
- _SC_AIO_MAX,
-
- _SC_AIO_PRIO_DELTA_MAX,
-
- _SC_DELAYTIMER_MAX,
-
- _SC_MQ_OPEN_MAX,
-
- _SC_MQ_PRIO_MAX,
-
- _SC_VERSION,
-
- _SC_PAGESIZE,
-
-
- _SC_RTSIG_MAX,
-
- _SC_SEM_NSEMS_MAX,
-
- _SC_SEM_VALUE_MAX,
-
- _SC_SIGQUEUE_MAX,
-
- _SC_TIMER_MAX,
-
-
-
-
- _SC_BC_BASE_MAX,
-
- _SC_BC_DIM_MAX,
-
- _SC_BC_SCALE_MAX,
-
- _SC_BC_STRING_MAX,
-
- _SC_COLL_WEIGHTS_MAX,
-
- _SC_EQUIV_CLASS_MAX,
-
- _SC_EXPR_NEST_MAX,
-
- _SC_LINE_MAX,
-
- _SC_RE_DUP_MAX,
-
- _SC_CHARCLASS_NAME_MAX,
-
-
- _SC_2_VERSION,
-
- _SC_2_C_BIND,
-
- _SC_2_C_DEV,
-
- _SC_2_FORT_DEV,
-
- _SC_2_FORT_RUN,
-
- _SC_2_SW_DEV,
-
- _SC_2_LOCALEDEF,
-
-
- _SC_PII,
-
- _SC_PII_XTI,
-
- _SC_PII_SOCKET,
-
- _SC_PII_INTERNET,
-
- _SC_PII_OSI,
-
- _SC_POLL,
-
- _SC_SELECT,
-
- _SC_UIO_MAXIOV,
-
- _SC_IOV_MAX = _SC_UIO_MAXIOV,
-
- _SC_PII_INTERNET_STREAM,
-
- _SC_PII_INTERNET_DGRAM,
-
- _SC_PII_OSI_COTS,
-
- _SC_PII_OSI_CLTS,
-
- _SC_PII_OSI_M,
-
- _SC_T_IOV_MAX,
-
-
-
- _SC_THREADS,
-
- _SC_THREAD_SAFE_FUNCTIONS,
-
- _SC_GETGR_R_SIZE_MAX,
-
- _SC_GETPW_R_SIZE_MAX,
-
- _SC_LOGIN_NAME_MAX,
-
- _SC_TTY_NAME_MAX,
-
- _SC_THREAD_DESTRUCTOR_ITERATIONS,
-
- _SC_THREAD_KEYS_MAX,
-
- _SC_THREAD_STACK_MIN,
-
- _SC_THREAD_THREADS_MAX,
-
- _SC_THREAD_ATTR_STACKADDR,
-
- _SC_THREAD_ATTR_STACKSIZE,
-
- _SC_THREAD_PRIORITY_SCHEDULING,
-
- _SC_THREAD_PRIO_INHERIT,
-
- _SC_THREAD_PRIO_PROTECT,
-
- _SC_THREAD_PROCESS_SHARED,
-
-
- _SC_NPROCESSORS_CONF,
-
- _SC_NPROCESSORS_ONLN,
-
- _SC_PHYS_PAGES,
-
- _SC_AVPHYS_PAGES,
-
- _SC_ATEXIT_MAX,
-
- _SC_PASS_MAX,
-
-
- _SC_XOPEN_VERSION,
-
- _SC_XOPEN_XCU_VERSION,
-
- _SC_XOPEN_UNIX,
-
- _SC_XOPEN_CRYPT,
-
- _SC_XOPEN_ENH_I18N,
-
- _SC_XOPEN_SHM,
-
-
- _SC_2_CHAR_TERM,
-
- _SC_2_C_VERSION,
-
- _SC_2_UPE,
-
-
- _SC_XOPEN_XPG2,
-
- _SC_XOPEN_XPG3,
-
- _SC_XOPEN_XPG4,
-
-
- _SC_CHAR_BIT,
-
- _SC_CHAR_MAX,
-
- _SC_CHAR_MIN,
-
- _SC_INT_MAX,
-
- _SC_INT_MIN,
-
- _SC_LONG_BIT,
-
- _SC_WORD_BIT,
-
- _SC_MB_LEN_MAX,
-
- _SC_NZERO,
-
- _SC_SSIZE_MAX,
-
- _SC_SCHAR_MAX,
-
- _SC_SCHAR_MIN,
-
- _SC_SHRT_MAX,
-
- _SC_SHRT_MIN,
-
- _SC_UCHAR_MAX,
-
- _SC_UINT_MAX,
-
- _SC_ULONG_MAX,
-
- _SC_USHRT_MAX,
-
-
- _SC_NL_ARGMAX,
-
- _SC_NL_LANGMAX,
-
- _SC_NL_MSGMAX,
-
- _SC_NL_NMAX,
-
- _SC_NL_SETMAX,
-
- _SC_NL_TEXTMAX,
-
-
- _SC_XBS5_ILP32_OFF32,
-
- _SC_XBS5_ILP32_OFFBIG,
-
- _SC_XBS5_LP64_OFF64,
-
- _SC_XBS5_LPBIG_OFFBIG,
-
-
- _SC_XOPEN_LEGACY,
-
- _SC_XOPEN_REALTIME,
-
- _SC_XOPEN_REALTIME_THREADS,
-
-
- _SC_ADVISORY_INFO,
-
- _SC_BARRIERS,
-
- _SC_BASE,
-
- _SC_C_LANG_SUPPORT,
-
- _SC_C_LANG_SUPPORT_R,
-
- _SC_CLOCK_SELECTION,
-
- _SC_CPUTIME,
-
- _SC_THREAD_CPUTIME,
-
- _SC_DEVICE_IO,
-
- _SC_DEVICE_SPECIFIC,
-
- _SC_DEVICE_SPECIFIC_R,
-
- _SC_FD_MGMT,
-
- _SC_FIFO,
-
- _SC_PIPE,
-
- _SC_FILE_ATTRIBUTES,
-
- _SC_FILE_LOCKING,
-
- _SC_FILE_SYSTEM,
-
- _SC_MONOTONIC_CLOCK,
-
- _SC_MULTI_PROCESS,
-
- _SC_SINGLE_PROCESS,
-
- _SC_NETWORKING,
-
- _SC_READER_WRITER_LOCKS,
-
- _SC_SPIN_LOCKS,
-
- _SC_REGEXP,
-
- _SC_REGEX_VERSION,
-
- _SC_SHELL,
-
- _SC_SIGNALS,
-
- _SC_SPAWN,
-
- _SC_SPORADIC_SERVER,
-
- _SC_THREAD_SPORADIC_SERVER,
-
- _SC_SYSTEM_DATABASE,
-
- _SC_SYSTEM_DATABASE_R,
-
- _SC_TIMEOUTS,
-
- _SC_TYPED_MEMORY_OBJECTS,
-
- _SC_USER_GROUPS,
-
- _SC_USER_GROUPS_R,
-
- _SC_2_PBS,
-
- _SC_2_PBS_ACCOUNTING,
-
- _SC_2_PBS_LOCATE,
-
- _SC_2_PBS_MESSAGE,
-
- _SC_2_PBS_TRACK,
-
- _SC_SYMLOOP_MAX,
-
- _SC_STREAMS,
-
- _SC_2_PBS_CHECKPOINT,
-
-
- _SC_V6_ILP32_OFF32,
-
- _SC_V6_ILP32_OFFBIG,
-
- _SC_V6_LP64_OFF64,
-
- _SC_V6_LPBIG_OFFBIG,
-
-
- _SC_HOST_NAME_MAX,
-
- _SC_TRACE,
-
- _SC_TRACE_EVENT_FILTER,
-
- _SC_TRACE_INHERIT,
-
- _SC_TRACE_LOG,
-
-
- _SC_LEVEL1_ICACHE_SIZE,
-
- _SC_LEVEL1_ICACHE_ASSOC,
-
- _SC_LEVEL1_ICACHE_LINESIZE,
-
- _SC_LEVEL1_DCACHE_SIZE,
-
- _SC_LEVEL1_DCACHE_ASSOC,
-
- _SC_LEVEL1_DCACHE_LINESIZE,
-
- _SC_LEVEL2_CACHE_SIZE,
-
- _SC_LEVEL2_CACHE_ASSOC,
-
- _SC_LEVEL2_CACHE_LINESIZE,
-
- _SC_LEVEL3_CACHE_SIZE,
-
- _SC_LEVEL3_CACHE_ASSOC,
-
- _SC_LEVEL3_CACHE_LINESIZE,
-
- _SC_LEVEL4_CACHE_SIZE,
-
- _SC_LEVEL4_CACHE_ASSOC,
-
- _SC_LEVEL4_CACHE_LINESIZE,
-
-
-
- _SC_IPV6 = _SC_LEVEL1_ICACHE_SIZE + 50,
-
- _SC_RAW_SOCKETS,
-
-
- _SC_V7_ILP32_OFF32,
-
- _SC_V7_ILP32_OFFBIG,
-
- _SC_V7_LP64_OFF64,
-
- _SC_V7_LPBIG_OFFBIG,
-
-
- _SC_SS_REPL_MAX,
-
-
- _SC_TRACE_EVENT_NAME_MAX,
-
- _SC_TRACE_NAME_MAX,
-
- _SC_TRACE_SYS_MAX,
-
- _SC_TRACE_USER_EVENT_MAX,
-
-
- _SC_XOPEN_STREAMS,
-
-
- _SC_THREAD_ROBUST_PRIO_INHERIT,
-
- _SC_THREAD_ROBUST_PRIO_PROTECT
-
- };
-
-
-enum
- {
- _CS_PATH,
-
-
- _CS_V6_WIDTH_RESTRICTED_ENVS,
-
-
-
- _CS_GNU_LIBC_VERSION,
-
- _CS_GNU_LIBPTHREAD_VERSION,
-
-
- _CS_V5_WIDTH_RESTRICTED_ENVS,
-
-
-
- _CS_V7_WIDTH_RESTRICTED_ENVS,
-
-
-
- _CS_LFS_CFLAGS = 1000,
-
- _CS_LFS_LDFLAGS,
-
- _CS_LFS_LIBS,
-
- _CS_LFS_LINTFLAGS,
-
- _CS_LFS64_CFLAGS,
-
- _CS_LFS64_LDFLAGS,
-
- _CS_LFS64_LIBS,
-
- _CS_LFS64_LINTFLAGS,
-
-
- _CS_XBS5_ILP32_OFF32_CFLAGS = 1100,
-
- _CS_XBS5_ILP32_OFF32_LDFLAGS,
-
- _CS_XBS5_ILP32_OFF32_LIBS,
-
- _CS_XBS5_ILP32_OFF32_LINTFLAGS,
-
- _CS_XBS5_ILP32_OFFBIG_CFLAGS,
-
- _CS_XBS5_ILP32_OFFBIG_LDFLAGS,
-
- _CS_XBS5_ILP32_OFFBIG_LIBS,
-
- _CS_XBS5_ILP32_OFFBIG_LINTFLAGS,
-
- _CS_XBS5_LP64_OFF64_CFLAGS,
-
- _CS_XBS5_LP64_OFF64_LDFLAGS,
-
- _CS_XBS5_LP64_OFF64_LIBS,
-
- _CS_XBS5_LP64_OFF64_LINTFLAGS,
-
- _CS_XBS5_LPBIG_OFFBIG_CFLAGS,
-
- _CS_XBS5_LPBIG_OFFBIG_LDFLAGS,
-
- _CS_XBS5_LPBIG_OFFBIG_LIBS,
-
- _CS_XBS5_LPBIG_OFFBIG_LINTFLAGS,
-
-
- _CS_POSIX_V6_ILP32_OFF32_CFLAGS,
-
- _CS_POSIX_V6_ILP32_OFF32_LDFLAGS,
-
- _CS_POSIX_V6_ILP32_OFF32_LIBS,
-
- _CS_POSIX_V6_ILP32_OFF32_LINTFLAGS,
-
- _CS_POSIX_V6_ILP32_OFFBIG_CFLAGS,
-
- _CS_POSIX_V6_ILP32_OFFBIG_LDFLAGS,
-
- _CS_POSIX_V6_ILP32_OFFBIG_LIBS,
-
- _CS_POSIX_V6_ILP32_OFFBIG_LINTFLAGS,
-
- _CS_POSIX_V6_LP64_OFF64_CFLAGS,
-
- _CS_POSIX_V6_LP64_OFF64_LDFLAGS,
-
- _CS_POSIX_V6_LP64_OFF64_LIBS,
-
- _CS_POSIX_V6_LP64_OFF64_LINTFLAGS,
-
- _CS_POSIX_V6_LPBIG_OFFBIG_CFLAGS,
-
- _CS_POSIX_V6_LPBIG_OFFBIG_LDFLAGS,
-
- _CS_POSIX_V6_LPBIG_OFFBIG_LIBS,
-
- _CS_POSIX_V6_LPBIG_OFFBIG_LINTFLAGS,
-
-
- _CS_POSIX_V7_ILP32_OFF32_CFLAGS,
-
- _CS_POSIX_V7_ILP32_OFF32_LDFLAGS,
-
- _CS_POSIX_V7_ILP32_OFF32_LIBS,
-
- _CS_POSIX_V7_ILP32_OFF32_LINTFLAGS,
-
- _CS_POSIX_V7_ILP32_OFFBIG_CFLAGS,
-
- _CS_POSIX_V7_ILP32_OFFBIG_LDFLAGS,
-
- _CS_POSIX_V7_ILP32_OFFBIG_LIBS,
-
- _CS_POSIX_V7_ILP32_OFFBIG_LINTFLAGS,
-
- _CS_POSIX_V7_LP64_OFF64_CFLAGS,
-
- _CS_POSIX_V7_LP64_OFF64_LDFLAGS,
-
- _CS_POSIX_V7_LP64_OFF64_LIBS,
-
- _CS_POSIX_V7_LP64_OFF64_LINTFLAGS,
-
- _CS_POSIX_V7_LPBIG_OFFBIG_CFLAGS,
-
- _CS_POSIX_V7_LPBIG_OFFBIG_LDFLAGS,
-
- _CS_POSIX_V7_LPBIG_OFFBIG_LIBS,
-
- _CS_POSIX_V7_LPBIG_OFFBIG_LINTFLAGS,
-
-
- _CS_V6_ENV,
-
- _CS_V7_ENV
-
- };
-# 613 "/usr/include/unistd.h" 2 3 4
-
-
-extern long int pathconf (const char *__path, int __name)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-
-
-extern long int fpathconf (int __fd, int __name) __attribute__ ((__nothrow__ , __leaf__));
-
-
-extern long int sysconf (int __name) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-extern size_t confstr (int __name, char *__buf, size_t __len) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-extern __pid_t getpid (void) __attribute__ ((__nothrow__ , __leaf__));
-
-
-extern __pid_t getppid (void) __attribute__ ((__nothrow__ , __leaf__));
-
-
-extern __pid_t getpgrp (void) __attribute__ ((__nothrow__ , __leaf__));
-
-
-extern __pid_t __getpgid (__pid_t __pid) __attribute__ ((__nothrow__ , __leaf__));
-
-extern __pid_t getpgid (__pid_t __pid) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-
-
-extern int setpgid (__pid_t __pid, __pid_t __pgid) __attribute__ ((__nothrow__ , __leaf__));
-# 663 "/usr/include/unistd.h" 3 4
-extern int setpgrp (void) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-
-
-extern __pid_t setsid (void) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-extern __pid_t getsid (__pid_t __pid) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-extern __uid_t getuid (void) __attribute__ ((__nothrow__ , __leaf__));
-
-
-extern __uid_t geteuid (void) __attribute__ ((__nothrow__ , __leaf__));
-
-
-extern __gid_t getgid (void) __attribute__ ((__nothrow__ , __leaf__));
-
-
-extern __gid_t getegid (void) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-extern int getgroups (int __size, __gid_t __list[]) __attribute__ ((__nothrow__ , __leaf__)) ;
-# 703 "/usr/include/unistd.h" 3 4
-extern int setuid (__uid_t __uid) __attribute__ ((__nothrow__ , __leaf__)) ;
-
-
-
-
-extern int setreuid (__uid_t __ruid, __uid_t __euid) __attribute__ ((__nothrow__ , __leaf__)) ;
-
-
-
-
-extern int seteuid (__uid_t __uid) __attribute__ ((__nothrow__ , __leaf__)) ;
-
-
-
-
-
-
-extern int setgid (__gid_t __gid) __attribute__ ((__nothrow__ , __leaf__)) ;
-
-
-
-
-extern int setregid (__gid_t __rgid, __gid_t __egid) __attribute__ ((__nothrow__ , __leaf__)) ;
-
-
-
-
-extern int setegid (__gid_t __gid) __attribute__ ((__nothrow__ , __leaf__)) ;
-# 759 "/usr/include/unistd.h" 3 4
-extern __pid_t fork (void) __attribute__ ((__nothrow__));
-
-
-
-
-
-
-
-extern __pid_t vfork (void) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-
-extern char *ttyname (int __fd) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-extern int ttyname_r (int __fd, char *__buf, size_t __buflen)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (2))) ;
-
-
-
-extern int isatty (int __fd) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-
-extern int ttyslot (void) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-extern int link (const char *__from, const char *__to)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1, 2))) ;
-
-
-
-
-extern int linkat (int __fromfd, const char *__from, int __tofd,
- const char *__to, int __flags)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (2, 4))) ;
-
-
-
-
-extern int symlink (const char *__from, const char *__to)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1, 2))) ;
-
-
-
-
-extern ssize_t readlink (const char *__restrict __path,
- char *__restrict __buf, size_t __len)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1, 2))) ;
-
-
-
-
-extern int symlinkat (const char *__from, int __tofd,
- const char *__to) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1, 3))) ;
-
-
-extern ssize_t readlinkat (int __fd, const char *__restrict __path,
- char *__restrict __buf, size_t __len)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (2, 3))) ;
-
-
-
-extern int unlink (const char *__name) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-
-
-
-extern int unlinkat (int __fd, const char *__name, int __flag)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (2)));
-
-
-
-extern int rmdir (const char *__path) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-
-
-
-extern __pid_t tcgetpgrp (int __fd) __attribute__ ((__nothrow__ , __leaf__));
-
-
-extern int tcsetpgrp (int __fd, __pid_t __pgrp_id) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-
-
-extern char *getlogin (void);
-
-
-
-
-
-
-
-extern int getlogin_r (char *__name, size_t __name_len) __attribute__ ((__nonnull__ (1)));
-
-
-
-
-extern int setlogin (const char *__name) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-# 874 "/usr/include/unistd.h" 3 4
-# 1 "/usr/include/getopt.h" 1 3 4
-# 57 "/usr/include/getopt.h" 3 4
-extern char *optarg;
-# 71 "/usr/include/getopt.h" 3 4
-extern int optind;
-
-
-
-
-extern int opterr;
-
-
-
-extern int optopt;
-# 150 "/usr/include/getopt.h" 3 4
-extern int getopt (int ___argc, char *const *___argv, const char *__shortopts)
- __attribute__ ((__nothrow__ , __leaf__));
-# 875 "/usr/include/unistd.h" 2 3 4
-
-
-
-
-
-
-
-extern int gethostname (char *__name, size_t __len) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-
-
-
-
-
-
-extern int sethostname (const char *__name, size_t __len)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1))) ;
-
-
-
-extern int sethostid (long int __id) __attribute__ ((__nothrow__ , __leaf__)) ;
-
-
-
-
-
-extern int getdomainname (char *__name, size_t __len)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1))) ;
-extern int setdomainname (const char *__name, size_t __len)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1))) ;
-
-
-
-
-
-extern int vhangup (void) __attribute__ ((__nothrow__ , __leaf__));
-
-
-extern int revoke (const char *__file) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1))) ;
-
-
-
-
-
-
-
-extern int profil (unsigned short int *__sample_buffer, size_t __size,
- size_t __offset, unsigned int __scale)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-
-
-
-
-
-extern int acct (const char *__name) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-extern char *getusershell (void) __attribute__ ((__nothrow__ , __leaf__));
-extern void endusershell (void) __attribute__ ((__nothrow__ , __leaf__));
-extern void setusershell (void) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-
-extern int daemon (int __nochdir, int __noclose) __attribute__ ((__nothrow__ , __leaf__)) ;
-
-
-
-
-
-
-extern int chroot (const char *__path) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1))) ;
-
-
-
-extern char *getpass (const char *__prompt) __attribute__ ((__nonnull__ (1)));
-
-
-
-
-
-
-
-extern int fsync (int __fd);
-# 972 "/usr/include/unistd.h" 3 4
-extern long int gethostid (void);
-
-
-extern void sync (void) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-
-extern int getpagesize (void) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__const__));
-
-
-
-
-extern int getdtablesize (void) __attribute__ ((__nothrow__ , __leaf__));
-# 996 "/usr/include/unistd.h" 3 4
-extern int truncate (const char *__file, __off_t __length)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1))) ;
-# 1019 "/usr/include/unistd.h" 3 4
-extern int ftruncate (int __fd, __off_t __length) __attribute__ ((__nothrow__ , __leaf__)) ;
-# 1040 "/usr/include/unistd.h" 3 4
-extern int brk (void *__addr) __attribute__ ((__nothrow__ , __leaf__)) ;
-
-
-
-
-
-extern void *sbrk (intptr_t __delta) __attribute__ ((__nothrow__ , __leaf__));
-# 1061 "/usr/include/unistd.h" 3 4
-extern long int syscall (long int __sysno, ...) __attribute__ ((__nothrow__ , __leaf__));
-# 1084 "/usr/include/unistd.h" 3 4
-extern int lockf (int __fd, int __cmd, __off_t __len) ;
-# 1115 "/usr/include/unistd.h" 3 4
-extern int fdatasync (int __fildes);
-# 1154 "/usr/include/unistd.h" 3 4
-
-# 29 "../../../server-code/src/common/utils.h" 2
-# 39 "../../../server-code/src/common/utils.h"
-
-# 39 "../../../server-code/src/common/utils.h"
-void WriteDump(FILE* fp, const void* buffer, size_t length);
-void ShowDump(const void* buffer, size_t length);
-
-void findfile(const char *p, const char *pat, void (func)(const char*));
-
-# 43 "../../../server-code/src/common/utils.h" 3 4
-_Bool
-# 43 "../../../server-code/src/common/utils.h"
- exists(const char* filename);
-
-
-unsigned int get_percentage(const unsigned int A, const unsigned int B);
-
-int64 apply_percentrate64(int64 value, int rate, int maxrate);
-int apply_percentrate(int value, int rate, int maxrate);
-
-const char* timestamp2string(char* str, size_t size, time_t timestamp, const char* format);
-
-
-
-
-
-extern uint8 GetByte(uint32 val, int idx);
-extern uint16 GetWord(uint32 val, int idx);
-extern uint16 MakeWord(uint8 byte0, uint8 byte1);
-extern uint32 MakeDWord(uint16 word0, uint16 word1);
-
-
-
-
-extern int16 MakeShortLE(int16 val);
-extern int32 MakeLongLE(int32 val);
-extern uint16 GetUShort(const unsigned char* buf);
-extern uint32 GetULong(const unsigned char* buf);
-extern int32 GetLong(const unsigned char* buf);
-extern float GetFloat(const unsigned char* buf);
-
-size_t hread(void * ptr, size_t size, size_t count, FILE * stream);
-size_t hwrite(const void * ptr, size_t size, size_t count, FILE * stream);
-# 83 "../../../server-code/src/common/utils.h"
-struct HCache_interface {
- void (*init) (void);
-
-
-# 86 "../../../server-code/src/common/utils.h" 3 4
-_Bool
-# 86 "../../../server-code/src/common/utils.h"
- (*check) (const char *file);
- FILE *(*open) (const char *file, const char *opt);
-
- time_t recompile_time;
-
-# 90 "../../../server-code/src/common/utils.h" 3 4
-_Bool
-# 90 "../../../server-code/src/common/utils.h"
- enabled;
-};
-
-
-void HCache_defaults(void);
-
-
-extern struct HCache_interface *HCache;
-# 58 "../../../server-code/src/char/char.c" 2
-
-# 1 "/usr/include/signal.h" 1 3 4
-# 30 "/usr/include/signal.h" 3 4
-
-
-# 1 "/usr/include/x86_64-linux-gnu/bits/sigset.h" 1 3 4
-# 22 "/usr/include/x86_64-linux-gnu/bits/sigset.h" 3 4
-
-# 22 "/usr/include/x86_64-linux-gnu/bits/sigset.h" 3 4
-typedef int __sig_atomic_t;
-
-
-
-
-typedef struct
- {
- unsigned long int __val[(1024 / (8 * sizeof (unsigned long int)))];
- } __sigset_t;
-# 102 "/usr/include/x86_64-linux-gnu/bits/sigset.h" 3 4
-extern int __sigismember (const __sigset_t *, int);
-extern int __sigaddset (__sigset_t *, int);
-extern int __sigdelset (__sigset_t *, int);
-# 33 "/usr/include/signal.h" 2 3 4
-
-
-
-
-
-
-
-typedef __sig_atomic_t sig_atomic_t;
-
-
-
-
-
-
-
-
-typedef __sigset_t sigset_t;
-
-
-
-
-
-
-
-# 1 "/usr/include/x86_64-linux-gnu/bits/signum.h" 1 3 4
-# 58 "/usr/include/signal.h" 2 3 4
-# 80 "/usr/include/signal.h" 3 4
-# 1 "/usr/include/x86_64-linux-gnu/bits/siginfo.h" 1 3 4
-# 24 "/usr/include/x86_64-linux-gnu/bits/siginfo.h" 3 4
-# 1 "/usr/include/x86_64-linux-gnu/bits/wordsize.h" 1 3 4
-# 25 "/usr/include/x86_64-linux-gnu/bits/siginfo.h" 2 3 4
-
-
-
-
-
-
-
-typedef union sigval
- {
- int sival_int;
- void *sival_ptr;
- } sigval_t;
-# 58 "/usr/include/x86_64-linux-gnu/bits/siginfo.h" 3 4
-typedef __clock_t __sigchld_clock_t;
-
-
-
-typedef struct
- {
- int si_signo;
- int si_errno;
-
- int si_code;
-
- union
- {
- int _pad[((128 / sizeof (int)) - 4)];
-
-
- struct
- {
- __pid_t si_pid;
- __uid_t si_uid;
- } _kill;
-
-
- struct
- {
- int si_tid;
- int si_overrun;
- sigval_t si_sigval;
- } _timer;
-
-
- struct
- {
- __pid_t si_pid;
- __uid_t si_uid;
- sigval_t si_sigval;
- } _rt;
-
-
- struct
- {
- __pid_t si_pid;
- __uid_t si_uid;
- int si_status;
- __sigchld_clock_t si_utime;
- __sigchld_clock_t si_stime;
- } _sigchld;
-
-
- struct
- {
- void *si_addr;
- short int si_addr_lsb;
- struct
- {
- void *_lower;
- void *_upper;
- } si_addr_bnd;
- } _sigfault;
-
-
- struct
- {
- long int si_band;
- int si_fd;
- } _sigpoll;
-
-
- struct
- {
- void *_call_addr;
- int _syscall;
- unsigned int _arch;
- } _sigsys;
- } _sifields;
- } siginfo_t ;
-# 160 "/usr/include/x86_64-linux-gnu/bits/siginfo.h" 3 4
-enum
-{
- SI_ASYNCNL = -60,
-
- SI_TKILL = -6,
-
- SI_SIGIO,
-
- SI_ASYNCIO,
-
- SI_MESGQ,
-
- SI_TIMER,
-
- SI_QUEUE,
-
- SI_USER,
-
- SI_KERNEL = 0x80
-
-};
-
-
-
-
-enum
-{
- ILL_ILLOPC = 1,
-
- ILL_ILLOPN,
-
- ILL_ILLADR,
-
- ILL_ILLTRP,
-
- ILL_PRVOPC,
-
- ILL_PRVREG,
-
- ILL_COPROC,
-
- ILL_BADSTK
-
-};
-
-
-enum
-{
- FPE_INTDIV = 1,
-
- FPE_INTOVF,
-
- FPE_FLTDIV,
-
- FPE_FLTOVF,
-
- FPE_FLTUND,
-
- FPE_FLTRES,
-
- FPE_FLTINV,
-
- FPE_FLTSUB
-
-};
-
-
-enum
-{
- SEGV_MAPERR = 1,
-
- SEGV_ACCERR
-
-};
-
-
-enum
-{
- BUS_ADRALN = 1,
-
- BUS_ADRERR,
-
- BUS_OBJERR,
-
- BUS_MCEERR_AR,
-
- BUS_MCEERR_AO
-
-};
-# 264 "/usr/include/x86_64-linux-gnu/bits/siginfo.h" 3 4
-enum
-{
- CLD_EXITED = 1,
-
- CLD_KILLED,
-
- CLD_DUMPED,
-
- CLD_TRAPPED,
-
- CLD_STOPPED,
-
- CLD_CONTINUED
-
-};
-
-
-enum
-{
- POLL_IN = 1,
-
- POLL_OUT,
-
- POLL_MSG,
-
- POLL_ERR,
-
- POLL_PRI,
-
- POLL_HUP
-
-};
-# 316 "/usr/include/x86_64-linux-gnu/bits/siginfo.h" 3 4
-typedef union pthread_attr_t pthread_attr_t;
-
-
-
-typedef struct sigevent
- {
- sigval_t sigev_value;
- int sigev_signo;
- int sigev_notify;
-
- union
- {
- int _pad[((64 / sizeof (int)) - 4)];
-
-
-
- __pid_t _tid;
-
- struct
- {
- void (*_function) (sigval_t);
- pthread_attr_t *_attribute;
- } _sigev_thread;
- } _sigev_un;
- } sigevent_t;
-
-
-
-
-
-
-enum
-{
- SIGEV_SIGNAL = 0,
-
- SIGEV_NONE,
-
- SIGEV_THREAD,
-
-
- SIGEV_THREAD_ID = 4
-
-};
-# 81 "/usr/include/signal.h" 2 3 4
-
-
-
-
-typedef void (*__sighandler_t) (int);
-
-
-
-
-extern __sighandler_t __sysv_signal (int __sig, __sighandler_t __handler)
- __attribute__ ((__nothrow__ , __leaf__));
-# 100 "/usr/include/signal.h" 3 4
-
-
-extern __sighandler_t signal (int __sig, __sighandler_t __handler)
- __attribute__ ((__nothrow__ , __leaf__));
-# 114 "/usr/include/signal.h" 3 4
-
-# 127 "/usr/include/signal.h" 3 4
-extern int kill (__pid_t __pid, int __sig) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-
-
-extern int killpg (__pid_t __pgrp, int __sig) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-extern int raise (int __sig) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-extern __sighandler_t ssignal (int __sig, __sighandler_t __handler)
- __attribute__ ((__nothrow__ , __leaf__));
-extern int gsignal (int __sig) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-extern void psignal (int __sig, const char *__s);
-
-
-extern void psiginfo (const siginfo_t *__pinfo, const char *__s);
-# 187 "/usr/include/signal.h" 3 4
-extern int sigblock (int __mask) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__deprecated__));
-
-
-extern int sigsetmask (int __mask) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__deprecated__));
-
-
-extern int siggetmask (void) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__deprecated__));
-# 207 "/usr/include/signal.h" 3 4
-typedef __sighandler_t sig_t;
-
-
-
-
-
-extern int sigemptyset (sigset_t *__set) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-
-
-extern int sigfillset (sigset_t *__set) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-
-
-extern int sigaddset (sigset_t *__set, int __signo) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-
-
-extern int sigdelset (sigset_t *__set, int __signo) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-
-
-extern int sigismember (const sigset_t *__set, int __signo)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-# 243 "/usr/include/signal.h" 3 4
-# 1 "/usr/include/x86_64-linux-gnu/bits/sigaction.h" 1 3 4
-# 24 "/usr/include/x86_64-linux-gnu/bits/sigaction.h" 3 4
-struct sigaction
- {
-
-
- union
- {
-
- __sighandler_t sa_handler;
-
- void (*sa_sigaction) (int, siginfo_t *, void *);
- }
- __sigaction_handler;
-
-
-
-
-
-
-
- __sigset_t sa_mask;
-
-
- int sa_flags;
-
-
- void (*sa_restorer) (void);
- };
-# 244 "/usr/include/signal.h" 2 3 4
-
-
-extern int sigprocmask (int __how, const sigset_t *__restrict __set,
- sigset_t *__restrict __oset) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-
-
-extern int sigsuspend (const sigset_t *__set) __attribute__ ((__nonnull__ (1)));
-
-
-extern int sigaction (int __sig, const struct sigaction *__restrict __act,
- struct sigaction *__restrict __oact) __attribute__ ((__nothrow__ , __leaf__));
-
-
-extern int sigpending (sigset_t *__set) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-
-
-
-
-
-
-extern int sigwait (const sigset_t *__restrict __set, int *__restrict __sig)
- __attribute__ ((__nonnull__ (1, 2)));
-
-
-
-
-
-
-extern int sigwaitinfo (const sigset_t *__restrict __set,
- siginfo_t *__restrict __info) __attribute__ ((__nonnull__ (1)));
-
-
-
-
-
-
-extern int sigtimedwait (const sigset_t *__restrict __set,
- siginfo_t *__restrict __info,
- const struct timespec *__restrict __timeout)
- __attribute__ ((__nonnull__ (1)));
-
-
-
-extern int sigqueue (__pid_t __pid, int __sig, const union sigval __val)
- __attribute__ ((__nothrow__ , __leaf__));
-# 301 "/usr/include/signal.h" 3 4
-extern const char *const _sys_siglist[65];
-extern const char *const sys_siglist[65];
-
-
-
-# 1 "/usr/include/x86_64-linux-gnu/bits/sigcontext.h" 1 3 4
-# 29 "/usr/include/x86_64-linux-gnu/bits/sigcontext.h" 3 4
-struct _fpx_sw_bytes
-{
- __uint32_t magic1;
- __uint32_t extended_size;
- __uint64_t xstate_bv;
- __uint32_t xstate_size;
- __uint32_t padding[7];
-};
-
-struct _fpreg
-{
- unsigned short significand[4];
- unsigned short exponent;
-};
-
-struct _fpxreg
-{
- unsigned short significand[4];
- unsigned short exponent;
- unsigned short padding[3];
-};
-
-struct _xmmreg
-{
- __uint32_t element[4];
-};
-# 121 "/usr/include/x86_64-linux-gnu/bits/sigcontext.h" 3 4
-struct _fpstate
-{
-
- __uint16_t cwd;
- __uint16_t swd;
- __uint16_t ftw;
- __uint16_t fop;
- __uint64_t rip;
- __uint64_t rdp;
- __uint32_t mxcsr;
- __uint32_t mxcr_mask;
- struct _fpxreg _st[8];
- struct _xmmreg _xmm[16];
- __uint32_t padding[24];
-};
-
-struct sigcontext
-{
- __uint64_t r8;
- __uint64_t r9;
- __uint64_t r10;
- __uint64_t r11;
- __uint64_t r12;
- __uint64_t r13;
- __uint64_t r14;
- __uint64_t r15;
- __uint64_t rdi;
- __uint64_t rsi;
- __uint64_t rbp;
- __uint64_t rbx;
- __uint64_t rdx;
- __uint64_t rax;
- __uint64_t rcx;
- __uint64_t rsp;
- __uint64_t rip;
- __uint64_t eflags;
- unsigned short cs;
- unsigned short gs;
- unsigned short fs;
- unsigned short __pad0;
- __uint64_t err;
- __uint64_t trapno;
- __uint64_t oldmask;
- __uint64_t cr2;
- __extension__ union
- {
- struct _fpstate * fpstate;
- __uint64_t __fpstate_word;
- };
- __uint64_t __reserved1 [8];
-};
-
-
-
-struct _xsave_hdr
-{
- __uint64_t xstate_bv;
- __uint64_t reserved1[2];
- __uint64_t reserved2[5];
-};
-
-struct _ymmh_state
-{
- __uint32_t ymmh_space[64];
-};
-
-struct _xstate
-{
- struct _fpstate fpstate;
- struct _xsave_hdr xstate_hdr;
- struct _ymmh_state ymmh;
-};
-# 307 "/usr/include/signal.h" 2 3 4
-
-
-extern int sigreturn (struct sigcontext *__scp) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-
-
-# 1 "/usr/lib/gcc/x86_64-linux-gnu/5/include/stddef.h" 1 3 4
-# 317 "/usr/include/signal.h" 2 3 4
-
-
-
-
-extern int siginterrupt (int __sig, int __interrupt) __attribute__ ((__nothrow__ , __leaf__));
-
-# 1 "/usr/include/x86_64-linux-gnu/bits/sigstack.h" 1 3 4
-# 25 "/usr/include/x86_64-linux-gnu/bits/sigstack.h" 3 4
-struct sigstack
- {
- void *ss_sp;
- int ss_onstack;
- };
-
-
-
-enum
-{
- SS_ONSTACK = 1,
-
- SS_DISABLE
-
-};
-# 49 "/usr/include/x86_64-linux-gnu/bits/sigstack.h" 3 4
-typedef struct sigaltstack
- {
- void *ss_sp;
- int ss_flags;
- size_t ss_size;
- } stack_t;
-# 324 "/usr/include/signal.h" 2 3 4
-
-
-# 1 "/usr/include/x86_64-linux-gnu/sys/ucontext.h" 1 3 4
-# 22 "/usr/include/x86_64-linux-gnu/sys/ucontext.h" 3 4
-# 1 "/usr/include/signal.h" 1 3 4
-# 23 "/usr/include/x86_64-linux-gnu/sys/ucontext.h" 2 3 4
-# 31 "/usr/include/x86_64-linux-gnu/sys/ucontext.h" 3 4
-__extension__ typedef long long int greg_t;
-
-
-
-
-
-typedef greg_t gregset_t[23];
-# 92 "/usr/include/x86_64-linux-gnu/sys/ucontext.h" 3 4
-struct _libc_fpxreg
-{
- unsigned short int significand[4];
- unsigned short int exponent;
- unsigned short int padding[3];
-};
-
-struct _libc_xmmreg
-{
- __uint32_t element[4];
-};
-
-struct _libc_fpstate
-{
-
- __uint16_t cwd;
- __uint16_t swd;
- __uint16_t ftw;
- __uint16_t fop;
- __uint64_t rip;
- __uint64_t rdp;
- __uint32_t mxcsr;
- __uint32_t mxcr_mask;
- struct _libc_fpxreg _st[8];
- struct _libc_xmmreg _xmm[16];
- __uint32_t padding[24];
-};
-
-
-typedef struct _libc_fpstate *fpregset_t;
-
-
-typedef struct
- {
- gregset_t gregs;
-
- fpregset_t fpregs;
- __extension__ unsigned long long __reserved1 [8];
-} mcontext_t;
-
-
-typedef struct ucontext
- {
- unsigned long int uc_flags;
- struct ucontext *uc_link;
- stack_t uc_stack;
- mcontext_t uc_mcontext;
- __sigset_t uc_sigmask;
- struct _libc_fpstate __fpregs_mem;
- } ucontext_t;
-# 327 "/usr/include/signal.h" 2 3 4
-
-
-
-
-
-extern int sigstack (struct sigstack *__ss, struct sigstack *__oss)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__deprecated__));
-
-
-
-extern int sigaltstack (const struct sigaltstack *__restrict __ss,
- struct sigaltstack *__restrict __oss) __attribute__ ((__nothrow__ , __leaf__));
-# 361 "/usr/include/signal.h" 3 4
-# 1 "/usr/include/x86_64-linux-gnu/bits/pthreadtypes.h" 1 3 4
-# 21 "/usr/include/x86_64-linux-gnu/bits/pthreadtypes.h" 3 4
-# 1 "/usr/include/x86_64-linux-gnu/bits/wordsize.h" 1 3 4
-# 22 "/usr/include/x86_64-linux-gnu/bits/pthreadtypes.h" 2 3 4
-# 60 "/usr/include/x86_64-linux-gnu/bits/pthreadtypes.h" 3 4
-typedef unsigned long int pthread_t;
-
-
-union pthread_attr_t
-{
- char __size[56];
- long int __align;
-};
-
-
-
-
-
-
-
-typedef struct __pthread_internal_list
-{
- struct __pthread_internal_list *__prev;
- struct __pthread_internal_list *__next;
-} __pthread_list_t;
-# 90 "/usr/include/x86_64-linux-gnu/bits/pthreadtypes.h" 3 4
-typedef union
-{
- struct __pthread_mutex_s
- {
- int __lock;
- unsigned int __count;
- int __owner;
-
- unsigned int __nusers;
-
-
-
- int __kind;
-
- short __spins;
- short __elision;
- __pthread_list_t __list;
-# 125 "/usr/include/x86_64-linux-gnu/bits/pthreadtypes.h" 3 4
- } __data;
- char __size[40];
- long int __align;
-} pthread_mutex_t;
-
-typedef union
-{
- char __size[4];
- int __align;
-} pthread_mutexattr_t;
-
-
-
-
-typedef union
-{
- struct
- {
- int __lock;
- unsigned int __futex;
- __extension__ unsigned long long int __total_seq;
- __extension__ unsigned long long int __wakeup_seq;
- __extension__ unsigned long long int __woken_seq;
- void *__mutex;
- unsigned int __nwaiters;
- unsigned int __broadcast_seq;
- } __data;
- char __size[48];
- __extension__ long long int __align;
-} pthread_cond_t;
-
-typedef union
-{
- char __size[4];
- int __align;
-} pthread_condattr_t;
-
-
-
-typedef unsigned int pthread_key_t;
-
-
-
-typedef int pthread_once_t;
-
-
-
-
-
-typedef union
-{
-
- struct
- {
- int __lock;
- unsigned int __nr_readers;
- unsigned int __readers_wakeup;
- unsigned int __writer_wakeup;
- unsigned int __nr_readers_queued;
- unsigned int __nr_writers_queued;
- int __writer;
- int __shared;
- signed char __rwelision;
-
-
-
-
- unsigned char __pad1[7];
-
-
- unsigned long int __pad2;
-
-
- unsigned int __flags;
-
- } __data;
-# 220 "/usr/include/x86_64-linux-gnu/bits/pthreadtypes.h" 3 4
- char __size[56];
- long int __align;
-} pthread_rwlock_t;
-
-typedef union
-{
- char __size[8];
- long int __align;
-} pthread_rwlockattr_t;
-
-
-
-
-
-typedef volatile int pthread_spinlock_t;
-
-
-
-
-typedef union
-{
- char __size[32];
- long int __align;
-} pthread_barrier_t;
-
-typedef union
-{
- char __size[4];
- int __align;
-} pthread_barrierattr_t;
-# 362 "/usr/include/signal.h" 2 3 4
-# 1 "/usr/include/x86_64-linux-gnu/bits/sigthread.h" 1 3 4
-# 30 "/usr/include/x86_64-linux-gnu/bits/sigthread.h" 3 4
-extern int pthread_sigmask (int __how,
- const __sigset_t *__restrict __newmask,
- __sigset_t *__restrict __oldmask)__attribute__ ((__nothrow__ , __leaf__));
-
-
-extern int pthread_kill (pthread_t __threadid, int __signo) __attribute__ ((__nothrow__ , __leaf__));
-# 363 "/usr/include/signal.h" 2 3 4
-
-
-
-
-
-
-extern int __libc_current_sigrtmin (void) __attribute__ ((__nothrow__ , __leaf__));
-
-extern int __libc_current_sigrtmax (void) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-# 60 "../../../server-code/src/char/char.c" 2
-
-
-# 1 "/usr/include/stdlib.h" 1 3 4
-# 32 "/usr/include/stdlib.h" 3 4
-# 1 "/usr/lib/gcc/x86_64-linux-gnu/5/include/stddef.h" 1 3 4
-# 33 "/usr/include/stdlib.h" 2 3 4
-
-
-
-
-
-
-
-
-# 1 "/usr/include/x86_64-linux-gnu/bits/waitflags.h" 1 3 4
-# 50 "/usr/include/x86_64-linux-gnu/bits/waitflags.h" 3 4
-typedef enum
-{
- P_ALL,
- P_PID,
- P_PGID
-} idtype_t;
-# 42 "/usr/include/stdlib.h" 2 3 4
-# 1 "/usr/include/x86_64-linux-gnu/bits/waitstatus.h" 1 3 4
-# 66 "/usr/include/x86_64-linux-gnu/bits/waitstatus.h" 3 4
-union wait
- {
- int w_status;
- struct
- {
-
- unsigned int __w_termsig:7;
- unsigned int __w_coredump:1;
- unsigned int __w_retcode:8;
- unsigned int:16;
-
-
-
-
-
-
-
- } __wait_terminated;
- struct
- {
-
- unsigned int __w_stopval:8;
- unsigned int __w_stopsig:8;
- unsigned int:16;
-
-
-
-
-
-
- } __wait_stopped;
- };
-# 43 "/usr/include/stdlib.h" 2 3 4
-# 67 "/usr/include/stdlib.h" 3 4
-typedef union
- {
- union wait *__uptr;
- int *__iptr;
- } __WAIT_STATUS __attribute__ ((__transparent_union__));
-# 95 "/usr/include/stdlib.h" 3 4
-
-
-typedef struct
- {
- int quot;
- int rem;
- } div_t;
-
-
-
-typedef struct
- {
- long int quot;
- long int rem;
- } ldiv_t;
-
-
-
-
-
-
-
-__extension__ typedef struct
- {
- long long int quot;
- long long int rem;
- } lldiv_t;
-
-
-# 139 "/usr/include/stdlib.h" 3 4
-extern size_t __ctype_get_mb_cur_max (void) __attribute__ ((__nothrow__ , __leaf__)) ;
-
-
-
-
-extern double atof (const char *__nptr)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__pure__)) __attribute__ ((__nonnull__ (1))) ;
-
-extern int atoi (const char *__nptr)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__pure__)) __attribute__ ((__nonnull__ (1))) ;
-
-extern long int atol (const char *__nptr)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__pure__)) __attribute__ ((__nonnull__ (1))) ;
-
-
-
-
-
-__extension__ extern long long int atoll (const char *__nptr)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__pure__)) __attribute__ ((__nonnull__ (1))) ;
-
-
-
-
-
-extern double strtod (const char *__restrict __nptr,
- char **__restrict __endptr)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-
-
-
-
-
-extern float strtof (const char *__restrict __nptr,
- char **__restrict __endptr) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-
-extern long double strtold (const char *__restrict __nptr,
- char **__restrict __endptr)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-
-
-
-
-
-extern long int strtol (const char *__restrict __nptr,
- char **__restrict __endptr, int __base)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-
-extern unsigned long int strtoul (const char *__restrict __nptr,
- char **__restrict __endptr, int __base)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-
-
-
-
-__extension__
-extern long long int strtoq (const char *__restrict __nptr,
- char **__restrict __endptr, int __base)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-
-__extension__
-extern unsigned long long int strtouq (const char *__restrict __nptr,
- char **__restrict __endptr, int __base)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-
-
-
-
-
-__extension__
-extern long long int strtoll (const char *__restrict __nptr,
- char **__restrict __endptr, int __base)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-
-__extension__
-extern unsigned long long int strtoull (const char *__restrict __nptr,
- char **__restrict __endptr, int __base)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-
-# 305 "/usr/include/stdlib.h" 3 4
-extern char *l64a (long int __n) __attribute__ ((__nothrow__ , __leaf__)) ;
-
-
-extern long int a64l (const char *__s)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__pure__)) __attribute__ ((__nonnull__ (1))) ;
-
-
-
-
-# 1 "/usr/include/x86_64-linux-gnu/sys/types.h" 1 3 4
-# 27 "/usr/include/x86_64-linux-gnu/sys/types.h" 3 4
-
-
-
-
-
-
-typedef __u_char u_char;
-typedef __u_short u_short;
-typedef __u_int u_int;
-typedef __u_long u_long;
-typedef __quad_t quad_t;
-typedef __u_quad_t u_quad_t;
-typedef __fsid_t fsid_t;
-
-
-
-
-typedef __loff_t loff_t;
-
-
-
-typedef __ino_t ino_t;
-# 60 "/usr/include/x86_64-linux-gnu/sys/types.h" 3 4
-typedef __dev_t dev_t;
-# 70 "/usr/include/x86_64-linux-gnu/sys/types.h" 3 4
-typedef __mode_t mode_t;
-
-
-
-
-typedef __nlink_t nlink_t;
-# 104 "/usr/include/x86_64-linux-gnu/sys/types.h" 3 4
-typedef __id_t id_t;
-# 115 "/usr/include/x86_64-linux-gnu/sys/types.h" 3 4
-typedef __daddr_t daddr_t;
-typedef __caddr_t caddr_t;
-
-
-
-
-
-typedef __key_t key_t;
-# 146 "/usr/include/x86_64-linux-gnu/sys/types.h" 3 4
-# 1 "/usr/lib/gcc/x86_64-linux-gnu/5/include/stddef.h" 1 3 4
-# 147 "/usr/include/x86_64-linux-gnu/sys/types.h" 2 3 4
-
-
-
-typedef unsigned long int ulong;
-typedef unsigned short int ushort;
-typedef unsigned int uint;
-# 200 "/usr/include/x86_64-linux-gnu/sys/types.h" 3 4
-typedef unsigned int u_int8_t __attribute__ ((__mode__ (__QI__)));
-typedef unsigned int u_int16_t __attribute__ ((__mode__ (__HI__)));
-typedef unsigned int u_int32_t __attribute__ ((__mode__ (__SI__)));
-typedef unsigned int u_int64_t __attribute__ ((__mode__ (__DI__)));
-
-typedef int register_t __attribute__ ((__mode__ (__word__)));
-# 219 "/usr/include/x86_64-linux-gnu/sys/types.h" 3 4
-# 1 "/usr/include/x86_64-linux-gnu/sys/select.h" 1 3 4
-# 30 "/usr/include/x86_64-linux-gnu/sys/select.h" 3 4
-# 1 "/usr/include/x86_64-linux-gnu/bits/select.h" 1 3 4
-# 22 "/usr/include/x86_64-linux-gnu/bits/select.h" 3 4
-# 1 "/usr/include/x86_64-linux-gnu/bits/wordsize.h" 1 3 4
-# 23 "/usr/include/x86_64-linux-gnu/bits/select.h" 2 3 4
-# 31 "/usr/include/x86_64-linux-gnu/sys/select.h" 2 3 4
-
-
-# 1 "/usr/include/x86_64-linux-gnu/bits/sigset.h" 1 3 4
-# 34 "/usr/include/x86_64-linux-gnu/sys/select.h" 2 3 4
-# 45 "/usr/include/x86_64-linux-gnu/sys/select.h" 3 4
-# 1 "/usr/include/x86_64-linux-gnu/bits/time.h" 1 3 4
-# 30 "/usr/include/x86_64-linux-gnu/bits/time.h" 3 4
-struct timeval
- {
- __time_t tv_sec;
- __suseconds_t tv_usec;
- };
-# 46 "/usr/include/x86_64-linux-gnu/sys/select.h" 2 3 4
-
-
-typedef __suseconds_t suseconds_t;
-
-
-
-
-
-typedef long int __fd_mask;
-# 64 "/usr/include/x86_64-linux-gnu/sys/select.h" 3 4
-typedef struct
- {
-
-
-
-
-
-
- __fd_mask __fds_bits[1024 / (8 * (int) sizeof (__fd_mask))];
-
-
- } fd_set;
-
-
-
-
-
-
-typedef __fd_mask fd_mask;
-# 96 "/usr/include/x86_64-linux-gnu/sys/select.h" 3 4
-
-# 106 "/usr/include/x86_64-linux-gnu/sys/select.h" 3 4
-extern int select (int __nfds, fd_set *__restrict __readfds,
- fd_set *__restrict __writefds,
- fd_set *__restrict __exceptfds,
- struct timeval *__restrict __timeout);
-# 118 "/usr/include/x86_64-linux-gnu/sys/select.h" 3 4
-extern int pselect (int __nfds, fd_set *__restrict __readfds,
- fd_set *__restrict __writefds,
- fd_set *__restrict __exceptfds,
- const struct timespec *__restrict __timeout,
- const __sigset_t *__restrict __sigmask);
-# 131 "/usr/include/x86_64-linux-gnu/sys/select.h" 3 4
-
-# 220 "/usr/include/x86_64-linux-gnu/sys/types.h" 2 3 4
-
-
-# 1 "/usr/include/x86_64-linux-gnu/sys/sysmacros.h" 1 3 4
-# 24 "/usr/include/x86_64-linux-gnu/sys/sysmacros.h" 3 4
-
-
-__extension__
-extern unsigned int gnu_dev_major (unsigned long long int __dev)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__const__));
-__extension__
-extern unsigned int gnu_dev_minor (unsigned long long int __dev)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__const__));
-__extension__
-extern unsigned long long int gnu_dev_makedev (unsigned int __major,
- unsigned int __minor)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__const__));
-# 58 "/usr/include/x86_64-linux-gnu/sys/sysmacros.h" 3 4
-
-# 223 "/usr/include/x86_64-linux-gnu/sys/types.h" 2 3 4
-
-
-
-
-
-typedef __blksize_t blksize_t;
-
-
-
-
-
-
-typedef __blkcnt_t blkcnt_t;
-
-
-
-typedef __fsblkcnt_t fsblkcnt_t;
-
-
-
-typedef __fsfilcnt_t fsfilcnt_t;
-# 273 "/usr/include/x86_64-linux-gnu/sys/types.h" 3 4
-
-# 315 "/usr/include/stdlib.h" 2 3 4
-
-
-
-
-
-
-extern long int random (void) __attribute__ ((__nothrow__ , __leaf__));
-
-
-extern void srandom (unsigned int __seed) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-
-extern char *initstate (unsigned int __seed, char *__statebuf,
- size_t __statelen) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (2)));
-
-
-
-extern char *setstate (char *__statebuf) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-
-
-
-
-
-
-
-struct random_data
- {
- int32_t *fptr;
- int32_t *rptr;
- int32_t *state;
- int rand_type;
- int rand_deg;
- int rand_sep;
- int32_t *end_ptr;
- };
-
-extern int random_r (struct random_data *__restrict __buf,
- int32_t *__restrict __result) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1, 2)));
-
-extern int srandom_r (unsigned int __seed, struct random_data *__buf)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (2)));
-
-extern int initstate_r (unsigned int __seed, char *__restrict __statebuf,
- size_t __statelen,
- struct random_data *__restrict __buf)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (2, 4)));
-
-extern int setstate_r (char *__restrict __statebuf,
- struct random_data *__restrict __buf)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1, 2)));
-
-
-
-
-
-
-extern int rand (void) __attribute__ ((__nothrow__ , __leaf__));
-
-extern void srand (unsigned int __seed) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-extern int rand_r (unsigned int *__seed) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-
-
-
-extern double drand48 (void) __attribute__ ((__nothrow__ , __leaf__));
-extern double erand48 (unsigned short int __xsubi[3]) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-
-
-extern long int lrand48 (void) __attribute__ ((__nothrow__ , __leaf__));
-extern long int nrand48 (unsigned short int __xsubi[3])
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-
-
-extern long int mrand48 (void) __attribute__ ((__nothrow__ , __leaf__));
-extern long int jrand48 (unsigned short int __xsubi[3])
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-
-
-extern void srand48 (long int __seedval) __attribute__ ((__nothrow__ , __leaf__));
-extern unsigned short int *seed48 (unsigned short int __seed16v[3])
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-extern void lcong48 (unsigned short int __param[7]) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-
-
-
-
-
-struct drand48_data
- {
- unsigned short int __x[3];
- unsigned short int __old_x[3];
- unsigned short int __c;
- unsigned short int __init;
- __extension__ unsigned long long int __a;
-
- };
-
-
-extern int drand48_r (struct drand48_data *__restrict __buffer,
- double *__restrict __result) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1, 2)));
-extern int erand48_r (unsigned short int __xsubi[3],
- struct drand48_data *__restrict __buffer,
- double *__restrict __result) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1, 2)));
-
-
-extern int lrand48_r (struct drand48_data *__restrict __buffer,
- long int *__restrict __result)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1, 2)));
-extern int nrand48_r (unsigned short int __xsubi[3],
- struct drand48_data *__restrict __buffer,
- long int *__restrict __result)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1, 2)));
-
-
-extern int mrand48_r (struct drand48_data *__restrict __buffer,
- long int *__restrict __result)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1, 2)));
-extern int jrand48_r (unsigned short int __xsubi[3],
- struct drand48_data *__restrict __buffer,
- long int *__restrict __result)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1, 2)));
-
-
-extern int srand48_r (long int __seedval, struct drand48_data *__buffer)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (2)));
-
-extern int seed48_r (unsigned short int __seed16v[3],
- struct drand48_data *__buffer) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1, 2)));
-
-extern int lcong48_r (unsigned short int __param[7],
- struct drand48_data *__buffer)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1, 2)));
-
-
-
-
-
-
-
-
-
-extern void *malloc (size_t __size) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__malloc__)) ;
-
-extern void *calloc (size_t __nmemb, size_t __size)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__malloc__)) ;
-
-
-
-
-
-
-
-
-
-
-extern void *realloc (void *__ptr, size_t __size)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__warn_unused_result__));
-
-extern void free (void *__ptr) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-extern void cfree (void *__ptr) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-# 1 "/usr/include/alloca.h" 1 3 4
-# 24 "/usr/include/alloca.h" 3 4
-# 1 "/usr/lib/gcc/x86_64-linux-gnu/5/include/stddef.h" 1 3 4
-# 25 "/usr/include/alloca.h" 2 3 4
-
-
-
-
-
-
-
-extern void *alloca (size_t __size) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-
-
-# 493 "/usr/include/stdlib.h" 2 3 4
-
-
-
-
-
-extern void *valloc (size_t __size) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__malloc__)) ;
-
-
-
-
-extern int posix_memalign (void **__memptr, size_t __alignment, size_t __size)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1))) ;
-
-
-
-
-extern void *aligned_alloc (size_t __alignment, size_t __size)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__malloc__)) __attribute__ ((__alloc_size__ (2))) ;
-
-
-
-
-extern void abort (void) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__noreturn__));
-
-
-
-extern int atexit (void (*__func) (void)) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-
-
-
-
-
-
-
-extern int at_quick_exit (void (*__func) (void)) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-
-
-
-
-
-
-
-extern int on_exit (void (*__func) (int __status, void *__arg), void *__arg)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-
-
-
-
-
-
-extern void exit (int __status) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__noreturn__));
-
-
-
-
-
-extern void quick_exit (int __status) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__noreturn__));
-
-
-
-
-
-
-
-extern void _Exit (int __status) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__noreturn__));
-
-
-
-
-
-
-extern char *getenv (const char *__name) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1))) ;
-
-# 578 "/usr/include/stdlib.h" 3 4
-extern int putenv (char *__string) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-
-
-
-
-
-extern int setenv (const char *__name, const char *__value, int __replace)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (2)));
-
-
-extern int unsetenv (const char *__name) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-
-
-
-
-
-
-extern int clearenv (void) __attribute__ ((__nothrow__ , __leaf__));
-# 606 "/usr/include/stdlib.h" 3 4
-extern char *mktemp (char *__template) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-# 619 "/usr/include/stdlib.h" 3 4
-extern int mkstemp (char *__template) __attribute__ ((__nonnull__ (1))) ;
-# 641 "/usr/include/stdlib.h" 3 4
-extern int mkstemps (char *__template, int __suffixlen) __attribute__ ((__nonnull__ (1))) ;
-# 662 "/usr/include/stdlib.h" 3 4
-extern char *mkdtemp (char *__template) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1))) ;
-# 711 "/usr/include/stdlib.h" 3 4
-
-
-
-
-
-extern int system (const char *__command) ;
-
-# 733 "/usr/include/stdlib.h" 3 4
-extern char *realpath (const char *__restrict __name,
- char *__restrict __resolved) __attribute__ ((__nothrow__ , __leaf__)) ;
-
-
-
-
-
-
-typedef int (*__compar_fn_t) (const void *, const void *);
-# 751 "/usr/include/stdlib.h" 3 4
-
-
-
-extern void *bsearch (const void *__key, const void *__base,
- size_t __nmemb, size_t __size, __compar_fn_t __compar)
- __attribute__ ((__nonnull__ (1, 2, 5))) ;
-
-
-
-
-
-
-
-extern void qsort (void *__base, size_t __nmemb, size_t __size,
- __compar_fn_t __compar) __attribute__ ((__nonnull__ (1, 4)));
-# 774 "/usr/include/stdlib.h" 3 4
-extern int abs (int __x) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__const__)) ;
-extern long int labs (long int __x) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__const__)) ;
-
-
-
-__extension__ extern long long int llabs (long long int __x)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__const__)) ;
-
-
-
-
-
-
-
-extern div_t div (int __numer, int __denom)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__const__)) ;
-extern ldiv_t ldiv (long int __numer, long int __denom)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__const__)) ;
-
-
-
-
-__extension__ extern lldiv_t lldiv (long long int __numer,
- long long int __denom)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__const__)) ;
-
-# 811 "/usr/include/stdlib.h" 3 4
-extern char *ecvt (double __value, int __ndigit, int *__restrict __decpt,
- int *__restrict __sign) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (3, 4))) ;
-
-
-
-
-extern char *fcvt (double __value, int __ndigit, int *__restrict __decpt,
- int *__restrict __sign) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (3, 4))) ;
-
-
-
-
-extern char *gcvt (double __value, int __ndigit, char *__buf)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (3))) ;
-
-
-
-
-extern char *qecvt (long double __value, int __ndigit,
- int *__restrict __decpt, int *__restrict __sign)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (3, 4))) ;
-extern char *qfcvt (long double __value, int __ndigit,
- int *__restrict __decpt, int *__restrict __sign)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (3, 4))) ;
-extern char *qgcvt (long double __value, int __ndigit, char *__buf)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (3))) ;
-
-
-
-
-extern int ecvt_r (double __value, int __ndigit, int *__restrict __decpt,
- int *__restrict __sign, char *__restrict __buf,
- size_t __len) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (3, 4, 5)));
-extern int fcvt_r (double __value, int __ndigit, int *__restrict __decpt,
- int *__restrict __sign, char *__restrict __buf,
- size_t __len) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (3, 4, 5)));
-
-extern int qecvt_r (long double __value, int __ndigit,
- int *__restrict __decpt, int *__restrict __sign,
- char *__restrict __buf, size_t __len)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (3, 4, 5)));
-extern int qfcvt_r (long double __value, int __ndigit,
- int *__restrict __decpt, int *__restrict __sign,
- char *__restrict __buf, size_t __len)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (3, 4, 5)));
-
-
-
-
-
-
-extern int mblen (const char *__s, size_t __n) __attribute__ ((__nothrow__ , __leaf__));
-
-
-extern int mbtowc (wchar_t *__restrict __pwc,
- const char *__restrict __s, size_t __n) __attribute__ ((__nothrow__ , __leaf__));
-
-
-extern int wctomb (char *__s, wchar_t __wchar) __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-extern size_t mbstowcs (wchar_t *__restrict __pwcs,
- const char *__restrict __s, size_t __n) __attribute__ ((__nothrow__ , __leaf__));
-
-extern size_t wcstombs (char *__restrict __s,
- const wchar_t *__restrict __pwcs, size_t __n)
- __attribute__ ((__nothrow__ , __leaf__));
-
-
-
-
-
-
-
-
-extern int rpmatch (const char *__response) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1))) ;
-# 898 "/usr/include/stdlib.h" 3 4
-extern int getsubopt (char **__restrict __optionp,
- char *const *__restrict __tokens,
- char **__restrict __valuep)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1, 2, 3))) ;
-# 950 "/usr/include/stdlib.h" 3 4
-extern int getloadavg (double __loadavg[], int __nelem)
- __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__nonnull__ (1)));
-
-
-# 1 "/usr/include/x86_64-linux-gnu/bits/stdlib-float.h" 1 3 4
-# 955 "/usr/include/stdlib.h" 2 3 4
-# 967 "/usr/include/stdlib.h" 3 4
-
-# 63 "../../../server-code/src/char/char.c" 2
-
-
-
-
-# 66 "../../../server-code/src/char/char.c"
-char char_db[256] = "char";
-char scdata_db[256] = "sc_data";
-char cart_db[256] = "cart_inventory";
-char inventory_db[256] = "inventory";
-char charlog_db[256] = "charlog";
-char storage_db[256] = "storage";
-char interlog_db[256] = "interlog";
-char skill_db[256] = "skill";
-char memo_db[256] = "memo";
-char guild_db[256] = "guild";
-char guild_alliance_db[256] = "guild_alliance";
-char guild_castle_db[256] = "guild_castle";
-char guild_expulsion_db[256] = "guild_expulsion";
-char guild_member_db[256] = "guild_member";
-char guild_position_db[256] = "guild_position";
-char guild_skill_db[256] = "guild_skill";
-char guild_storage_db[256] = "guild_storage";
-char party_db[256] = "party";
-char pet_db[256] = "pet";
-char mail_db[256] = "mail";
-char auction_db[256] = "auction";
-char friend_db[256] = "friends";
-char hotkey_db[256] = "hotkey";
-char quest_db[256] = "quest";
-char homunculus_db[256] = "homunculus";
-char skill_homunculus_db[256] = "skill_homunculus";
-char mercenary_db[256] = "mercenary";
-char mercenary_owner_db[256] = "mercenary_owner";
-char ragsrvinfo_db[256] = "ragsrvinfo";
-char elemental_db[256] = "elemental";
-char account_data_db[256] = "account_data";
-char acc_reg_num_db[32] = "acc_reg_num_db";
-char acc_reg_str_db[32] = "acc_reg_str_db";
-char char_reg_str_db[32] = "char_reg_str_db";
-char char_reg_num_db[32] = "char_reg_num_db";
-
-struct char_interface char_s;
-struct char_interface *chr;
-
-
-int save_log = 1;
-
-char db_path[1024] = "db";
-
-char wisp_server_name[(23 + 1)] = "Server";
-char login_ip_str[128];
-uint32 login_ip = 0;
-uint16 login_port = 6900;
-char char_ip_str[128];
-char bind_ip_str[128];
-uint32 bind_ip = INADDR_ANY;
-int char_maintenance_min_group_id = 0;
-
-# 118 "../../../server-code/src/char/char.c" 3 4
-_Bool
-# 118 "../../../server-code/src/char/char.c"
- char_new =
-# 118 "../../../server-code/src/char/char.c" 3 4
- 1
-# 118 "../../../server-code/src/char/char.c"
- ;
-
-
-# 120 "../../../server-code/src/char/char.c" 3 4
-_Bool
-# 120 "../../../server-code/src/char/char.c"
- name_ignoring_case =
-# 120 "../../../server-code/src/char/char.c" 3 4
- 0
-# 120 "../../../server-code/src/char/char.c"
- ;
-int char_name_option = 0;
-char unknown_char_name[(23 + 1)] = "Unknown";
-
-char char_name_letters[1024] = "";
-
-int char_del_level = 0;
-int char_del_delay = 86400;
-
-int log_char = 1;
-int log_inter = 1;
-
-int char_aegis_delete = 0;
-
-int max_connect_user = -1;
-int gm_allow_group = -1;
-int autosave_interval = (300*1000);
-int start_zeny = 0;
-int start_items[32*3];
-int guild_exp_rate = 100;
-
-
-int fame_list_size_chemist = 10;
-int fame_list_size_smith = 10;
-int fame_list_size_taekwon = 10;
-
-
-struct fame_list smith_fame_list[10];
-struct fame_list chemist_fame_list[10];
-struct fame_list taekwon_fame_list[10];
-
-
-
- struct point start_point = { 0, 97, 90 };
-
-
-
-
-unsigned short skillid2idx[10015];
-
-
-
-
-
-
-static struct DBMap *auth_db;
-# 174 "../../../server-code/src/char/char.c"
-static struct DBData char_create_online_char_data(union DBKey key, va_list args)
-{
- struct online_char_data* character;
- ((character) = (struct online_char_data *) (iMalloc->calloc(((1)),(sizeof(struct online_char_data)),"../../../server-code/src/char/char.c", 177, __func__)));
- character->account_id = key.i;
- character->char_id = -1;
- character->server = -1;
- character->pincode_enable = -1;
- character->fd = -1;
- character->waiting_disconnect = (-1);
- return DB->ptr2data(character);
-}
-
-void char_set_account_online(int account_id)
-{
- WFIFOHEAD(chr->login_fd,6);
- WFIFOW(chr->login_fd,0) = 0x272b;
- WFIFOL(chr->login_fd,2) = account_id;
- WFIFOSET(chr->login_fd,6);
-}
-
-void char_set_account_offline(int account_id)
-{
- WFIFOHEAD(chr->login_fd,6);
- WFIFOW(chr->login_fd,0) = 0x272c;
- WFIFOL(chr->login_fd,2) = account_id;
- WFIFOSET(chr->login_fd,6);
-}
-
-void char_set_char_charselect(int account_id)
-{
- struct online_char_data* character;
-
- character = (struct online_char_data*)( DB->data2ptr((chr->online_char_db)->ensure((chr->online_char_db),DB->i2key(account_id),(chr->create_online_char_data))) );
-
- if( character->server > -1 )
- if( chr->server[character->server].users > 0 )
- chr->server[character->server].users--;
-
- character->char_id = -1;
- character->server = -1;
- if(character->pincode_enable == -1)
- character->pincode_enable = pincode->charselect + pincode->enabled;
-
- if(character->waiting_disconnect != (-1)) {
- timer->delete(character->waiting_disconnect, chr->waiting_disconnect);
- character->waiting_disconnect = (-1);
- }
-
- if (chr->login_fd > 0 && !sockt->session[chr->login_fd]->flag.eof)
- chr->set_account_online(account_id);
-}
-
-void char_set_char_online(int map_id, int char_id, int account_id)
-{
- struct online_char_data* character;
- struct mmo_charstatus *cp;
-
-
- if( (-1) == SQL->Query(inter->sql_handle, "UPDATE `%s` SET `online`='1' WHERE `char_id`='%d' LIMIT 1", char_db, char_id) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 234));
-
-
- character = (struct online_char_data*)( DB->data2ptr((chr->online_char_db)->ensure((chr->online_char_db),DB->i2key(account_id),(chr->create_online_char_data))) );
- if( character->char_id != -1 && character->server > -1 && character->server != map_id )
- {
- (showmsg->showNotice(("chr->set_char_online: Character %d:%d marked in map server %d, but map server %d claims to have (%d:%d) online!\n"), character->account_id, character->char_id, character->server, map_id, account_id, char_id))
- ;
- mapif->disconnectplayer(chr->server[character->server].fd, character->account_id, character->char_id, 2);
- }
-
-
- character->char_id = char_id;
- character->server = map_id;
-
- if( character->server > -1 )
- chr->server[character->server].users++;
-
-
- if(character->waiting_disconnect != (-1)) {
- timer->delete(character->waiting_disconnect, chr->waiting_disconnect);
- character->waiting_disconnect = (-1);
- }
-
-
- cp = (struct mmo_charstatus*)( DB->data2ptr((chr->char_db_)->get((chr->char_db_),DB->i2key(char_id))) );
- inter_guild->CharOnline(char_id, cp?cp->guild_id:-1);
-
-
- if (chr->login_fd > 0 && !sockt->session[chr->login_fd]->flag.eof)
- chr->set_account_online(account_id);
-}
-
-void char_set_char_offline(int char_id, int account_id)
-{
- struct online_char_data* character;
-
- if ( char_id == -1 )
- {
- if( (-1) == SQL->Query(inter->sql_handle, "UPDATE `%s` SET `online`='0' WHERE `account_id`='%d'", char_db, account_id) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 274));
- }
- else
- {
- struct mmo_charstatus* cp = (struct mmo_charstatus*)( DB->data2ptr((chr->char_db_)->get((chr->char_db_),DB->i2key(char_id))) );
- inter_guild->CharOffline(char_id, cp?cp->guild_id:-1);
- if (cp)
- ( (chr->char_db_)->remove((chr->char_db_),DB->i2key(char_id),
-# 281 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 281 "../../../server-code/src/char/char.c"
- ) );
-
- if( (-1) == SQL->Query(inter->sql_handle, "UPDATE `%s` SET `online`='0' WHERE `char_id`='%d' LIMIT 1", char_db, char_id) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 284));
- }
-
- if ((character = (struct online_char_data*)( DB->data2ptr((chr->online_char_db)->get((chr->online_char_db),DB->i2key(account_id))) )) !=
-# 287 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 287 "../../../server-code/src/char/char.c"
- ) {
-
- if( character->server > -1 )
- if( chr->server[character->server].users > 0 )
- chr->server[character->server].users--;
-
- if(character->waiting_disconnect != (-1)){
- timer->delete(character->waiting_disconnect, chr->waiting_disconnect);
- character->waiting_disconnect = (-1);
- }
-
- if(character->char_id == char_id)
- {
- character->char_id = -1;
- character->server = -1;
- character->pincode_enable = -1;
- }
-
-
- }
-
-
- if (chr->login_fd > 0 && !sockt->session[chr->login_fd]->flag.eof && (char_id == -1 || character ==
-# 309 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 309 "../../../server-code/src/char/char.c"
- || character->fd == -1))
- chr->set_account_offline(account_id);
-}
-
-
-
-
-static int char_db_setoffline(union DBKey key, struct DBData *data, va_list ap)
-{
- struct online_char_data* character = (struct online_char_data*)DB->data2ptr(data);
- int server_id =
-# 319 "../../../server-code/src/char/char.c" 3 4
- __builtin_va_arg(
-# 319 "../../../server-code/src/char/char.c"
- ap
-# 319 "../../../server-code/src/char/char.c" 3 4
- ,
-# 319 "../../../server-code/src/char/char.c"
- int
-# 319 "../../../server-code/src/char/char.c" 3 4
- )
-# 319 "../../../server-code/src/char/char.c"
- ;
- do { if (((void)(character),
-# 320 "../../../server-code/src/char/char.c" 3 4
-0
-# 320 "../../../server-code/src/char/char.c"
-)) return(0); } while(0);
- if (server_id == -1) {
- character->char_id = -1;
- character->server = -1;
- if(character->waiting_disconnect != (-1)){
- timer->delete(character->waiting_disconnect, chr->waiting_disconnect);
- character->waiting_disconnect = (-1);
- }
- } else if (character->server == server_id)
- character->server = -2;
- return 0;
-}
-
-
-
-
-static int char_db_kickoffline(union DBKey key, struct DBData *data, va_list ap)
-{
- struct online_char_data* character = (struct online_char_data*)DB->data2ptr(data);
- int server_id =
-# 339 "../../../server-code/src/char/char.c" 3 4
- __builtin_va_arg(
-# 339 "../../../server-code/src/char/char.c"
- ap
-# 339 "../../../server-code/src/char/char.c" 3 4
- ,
-# 339 "../../../server-code/src/char/char.c"
- int
-# 339 "../../../server-code/src/char/char.c" 3 4
- )
-# 339 "../../../server-code/src/char/char.c"
- ;
- do { if (((void)(character),
-# 340 "../../../server-code/src/char/char.c" 3 4
-0
-# 340 "../../../server-code/src/char/char.c"
-)) return(0); } while(0);
-
- if (server_id > -1 && character->server != server_id)
- return 0;
-
-
- if (character->server > -1 && character->server < 2)
- mapif->disconnectplayer(chr->server[character->server].fd, character->account_id, character->char_id, 1);
- else if (character->waiting_disconnect == (-1))
- chr->set_char_offline(character->char_id, character->account_id);
- else
- return 0;
-
- return 1;
-}
-
-void char_set_login_all_offline(void)
-{
-
- WFIFOHEAD(chr->login_fd,2);
- WFIFOW(chr->login_fd,0) = 0x2737;
- WFIFOSET(chr->login_fd,2);
-}
-
-void char_set_all_offline(int id)
-{
- if (id < 0)
- (showmsg->showNotice(("Sending all users offline.\n")));
- else
- (showmsg->showNotice(("Sending users of map-server %d offline.\n"),id));
- chr->online_char_db->foreach(chr->online_char_db,chr->db_kickoffline,id);
-
- if (id >= 0 || chr->login_fd <= 0 || sockt->session[chr->login_fd]->flag.eof)
- return;
- chr->set_login_all_offline();
-}
-
-void char_set_all_offline_sql(void)
-{
-
- if( (-1) == SQL->Query(inter->sql_handle, "UPDATE `%s` SET `online` = '0'", char_db) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 381));
- if( (-1) == SQL->Query(inter->sql_handle, "UPDATE `%s` SET `online` = '0'", guild_member_db) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 383));
- if( (-1) == SQL->Query(inter->sql_handle, "UPDATE `%s` SET `connect_member` = '0'", guild_db) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 385));
-}
-
-
-
-
-static struct DBData char_create_charstatus(union DBKey key, va_list args)
-{
- struct mmo_charstatus *cp;
- cp = (struct mmo_charstatus *) (iMalloc->calloc((1),(sizeof(struct mmo_charstatus)),"../../../server-code/src/char/char.c", 394, __func__));
- cp->char_id = key.i;
- return DB->ptr2data(cp);
-}
-
-int char_mmo_char_tosql(int char_id, struct mmo_charstatus* p)
-{
- int i = 0;
- int count = 0;
- int diff = 0;
- char save_status[128];
- struct mmo_charstatus *cp;
- int errors = 0;
- StringBuf buf;
-
- do { if (((void)(p),
-# 409 "../../../server-code/src/char/char.c" 3 4
-0
-# 409 "../../../server-code/src/char/char.c"
-)) return(0); } while(0);
- if (char_id != p->char_id) return 0;
-
- cp = ( DB->data2ptr((chr->char_db_)->ensure((chr->char_db_),DB->i2key(char_id),(chr->create_charstatus))) );
-
- StrBuf->Init(&buf);
- memset(save_status, 0, sizeof(save_status));
-
-
- if( memcmp(p->inventory, cp->inventory, sizeof(p->inventory)) ) {
- if (!chr->memitemdata_to_sql(p->inventory, 100, p->char_id, TABLE_INVENTORY))
- strcat(save_status, " inventory");
- else
- errors++;
- }
-
-
- if( memcmp(p->cart, cp->cart, sizeof(p->cart)) ) {
- if (!chr->memitemdata_to_sql(p->cart, 100, p->char_id, TABLE_CART))
- strcat(save_status, " cart");
- else
- errors++;
- }
-
-
- if( memcmp(p->storage.items, cp->storage.items, sizeof(p->storage.items)) ) {
- if (!chr->memitemdata_to_sql(p->storage.items, 600, p->account_id, TABLE_STORAGE))
- strcat(save_status, " storage");
- else
- errors++;
- }
-
- if (
- (p->base_exp != cp->base_exp) || (p->base_level != cp->base_level) ||
- (p->job_level != cp->job_level) || (p->job_exp != cp->job_exp) ||
- (p->zeny != cp->zeny) ||
- (p->last_point.map != cp->last_point.map) ||
- (p->last_point.x != cp->last_point.x) || (p->last_point.y != cp->last_point.y) ||
- (p->max_hp != cp->max_hp) || (p->hp != cp->hp) ||
- (p->max_sp != cp->max_sp) || (p->sp != cp->sp) ||
- (p->status_point != cp->status_point) || (p->skill_point != cp->skill_point) ||
- (p->str != cp->str) || (p->agi != cp->agi) || (p->vit != cp->vit) ||
- (p->int_ != cp->int_) || (p->dex != cp->dex) || (p->luk != cp->luk) ||
- (p->option != cp->option) ||
- (p->party_id != cp->party_id) || (p->guild_id != cp->guild_id) ||
- (p->pet_id != cp->pet_id) || (p->weapon != cp->weapon) || (p->hom_id != cp->hom_id) ||
- (p->ele_id != cp->ele_id) || (p->shield != cp->shield) || (p->head_top != cp->head_top) ||
- (p->head_mid != cp->head_mid) || (p->head_bottom != cp->head_bottom) || (p->delete_date != cp->delete_date) ||
- (p->rename != cp->rename) || (p->slotchange != cp->slotchange) || (p->robe != cp->robe) ||
- (p->show_equip != cp->show_equip) || (p->allow_party != cp->allow_party) || (p->font != cp->font) ||
- (p->uniqueitem_counter != cp->uniqueitem_counter) || (p->hotkey_rowshift != cp->hotkey_rowshift)
- ) {
-
- unsigned int opt = 0;
-
- if( p->allow_party )
- opt |= OPT_ALLOW_PARTY;
- if( p->show_equip )
- opt |= OPT_SHOW_EQUIP;
-
- if( (-1) == SQL->Query(inter->sql_handle, "UPDATE `%s` SET `base_level`='%u', `job_level`='%u',"
- "`base_exp`='%u', `job_exp`='%u', `zeny`='%d',"
- "`max_hp`='%d',`hp`='%d',`max_sp`='%d',`sp`='%d',`status_point`='%u',`skill_point`='%u',"
- "`str`='%d',`agi`='%d',`vit`='%d',`int`='%d',`dex`='%d',`luk`='%d',"
- "`option`='%u',`party_id`='%d',`guild_id`='%d',`pet_id`='%d',`homun_id`='%d',`elemental_id`='%d',"
- "`weapon`='%d',`shield`='%d',`head_top`='%d',`head_mid`='%d',`head_bottom`='%d',"
- "`last_map`='%s',`last_x`='%d',`last_y`='%d',`save_map`='%s',`save_x`='%d',`save_y`='%d', `rename`='%d',"
- "`delete_date`='%lu',`robe`='%d',`slotchange`='%d', `char_opt`='%u', `font`='%u', `uniqueitem_counter` ='%u',"
- "`hotkey_rowshift`='%d'"
- " WHERE `account_id`='%d' AND `char_id` = '%d'",
- char_db, p->base_level, p->job_level,
- p->base_exp, p->job_exp, p->zeny,
- p->max_hp, p->hp, p->max_sp, p->sp, p->status_point, p->skill_point,
- p->str, p->agi, p->vit, p->int_, p->dex, p->luk,
- p->option, p->party_id, p->guild_id, p->pet_id, p->hom_id, p->ele_id,
- p->weapon, p->shield, p->head_top, p->head_mid, p->head_bottom,
- mapindex->id2name((p->last_point.map),"../../../server-code/src/char/char.c", 485, __func__), p->last_point.x, p->last_point.y,
- mapindex->id2name((p->save_point.map),"../../../server-code/src/char/char.c", 486, __func__), p->save_point.x, p->save_point.y, p->rename,
- (unsigned long)p->delete_date,
- p->robe,p->slotchange,opt,p->font,p->uniqueitem_counter,
- p->hotkey_rowshift,
- p->account_id, p->char_id) )
- {
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 492));
- errors++;
- } else
- strcat(save_status, " status");
- }
-
- if( p->bank_vault != cp->bank_vault || p->mod_exp != cp->mod_exp || p->mod_drop != cp->mod_drop || p->mod_death != cp->mod_death ) {
- if( (-1) == SQL->Query(inter->sql_handle, "REPLACE INTO `%s` (`account_id`,`bank_vault`,`base_exp`,`base_drop`,`base_death`) VALUES ('%d','%d','%d','%d','%d')",account_data_db,p->account_id,p->bank_vault,p->mod_exp,p->mod_drop,p->mod_death) ) {
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 500));
- errors++;
- } else
- strcat(save_status, " accdata");
- }
-
-
- if (
- (p->hair != cp->hair) || (p->hair_color != cp->hair_color) ||
- (p->clothes_color != cp->clothes_color) || (p->body != cp->body) ||
- (p->class_ != cp->class_) ||
- (p->partner_id != cp->partner_id) || (p->father != cp->father) ||
- (p->mother != cp->mother) || (p->child != cp->child) ||
- (p->karma != cp->karma) || (p->manner != cp->manner) ||
- (p->fame != cp->fame)
- )
- {
- if( (-1) == SQL->Query(inter->sql_handle, "UPDATE `%s` SET `class`='%d',"
- "`hair`='%d', `hair_color`='%d', `clothes_color`='%d', `body`='%d',"
- "`partner_id`='%d', `father`='%d', `mother`='%d', `child`='%d',"
- "`karma`='%d', `manner`='%d', `fame`='%d'"
- " WHERE `account_id`='%d' AND `char_id` = '%d'",
- char_db, p->class_,
- p->hair, p->hair_color, p->clothes_color, p->body,
- p->partner_id, p->father, p->mother, p->child,
- p->karma, p->manner, p->fame,
- p->account_id, p->char_id) )
- {
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 528));
- errors++;
- } else
- strcat(save_status, " status2");
- }
-
-
- if( (p->mer_id != cp->mer_id) ||
- (p->arch_calls != cp->arch_calls) || (p->arch_faith != cp->arch_faith) ||
- (p->spear_calls != cp->spear_calls) || (p->spear_faith != cp->spear_faith) ||
- (p->sword_calls != cp->sword_calls) || (p->sword_faith != cp->sword_faith) )
- {
- if (inter_mercenary->owner_tosql(char_id, p))
- strcat(save_status, " mercenary");
- else
- errors++;
- }
-
-
- if( memcmp(p->memo_point, cp->memo_point, sizeof(p->memo_point)) )
- {
- char esc_mapname[(23 + 1)*2+1];
-
-
- if( (-1) == SQL->Query(inter->sql_handle, "DELETE FROM `%s` WHERE `char_id`='%d'", memo_db, p->char_id) )
- {
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 554));
- errors++;
- }
-
-
- StrBuf->Clear(&buf);
- StrBuf->Printf(&buf, "INSERT INTO `%s`(`char_id`,`map`,`x`,`y`) VALUES ", memo_db);
- for( i = 0, count = 0; i < 3; ++i )
- {
- if( p->memo_point[i].map )
- {
- if( count )
- StrBuf->AppendStr(&buf, ",");
- SQL->EscapeString(inter->sql_handle, esc_mapname, mapindex->id2name((p->memo_point[i].map),"../../../server-code/src/char/char.c", 567, __func__));
- StrBuf->Printf(&buf, "('%d', '%s', '%d', '%d')", char_id, esc_mapname, p->memo_point[i].x, p->memo_point[i].y);
- ++count;
- }
- }
- if( count )
- {
- if( (-1) == SQL->QueryStr(inter->sql_handle, StrBuf->Value(&buf)) )
- {
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 576));
- errors++;
- }
- }
- strcat(save_status, " memo");
- }
-
-
- if( memcmp(p->skill, cp->skill, sizeof(p->skill)) ) {
-
- if( (-1) == SQL->Query(inter->sql_handle, "DELETE FROM `%s` WHERE `char_id`='%d'", skill_db, p->char_id) ) {
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 587));
- errors++;
- }
-
- StrBuf->Clear(&buf);
- StrBuf->Printf(&buf, "INSERT INTO `%s`(`char_id`,`id`,`lv`,`flag`) VALUES ", skill_db);
-
- for( i = 0, count = 0; i < 1478; ++i ) {
- if( p->skill[i].id != 0 && p->skill[i].flag != SKILL_FLAG_TEMPORARY ) {
- if( p->skill[i].lv == 0 && ( p->skill[i].flag == SKILL_FLAG_PERM_GRANTED || p->skill[i].flag == SKILL_FLAG_PERMANENT ) )
- continue;
- if( p->skill[i].flag != SKILL_FLAG_PERMANENT && p->skill[i].flag != SKILL_FLAG_PERM_GRANTED && (p->skill[i].flag - SKILL_FLAG_REPLACED_LV_0) == 0 )
- continue;
- if( count )
- StrBuf->AppendStr(&buf, ",");
- StrBuf->Printf(&buf, "('%d','%d','%d','%d')", char_id, p->skill[i].id,
- ( (p->skill[i].flag == SKILL_FLAG_PERMANENT || p->skill[i].flag == SKILL_FLAG_PERM_GRANTED) ? p->skill[i].lv : p->skill[i].flag - SKILL_FLAG_REPLACED_LV_0),
- p->skill[i].flag == SKILL_FLAG_PERM_GRANTED ? p->skill[i].flag : 0);
- ++count;
- }
- }
- if( count )
- {
- if( (-1) == SQL->QueryStr(inter->sql_handle, StrBuf->Value(&buf)) )
- {
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 612));
- errors++;
- }
- }
-
- strcat(save_status, " skills");
- }
-
- diff = 0;
- for(i = 0; i < 40; i++){
- if(p->friends[i].char_id != cp->friends[i].char_id ||
- p->friends[i].account_id != cp->friends[i].account_id){
- diff = 1;
- break;
- }
- }
-
- if(diff == 1) {
-
- if( (-1) == SQL->Query(inter->sql_handle, "DELETE FROM `%s` WHERE `char_id`='%d'", friend_db, char_id) )
- {
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 633));
- errors++;
- }
-
- StrBuf->Clear(&buf);
- StrBuf->Printf(&buf, "INSERT INTO `%s` (`char_id`, `friend_account`, `friend_id`) VALUES ", friend_db);
- for( i = 0, count = 0; i < 40; ++i )
- {
- if( p->friends[i].char_id > 0 )
- {
- if( count )
- StrBuf->AppendStr(&buf, ",");
- StrBuf->Printf(&buf, "('%d','%d','%d')", char_id, p->friends[i].account_id, p->friends[i].char_id);
- count++;
- }
- }
- if( count )
- {
- if( (-1) == SQL->QueryStr(inter->sql_handle, StrBuf->Value(&buf)) )
- {
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 653));
- errors++;
- }
- }
- strcat(save_status, " friends");
- }
-
-
-
- StrBuf->Clear(&buf);
- StrBuf->Printf(&buf, "REPLACE INTO `%s` (`char_id`, `hotkey`, `type`, `itemskill_id`, `skill_lvl`) VALUES ", hotkey_db);
- diff = 0;
- for(i = 0; i < ( (int)(sizeof(p->hotkeys)/sizeof((p->hotkeys)[0])) ); i++){
- if(memcmp(&p->hotkeys[i], &cp->hotkeys[i], sizeof(struct hotkey)))
- {
- if( diff )
- StrBuf->AppendStr(&buf, ",");
- StrBuf->Printf(&buf, "('%d','%u','%u','%u','%u')", char_id, (unsigned int)i, (unsigned int)p->hotkeys[i].type, p->hotkeys[i].id , (unsigned int)p->hotkeys[i].lv);
- diff = 1;
- }
- }
- if(diff) {
- if( (-1) == SQL->QueryStr(inter->sql_handle, StrBuf->Value(&buf)) )
- {
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 677));
- errors++;
- } else
- strcat(save_status, " hotkeys");
- }
-
-
- StrBuf->Destroy(&buf);
- if (save_status[0]!='\0' && save_log)
- (showmsg->showInfo(("Saved char %d - %s:%s.\n"), char_id, p->name, save_status));
- if (!errors)
- memcpy(cp, p, sizeof(struct mmo_charstatus));
- return 0;
-}
-# 702 "../../../server-code/src/char/char.c"
-int char_memitemdata_to_sql(const struct item items[], int max, int id, int tableswitch)
-{
- StringBuf buf;
- struct SqlStmt *stmt =
-# 705 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 705 "../../../server-code/src/char/char.c"
- ;
- int i, j;
- const char *tablename =
-# 707 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 707 "../../../server-code/src/char/char.c"
- ;
- const char *selectoption =
-# 708 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 708 "../../../server-code/src/char/char.c"
- ;
-
-# 709 "../../../server-code/src/char/char.c" 3 4
-_Bool
-# 709 "../../../server-code/src/char/char.c"
- has_favorite =
-# 709 "../../../server-code/src/char/char.c" 3 4
- 0
-# 709 "../../../server-code/src/char/char.c"
- ;
- struct item item = { 0 };
-
-# 711 "../../../server-code/src/char/char.c" 3 4
-_Bool
-# 711 "../../../server-code/src/char/char.c"
- *flag =
-# 711 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 711 "../../../server-code/src/char/char.c"
- ;
-
-# 712 "../../../server-code/src/char/char.c" 3 4
-_Bool
-# 712 "../../../server-code/src/char/char.c"
- found;
- int errors = 0;
-
- do { if (((void)(items),
-# 715 "../../../server-code/src/char/char.c" 3 4
-0
-# 715 "../../../server-code/src/char/char.c"
-)) return(0); } while(0);
-
- switch (tableswitch) {
- case TABLE_INVENTORY: tablename = inventory_db; selectoption = "char_id"; has_favorite =
-# 718 "../../../server-code/src/char/char.c" 3 4
- 1
-# 718 "../../../server-code/src/char/char.c"
- ; break;
- case TABLE_CART: tablename = cart_db; selectoption = "char_id"; break;
- case TABLE_STORAGE: tablename = storage_db; selectoption = "account_id"; break;
- case TABLE_GUILD_STORAGE: tablename = guild_storage_db; selectoption = "guild_id"; break;
- default:
- (showmsg->showError(("Invalid table name!\n")));
- do { if (( (tableswitch) ?
-# 724 "../../../server-code/src/char/char.c" 3 4
- 0
-# 724 "../../../server-code/src/char/char.c"
- : (nullpo->assert_report("../../../server-code/src/char/char.c", 724, __func__, "tableswitch", "failed assertion"),
-# 724 "../../../server-code/src/char/char.c" 3 4
- 1
-# 724 "../../../server-code/src/char/char.c"
- ) )) return(1); } while(0);
- }
-
-
-
-
-
-
- StrBuf->Init(&buf);
- StrBuf->AppendStr(&buf, "SELECT `id`, `nameid`, `amount`, `equip`, `identify`, `refine`, `attribute`, `expire_time`, `bound`, `unique_id`");
- for (j = 0; j < 4; ++j)
- StrBuf->Printf(&buf, ", `card%d`", j);
- if (has_favorite)
- StrBuf->AppendStr(&buf, ", `favorite`");
- StrBuf->Printf(&buf, " FROM `%s` WHERE `%s`='%d'", tablename, selectoption, id);
-
- stmt = SQL->StmtMalloc(inter->sql_handle);
- if ((-1) == SQL->StmtPrepareStr(stmt, StrBuf->Value(&buf))
- || (-1) == SQL->StmtExecute(stmt)) {
- (SQL->StmtShowDebug_((stmt), "../../../server-code/src/char/char.c", 743));
- SQL->StmtFree(stmt);
- StrBuf->Destroy(&buf);
- return 1;
- }
-
- SQL->StmtBindColumn(stmt, 0, SQLDT_INT, &item.id, 0,
-# 749 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 749 "../../../server-code/src/char/char.c"
- ,
-# 749 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 749 "../../../server-code/src/char/char.c"
- );
- SQL->StmtBindColumn(stmt, 1, SQLDT_SHORT, &item.nameid, 0,
-# 750 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 750 "../../../server-code/src/char/char.c"
- ,
-# 750 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 750 "../../../server-code/src/char/char.c"
- );
- SQL->StmtBindColumn(stmt, 2, SQLDT_SHORT, &item.amount, 0,
-# 751 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 751 "../../../server-code/src/char/char.c"
- ,
-# 751 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 751 "../../../server-code/src/char/char.c"
- );
- SQL->StmtBindColumn(stmt, 3, SQLDT_UINT, &item.equip, 0,
-# 752 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 752 "../../../server-code/src/char/char.c"
- ,
-# 752 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 752 "../../../server-code/src/char/char.c"
- );
- SQL->StmtBindColumn(stmt, 4, SQLDT_CHAR, &item.identify, 0,
-# 753 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 753 "../../../server-code/src/char/char.c"
- ,
-# 753 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 753 "../../../server-code/src/char/char.c"
- );
- SQL->StmtBindColumn(stmt, 5, SQLDT_CHAR, &item.refine, 0,
-# 754 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 754 "../../../server-code/src/char/char.c"
- ,
-# 754 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 754 "../../../server-code/src/char/char.c"
- );
- SQL->StmtBindColumn(stmt, 6, SQLDT_CHAR, &item.attribute, 0,
-# 755 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 755 "../../../server-code/src/char/char.c"
- ,
-# 755 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 755 "../../../server-code/src/char/char.c"
- );
- SQL->StmtBindColumn(stmt, 7, SQLDT_UINT, &item.expire_time, 0,
-# 756 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 756 "../../../server-code/src/char/char.c"
- ,
-# 756 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 756 "../../../server-code/src/char/char.c"
- );
- SQL->StmtBindColumn(stmt, 8, SQLDT_UCHAR, &item.bound, 0,
-# 757 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 757 "../../../server-code/src/char/char.c"
- ,
-# 757 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 757 "../../../server-code/src/char/char.c"
- );
- SQL->StmtBindColumn(stmt, 9, SQLDT_UINT64, &item.unique_id, 0,
-# 758 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 758 "../../../server-code/src/char/char.c"
- ,
-# 758 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 758 "../../../server-code/src/char/char.c"
- );
- for (j = 0; j < 4; ++j)
- SQL->StmtBindColumn(stmt, 10+j, SQLDT_SHORT, &item.card[j], 0,
-# 760 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 760 "../../../server-code/src/char/char.c"
- ,
-# 760 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 760 "../../../server-code/src/char/char.c"
- );
- if (has_favorite)
- SQL->StmtBindColumn(stmt, 10+4, SQLDT_UCHAR, &item.favorite, 0,
-# 762 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 762 "../../../server-code/src/char/char.c"
- ,
-# 762 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 762 "../../../server-code/src/char/char.c"
- );
-
-
- flag = (iMalloc->calloc((max),(sizeof(
-# 765 "../../../server-code/src/char/char.c" 3 4
- _Bool
-# 765 "../../../server-code/src/char/char.c"
- )),"../../../server-code/src/char/char.c", 765, __func__));
-
- while (0 == SQL->StmtNextRow(stmt)) {
- found =
-# 768 "../../../server-code/src/char/char.c" 3 4
- 0
-# 768 "../../../server-code/src/char/char.c"
- ;
-
- for (i = 0; i < max; ++i) {
-
- if (items[i].nameid == 0 || flag[i])
- continue;
-
- if (items[i].nameid == item.nameid
- && items[i].unique_id == item.unique_id
- && items[i].card[0] == item.card[0]
- && items[i].card[2] == item.card[2]
- && items[i].card[3] == item.card[3]
- ) {
-
- do { for ((j) = (0); (j) < (4); ++(j)) if (items[i].card[j] != item.card[j]) break; } while(
-# 782 "../../../server-code/src/char/char.c" 3 4
- 0
-# 782 "../../../server-code/src/char/char.c"
- );
- if (j == 4
- && items[i].amount == item.amount
- && items[i].equip == item.equip
- && items[i].identify == item.identify
- && items[i].refine == item.refine
- && items[i].attribute == item.attribute
- && items[i].expire_time == item.expire_time
- && items[i].bound == item.bound
- && (!has_favorite || items[i].favorite == item.favorite)
- ) {
- ;
- } else {
-
- StrBuf->Clear(&buf);
- StrBuf->Printf(&buf, "UPDATE `%s` SET `amount`='%d', `equip`='%u', `identify`='%d', `refine`='%d',`attribute`='%d', `expire_time`='%u', `bound`='%d'",
- tablename, items[i].amount, items[i].equip, items[i].identify, items[i].refine, items[i].attribute, items[i].expire_time, items[i].bound);
- for (j = 0; j < 4; ++j)
- StrBuf->Printf(&buf, ", `card%d`=%d", j, items[i].card[j]);
- if (has_favorite)
- StrBuf->Printf(&buf, ", `favorite`='%d'", items[i].favorite);
- StrBuf->Printf(&buf, " WHERE `id`='%d' LIMIT 1", item.id);
-
- if ((-1) == SQL->QueryStr(inter->sql_handle, StrBuf->Value(&buf))) {
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 806));
- errors++;
- }
- }
-
- found = flag[i] =
-# 811 "../../../server-code/src/char/char.c" 3 4
- 1
-# 811 "../../../server-code/src/char/char.c"
- ;
- break;
- }
- }
- if (!found) {
-
- if ((-1) == SQL->Query(inter->sql_handle, "DELETE from `%s` where `id`='%d' LIMIT 1", tablename, item.id)) {
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 818));
- errors++;
- }
- }
- }
- SQL->StmtFree(stmt);
-
- StrBuf->Clear(&buf);
- StrBuf->Printf(&buf, "INSERT INTO `%s`(`%s`, `nameid`, `amount`, `equip`, `identify`, `refine`, `attribute`, `expire_time`, `bound`, `unique_id`", tablename, selectoption);
- for (j = 0; j < 4; ++j)
- StrBuf->Printf(&buf, ", `card%d`", j);
- if (has_favorite)
- StrBuf->AppendStr(&buf, ", `favorite`");
- StrBuf->AppendStr(&buf, ") VALUES ");
-
- found =
-# 833 "../../../server-code/src/char/char.c" 3 4
- 0
-# 833 "../../../server-code/src/char/char.c"
- ;
-
- for (i = 0; i < max; ++i) {
-
- if (items[i].nameid == 0 || flag[i])
- continue;
-
- if (found)
- StrBuf->AppendStr(&buf, ",");
- else
- found =
-# 843 "../../../server-code/src/char/char.c" 3 4
- 1
-# 843 "../../../server-code/src/char/char.c"
- ;
-
- StrBuf->Printf(&buf, "('%d', '%d', '%d', '%u', '%d', '%d', '%d', '%u', '%d', '%"
-# 845 "../../../server-code/src/char/char.c" 3 4
- "l" "u"
-# 845 "../../../server-code/src/char/char.c"
- "'",
- id, items[i].nameid, items[i].amount, items[i].equip, items[i].identify, items[i].refine, items[i].attribute, items[i].expire_time, items[i].bound, items[i].unique_id);
- for (j = 0; j < 4; ++j)
- StrBuf->Printf(&buf, ", '%d'", items[i].card[j]);
- if (has_favorite)
- StrBuf->Printf(&buf, ", '%d'", items[i].favorite);
- StrBuf->AppendStr(&buf, ")");
- }
-
- if (found && (-1) == SQL->QueryStr(inter->sql_handle, StrBuf->Value(&buf))) {
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 855));
- errors++;
- }
-
- StrBuf->Destroy(&buf);
- (iMalloc->free((flag),"../../../server-code/src/char/char.c", 860, __func__));
-
- return errors;
-}
-# 878 "../../../server-code/src/char/char.c"
-int char_mmo_gender(const struct char_session_data *sd, const struct mmo_charstatus *p, char sex)
-{
-
- (void)sd; (void)p;
- switch (sex) {
- case 'M':
- return SEX_MALE;
- case 'F':
- return SEX_FEMALE;
- case 'U':
- default:
- return 99;
- }
-# 912 "../../../server-code/src/char/char.c"
-}
-
-
-
-int char_mmo_chars_fromsql(struct char_session_data* sd, uint8* buf)
-{
- struct SqlStmt *stmt;
- struct mmo_charstatus p;
- int j = 0, i;
- char last_map[((11 + 1) + 4)];
- time_t unban_time = 0;
- char sex[2];
-
- do { if (((void)(sd),
-# 925 "../../../server-code/src/char/char.c" 3 4
-0
-# 925 "../../../server-code/src/char/char.c"
-)) return(0); } while(0);
- do { if (((void)(buf),
-# 926 "../../../server-code/src/char/char.c" 3 4
-0
-# 926 "../../../server-code/src/char/char.c"
-)) return(0); } while(0);
-
- stmt = SQL->StmtMalloc(inter->sql_handle);
- if( stmt ==
-# 929 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 929 "../../../server-code/src/char/char.c"
- ) {
- (SQL->StmtShowDebug_((stmt), "../../../server-code/src/char/char.c", 930));
- return 0;
- }
- memset(&p, 0, sizeof(p));
-
- for(i = 0 ; i < 9; i++ ) {
- sd->found_char[i] = -1;
- sd->unban_time[i] = 0;
- }
-
-
- if ((-1) == SQL->StmtPrepare(stmt, "SELECT "
- "`char_id`,`char_num`,`name`,`class`,`base_level`,`job_level`,`base_exp`,`job_exp`,`zeny`,"
- "`str`,`agi`,`vit`,`int`,`dex`,`luk`,`max_hp`,`hp`,`max_sp`,`sp`,"
- "`status_point`,`skill_point`,`option`,`karma`,`manner`,`hair`,`hair_color`,"
- "`clothes_color`,`body`,`weapon`,`shield`,`head_top`,`head_mid`,`head_bottom`,`last_map`,`rename`,`delete_date`,"
- "`robe`,`slotchange`,`unban_time`,`sex`"
- " FROM `%s` WHERE `account_id`='%d' AND `char_num` < '%d'", char_db, sd->account_id, 9)
- || (-1) == SQL->StmtExecute(stmt)
- || (-1) == SQL->StmtBindColumn(stmt, 0, SQLDT_INT, &p.char_id, 0,
-# 949 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 949 "../../../server-code/src/char/char.c"
- ,
-# 949 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 949 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 1, SQLDT_UCHAR, &p.slot, 0,
-# 950 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 950 "../../../server-code/src/char/char.c"
- ,
-# 950 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 950 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 2, SQLDT_STRING, &p.name, sizeof(p.name),
-# 951 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 951 "../../../server-code/src/char/char.c"
- ,
-# 951 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 951 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 3, SQLDT_SHORT, &p.class_, 0,
-# 952 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 952 "../../../server-code/src/char/char.c"
- ,
-# 952 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 952 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 4, SQLDT_UINT, &p.base_level, 0,
-# 953 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 953 "../../../server-code/src/char/char.c"
- ,
-# 953 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 953 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 5, SQLDT_UINT, &p.job_level, 0,
-# 954 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 954 "../../../server-code/src/char/char.c"
- ,
-# 954 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 954 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 6, SQLDT_UINT, &p.base_exp, 0,
-# 955 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 955 "../../../server-code/src/char/char.c"
- ,
-# 955 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 955 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 7, SQLDT_UINT, &p.job_exp, 0,
-# 956 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 956 "../../../server-code/src/char/char.c"
- ,
-# 956 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 956 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 8, SQLDT_INT, &p.zeny, 0,
-# 957 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 957 "../../../server-code/src/char/char.c"
- ,
-# 957 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 957 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 9, SQLDT_SHORT, &p.str, 0,
-# 958 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 958 "../../../server-code/src/char/char.c"
- ,
-# 958 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 958 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 10, SQLDT_SHORT, &p.agi, 0,
-# 959 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 959 "../../../server-code/src/char/char.c"
- ,
-# 959 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 959 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 11, SQLDT_SHORT, &p.vit, 0,
-# 960 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 960 "../../../server-code/src/char/char.c"
- ,
-# 960 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 960 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 12, SQLDT_SHORT, &p.int_, 0,
-# 961 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 961 "../../../server-code/src/char/char.c"
- ,
-# 961 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 961 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 13, SQLDT_SHORT, &p.dex, 0,
-# 962 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 962 "../../../server-code/src/char/char.c"
- ,
-# 962 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 962 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 14, SQLDT_SHORT, &p.luk, 0,
-# 963 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 963 "../../../server-code/src/char/char.c"
- ,
-# 963 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 963 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 15, SQLDT_INT, &p.max_hp, 0,
-# 964 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 964 "../../../server-code/src/char/char.c"
- ,
-# 964 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 964 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 16, SQLDT_INT, &p.hp, 0,
-# 965 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 965 "../../../server-code/src/char/char.c"
- ,
-# 965 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 965 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 17, SQLDT_INT, &p.max_sp, 0,
-# 966 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 966 "../../../server-code/src/char/char.c"
- ,
-# 966 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 966 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 18, SQLDT_INT, &p.sp, 0,
-# 967 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 967 "../../../server-code/src/char/char.c"
- ,
-# 967 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 967 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 19, SQLDT_UINT, &p.status_point, 0,
-# 968 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 968 "../../../server-code/src/char/char.c"
- ,
-# 968 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 968 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 20, SQLDT_UINT, &p.skill_point, 0,
-# 969 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 969 "../../../server-code/src/char/char.c"
- ,
-# 969 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 969 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 21, SQLDT_UINT, &p.option, 0,
-# 970 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 970 "../../../server-code/src/char/char.c"
- ,
-# 970 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 970 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 22, SQLDT_UCHAR, &p.karma, 0,
-# 971 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 971 "../../../server-code/src/char/char.c"
- ,
-# 971 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 971 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 23, SQLDT_SHORT, &p.manner, 0,
-# 972 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 972 "../../../server-code/src/char/char.c"
- ,
-# 972 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 972 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 24, SQLDT_SHORT, &p.hair, 0,
-# 973 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 973 "../../../server-code/src/char/char.c"
- ,
-# 973 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 973 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 25, SQLDT_SHORT, &p.hair_color, 0,
-# 974 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 974 "../../../server-code/src/char/char.c"
- ,
-# 974 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 974 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 26, SQLDT_SHORT, &p.clothes_color, 0,
-# 975 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 975 "../../../server-code/src/char/char.c"
- ,
-# 975 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 975 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 27, SQLDT_SHORT, &p.body, 0,
-# 976 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 976 "../../../server-code/src/char/char.c"
- ,
-# 976 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 976 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 28, SQLDT_SHORT, &p.weapon, 0,
-# 977 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 977 "../../../server-code/src/char/char.c"
- ,
-# 977 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 977 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 29, SQLDT_SHORT, &p.shield, 0,
-# 978 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 978 "../../../server-code/src/char/char.c"
- ,
-# 978 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 978 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 30, SQLDT_SHORT, &p.head_top, 0,
-# 979 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 979 "../../../server-code/src/char/char.c"
- ,
-# 979 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 979 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 31, SQLDT_SHORT, &p.head_mid, 0,
-# 980 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 980 "../../../server-code/src/char/char.c"
- ,
-# 980 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 980 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 32, SQLDT_SHORT, &p.head_bottom, 0,
-# 981 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 981 "../../../server-code/src/char/char.c"
- ,
-# 981 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 981 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 33, SQLDT_STRING, &last_map, sizeof(last_map),
-# 982 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 982 "../../../server-code/src/char/char.c"
- ,
-# 982 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 982 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 34, SQLDT_USHORT, &p.rename, 0,
-# 983 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 983 "../../../server-code/src/char/char.c"
- ,
-# 983 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 983 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 35, SQLDT_UINT32, &p.delete_date, 0,
-# 984 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 984 "../../../server-code/src/char/char.c"
- ,
-# 984 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 984 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 36, SQLDT_SHORT, &p.robe, 0,
-# 985 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 985 "../../../server-code/src/char/char.c"
- ,
-# 985 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 985 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 37, SQLDT_USHORT, &p.slotchange, 0,
-# 986 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 986 "../../../server-code/src/char/char.c"
- ,
-# 986 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 986 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 38, SQLDT_LONG, &unban_time, 0,
-# 987 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 987 "../../../server-code/src/char/char.c"
- ,
-# 987 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 987 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 39, SQLDT_ENUM, &sex, sizeof(sex),
-# 988 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 988 "../../../server-code/src/char/char.c"
- ,
-# 988 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 988 "../../../server-code/src/char/char.c"
- )
- ) {
- (SQL->StmtShowDebug_((stmt), "../../../server-code/src/char/char.c", 990));
- SQL->StmtFree(stmt);
- return 0;
- }
-
- for( i = 0; i < 9 && 0 == SQL->StmtNextRow(stmt); i++ ) {
- if (p.slot >= 9)
- continue;
- p.last_point.map = mapindex->name2id(last_map);
- sd->found_char[p.slot] = p.char_id;
- sd->unban_time[p.slot] = unban_time;
- p.sex = chr->mmo_gender(sd, &p, sex[0]);
- j += chr->mmo_char_tobuf(WBUFP(buf, j), &p);
- }
-
- memset(sd->new_name,0,sizeof(sd->new_name));
-
- SQL->StmtFree(stmt);
- return j;
-}
-
-
-int char_mmo_char_fromsql(int char_id, struct mmo_charstatus* p,
-# 1012 "../../../server-code/src/char/char.c" 3 4
- _Bool
-# 1012 "../../../server-code/src/char/char.c"
- load_everything)
-{
- int i,j;
- char t_msg[128] = "";
- struct mmo_charstatus* cp;
- StringBuf buf;
- struct SqlStmt *stmt;
- char last_map[((11 + 1) + 4)];
- char save_map[((11 + 1) + 4)];
- char point_map[((11 + 1) + 4)];
- struct point tmp_point;
- struct item tmp_item;
- struct s_skill tmp_skill;
- struct s_friend tmp_friend;
-
- struct hotkey tmp_hotkey;
- int hotkey_num = 0;
-
- unsigned int opt;
- int account_id;
- char sex[2];
-
- do { if (((void)(p),
-# 1034 "../../../server-code/src/char/char.c" 3 4
-0
-# 1034 "../../../server-code/src/char/char.c"
-)) return(0); } while(0);
-
- memset(p, 0, sizeof(struct mmo_charstatus));
-
- if (save_log) (showmsg->showInfo(("Char load request (%d)\n"), char_id));
-
- stmt = SQL->StmtMalloc(inter->sql_handle);
- if( stmt ==
-# 1041 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1041 "../../../server-code/src/char/char.c"
- )
- {
- (SQL->StmtShowDebug_((stmt), "../../../server-code/src/char/char.c", 1043));
- return 0;
- }
-
-
- if ((-1) == SQL->StmtPrepare(stmt, "SELECT "
- "`char_id`,`account_id`,`char_num`,`name`,`class`,`base_level`,`job_level`,`base_exp`,`job_exp`,`zeny`,"
- "`str`,`agi`,`vit`,`int`,`dex`,`luk`,`max_hp`,`hp`,`max_sp`,`sp`,"
- "`status_point`,`skill_point`,`option`,`karma`,`manner`,`party_id`,`guild_id`,`pet_id`,`homun_id`,`elemental_id`,`hair`,"
- "`hair_color`,`clothes_color`,`body`,`weapon`,`shield`,`head_top`,`head_mid`,`head_bottom`,`last_map`,`last_x`,`last_y`,"
- "`save_map`,`save_x`,`save_y`,`partner_id`,`father`,`mother`,`child`,`fame`,`rename`,`delete_date`,`robe`,`slotchange`,"
- "`char_opt`,`font`,`uniqueitem_counter`,`sex`,`hotkey_rowshift`"
- " FROM `%s` WHERE `char_id`=? LIMIT 1", char_db)
- || (-1) == SQL->StmtBindParam(stmt, 0, SQLDT_INT, &char_id, 0)
- || (-1) == SQL->StmtExecute(stmt)
- || (-1) == SQL->StmtBindColumn(stmt, 0, SQLDT_INT, &p->char_id, 0,
-# 1058 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1058 "../../../server-code/src/char/char.c"
- ,
-# 1058 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1058 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 1, SQLDT_INT, &p->account_id, 0,
-# 1059 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1059 "../../../server-code/src/char/char.c"
- ,
-# 1059 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1059 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 2, SQLDT_UCHAR, &p->slot, 0,
-# 1060 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1060 "../../../server-code/src/char/char.c"
- ,
-# 1060 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1060 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 3, SQLDT_STRING, &p->name, sizeof(p->name),
-# 1061 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1061 "../../../server-code/src/char/char.c"
- ,
-# 1061 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1061 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 4, SQLDT_SHORT, &p->class_, 0,
-# 1062 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1062 "../../../server-code/src/char/char.c"
- ,
-# 1062 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1062 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 5, SQLDT_UINT, &p->base_level, 0,
-# 1063 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1063 "../../../server-code/src/char/char.c"
- ,
-# 1063 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1063 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 6, SQLDT_UINT, &p->job_level, 0,
-# 1064 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1064 "../../../server-code/src/char/char.c"
- ,
-# 1064 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1064 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 7, SQLDT_UINT, &p->base_exp, 0,
-# 1065 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1065 "../../../server-code/src/char/char.c"
- ,
-# 1065 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1065 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 8, SQLDT_UINT, &p->job_exp, 0,
-# 1066 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1066 "../../../server-code/src/char/char.c"
- ,
-# 1066 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1066 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 9, SQLDT_INT, &p->zeny, 0,
-# 1067 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1067 "../../../server-code/src/char/char.c"
- ,
-# 1067 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1067 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 10, SQLDT_SHORT, &p->str, 0,
-# 1068 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1068 "../../../server-code/src/char/char.c"
- ,
-# 1068 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1068 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 11, SQLDT_SHORT, &p->agi, 0,
-# 1069 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1069 "../../../server-code/src/char/char.c"
- ,
-# 1069 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1069 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 12, SQLDT_SHORT, &p->vit, 0,
-# 1070 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1070 "../../../server-code/src/char/char.c"
- ,
-# 1070 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1070 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 13, SQLDT_SHORT, &p->int_, 0,
-# 1071 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1071 "../../../server-code/src/char/char.c"
- ,
-# 1071 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1071 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 14, SQLDT_SHORT, &p->dex, 0,
-# 1072 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1072 "../../../server-code/src/char/char.c"
- ,
-# 1072 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1072 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 15, SQLDT_SHORT, &p->luk, 0,
-# 1073 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1073 "../../../server-code/src/char/char.c"
- ,
-# 1073 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1073 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 16, SQLDT_INT, &p->max_hp, 0,
-# 1074 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1074 "../../../server-code/src/char/char.c"
- ,
-# 1074 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1074 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 17, SQLDT_INT, &p->hp, 0,
-# 1075 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1075 "../../../server-code/src/char/char.c"
- ,
-# 1075 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1075 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 18, SQLDT_INT, &p->max_sp, 0,
-# 1076 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1076 "../../../server-code/src/char/char.c"
- ,
-# 1076 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1076 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 19, SQLDT_INT, &p->sp, 0,
-# 1077 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1077 "../../../server-code/src/char/char.c"
- ,
-# 1077 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1077 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 20, SQLDT_UINT, &p->status_point, 0,
-# 1078 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1078 "../../../server-code/src/char/char.c"
- ,
-# 1078 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1078 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 21, SQLDT_UINT, &p->skill_point, 0,
-# 1079 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1079 "../../../server-code/src/char/char.c"
- ,
-# 1079 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1079 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 22, SQLDT_UINT, &p->option, 0,
-# 1080 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1080 "../../../server-code/src/char/char.c"
- ,
-# 1080 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1080 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 23, SQLDT_UCHAR, &p->karma, 0,
-# 1081 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1081 "../../../server-code/src/char/char.c"
- ,
-# 1081 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1081 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 24, SQLDT_SHORT, &p->manner, 0,
-# 1082 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1082 "../../../server-code/src/char/char.c"
- ,
-# 1082 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1082 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 25, SQLDT_INT, &p->party_id, 0,
-# 1083 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1083 "../../../server-code/src/char/char.c"
- ,
-# 1083 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1083 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 26, SQLDT_INT, &p->guild_id, 0,
-# 1084 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1084 "../../../server-code/src/char/char.c"
- ,
-# 1084 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1084 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 27, SQLDT_INT, &p->pet_id, 0,
-# 1085 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1085 "../../../server-code/src/char/char.c"
- ,
-# 1085 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1085 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 28, SQLDT_INT, &p->hom_id, 0,
-# 1086 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1086 "../../../server-code/src/char/char.c"
- ,
-# 1086 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1086 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 29, SQLDT_INT, &p->ele_id, 0,
-# 1087 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1087 "../../../server-code/src/char/char.c"
- ,
-# 1087 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1087 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 30, SQLDT_SHORT, &p->hair, 0,
-# 1088 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1088 "../../../server-code/src/char/char.c"
- ,
-# 1088 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1088 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 31, SQLDT_SHORT, &p->hair_color, 0,
-# 1089 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1089 "../../../server-code/src/char/char.c"
- ,
-# 1089 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1089 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 32, SQLDT_SHORT, &p->clothes_color, 0,
-# 1090 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1090 "../../../server-code/src/char/char.c"
- ,
-# 1090 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1090 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 33, SQLDT_SHORT, &p->body, 0,
-# 1091 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1091 "../../../server-code/src/char/char.c"
- ,
-# 1091 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1091 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 34, SQLDT_SHORT, &p->weapon, 0,
-# 1092 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1092 "../../../server-code/src/char/char.c"
- ,
-# 1092 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1092 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 35, SQLDT_SHORT, &p->shield, 0,
-# 1093 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1093 "../../../server-code/src/char/char.c"
- ,
-# 1093 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1093 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 36, SQLDT_SHORT, &p->head_top, 0,
-# 1094 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1094 "../../../server-code/src/char/char.c"
- ,
-# 1094 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1094 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 37, SQLDT_SHORT, &p->head_mid, 0,
-# 1095 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1095 "../../../server-code/src/char/char.c"
- ,
-# 1095 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1095 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 38, SQLDT_SHORT, &p->head_bottom, 0,
-# 1096 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1096 "../../../server-code/src/char/char.c"
- ,
-# 1096 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1096 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 39, SQLDT_STRING, &last_map, sizeof(last_map),
-# 1097 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1097 "../../../server-code/src/char/char.c"
- ,
-# 1097 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1097 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 40, SQLDT_SHORT, &p->last_point.x, 0,
-# 1098 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1098 "../../../server-code/src/char/char.c"
- ,
-# 1098 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1098 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 41, SQLDT_SHORT, &p->last_point.y, 0,
-# 1099 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1099 "../../../server-code/src/char/char.c"
- ,
-# 1099 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1099 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 42, SQLDT_STRING, &save_map, sizeof(save_map),
-# 1100 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1100 "../../../server-code/src/char/char.c"
- ,
-# 1100 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1100 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 43, SQLDT_SHORT, &p->save_point.x, 0,
-# 1101 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1101 "../../../server-code/src/char/char.c"
- ,
-# 1101 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1101 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 44, SQLDT_SHORT, &p->save_point.y, 0,
-# 1102 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1102 "../../../server-code/src/char/char.c"
- ,
-# 1102 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1102 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 45, SQLDT_INT, &p->partner_id, 0,
-# 1103 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1103 "../../../server-code/src/char/char.c"
- ,
-# 1103 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1103 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 46, SQLDT_INT, &p->father, 0,
-# 1104 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1104 "../../../server-code/src/char/char.c"
- ,
-# 1104 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1104 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 47, SQLDT_INT, &p->mother, 0,
-# 1105 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1105 "../../../server-code/src/char/char.c"
- ,
-# 1105 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1105 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 48, SQLDT_INT, &p->child, 0,
-# 1106 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1106 "../../../server-code/src/char/char.c"
- ,
-# 1106 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1106 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 49, SQLDT_INT, &p->fame, 0,
-# 1107 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1107 "../../../server-code/src/char/char.c"
- ,
-# 1107 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1107 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 50, SQLDT_USHORT, &p->rename, 0,
-# 1108 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1108 "../../../server-code/src/char/char.c"
- ,
-# 1108 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1108 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 51, SQLDT_UINT32, &p->delete_date, 0,
-# 1109 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1109 "../../../server-code/src/char/char.c"
- ,
-# 1109 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1109 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 52, SQLDT_SHORT, &p->robe, 0,
-# 1110 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1110 "../../../server-code/src/char/char.c"
- ,
-# 1110 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1110 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 53, SQLDT_USHORT, &p->slotchange, 0,
-# 1111 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1111 "../../../server-code/src/char/char.c"
- ,
-# 1111 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1111 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 54, SQLDT_UINT, &opt, 0,
-# 1112 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1112 "../../../server-code/src/char/char.c"
- ,
-# 1112 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1112 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 55, SQLDT_UCHAR, &p->font, 0,
-# 1113 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1113 "../../../server-code/src/char/char.c"
- ,
-# 1113 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1113 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 56, SQLDT_UINT, &p->uniqueitem_counter, 0,
-# 1114 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1114 "../../../server-code/src/char/char.c"
- ,
-# 1114 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1114 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 57, SQLDT_ENUM, &sex, sizeof(sex),
-# 1115 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1115 "../../../server-code/src/char/char.c"
- ,
-# 1115 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1115 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 58, SQLDT_UCHAR, &p->hotkey_rowshift, 0,
-# 1116 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1116 "../../../server-code/src/char/char.c"
- ,
-# 1116 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1116 "../../../server-code/src/char/char.c"
- )
- ) {
- (SQL->StmtShowDebug_((stmt), "../../../server-code/src/char/char.c", 1118));
- SQL->StmtFree(stmt);
- return 0;
- }
- if (0 != SQL->StmtNextRow(stmt))
- {
- (showmsg->showError(("Requested non-existant character id: %d!\n"), char_id));
- SQL->StmtFree(stmt);
- return 0;
- }
-
- p->sex = chr->mmo_gender(
-# 1129 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1129 "../../../server-code/src/char/char.c"
- , p, sex[0]);
-
- account_id = p->account_id;
-
- p->last_point.map = mapindex->name2id(last_map);
- p->save_point.map = mapindex->name2id(save_map);
-
- if( p->last_point.map == 0 ) {
- p->last_point.map = (unsigned short)( DB->data2i((mapindex->db)->get((mapindex->db),DB->str2key(mapindex->default_map))) );
- p->last_point.x = mapindex->default_x;
- p->last_point.y = mapindex->default_y;
- }
-
- if( p->save_point.map == 0 ) {
- p->save_point.map = (unsigned short)( DB->data2i((mapindex->db)->get((mapindex->db),DB->str2key(mapindex->default_map))) );
- p->save_point.x = mapindex->default_x;
- p->save_point.y = mapindex->default_y;
- }
-
- strcat(t_msg, " status");
-
- if (!load_everything)
- {
- SQL->StmtFree(stmt);
- return 1;
- }
-
-
-
- memset(&tmp_point, 0, sizeof(tmp_point));
- if ((-1) == SQL->StmtPrepare(stmt, "SELECT `map`,`x`,`y` FROM `%s` WHERE `char_id`=? ORDER by `memo_id` LIMIT %d", memo_db, 3)
- || (-1) == SQL->StmtBindParam(stmt, 0, SQLDT_INT, &char_id, 0)
- || (-1) == SQL->StmtExecute(stmt)
- || (-1) == SQL->StmtBindColumn(stmt, 0, SQLDT_STRING, &point_map, sizeof(point_map),
-# 1162 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1162 "../../../server-code/src/char/char.c"
- ,
-# 1162 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1162 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 1, SQLDT_SHORT, &tmp_point.x, 0,
-# 1163 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1163 "../../../server-code/src/char/char.c"
- ,
-# 1163 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1163 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 2, SQLDT_SHORT, &tmp_point.y, 0,
-# 1164 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1164 "../../../server-code/src/char/char.c"
- ,
-# 1164 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1164 "../../../server-code/src/char/char.c"
- )
- )
- (SQL->StmtShowDebug_((stmt), "../../../server-code/src/char/char.c", 1166));
-
- for( i = 0; i < 3 && 0 == SQL->StmtNextRow(stmt); ++i ) {
- tmp_point.map = mapindex->name2id(point_map);
- memcpy(&p->memo_point[i], &tmp_point, sizeof(tmp_point));
- }
- strcat(t_msg, " memo");
-
-
-
- StrBuf->Init(&buf);
- StrBuf->AppendStr(&buf, "SELECT `id`, `nameid`, `amount`, `equip`, `identify`, `refine`, `attribute`, `expire_time`, `favorite`, `bound`, `unique_id`");
- for( i = 0; i < 4; ++i )
- StrBuf->Printf(&buf, ", `card%d`", i);
- StrBuf->Printf(&buf, " FROM `%s` WHERE `char_id`=? LIMIT %d", inventory_db, 100);
-
- memset(&tmp_item, 0, sizeof(tmp_item));
- if ((-1) == SQL->StmtPrepareStr(stmt, StrBuf->Value(&buf))
- || (-1) == SQL->StmtBindParam(stmt, 0, SQLDT_INT, &char_id, 0)
- || (-1) == SQL->StmtExecute(stmt)
- || (-1) == SQL->StmtBindColumn(stmt, 0, SQLDT_INT, &tmp_item.id, 0,
-# 1186 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1186 "../../../server-code/src/char/char.c"
- ,
-# 1186 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1186 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 1, SQLDT_SHORT, &tmp_item.nameid, 0,
-# 1187 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1187 "../../../server-code/src/char/char.c"
- ,
-# 1187 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1187 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 2, SQLDT_SHORT, &tmp_item.amount, 0,
-# 1188 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1188 "../../../server-code/src/char/char.c"
- ,
-# 1188 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1188 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 3, SQLDT_UINT, &tmp_item.equip, 0,
-# 1189 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1189 "../../../server-code/src/char/char.c"
- ,
-# 1189 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1189 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 4, SQLDT_CHAR, &tmp_item.identify, 0,
-# 1190 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1190 "../../../server-code/src/char/char.c"
- ,
-# 1190 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1190 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 5, SQLDT_CHAR, &tmp_item.refine, 0,
-# 1191 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1191 "../../../server-code/src/char/char.c"
- ,
-# 1191 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1191 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 6, SQLDT_CHAR, &tmp_item.attribute, 0,
-# 1192 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1192 "../../../server-code/src/char/char.c"
- ,
-# 1192 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1192 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 7, SQLDT_UINT, &tmp_item.expire_time, 0,
-# 1193 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1193 "../../../server-code/src/char/char.c"
- ,
-# 1193 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1193 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 8, SQLDT_CHAR, &tmp_item.favorite, 0,
-# 1194 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1194 "../../../server-code/src/char/char.c"
- ,
-# 1194 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1194 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 9, SQLDT_UCHAR, &tmp_item.bound, 0,
-# 1195 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1195 "../../../server-code/src/char/char.c"
- ,
-# 1195 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1195 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 10, SQLDT_UINT64, &tmp_item.unique_id, 0,
-# 1196 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1196 "../../../server-code/src/char/char.c"
- ,
-# 1196 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1196 "../../../server-code/src/char/char.c"
- )
- )
- (SQL->StmtShowDebug_((stmt), "../../../server-code/src/char/char.c", 1198));
- for( i = 0; i < 4; ++i )
- if( (-1) == SQL->StmtBindColumn(stmt, 11+i, SQLDT_SHORT, &tmp_item.card[i], 0,
-# 1200 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1200 "../../../server-code/src/char/char.c"
- ,
-# 1200 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1200 "../../../server-code/src/char/char.c"
- ) )
- (SQL->StmtShowDebug_((stmt), "../../../server-code/src/char/char.c", 1201));
-
- for( i = 0; i < 100 && 0 == SQL->StmtNextRow(stmt); ++i )
- memcpy(&p->inventory[i], &tmp_item, sizeof(tmp_item));
-
- strcat(t_msg, " inventory");
-
-
-
- StrBuf->Clear(&buf);
- StrBuf->AppendStr(&buf, "SELECT `id`, `nameid`, `amount`, `equip`, `identify`, `refine`, `attribute`, `expire_time`, `bound`, `unique_id`");
- for( j = 0; j < 4; ++j )
- StrBuf->Printf(&buf, ", `card%d`", j);
- StrBuf->Printf(&buf, " FROM `%s` WHERE `char_id`=? LIMIT %d", cart_db, 100);
-
- memset(&tmp_item, 0, sizeof(tmp_item));
- if ((-1) == SQL->StmtPrepareStr(stmt, StrBuf->Value(&buf))
- || (-1) == SQL->StmtBindParam(stmt, 0, SQLDT_INT, &char_id, 0)
- || (-1) == SQL->StmtExecute(stmt)
- || (-1) == SQL->StmtBindColumn(stmt, 0, SQLDT_INT, &tmp_item.id, 0,
-# 1220 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1220 "../../../server-code/src/char/char.c"
- ,
-# 1220 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1220 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 1, SQLDT_SHORT, &tmp_item.nameid, 0,
-# 1221 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1221 "../../../server-code/src/char/char.c"
- ,
-# 1221 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1221 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 2, SQLDT_SHORT, &tmp_item.amount, 0,
-# 1222 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1222 "../../../server-code/src/char/char.c"
- ,
-# 1222 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1222 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 3, SQLDT_UINT, &tmp_item.equip, 0,
-# 1223 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1223 "../../../server-code/src/char/char.c"
- ,
-# 1223 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1223 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 4, SQLDT_CHAR, &tmp_item.identify, 0,
-# 1224 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1224 "../../../server-code/src/char/char.c"
- ,
-# 1224 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1224 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 5, SQLDT_CHAR, &tmp_item.refine, 0,
-# 1225 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1225 "../../../server-code/src/char/char.c"
- ,
-# 1225 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1225 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 6, SQLDT_CHAR, &tmp_item.attribute, 0,
-# 1226 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1226 "../../../server-code/src/char/char.c"
- ,
-# 1226 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1226 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 7, SQLDT_UINT, &tmp_item.expire_time, 0,
-# 1227 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1227 "../../../server-code/src/char/char.c"
- ,
-# 1227 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1227 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 8, SQLDT_UCHAR, &tmp_item.bound, 0,
-# 1228 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1228 "../../../server-code/src/char/char.c"
- ,
-# 1228 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1228 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 9, SQLDT_UINT64, &tmp_item.unique_id, 0,
-# 1229 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1229 "../../../server-code/src/char/char.c"
- ,
-# 1229 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1229 "../../../server-code/src/char/char.c"
- )
- ) {
- (SQL->StmtShowDebug_((stmt), "../../../server-code/src/char/char.c", 1231));
- }
- for( i = 0; i < 4; ++i )
- if( (-1) == SQL->StmtBindColumn(stmt, 10+i, SQLDT_SHORT, &tmp_item.card[i], 0,
-# 1234 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1234 "../../../server-code/src/char/char.c"
- ,
-# 1234 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1234 "../../../server-code/src/char/char.c"
- ) )
- (SQL->StmtShowDebug_((stmt), "../../../server-code/src/char/char.c", 1235));
-
- for( i = 0; i < 100 && 0 == SQL->StmtNextRow(stmt); ++i )
- memcpy(&p->cart[i], &tmp_item, sizeof(tmp_item));
- strcat(t_msg, " cart");
-
-
- inter_storage->fromsql(p->account_id, &p->storage);
- strcat(t_msg, " storage");
-
-
-
- memset(&tmp_skill, 0, sizeof(tmp_skill));
- if ((-1) == SQL->StmtPrepare(stmt, "SELECT `id`, `lv`,`flag` FROM `%s` WHERE `char_id`=? LIMIT %d", skill_db, 1478)
- || (-1) == SQL->StmtBindParam(stmt, 0, SQLDT_INT, &char_id, 0)
- || (-1) == SQL->StmtExecute(stmt)
- || (-1) == SQL->StmtBindColumn(stmt, 0, SQLDT_USHORT, &tmp_skill.id , 0,
-# 1251 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1251 "../../../server-code/src/char/char.c"
- ,
-# 1251 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1251 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 1, SQLDT_UCHAR , &tmp_skill.lv , 0,
-# 1252 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1252 "../../../server-code/src/char/char.c"
- ,
-# 1252 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1252 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 2, SQLDT_UCHAR , &tmp_skill.flag, 0,
-# 1253 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1253 "../../../server-code/src/char/char.c"
- ,
-# 1253 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1253 "../../../server-code/src/char/char.c"
- )
- ) {
- (SQL->StmtShowDebug_((stmt), "../../../server-code/src/char/char.c", 1255));
- }
-
- if( tmp_skill.flag != SKILL_FLAG_PERM_GRANTED )
- tmp_skill.flag = SKILL_FLAG_PERMANENT;
-
- for( i = 0; i < 1478 && 0 == SQL->StmtNextRow(stmt); ++i ) {
- if( skillid2idx[tmp_skill.id] )
- memcpy(&p->skill[skillid2idx[tmp_skill.id]], &tmp_skill, sizeof(tmp_skill));
- else
- (showmsg->showWarning(("chr->mmo_char_fromsql: ignoring invalid skill (id=%u,lv=%u) of character %s (AID=%d,CID=%d)\n"), tmp_skill.id, tmp_skill.lv, p->name, p->account_id, p->char_id));
- }
- strcat(t_msg, " skills");
-
-
-
- memset(&tmp_friend, 0, sizeof(tmp_friend));
- if ((-1) == SQL->StmtPrepare(stmt, "SELECT c.`account_id`, c.`char_id`, c.`name` FROM `%s` c LEFT JOIN `%s` f ON f.`friend_account` = c.`account_id` AND f.`friend_id` = c.`char_id` WHERE f.`char_id`=? LIMIT %d", char_db, friend_db, 40)
- || (-1) == SQL->StmtBindParam(stmt, 0, SQLDT_INT, &char_id, 0)
- || (-1) == SQL->StmtExecute(stmt)
- || (-1) == SQL->StmtBindColumn(stmt, 0, SQLDT_INT, &tmp_friend.account_id, 0,
-# 1275 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1275 "../../../server-code/src/char/char.c"
- ,
-# 1275 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1275 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 1, SQLDT_INT, &tmp_friend.char_id, 0,
-# 1276 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1276 "../../../server-code/src/char/char.c"
- ,
-# 1276 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1276 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 2, SQLDT_STRING, &tmp_friend.name, sizeof(tmp_friend.name),
-# 1277 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1277 "../../../server-code/src/char/char.c"
- ,
-# 1277 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1277 "../../../server-code/src/char/char.c"
- )
- ) {
- (SQL->StmtShowDebug_((stmt), "../../../server-code/src/char/char.c", 1279));
- }
-
- for( i = 0; i < 40 && 0 == SQL->StmtNextRow(stmt); ++i )
- memcpy(&p->friends[i], &tmp_friend, sizeof(tmp_friend));
- strcat(t_msg, " friends");
-
-
-
-
- memset(&tmp_hotkey, 0, sizeof(tmp_hotkey));
- if ((-1) == SQL->StmtPrepare(stmt, "SELECT `hotkey`, `type`, `itemskill_id`, `skill_lvl` FROM `%s` WHERE `char_id`=?", hotkey_db)
- || (-1) == SQL->StmtBindParam(stmt, 0, SQLDT_INT, &char_id, 0)
- || (-1) == SQL->StmtExecute(stmt)
- || (-1) == SQL->StmtBindColumn(stmt, 0, SQLDT_INT, &hotkey_num, 0,
-# 1293 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1293 "../../../server-code/src/char/char.c"
- ,
-# 1293 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1293 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 1, SQLDT_UCHAR, &tmp_hotkey.type, 0,
-# 1294 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1294 "../../../server-code/src/char/char.c"
- ,
-# 1294 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1294 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 2, SQLDT_UINT, &tmp_hotkey.id, 0,
-# 1295 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1295 "../../../server-code/src/char/char.c"
- ,
-# 1295 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1295 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 3, SQLDT_USHORT, &tmp_hotkey.lv, 0,
-# 1296 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1296 "../../../server-code/src/char/char.c"
- ,
-# 1296 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1296 "../../../server-code/src/char/char.c"
- ) )
- (SQL->StmtShowDebug_((stmt), "../../../server-code/src/char/char.c", 1297));
-
- while( 0 == SQL->StmtNextRow(stmt) )
- {
- if( hotkey_num >= 0 && hotkey_num < 38 )
- memcpy(&p->hotkeys[hotkey_num], &tmp_hotkey, sizeof(tmp_hotkey));
- else
- (showmsg->showWarning(("chr->mmo_char_fromsql: ignoring invalid hotkey (hotkey=%d,type=%u,id=%u,lv=%u) of character %s (AID=%d,CID=%d)\n"), hotkey_num, tmp_hotkey.type, tmp_hotkey.id, tmp_hotkey.lv, p->name, p->account_id, p->char_id));
- }
- strcat(t_msg, " hotkeys");
-
-
-
- inter_mercenary->owner_fromsql(char_id, p);
- strcat(t_msg, " mercenary");
-
-
- p->mod_exp = p->mod_drop = p->mod_death = 100;
-
-
- if ((-1) == SQL->StmtPrepare(stmt, "SELECT `bank_vault`,`base_exp`,`base_drop`,`base_death` FROM `%s` WHERE `account_id`=? LIMIT 1", account_data_db)
- || (-1) == SQL->StmtBindParam(stmt, 0, SQLDT_INT, &account_id, 0)
- || (-1) == SQL->StmtExecute(stmt)
- || (-1) == SQL->StmtBindColumn(stmt, 0, SQLDT_INT, &p->bank_vault, 0,
-# 1320 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1320 "../../../server-code/src/char/char.c"
- ,
-# 1320 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1320 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 1, SQLDT_USHORT, &p->mod_exp, 0,
-# 1321 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1321 "../../../server-code/src/char/char.c"
- ,
-# 1321 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1321 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 2, SQLDT_USHORT, &p->mod_drop, 0,
-# 1322 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1322 "../../../server-code/src/char/char.c"
- ,
-# 1322 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1322 "../../../server-code/src/char/char.c"
- )
- || (-1) == SQL->StmtBindColumn(stmt, 3, SQLDT_USHORT, &p->mod_death, 0,
-# 1323 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1323 "../../../server-code/src/char/char.c"
- ,
-# 1323 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1323 "../../../server-code/src/char/char.c"
- )
- ) {
- (SQL->StmtShowDebug_((stmt), "../../../server-code/src/char/char.c", 1325));
- }
-
- if( 0 == SQL->StmtNextRow(stmt) )
- strcat(t_msg, " accdata");
-
- if (save_log) (showmsg->showInfo(("Loaded char (%d - %s): %s\n"), char_id, p->name, t_msg));
- SQL->StmtFree(stmt);
- StrBuf->Destroy(&buf);
-
-
- if( opt & OPT_ALLOW_PARTY )
- p->allow_party =
-# 1337 "../../../server-code/src/char/char.c" 3 4
- 1
-# 1337 "../../../server-code/src/char/char.c"
- ;
- if( opt & OPT_SHOW_EQUIP )
- p->show_equip =
-# 1339 "../../../server-code/src/char/char.c" 3 4
- 1
-# 1339 "../../../server-code/src/char/char.c"
- ;
-
- cp = ( DB->data2ptr((chr->char_db_)->ensure((chr->char_db_),DB->i2key(char_id),(chr->create_charstatus))) );
- memcpy(cp, p, sizeof(struct mmo_charstatus));
- return 1;
-}
-
-
-int char_mmo_char_sql_init(void)
-{
- chr->char_db_= DB->alloc("../../../server-code/src/char/char.c",__func__,1349,DB_INT,(DB_OPT_RELEASE_DATA),sizeof(int));
-# 1358 "../../../server-code/src/char/char.c"
- chr->set_all_offline_sql();
-
- return 0;
-}
-
-
-
-# 1364 "../../../server-code/src/char/char.c" 3 4
-_Bool
-# 1364 "../../../server-code/src/char/char.c"
- char_char_slotchange(struct char_session_data *sd, int fd, unsigned short from, unsigned short to) {
- struct mmo_charstatus char_dat;
- int from_id = 0;
-
- do { if (((void)(sd),
-# 1368 "../../../server-code/src/char/char.c" 3 4
-0
-# 1368 "../../../server-code/src/char/char.c"
-)) return(0); } while(0);
- if( from >= 9 || to >= 9 || ( sd->char_slots && to > sd->char_slots ) || sd->found_char[from] <= 0 )
- return
-# 1370 "../../../server-code/src/char/char.c" 3 4
- 0
-# 1370 "../../../server-code/src/char/char.c"
- ;
-
- if( !chr->mmo_char_fromsql(sd->found_char[from], &char_dat,
-# 1372 "../../../server-code/src/char/char.c" 3 4
- 0
-# 1372 "../../../server-code/src/char/char.c"
- ) )
- return
-# 1373 "../../../server-code/src/char/char.c" 3 4
- 0
-# 1373 "../../../server-code/src/char/char.c"
- ;
-
- if( char_dat.slotchange == 0 )
- return
-# 1376 "../../../server-code/src/char/char.c" 3 4
- 0
-# 1376 "../../../server-code/src/char/char.c"
- ;
-
- from_id = sd->found_char[from];
-
- if( sd->found_char[to] > 0 ) {
-
-# 1381 "../../../server-code/src/char/char.c" 3 4
- _Bool
-# 1381 "../../../server-code/src/char/char.c"
- result =
-# 1381 "../../../server-code/src/char/char.c" 3 4
- 0
-# 1381 "../../../server-code/src/char/char.c"
- ;
-
- if( 0 != SQL->QueryStr(inter->sql_handle, "START TRANSACTION")
- || 0 != SQL->Query(inter->sql_handle, "UPDATE `%s` SET `char_num`='%d' WHERE `char_id`='%d' LIMIT 1", char_db, from, sd->found_char[to])
- || 0 != SQL->Query(inter->sql_handle, "UPDATE `%s` SET `char_num`='%d' WHERE `char_id`='%d' LIMIT 1", char_db, to, sd->found_char[from])
- )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 1387));
- else
- result =
-# 1389 "../../../server-code/src/char/char.c" 3 4
- 1
-# 1389 "../../../server-code/src/char/char.c"
- ;
-
- if( (-1) == SQL->QueryStr(inter->sql_handle, (result ==
-# 1391 "../../../server-code/src/char/char.c" 3 4
- 1
-# 1391 "../../../server-code/src/char/char.c"
- ) ? "COMMIT" : "ROLLBACK") ) {
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 1392));
- result =
-# 1393 "../../../server-code/src/char/char.c" 3 4
- 0
-# 1393 "../../../server-code/src/char/char.c"
- ;
- }
- if( !result )
- return
-# 1396 "../../../server-code/src/char/char.c" 3 4
- 0
-# 1396 "../../../server-code/src/char/char.c"
- ;
- } else {
- if( (-1) == SQL->Query(inter->sql_handle, "UPDATE `%s` SET `char_num`='%d' WHERE `char_id`='%d' LIMIT 1", char_db, to, sd->found_char[from] ) ) {
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 1399));
- return
-# 1400 "../../../server-code/src/char/char.c" 3 4
- 0
-# 1400 "../../../server-code/src/char/char.c"
- ;
- }
- }
-
-
- if( (-1) == SQL->Query(inter->sql_handle, "UPDATE `%s` SET `slotchange`=`slotchange`-1 WHERE `char_id`='%d' LIMIT 1", char_db, from_id ) ) {
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 1406));
- return
-# 1407 "../../../server-code/src/char/char.c" 3 4
- 0
-# 1407 "../../../server-code/src/char/char.c"
- ;
- }
-
- return
-# 1410 "../../../server-code/src/char/char.c" 3 4
- 1
-# 1410 "../../../server-code/src/char/char.c"
- ;
-}
-
-
-
-
-int char_rename_char_sql(struct char_session_data *sd, int char_id)
-{
- struct mmo_charstatus char_dat;
- char esc_name[(23 + 1)*2+1];
-
- do { if (((void)(sd),
-# 1421 "../../../server-code/src/char/char.c" 3 4
-0
-# 1421 "../../../server-code/src/char/char.c"
-)) return(2); } while(0);
-
- if( sd->new_name[0] == 0 )
- return 2;
-
- if( !chr->mmo_char_fromsql(char_id, &char_dat,
-# 1426 "../../../server-code/src/char/char.c" 3 4
- 0
-# 1426 "../../../server-code/src/char/char.c"
- ) )
- return 2;
-
- if (sd->account_id != char_dat.account_id)
- return 2;
-
- if( char_dat.rename == 0 )
- return 1;
-
- SQL->EscapeStringLen(inter->sql_handle, esc_name, sd->new_name, (strlib->strnlen_((sd->new_name),((23 + 1)))));
-
-
- if( (-1) == SQL->Query(inter->sql_handle, "SELECT 1 FROM `%s` WHERE `name` LIKE '%s' LIMIT 1", char_db, esc_name) )
- {
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 1440));
- return 4;
- }
-
- if( (-1) == SQL->Query(inter->sql_handle, "UPDATE `%s` SET `name` = '%s', `rename` = '%d' WHERE `char_id` = '%d'", char_db, esc_name, --char_dat.rename, char_id) )
- {
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 1446));
- return 3;
- }
-
-
- if( char_dat.guild_id )
- inter_guild->charname_changed(char_dat.guild_id, sd->account_id, char_id, sd->new_name);
-
- (strlib->safestrncpy_((char_dat.name),(sd->new_name),((23 + 1))));
- memset(sd->new_name,0,sizeof(sd->new_name));
-
-
- if( log_char )
- {
- if( (-1) == SQL->Query(inter->sql_handle,
- "INSERT INTO `%s` (`time`, `char_msg`,`account_id`,`char_id`,`char_num`,`name`,`str`,`agi`,`vit`,`int`,`dex`,`luk`,`hair`,`hair_color`)"
- "VALUES (NOW(), '%s', '%d', '%d', '%d', '%s', '0', '0', '0', '0', '0', '0', '0', '0')",
- charlog_db, "change char name", sd->account_id, char_dat.char_id, char_dat.slot, esc_name) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 1464));
- }
-
- return 0;
-}
-
-int char_check_char_name(char * name, char * esc_name)
-{
- int i;
-
- do { if (((void)(name),
-# 1474 "../../../server-code/src/char/char.c" 3 4
-0
-# 1474 "../../../server-code/src/char/char.c"
-)) return(-2); } while(0);
- do { if (((void)(esc_name),
-# 1475 "../../../server-code/src/char/char.c" 3 4
-0
-# 1475 "../../../server-code/src/char/char.c"
-)) return(-2); } while(0);
-
-
- if (name[0] == '\0')
- return -2;
-
-
-
-
- if( strlen( name ) < 4 )
- return -2;
-
- if( (strlib->remove_control_chars_(name)) )
- return -2;
-
-
- if( strcasecmp(name, wisp_server_name) == 0 )
- return -1;
-
-
- if( char_name_option == 1 )
- {
- for( i = 0; i < (23 + 1) && name[i]; i++ )
- if( strchr(char_name_letters, name[i]) ==
-# 1498 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1498 "../../../server-code/src/char/char.c"
- )
- return -2;
- }
- else if( char_name_option == 2 )
- {
- for( i = 0; i < (23 + 1) && name[i]; i++ )
- if( strchr(char_name_letters, name[i]) !=
-# 1504 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1504 "../../../server-code/src/char/char.c"
- )
- return -5;
- }
- if( name_ignoring_case ) {
- if( (-1) == SQL->Query(inter->sql_handle, "SELECT 1 FROM `%s` WHERE BINARY `name` = '%s' LIMIT 1", char_db, esc_name) ) {
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 1509));
- return -2;
- }
- } else {
- if( (-1) == SQL->Query(inter->sql_handle, "SELECT 1 FROM `%s` WHERE `name` = '%s' LIMIT 1", char_db, esc_name) ) {
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 1514));
- return -2;
- }
- }
- if( SQL->NumRows(inter->sql_handle) > 0 )
- return -1;
-
- return 0;
-}
-# 1534 "../../../server-code/src/char/char.c"
-int char_make_new_char_sql(struct char_session_data *sd, const char *name_, int str, int agi, int vit, int int_, int dex, int luk, int slot, int hair_color, int hair_style)
-{
- char name[(23 + 1)];
- char esc_name[(23 + 1)*2+1];
- int char_id, flag, k, l;
-
- do { if (((void)(sd),
-# 1540 "../../../server-code/src/char/char.c" 3 4
-0
-# 1540 "../../../server-code/src/char/char.c"
-)) return(-2); } while(0);
- do { if (((void)(name_),
-# 1541 "../../../server-code/src/char/char.c" 3 4
-0
-# 1541 "../../../server-code/src/char/char.c"
-)) return(-2); } while(0);
- (strlib->safestrncpy_((name),(name_),((23 + 1))));
- (strlib->normalize_name_((name),("\255\xA0\032\t\x0A\x0D ")));
- SQL->EscapeStringLen(inter->sql_handle, esc_name, name, (strlib->strnlen_((name),((23 + 1)))));
-
- flag = chr->check_char_name(name,esc_name);
- if( flag < 0 )
- return flag;
-
-
-
- if(slot < 0 || slot >= sd->char_slots)
-
-
-
-
-
-
-
- return -4;
-
-
-
-
-
- if( sd->found_char[slot] != -1 )
- return -2;
-
-
-
- if( (-1) == SQL->Query(inter->sql_handle, "INSERT INTO `%s` (`account_id`, `char_num`, `name`, `zeny`, `status_point`,`str`, `agi`, `vit`, `int`, `dex`, `luk`, `max_hp`, `hp`,"
- "`max_sp`, `sp`, `hair`, `hair_color`, `last_map`, `last_x`, `last_y`, `save_map`, `save_x`, `save_y`) VALUES ("
- "'%d', '%d', '%s', '%d', '%d','%d', '%d', '%d', '%d', '%d', '%d', '%d', '%d','%d', '%d','%d', '%d', '%s', '%d', '%d', '%s', '%d', '%d')",
- char_db, sd->account_id , slot, esc_name, start_zeny, 48, str, agi, vit, int_, dex, luk,
- (40 * (100 + vit)/100) , (40 * (100 + vit)/100 ), (11 * (100 + int_)/100), (11 * (100 + int_)/100), hair_style, hair_color,
- mapindex->id2name((start_point.map),"../../../server-code/src/char/char.c", 1576, __func__), start_point.x, start_point.y, mapindex->id2name((start_point.map),"../../../server-code/src/char/char.c", 1576, __func__), start_point.x, start_point.y) )
- {
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 1578));
- return -2;
- }
-# 1595 "../../../server-code/src/char/char.c"
- char_id = (int)SQL->LastInsertId(inter->sql_handle);
-
- if( !char_id )
- return -2;
-
-
- if (log_char) {
- if( (-1) == SQL->Query(inter->sql_handle, "INSERT INTO `%s` (`time`, `char_msg`,`account_id`,`char_id`,`char_num`,`name`,`str`,`agi`,`vit`,`int`,`dex`,`luk`,`hair`,`hair_color`)"
- "VALUES (NOW(), '%s', '%d', '%d', '%d', '%s', '%d', '%d', '%d', '%d', '%d', '%d', '%d', '%d')",
- charlog_db, "make new char", sd->account_id, char_id, slot, esc_name, str, agi, vit, int_, dex, luk, hair_style, hair_color) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 1605));
- }
-
-
- for (k = 0; k < ( (int)(sizeof(start_items)/sizeof((start_items)[0])) ) && start_items[k] != 0; k += 3) {
-
- if( start_items[k+2] == 1 )
- {
- if( (-1) == SQL->Query(inter->sql_handle,
- "INSERT INTO `%s` (`char_id`,`nameid`, `amount`, `identify`) VALUES ('%d', '%d', '%d', '%d')",
- inventory_db, char_id, start_items[k], start_items[k + 1], 1) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 1616));
- }
- else if( start_items[k+2] == 0 )
- {
-
- for( l = 0; l < start_items[k+1]; l++ )
- {
- if( (-1) == SQL->Query(inter->sql_handle,
- "INSERT INTO `%s` (`char_id`,`nameid`, `amount`, `identify`) VALUES ('%d', '%d', '%d', '%d')",
- inventory_db, char_id, start_items[k], 1, 1)
- )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 1627));
- }
- }
- }
-
- (showmsg->showInfo(("Created char: account: %d, char: %d, slot: %d, name: %s\n"), sd->account_id, char_id, slot, name));
- return char_id;
-}
-
-
-
-
-int char_divorce_char_sql(int partner_id1, int partner_id2)
-{
- unsigned char buf[64];
-
- if( (-1) == SQL->Query(inter->sql_handle, "UPDATE `%s` SET `partner_id`='0' WHERE `char_id`='%d' OR `char_id`='%d' LIMIT 2", char_db, partner_id1, partner_id2) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 1644));
- if( (-1) == SQL->Query(inter->sql_handle, "DELETE FROM `%s` WHERE (`nameid`='%d' OR `nameid`='%d') AND (`char_id`='%d' OR `char_id`='%d') LIMIT 2", inventory_db, 2634, 2635, partner_id1, partner_id2) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 1646));
-
- WBUFW(buf,0) = 0x2b12;
- WBUFL(buf,2) = partner_id1;
- WBUFL(buf,6) = partner_id2;
- mapif->sendall(buf,10);
-
- return 0;
-}
-
-
-
-
-
-
-
-int char_delete_char_sql(int char_id)
-{
- char name[(23 + 1)];
- char esc_name[(23 + 1)*2+1];
- int account_id, party_id, guild_id, hom_id, base_level, partner_id, father_id, mother_id, elemental_id;
- char *data;
- size_t len;
-
- if ((-1) == SQL->Query(inter->sql_handle, "SELECT `name`,`account_id`,`party_id`,`guild_id`,`base_level`,`homun_id`,`partner_id`,`father`,`mother`,`elemental_id` FROM `%s` WHERE `char_id`='%d'", char_db, char_id))
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 1671));
-
- if( 0 != SQL->NextRow(inter->sql_handle) )
- {
- (showmsg->showError(("chr->delete_char_sql: Unable to fetch character data, deletion aborted.\n")));
- SQL->FreeResult(inter->sql_handle);
- return -1;
- }
-
- SQL->GetData(inter->sql_handle, 0, &data, &len); (strlib->safestrncpy_((name),(data),((23 + 1))));
- SQL->GetData(inter->sql_handle, 1, &data,
-# 1681 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1681 "../../../server-code/src/char/char.c"
- ); account_id = atoi(data);
- SQL->GetData(inter->sql_handle, 2, &data,
-# 1682 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1682 "../../../server-code/src/char/char.c"
- ); party_id = atoi(data);
- SQL->GetData(inter->sql_handle, 3, &data,
-# 1683 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1683 "../../../server-code/src/char/char.c"
- ); guild_id = atoi(data);
- SQL->GetData(inter->sql_handle, 4, &data,
-# 1684 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1684 "../../../server-code/src/char/char.c"
- ); base_level = atoi(data);
- SQL->GetData(inter->sql_handle, 5, &data,
-# 1685 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1685 "../../../server-code/src/char/char.c"
- ); hom_id = atoi(data);
- SQL->GetData(inter->sql_handle, 6, &data,
-# 1686 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1686 "../../../server-code/src/char/char.c"
- ); partner_id = atoi(data);
- SQL->GetData(inter->sql_handle, 7, &data,
-# 1687 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1687 "../../../server-code/src/char/char.c"
- ); father_id = atoi(data);
- SQL->GetData(inter->sql_handle, 8, &data,
-# 1688 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1688 "../../../server-code/src/char/char.c"
- ); mother_id = atoi(data);
- SQL->GetData(inter->sql_handle, 9, &data,
-# 1689 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1689 "../../../server-code/src/char/char.c"
- );
- elemental_id = atoi(data);
-
- SQL->EscapeStringLen(inter->sql_handle, esc_name, name, (((len) < ((23 + 1))) ? (len) : ((23 + 1))));
- SQL->FreeResult(inter->sql_handle);
-
-
-
- if( ( char_del_level > 0 && base_level >= char_del_level )
- || ( char_del_level < 0 && base_level <= -char_del_level )
- ) {
- (showmsg->showInfo(("Char deletion aborted: %s, BaseLevel: %i\n"), name, base_level));
- return -1;
- }
-
-
- if( partner_id )
- chr->divorce_char_sql(char_id, partner_id);
-
-
- if( father_id || mother_id )
- {
- unsigned char buf[64];
-
- if( (-1) == SQL->Query(inter->sql_handle, "UPDATE `%s` SET `child`='0' WHERE `char_id`='%d' OR `char_id`='%d'", char_db, father_id, mother_id) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 1714));
- if( (-1) == SQL->Query(inter->sql_handle, "DELETE FROM `%s` WHERE `id` = '410'AND (`char_id`='%d' OR `char_id`='%d')", skill_db, father_id, mother_id) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 1716));
-
- WBUFW(buf,0) = 0x2b25;
- WBUFL(buf,2) = father_id;
- WBUFL(buf,6) = mother_id;
- WBUFL(buf,10) = char_id;
- mapif->sendall(buf,14);
- }
-
-
- if (party_id)
- inter_party->leave(party_id, account_id, char_id);
-
-
-
- if( (-1) == SQL->Query(inter->sql_handle, "DELETE FROM `%s` WHERE `char_id`='%d' AND `incubate` = '0'", pet_db, char_id) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 1732));
-
-
- if( (-1) == SQL->Query(inter->sql_handle, "DELETE FROM `%s` USING `%s` JOIN `%s` ON `pet_id` = `card1`|`card2`<<16 WHERE `%s`.char_id = '%d' AND card0 = -256", pet_db, pet_db, inventory_db, inventory_db, char_id) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 1736));
- if( (-1) == SQL->Query(inter->sql_handle, "DELETE FROM `%s` USING `%s` JOIN `%s` ON `pet_id` = `card1`|`card2`<<16 WHERE `%s`.char_id = '%d' AND card0 = -256", pet_db, pet_db, cart_db, cart_db, char_id) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 1738));
-
-
- if( hom_id )
- mapif->homunculus_delete(hom_id);
-
-
- if (elemental_id)
- mapif->elemental_delete(elemental_id);
-
-
- inter_mercenary->owner_delete(char_id);
-
-
- if( (-1) == SQL->Query(inter->sql_handle, "DELETE FROM `%s` WHERE `char_id` = '%d'", friend_db, char_id) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 1753));
-
-
-
- if( (-1) == SQL->Query(inter->sql_handle, "DELETE FROM `%s` WHERE `friend_id` = '%d'", friend_db, char_id) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 1758));
-
-
-
- if( (-1) == SQL->Query(inter->sql_handle, "DELETE FROM `%s` WHERE `char_id`='%d'", hotkey_db, char_id) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 1763));
-
-
-
- if( (-1) == SQL->Query(inter->sql_handle, "DELETE FROM `%s` WHERE `char_id`='%d'", inventory_db, char_id) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 1768));
-
-
- if( (-1) == SQL->Query(inter->sql_handle, "DELETE FROM `%s` WHERE `char_id`='%d'", cart_db, char_id) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 1772));
-
-
- if( (-1) == SQL->Query(inter->sql_handle, "DELETE FROM `%s` WHERE `char_id`='%d'", memo_db, char_id) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 1776));
-
-
- if( (-1) == SQL->Query(inter->sql_handle, "DELETE FROM `%s` WHERE `char_id`='%d'", char_reg_str_db, char_id) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 1780));
- if( (-1) == SQL->Query(inter->sql_handle, "DELETE FROM `%s` WHERE `char_id`='%d'", char_reg_num_db, char_id) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 1782));
-
-
- if( (-1) == SQL->Query(inter->sql_handle, "DELETE FROM `%s` WHERE `char_id`='%d'", skill_db, char_id) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 1786));
-
-
- if ((-1) == SQL->Query(inter->sql_handle, "DELETE FROM `%s` WHERE `dest_id`='%d'", mail_db, char_id))
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 1790));
-
-
-
- if( (-1) == SQL->Query(inter->sql_handle, "DELETE FROM `%s` WHERE `account_id` = '%d' AND `char_id`='%d'", scdata_db, account_id, char_id) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 1795));
-
-
-
- if( (-1) == SQL->Query(inter->sql_handle, "DELETE FROM `%s` WHERE `char_id`='%d'", char_db, char_id) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 1800));
- else if( log_char ) {
- if( (-1) == SQL->Query(inter->sql_handle,
- "INSERT INTO `%s`(`time`, `account_id`, `char_id`, `char_num`, `char_msg`, `name`)"
- " VALUES (NOW(), '%d', '%d', '%d', 'Deleted character', '%s')",
- charlog_db, account_id, char_id, 0, esc_name) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 1806));
- }
-
-
-
-
-
-
-
- if( (-1) == SQL->Query(inter->sql_handle, "SELECT `guild_id` FROM `%s` WHERE `char_id` = '%d'", guild_db, char_id) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 1816));
- else if( SQL->NumRows(inter->sql_handle) > 0 )
- mapif->parse_BreakGuild(0,guild_id);
- else if( guild_id )
- inter_guild->leave(guild_id, account_id, char_id);
- return 0;
-}
-
-
-
-
-int char_count_users(void)
-{
- int i, users;
-
- users = 0;
- for(i = 0; i < ( (int)(sizeof(chr->server)/sizeof((chr->server)[0])) ); i++) {
- if (chr->server[i].fd > 0) {
- users += chr->server[i].users;
- }
- }
- return users;
-}
-
-
-
-
-
-int char_mmo_char_tobuf(uint8* buffer, struct mmo_charstatus* p) {
- unsigned short offset = 0;
- uint8* buf;
-
- if( buffer ==
-# 1848 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1848 "../../../server-code/src/char/char.c"
- || p ==
-# 1848 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1848 "../../../server-code/src/char/char.c"
- )
- return 0;
-
- buf = WBUFP(buffer,0);
- WBUFL(buf,0) = p->char_id;
- WBUFL(buf,4) = (((p->base_exp) < (
-# 1853 "../../../server-code/src/char/char.c" 3 4
- (2147483647)
-# 1853 "../../../server-code/src/char/char.c"
- )) ? (p->base_exp) : (
-# 1853 "../../../server-code/src/char/char.c" 3 4
- (2147483647)
-# 1853 "../../../server-code/src/char/char.c"
- ));
- WBUFL(buf,8) = p->zeny;
- WBUFL(buf,12) = (((p->job_exp) < (
-# 1855 "../../../server-code/src/char/char.c" 3 4
- (2147483647)
-# 1855 "../../../server-code/src/char/char.c"
- )) ? (p->job_exp) : (
-# 1855 "../../../server-code/src/char/char.c" 3 4
- (2147483647)
-# 1855 "../../../server-code/src/char/char.c"
- ));
- WBUFL(buf,16) = p->job_level;
- WBUFL(buf,20) = 0;
- WBUFL(buf,24) = 0;
- WBUFL(buf,28) = (p->option &~ 0x40);
- WBUFL(buf,32) = p->karma;
- WBUFL(buf,36) = p->manner;
- WBUFW(buf,40) = (((p->status_point) < (
-# 1862 "../../../server-code/src/char/char.c" 3 4
- (32767)
-# 1862 "../../../server-code/src/char/char.c"
- )) ? (p->status_point) : (
-# 1862 "../../../server-code/src/char/char.c" 3 4
- (32767)
-# 1862 "../../../server-code/src/char/char.c"
- ));
-
- WBUFL(buf,42) = p->hp;
- WBUFL(buf,46) = p->max_hp;
- offset+=4;
- buf = WBUFP(buffer,offset);
-
-
-
-
- WBUFW(buf,46) = (((p->sp) < (
-# 1872 "../../../server-code/src/char/char.c" 3 4
- (32767)
-# 1872 "../../../server-code/src/char/char.c"
- )) ? (p->sp) : (
-# 1872 "../../../server-code/src/char/char.c" 3 4
- (32767)
-# 1872 "../../../server-code/src/char/char.c"
- ));
- WBUFW(buf,48) = (((p->max_sp) < (
-# 1873 "../../../server-code/src/char/char.c" 3 4
- (32767)
-# 1873 "../../../server-code/src/char/char.c"
- )) ? (p->max_sp) : (
-# 1873 "../../../server-code/src/char/char.c" 3 4
- (32767)
-# 1873 "../../../server-code/src/char/char.c"
- ));
- WBUFW(buf,50) = 150;
- WBUFW(buf,52) = p->class_;
- WBUFW(buf,54) = p->hair;
-# 1885 "../../../server-code/src/char/char.c"
- WBUFW(buf,56) = p->option&(OPTION_RIDING|OPTION_DRAGON|OPTION_WUG|OPTION_WUGRIDER|OPTION_MADOGEAR|OPTION_HANBOK) ? 0 : p->weapon;
-
- WBUFW(buf,58) = p->base_level;
- WBUFW(buf,60) = (((p->skill_point) < (
-# 1888 "../../../server-code/src/char/char.c" 3 4
- (32767)
-# 1888 "../../../server-code/src/char/char.c"
- )) ? (p->skill_point) : (
-# 1888 "../../../server-code/src/char/char.c" 3 4
- (32767)
-# 1888 "../../../server-code/src/char/char.c"
- ));
- WBUFW(buf,62) = p->head_bottom;
- WBUFW(buf,64) = p->shield;
- WBUFW(buf,66) = p->head_top;
- WBUFW(buf,68) = p->head_mid;
- WBUFW(buf,70) = p->hair_color;
- WBUFW(buf,72) = p->clothes_color;
- memcpy(WBUFP(buf,74), p->name, (23 + 1));
- WBUFB(buf,98) = (((p->str) < (((uint8) 0xFF))) ? (p->str) : (((uint8) 0xFF)));
- WBUFB(buf,99) = (((p->agi) < (((uint8) 0xFF))) ? (p->agi) : (((uint8) 0xFF)));
- WBUFB(buf,100) = (((p->vit) < (((uint8) 0xFF))) ? (p->vit) : (((uint8) 0xFF)));
- WBUFB(buf,101) = (((p->int_) < (((uint8) 0xFF))) ? (p->int_) : (((uint8) 0xFF)));
- WBUFB(buf,102) = (((p->dex) < (((uint8) 0xFF))) ? (p->dex) : (((uint8) 0xFF)));
- WBUFB(buf,103) = (((p->luk) < (((uint8) 0xFF))) ? (p->luk) : (((uint8) 0xFF)));
- WBUFW(buf,104) = p->slot;
-
- WBUFW(buf,106) = ( p->rename > 0 ) ? 0 : 1;
- offset += 2;
-
-
- mapindex->getmapname_ext(mapindex->id2name((p->last_point.map),"../../../server-code/src/char/char.c", 1908, __func__), WBUFP(buf,108));
- offset += ((11 + 1) + 4);
-
-
- WBUFL(buf,124) = (int)p->delete_date;
- offset += 4;
-
-
- WBUFL(buf,128) = p->robe;
- offset += 4;
-
-
-
- WBUFL(buf,132) = ( p->slotchange > 0 ) ? 1 : 0;
- offset += 4;
-
-
- WBUFL(buf,136) = ( p->rename > 0 ) ? 1 : 0;
- offset += 4;
-
-
- WBUFB(buf,140) = p->sex;
- offset += 1;
-
-
-
- return 106+offset;
-}
-
-
-void char_mmo_char_send099d(int fd, struct char_session_data *sd) {
- WFIFOHEAD(fd,4 + (9*150));
- WFIFOW(fd,0) = 0x99d;
- WFIFOW(fd,2) = chr->mmo_chars_fromsql(sd, WFIFOP(fd,4)) + 4;
- WFIFOSET(fd,WFIFOW(fd,2));
-}
-
-
-
-void char_mmo_char_send_ban_list(int fd, struct char_session_data *sd) {
- int i;
- time_t now = time(
-# 1949 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 1949 "../../../server-code/src/char/char.c"
- );
-
- do { if (((void)(sd),
-# 1951 "../../../server-code/src/char/char.c" 3 4
-0
-# 1951 "../../../server-code/src/char/char.c"
-)) return; } while(0);
- do { for ((i) = (0); (i) < (9); ++(i)) if (sd->unban_time[i]) break; } while(
-# 1952 "../../../server-code/src/char/char.c" 3 4
-0
-# 1952 "../../../server-code/src/char/char.c"
-);
- if( i != 9 ) {
- int c;
-
- WFIFOHEAD(fd, 4 + (9*24));
-
- WFIFOW(fd,0) = 0x20d;
-
- for(i = 0, c = 0; i < 9; i++) {
- if( sd->unban_time[i] ) {
- timestamp2string(WFIFOP(fd,8 + (28*c)), 20, sd->unban_time[i], "%Y-%m-%d %H:%M:%S");
-
- if( sd->unban_time[i] > now )
- WFIFOL(fd, 4 + (24*c)) = sd->found_char[i];
- else {
-
- WFIFOL(fd, 4 + (24*c)) = 0;
-
- sd->unban_time[i] = 0;
- if( (-1) == SQL->Query(inter->sql_handle, "UPDATE `%s` SET `unban_time`='0' WHERE `char_id`='%d' LIMIT 1", char_db, sd->found_char[i]) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 1972));
- }
- c++;
- }
- }
-
- WFIFOW(fd,2) = 4 + (24*c);
-
- WFIFOSET(fd, WFIFOW(fd,2));
- }
-}
-
-
-
-
-void char_mmo_char_send_slots_info(int fd, struct char_session_data* sd) {
- do { if (((void)(sd),
-# 1988 "../../../server-code/src/char/char.c" 3 4
-0
-# 1988 "../../../server-code/src/char/char.c"
-)) return; } while(0);
- WFIFOHEAD(fd,29);
- WFIFOW(fd,0) = 0x82d;
- WFIFOW(fd,2) = 29;
- WFIFOB(fd,4) = sd->char_slots;
- WFIFOB(fd,5) = 9 - sd->char_slots;
- WFIFOB(fd,6) = 0;
- WFIFOB(fd,7) = sd->char_slots;
- WFIFOB(fd,8) = sd->char_slots;
- memset(WFIFOP(fd,9), 0, 20);
- WFIFOSET(fd,29);
-}
-
-
-
-int char_mmo_char_send_characters(int fd, struct char_session_data* sd)
-{
- int j, offset = 0;
- do { if (((void)(sd),
-# 2006 "../../../server-code/src/char/char.c" 3 4
-0
-# 2006 "../../../server-code/src/char/char.c"
-)) return(0); } while(0);
-
- offset += 3;
-
- if (save_log)
- (showmsg->showInfo(("Loading Char Data (""\033[1m""%d""\033[0m"")\n"),sd->account_id));
-
- j = 24 + offset;
- WFIFOHEAD(fd,j + 9*150);
- WFIFOW(fd,0) = 0x6b;
-
- WFIFOB(fd,4) = 9;
- WFIFOB(fd,5) = sd->char_slots;
- WFIFOB(fd,6) = 9;
-
- memset(WFIFOP(fd,4 + offset), 0, 20);
- j+=chr->mmo_chars_fromsql(sd, WFIFOP(fd,j));
- WFIFOW(fd,2) = j;
- WFIFOSET(fd,j);
-
- return 0;
-}
-
-int char_char_married(int pl1, int pl2)
-{
- if( (-1) == SQL->Query(inter->sql_handle, "SELECT `partner_id` FROM `%s` WHERE `char_id` = '%d'", char_db, pl1) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 2032));
- else if( 0 == SQL->NextRow(inter->sql_handle) )
- {
- char* data;
-
- SQL->GetData(inter->sql_handle, 0, &data,
-# 2037 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 2037 "../../../server-code/src/char/char.c"
- );
- if( pl2 == atoi(data) )
- {
- SQL->FreeResult(inter->sql_handle);
- return 1;
- }
- }
- SQL->FreeResult(inter->sql_handle);
- return 0;
-}
-
-int char_char_child(int parent_id, int child_id)
-{
- if( (-1) == SQL->Query(inter->sql_handle, "SELECT `child` FROM `%s` WHERE `char_id` = '%d'", char_db, parent_id) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 2051));
- else if( 0 == SQL->NextRow(inter->sql_handle) )
- {
- char* data;
-
- SQL->GetData(inter->sql_handle, 0, &data,
-# 2056 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 2056 "../../../server-code/src/char/char.c"
- );
- if( child_id == atoi(data) )
- {
- SQL->FreeResult(inter->sql_handle);
- return 1;
- }
- }
- SQL->FreeResult(inter->sql_handle);
- return 0;
-}
-
-int char_char_family(int cid1, int cid2, int cid3)
-{
- if( (-1) == SQL->Query(inter->sql_handle, "SELECT `char_id`,`partner_id`,`child` FROM `%s` WHERE `char_id` IN ('%d','%d','%d')", char_db, cid1, cid2, cid3) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 2070));
- else while( 0 == SQL->NextRow(inter->sql_handle) )
- {
- int charid;
- int partnerid;
- int childid;
- char* data;
-
- SQL->GetData(inter->sql_handle, 0, &data,
-# 2078 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 2078 "../../../server-code/src/char/char.c"
- ); charid = atoi(data);
- SQL->GetData(inter->sql_handle, 1, &data,
-# 2079 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 2079 "../../../server-code/src/char/char.c"
- ); partnerid = atoi(data);
- SQL->GetData(inter->sql_handle, 2, &data,
-# 2080 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 2080 "../../../server-code/src/char/char.c"
- ); childid = atoi(data);
-
- if( (cid1 == charid && ((cid2 == partnerid && cid3 == childid ) || (cid2 == childid && cid3 == partnerid))) ||
- (cid1 == partnerid && ((cid2 == charid && cid3 == childid ) || (cid2 == childid && cid3 == charid ))) ||
- (cid1 == childid && ((cid2 == charid && cid3 == partnerid) || (cid2 == partnerid && cid3 == charid ))) )
- {
- SQL->FreeResult(inter->sql_handle);
- return childid;
- }
- }
- SQL->FreeResult(inter->sql_handle);
- return 0;
-}
-
-
-
-
-void char_disconnect_player(int account_id)
-{
- int i;
- struct char_session_data* sd;
-
-
- do { for ((i) = (0); (i) < (sockt->fd_max); ++(i)) if (sockt->session[i] && (sd = (struct char_session_data*)sockt->session[i]->session_data) && sd->account_id == account_id) break; } while(
-# 2103 "../../../server-code/src/char/char.c" 3 4
-0
-# 2103 "../../../server-code/src/char/char.c"
-);
- if( i < sockt->fd_max )
- sockt->eof(i);
-}
-
-void char_authfail_fd(int fd, int type)
-{
- WFIFOHEAD(fd,3);
- WFIFOW(fd,0) = 0x81;
- WFIFOB(fd,2) = type;
- WFIFOSET(fd,3);
-}
-
-void char_request_account_data(int account_id)
-{
- WFIFOHEAD(chr->login_fd,6);
- WFIFOW(chr->login_fd,0) = 0x2716;
- WFIFOL(chr->login_fd,2) = account_id;
- WFIFOSET(chr->login_fd,6);
-}
-
-static void char_auth_ok(int fd, struct char_session_data *sd)
-{
- struct online_char_data* character;
-
- do { if (((void)(sd),
-# 2128 "../../../server-code/src/char/char.c" 3 4
-0
-# 2128 "../../../server-code/src/char/char.c"
-)) return; } while(0);
-
- if( (character = (struct online_char_data*)( DB->data2ptr((chr->online_char_db)->get((chr->online_char_db),DB->i2key(sd->account_id))) )) !=
-# 2130 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 2130 "../../../server-code/src/char/char.c"
- ) {
-
- if (character->server > -1) {
-
- mapif->disconnectplayer(chr->server[character->server].fd, character->account_id, character->char_id, 2);
- if (character->waiting_disconnect == (-1))
- character->waiting_disconnect = timer->add(timer->gettick()+20000, chr->waiting_disconnect, character->account_id, 0);
- character->pincode_enable = -1;
- chr->authfail_fd(fd, 8);
- return;
- }
- if (character->fd >= 0 && character->fd != fd) {
-
- chr->authfail_fd(fd, 8);
- return;
- }
- character->fd = fd;
- }
-
- if (chr->login_fd > 0) {
- chr->request_account_data(sd->account_id);
- }
-
-
- sd->auth =
-# 2154 "../../../server-code/src/char/char.c" 3 4
- 1
-# 2154 "../../../server-code/src/char/char.c"
- ;
-
-
- chr->set_char_charselect(sd->account_id);
-
-
-}
-
-void char_ping_login_server(int fd)
-{
- WFIFOHEAD(fd,2);
- WFIFOW(fd,0) = 0x2719;
- WFIFOSET(fd,2);
-}
-
-int char_parse_fromlogin_connection_state(int fd)
-{
- if (RFIFOB(fd,2)) {
-
- (showmsg->showError(("Can not connect to login-server.\n")));
- (showmsg->showError(("The server communication passwords (default s1/p1) are probably invalid.\n")));
- (showmsg->showError(("Also, please make sure your login db has the correct communication username/passwords and the gender of the account is S.\n")));
- (showmsg->showError(("The communication passwords are set in /conf/map-server.conf and /conf/char-server.conf\n")));
- sockt->eof(fd);
- return 1;
- } else {
- (showmsg->showStatus(("Connected to login-server (connection #%d).\n"), fd));
- loginif->on_ready();
- }
- RFIFOSKIP(fd,3);
- return 0;
-}
-
-
-
-void char_auth_error(int fd, unsigned char flag)
-{
- WFIFOHEAD(fd,3);
- WFIFOW(fd,0) = 0x6c;
- WFIFOB(fd,2) = flag;
- WFIFOSET(fd,3);
-}
-
-void char_parse_fromlogin_auth_state(int fd)
-{
- struct char_session_data* sd =
-# 2199 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 2199 "../../../server-code/src/char/char.c"
- ;
- int account_id = RFIFOL(fd,2);
- uint32 login_id1 = RFIFOL(fd,6);
- uint32 login_id2 = RFIFOL(fd,10);
- uint8 sex = RFIFOB(fd,14);
- uint8 result = RFIFOB(fd,15);
- int request_id = RFIFOL(fd,16);
- uint32 version = RFIFOL(fd,20);
- uint8 clienttype = RFIFOB(fd,24);
- int group_id = RFIFOL(fd,25);
- unsigned int expiration_time = RFIFOL(fd, 29);
- RFIFOSKIP(fd,33);
-
- if (sockt->session_is_active(request_id) && (sd=(struct char_session_data*)sockt->session[request_id]->session_data) &&
- !sd->auth && sd->account_id == account_id && sd->login_id1 == login_id1 && sd->login_id2 == login_id2 && sd->sex == sex )
- {
- int client_fd = request_id;
- sd->version = version;
- sd->clienttype = clienttype;
- switch( result ) {
- case 0:
-
- if( chr->server_type == CST_MAINTENANCE && group_id < char_maintenance_min_group_id ) {
- chr->auth_error(client_fd, 0);
- break;
- }
-
- if( chr->server_type == CST_PAYING && (time_t)expiration_time < time(
-# 2226 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 2226 "../../../server-code/src/char/char.c"
- ) ) {
- chr->auth_error(client_fd, 0);
- break;
- }
- chr->auth_ok(client_fd, sd);
- break;
- case 1:
- chr->auth_error(client_fd, 0);
- break;
- }
- }
-}
-
-void char_parse_fromlogin_account_data(int fd)
-{
- struct char_session_data* sd = (struct char_session_data*)sockt->session[fd]->session_data;
- int i;
-
- do { for ((i) = (0); (i) < (sockt->fd_max); ++(i)) if (sockt->session[i] && (sd = (struct char_session_data*)sockt->session[i]->session_data) && sd->auth && sd->account_id == RFIFOL(fd,2)) break; } while(
-# 2244 "../../../server-code/src/char/char.c" 3 4
-0
-# 2244 "../../../server-code/src/char/char.c"
-);
- if( i < sockt->fd_max ) {
- memcpy(sd->email, RFIFOP(fd,6), 40);
- sd->expiration_time = (time_t)RFIFOL(fd,46);
- sd->group_id = RFIFOB(fd,50);
- sd->char_slots = RFIFOB(fd,51);
- if( sd->char_slots > 9 ) {
- (showmsg->showError(("Account '%d' `character_slots` column is higher than supported MAX_CHARS (%d), update MAX_CHARS in mmo.h! capping to MAX_CHARS...\n"),sd->account_id,sd->char_slots));
- sd->char_slots = 9;
- } else if ( sd->char_slots <= 0 )
- sd->char_slots = 9;
- (strlib->safestrncpy_((sd->birthdate),(RFIFOP(fd,52)),(sizeof(sd->birthdate))));
- (strlib->safestrncpy_((sd->pincode),(RFIFOP(fd,63)),(sizeof(sd->pincode))));
- sd->pincode_change = RFIFOL(fd,68);
-
- if( (max_connect_user == 0 && sd->group_id != gm_allow_group) ||
- ( max_connect_user > 0 && chr->count_users() >= max_connect_user && sd->group_id != gm_allow_group ) ) {
-
- chr->auth_error(i, 0);
- } else {
-
-
- chr->mmo_char_send_slots_info(i, sd);
- chr->mmo_char_send_characters(i, sd);
-
-
-
-
- chr->mmo_char_send_ban_list(i, sd);
-
-
- pincode->handle(i, sd);
-
- }
- }
- RFIFOSKIP(fd,72);
-}
-
-void char_parse_fromlogin_login_pong(int fd)
-{
- RFIFOSKIP(fd,2);
- if (sockt->session[fd])
- sockt->session[fd]->flag.ping = 0;
-}
-
-void char_changesex(int account_id, int sex)
-{
- unsigned char buf[7];
-
- WBUFW(buf,0) = 0x2b0d;
- WBUFL(buf,2) = account_id;
- WBUFB(buf,6) = sex;
- mapif->sendall(buf, 7);
-}
-# 2310 "../../../server-code/src/char/char.c"
-void char_change_sex_sub(int sex, int acc, int char_id, int class_, int guild_id)
-{
-
- if (class_ == JOB_BARD || class_ == JOB_DANCER)
- class_ = (sex == SEX_MALE ? JOB_BARD : JOB_DANCER);
- else if (class_ == JOB_CLOWN || class_ == JOB_GYPSY)
- class_ = (sex == SEX_MALE ? JOB_CLOWN : JOB_GYPSY);
- else if (class_ == JOB_BABY_BARD || class_ == JOB_BABY_DANCER)
- class_ = (sex == SEX_MALE ? JOB_BABY_BARD : JOB_BABY_DANCER);
- else if (class_ == JOB_MINSTREL || class_ == JOB_WANDERER)
- class_ = (sex == SEX_MALE ? JOB_MINSTREL : JOB_WANDERER);
- else if (class_ == JOB_MINSTREL_T || class_ == JOB_WANDERER_T)
- class_ = (sex == SEX_MALE ? JOB_MINSTREL_T : JOB_WANDERER_T);
- else if (class_ == JOB_BABY_MINSTREL || class_ == JOB_BABY_WANDERER)
- class_ = (sex == SEX_MALE ? JOB_BABY_MINSTREL : JOB_BABY_WANDERER);
- else if (class_ == JOB_KAGEROU || class_ == JOB_OBORO)
- class_ = (sex == SEX_MALE ? JOB_KAGEROU : JOB_OBORO);
-
- if ((-1) == SQL->Query(inter->sql_handle, "UPDATE `%s` SET `equip`='0' WHERE `char_id`='%d'", inventory_db, char_id))
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 2329));
-
- if ((-1) == SQL->Query(inter->sql_handle, "UPDATE `%s` SET `class`='%d', `weapon`='0', `shield`='0', "
- "`head_top`='0', `head_mid`='0', `head_bottom`='0' WHERE `char_id`='%d'",
- char_db, class_, char_id))
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 2334));
- if (guild_id)
- inter_guild->sex_changed(guild_id, acc, char_id, sex);
-}
-
-int char_parse_fromlogin_changesex_reply(int fd)
-{
- int char_id = 0, class_ = 0, guild_id = 0;
- int i;
- struct char_auth_node *node;
- struct SqlStmt *stmt;
-
- int acc = RFIFOL(fd,2);
- int sex = RFIFOB(fd,6);
-
- RFIFOSKIP(fd,7);
-
-
- if (acc <= 0) {
- (showmsg->showError(("Received invalid account id from login server! (aid: %d)\n"), acc));
- return 1;
- }
-
- node = (struct char_auth_node*)( DB->data2ptr((auth_db)->get((auth_db),DB->i2key(acc))) );
- if (node !=
-# 2358 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 2358 "../../../server-code/src/char/char.c"
- )
- node->sex = sex;
-
-
- stmt = SQL->StmtMalloc(inter->sql_handle);
- if ((-1) == SQL->StmtPrepare(stmt, "SELECT `char_id`,`class`,`guild_id` FROM `%s` WHERE `account_id` = '%d'", char_db, acc)
- || (-1) == SQL->StmtExecute(stmt)
- ) {
- (SQL->StmtShowDebug_((stmt), "../../../server-code/src/char/char.c", 2366));
- SQL->StmtFree(stmt);
- }
- SQL->StmtBindColumn(stmt, 0, SQLDT_INT, &char_id, 0,
-# 2369 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 2369 "../../../server-code/src/char/char.c"
- ,
-# 2369 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 2369 "../../../server-code/src/char/char.c"
- );
- SQL->StmtBindColumn(stmt, 1, SQLDT_INT, &class_, 0,
-# 2370 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 2370 "../../../server-code/src/char/char.c"
- ,
-# 2370 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 2370 "../../../server-code/src/char/char.c"
- );
- SQL->StmtBindColumn(stmt, 2, SQLDT_INT, &guild_id, 0,
-# 2371 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 2371 "../../../server-code/src/char/char.c"
- ,
-# 2371 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 2371 "../../../server-code/src/char/char.c"
- );
-
- for (i = 0; i < 9 && 0 == SQL->StmtNextRow(stmt); ++i) {
- char_change_sex_sub(sex, acc, char_id, class_, guild_id);
- }
- SQL->StmtFree(stmt);
-
-
- chr->disconnect_player(acc);
-
-
- chr->changesex(acc, sex);
- return 0;
-}
-
-void char_parse_fromlogin_account_reg2(int fd)
-{
-
- mapif->sendall(RFIFOP(fd, 0), RFIFOW(fd,2));
- RFIFOSKIP(fd, RFIFOW(fd,2));
-}
-
-void mapif_ban(int id, unsigned int flag, int status)
-{
-
- unsigned char buf[11];
- WBUFW(buf,0) = 0x2b14;
- WBUFL(buf,2) = id;
- WBUFB(buf,6) = flag;
- WBUFL(buf,7) = status;
- mapif->sendall(buf, 11);
-}
-
-void char_parse_fromlogin_ban(int fd)
-{
- mapif->ban(RFIFOL(fd,2), RFIFOB(fd,6), RFIFOL(fd,7));
-
- chr->disconnect_player(RFIFOL(fd,2));
- RFIFOSKIP(fd,11);
-}
-
-void char_parse_fromlogin_kick(int fd)
-{
- int aid = RFIFOL(fd,2);
- struct online_char_data* character = (struct online_char_data*)( DB->data2ptr((chr->online_char_db)->get((chr->online_char_db),DB->i2key(aid))) );
- RFIFOSKIP(fd,6);
- if( character !=
-# 2417 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 2417 "../../../server-code/src/char/char.c"
- )
- {
- if( character->server > -1 ) {
-
- mapif->disconnectplayer(chr->server[character->server].fd, character->account_id, character->char_id, 2);
- if (character->waiting_disconnect == (-1))
- character->waiting_disconnect = timer->add(timer->gettick()+30000, chr->waiting_disconnect, character->account_id, 0);
- }
- else
- {
- struct char_session_data *tsd;
- int i;
- do { for ((i) = (0); (i) < (sockt->fd_max); ++(i)) if (sockt->session[i] && (tsd = (struct char_session_data*)sockt->session[i]->session_data) && tsd->account_id == aid) break; } while(
-# 2429 "../../../server-code/src/char/char.c" 3 4
- 0
-# 2429 "../../../server-code/src/char/char.c"
- );
- if( i < sockt->fd_max )
- {
- chr->authfail_fd(i, 2);
- sockt->eof(i);
- }
- else
- chr->set_char_offline(-1, aid);
- }
- }
- ( (auth_db)->remove((auth_db),DB->i2key(aid),
-# 2439 "../../../server-code/src/char/char.c" 3 4
-((void *)0)
-# 2439 "../../../server-code/src/char/char.c"
-) );
-}
-
-void char_update_ip(int fd)
-{
- WFIFOHEAD(fd,6);
- WFIFOW(fd,0) = 0x2736;
- WFIFOL(fd,2) = htonl(chr->ip);
- WFIFOSET(fd,6);
-}
-
-void char_parse_fromlogin_update_ip(int fd)
-{
- unsigned char buf[2];
- uint32 new_ip = 0;
-
- WBUFW(buf,0) = 0x2b1e;
- mapif->sendall(buf, 2);
-
- new_ip = sockt->host2ip(login_ip_str);
- if (new_ip && new_ip != login_ip)
- login_ip = new_ip;
-
- new_ip = sockt->host2ip(char_ip_str);
- if (new_ip && new_ip != chr->ip) {
-
- chr->ip = new_ip;
- (showmsg->showInfo(("Updating IP for [%s].\n"), char_ip_str));
-
- chr->update_ip(fd);
- }
- RFIFOSKIP(fd,2);
-}
-
-void char_parse_fromlogin_accinfo2_failed(int fd)
-{
- mapif->parse_accinfo2(
-# 2475 "../../../server-code/src/char/char.c" 3 4
- 0
-# 2475 "../../../server-code/src/char/char.c"
- , RFIFOL(fd,2), RFIFOL(fd,6), RFIFOL(fd,10), RFIFOL(fd,14),
-
-# 2476 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 2476 "../../../server-code/src/char/char.c"
- ,
-# 2476 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 2476 "../../../server-code/src/char/char.c"
- ,
-# 2476 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 2476 "../../../server-code/src/char/char.c"
- ,
-# 2476 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 2476 "../../../server-code/src/char/char.c"
- ,
-# 2476 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 2476 "../../../server-code/src/char/char.c"
- ,
-# 2476 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 2476 "../../../server-code/src/char/char.c"
- ,
-# 2476 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 2476 "../../../server-code/src/char/char.c"
- , -1, 0, 0);
- RFIFOSKIP(fd,18);
-}
-
-void char_parse_fromlogin_accinfo2_ok(int fd)
-{
- mapif->parse_accinfo2(
-# 2482 "../../../server-code/src/char/char.c" 3 4
- 1
-# 2482 "../../../server-code/src/char/char.c"
- , RFIFOL(fd,167), RFIFOL(fd,171), RFIFOL(fd,175), RFIFOL(fd,179),
- RFIFOP(fd,2), RFIFOP(fd,26), RFIFOP(fd,59), RFIFOP(fd,99), RFIFOP(fd,119),
- RFIFOP(fd,151), RFIFOP(fd,156), RFIFOL(fd,115), RFIFOL(fd,143), RFIFOL(fd,147));
- RFIFOSKIP(fd,183);
-}
-
-int char_parse_fromlogin(int fd) {
-
- if( fd != chr->login_fd ) {
- (showmsg->showDebug(("chr->parse_fromlogin: Disconnecting invalid session #%d (is not the login-server)\n"), fd));
- sockt->close(fd);
- return 0;
- }
-
- if( sockt->session[fd]->flag.eof ) {
- sockt->close(fd);
- chr->login_fd = -1;
- loginif->on_disconnect();
- return 0;
- } else if ( sockt->session[fd]->flag.ping ) {
- if( ((sockt->last_tick)-(sockt->session[fd]->rdata_tick)) > (sockt->stall_time * 2) ) {
- sockt->eof(fd);
- return 0;
- } else if( sockt->session[fd]->flag.ping != 2 ) {
- chr->ping_login_server(fd);
- sockt->session[fd]->flag.ping = 2;
- }
- }
-
- while (RFIFOREST(fd) >= 2) {
- uint16 command = RFIFOW(fd,0);
-
- if (( (HPM->packets[hpParse_FromLogin])._len_ ) > 0) {
- int result = HPM->parse_packets(fd,command,hpParse_FromLogin);
- if (result == 1)
- continue;
- if (result == 2)
- return 0;
- }
-
- switch (command) {
-
- case 0x2711:
- if (RFIFOREST(fd) < 3)
- return 0;
- if (chr->parse_fromlogin_connection_state(fd))
- return 0;
- break;
-
-
- case 0x2713:
- if (RFIFOREST(fd) < 33)
- return 0;
- {
- chr->parse_fromlogin_auth_state(fd);
- }
- break;
-
- case 0x2717:
- {
- if (RFIFOREST(fd) < 72)
- return 0;
- chr->parse_fromlogin_account_data(fd);
- }
- break;
-
-
- case 0x2718:
- if (RFIFOREST(fd) < 2)
- return 0;
- chr->parse_fromlogin_login_pong(fd);
- break;
-
-
- case 0x2723:
- if (RFIFOREST(fd) < 7)
- return 0;
- {
- if (chr->parse_fromlogin_changesex_reply(fd))
- return 0;
- }
- break;
-
-
- case 0x3804:
- if (RFIFOREST(fd) < 4 || RFIFOREST(fd) < RFIFOW(fd,2))
- return 0;
- chr->parse_fromlogin_account_reg2(fd);
- break;
-
-
- case 0x2731:
- if (RFIFOREST(fd) < 11)
- return 0;
- chr->parse_fromlogin_ban(fd);
- break;
-
-
- case 0x2734:
- if (RFIFOREST(fd) < 6)
- return 0;
- {
- chr->parse_fromlogin_kick(fd);
- }
- break;
-
-
- case 0x2735:
- {
- chr->parse_fromlogin_update_ip(fd);
- }
- break;
-
- case 0x2736:
- if (RFIFOREST(fd) < 18)
- return 0;
-
- chr->parse_fromlogin_accinfo2_failed(fd);
- break;
-
- case 0x2737:
- if (RFIFOREST(fd) < 183)
- return 0;
-
- chr->parse_fromlogin_accinfo2_ok(fd);
- break;
-
- default:
- (showmsg->showError(("Unknown packet 0x%04x received from login-server, disconnecting.\n"), command));
- sockt->eof(fd);
- return 0;
- }
- }
-
- RFIFOFLUSH(fd);
- return 0;
-}
-
-int char_request_accreg2(int account_id, int char_id)
-{
- if (chr->login_fd > 0) {
- WFIFOHEAD(chr->login_fd,10);
- WFIFOW(chr->login_fd,0) = 0x272e;
- WFIFOL(chr->login_fd,2) = account_id;
- WFIFOL(chr->login_fd,6) = char_id;
- WFIFOSET(chr->login_fd,10);
- return 1;
- }
- return 0;
-}
-
-
-
-
-void char_global_accreg_to_login_start (int account_id, int char_id) {
- WFIFOHEAD(chr->login_fd, 60000 + 300);
- WFIFOW(chr->login_fd,0) = 0x2728;
- WFIFOW(chr->login_fd,2) = 14;
- WFIFOL(chr->login_fd,4) = account_id;
- WFIFOL(chr->login_fd,8) = char_id;
- WFIFOW(chr->login_fd,12) = 0;
-}
-
-
-
-
-void char_global_accreg_to_login_send (void) {
- WFIFOSET(chr->login_fd, WFIFOW(chr->login_fd,2));
-}
-
-
-
-
-void char_global_accreg_to_login_add (const char *key, unsigned int index, intptr_t val,
-# 2655 "../../../server-code/src/char/char.c" 3 4
- _Bool
-# 2655 "../../../server-code/src/char/char.c"
- is_string) {
- int nlen = WFIFOW(chr->login_fd,2);
- size_t len = strlen(key)+1;
-
- WFIFOB(chr->login_fd, nlen) = (unsigned char)len;
- nlen += 1;
-
- (strlib->safestrncpy_((WFIFOP(chr->login_fd,nlen)),(key),(len)));
- nlen += len;
-
- WFIFOL(chr->login_fd, nlen) = index;
- nlen += 4;
-
- if( is_string ) {
- WFIFOB(chr->login_fd, nlen) = val ? 2 : 3;
- nlen += 1;
-
- if( val ) {
- char *sval = (char*)val;
- len = strlen(sval)+1;
-
- WFIFOB(chr->login_fd, nlen) = (unsigned char)len;
- nlen += 1;
-
- (strlib->safestrncpy_((WFIFOP(chr->login_fd,nlen)),(sval),(len)));
- nlen += len;
- }
- } else {
- WFIFOB(chr->login_fd, nlen) = val ? 0 : 1;
- nlen += 1;
-
- if( val ) {
- WFIFOL(chr->login_fd, nlen) = (int)val;
- nlen += 4;
- }
- }
-
- WFIFOW(chr->login_fd,12) += 1;
-
- WFIFOW(chr->login_fd,2) = nlen;
- if( WFIFOW(chr->login_fd,2) > 60000 ) {
- int account_id = WFIFOL(chr->login_fd,4), char_id = WFIFOL(chr->login_fd,8);
- chr->global_accreg_to_login_send();
- chr->global_accreg_to_login_start(account_id,char_id);
- }
-}
-
-void char_read_fame_list(void) {
- int i;
- char* data;
- size_t len;
-
-
- memset(smith_fame_list, 0, sizeof(smith_fame_list));
- memset(chemist_fame_list, 0, sizeof(chemist_fame_list));
- memset(taekwon_fame_list, 0, sizeof(taekwon_fame_list));
-
- if( (-1) == SQL->Query(inter->sql_handle, "SELECT `char_id`,`fame`,`name` FROM `%s` WHERE `fame`>0 AND (`class`='%d' OR `class`='%d' OR `class`='%d' OR `class`='%d' OR `class`='%d' OR `class`='%d') ORDER BY `fame` DESC LIMIT 0,%d", char_db, JOB_BLACKSMITH, JOB_WHITESMITH, JOB_BABY_BLACKSMITH, JOB_MECHANIC, JOB_MECHANIC_T, JOB_BABY_MECHANIC, fame_list_size_smith) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 2713));
- for( i = 0; i < fame_list_size_smith && 0 == SQL->NextRow(inter->sql_handle); ++i )
- {
-
- SQL->GetData(inter->sql_handle, 0, &data,
-# 2717 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 2717 "../../../server-code/src/char/char.c"
- );
- smith_fame_list[i].id = atoi(data);
-
- SQL->GetData(inter->sql_handle, 1, &data, &len);
- smith_fame_list[i].fame = atoi(data);
-
- SQL->GetData(inter->sql_handle, 2, &data, &len);
- memcpy(smith_fame_list[i].name, data, (((len) < ((23 + 1))) ? (len) : ((23 + 1))));
- }
-
- if( (-1) == SQL->Query(inter->sql_handle, "SELECT `char_id`,`fame`,`name` FROM `%s` WHERE `fame`>0 AND (`class`='%d' OR `class`='%d' OR `class`='%d' OR `class`='%d' OR `class`='%d' OR `class`='%d') ORDER BY `fame` DESC LIMIT 0,%d", char_db, JOB_ALCHEMIST, JOB_CREATOR, JOB_BABY_ALCHEMIST, JOB_GENETIC, JOB_GENETIC_T, JOB_BABY_GENETIC, fame_list_size_chemist) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 2728));
- for( i = 0; i < fame_list_size_chemist && 0 == SQL->NextRow(inter->sql_handle); ++i )
- {
-
- SQL->GetData(inter->sql_handle, 0, &data,
-# 2732 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 2732 "../../../server-code/src/char/char.c"
- );
- chemist_fame_list[i].id = atoi(data);
-
- SQL->GetData(inter->sql_handle, 1, &data, &len);
- chemist_fame_list[i].fame = atoi(data);
-
- SQL->GetData(inter->sql_handle, 2, &data, &len);
- memcpy(chemist_fame_list[i].name, data, (((len) < ((23 + 1))) ? (len) : ((23 + 1))));
- }
-
- if( (-1) == SQL->Query(inter->sql_handle, "SELECT `char_id`,`fame`,`name` FROM `%s` WHERE `fame`>0 AND (`class`='%d') ORDER BY `fame` DESC LIMIT 0,%d", char_db, JOB_TAEKWON, fame_list_size_taekwon) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 2743));
- for( i = 0; i < fame_list_size_taekwon && 0 == SQL->NextRow(inter->sql_handle); ++i )
- {
-
- SQL->GetData(inter->sql_handle, 0, &data,
-# 2747 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 2747 "../../../server-code/src/char/char.c"
- );
- taekwon_fame_list[i].id = atoi(data);
-
- SQL->GetData(inter->sql_handle, 1, &data, &len);
- taekwon_fame_list[i].fame = atoi(data);
-
- SQL->GetData(inter->sql_handle, 2, &data, &len);
- memcpy(taekwon_fame_list[i].name, data, (((len) < ((23 + 1))) ? (len) : ((23 + 1))));
- }
- SQL->FreeResult(inter->sql_handle);
-}
-
-
-int char_send_fame_list(int fd) {
- int i, len = 8;
- unsigned char buf[32000];
-
- WBUFW(buf,0) = 0x2b1b;
-
- for(i = 0; i < fame_list_size_smith && smith_fame_list[i].id; i++) {
- memcpy(WBUFP(buf, len), &smith_fame_list[i], sizeof(struct fame_list));
- len += sizeof(struct fame_list);
- }
-
- WBUFW(buf,6) = len;
-
- for(i = 0; i < fame_list_size_chemist && chemist_fame_list[i].id; i++) {
- memcpy(WBUFP(buf, len), &chemist_fame_list[i], sizeof(struct fame_list));
- len += sizeof(struct fame_list);
- }
-
- WBUFW(buf,4) = len;
-
- for(i = 0; i < fame_list_size_taekwon && taekwon_fame_list[i].id; i++) {
- memcpy(WBUFP(buf, len), &taekwon_fame_list[i], sizeof(struct fame_list));
- len += sizeof(struct fame_list);
- }
-
- WBUFW(buf,2) = len;
-
- if (fd != -1)
- mapif->send(fd, buf, len);
- else
- mapif->sendall(buf, len);
-
- return 0;
-}
-
-void char_update_fame_list(int type, int index, int fame) {
- unsigned char buf[8];
- WBUFW(buf,0) = 0x2b22;
- WBUFB(buf,2) = type;
- WBUFB(buf,3) = index;
- WBUFL(buf,4) = fame;
- mapif->sendall(buf, 8);
-}
-
-
-
-int char_loadName(int char_id, char* name)
-{
- char* data;
- size_t len;
-
- if( (-1) == SQL->Query(inter->sql_handle, "SELECT `name` FROM `%s` WHERE `char_id`='%d'", char_db, char_id) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 2812));
- else if( 0 == SQL->NextRow(inter->sql_handle) )
- {
- SQL->GetData(inter->sql_handle, 0, &data, &len);
- (strlib->safestrncpy_((name),(data),((23 + 1))));
- return 1;
- }
- else
- {
- (strlib->safestrncpy_((name),(unknown_char_name),((23 + 1))));
- }
- return 0;
-}
-
-
-void mapif_server_init(int id)
-{
-
- chr->server[id].fd = -1;
-}
-
-
-void mapif_server_destroy(int id)
-{
- if( chr->server[id].fd == -1 )
- {
- sockt->close(chr->server[id].fd);
- chr->server[id].fd = -1;
- }
-}
-
-
-
-void mapif_server_reset(int id)
-{
- int i,j;
- unsigned char buf[16384];
- int fd = chr->server[id].fd;
-
- WBUFW(buf,0) = 0x2b20;
- WBUFL(buf,4) = htonl(chr->server[id].ip);
- WBUFW(buf,8) = htons(chr->server[id].port);
- j = 0;
- for (i = 0; i < ( (chr->server[id].maps)._len_ ); i++) {
- uint16 m = ( ( (chr->server[id].maps)._data_ )[i] );
- if (m != 0)
- WBUFW(buf,10+(j++)*4) = m;
- }
- if (j > 0) {
- WBUFW(buf,2) = j * 4 + 10;
- mapif->sendallwos(fd, buf, WBUFW(buf,2));
- }
- if( (-1) == SQL->Query(inter->sql_handle, "DELETE FROM `%s` WHERE `index`='%d'", ragsrvinfo_db, chr->server[id].fd) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 2865));
- chr->online_char_db->foreach(chr->online_char_db,chr->db_setoffline,id);
- mapif->server_destroy(id);
- mapif->server_init(id);
-}
-
-
-void mapif_on_disconnect(int id)
-{
- (showmsg->showStatus(("Map-server #%d has disconnected.\n"), id));
- mapif->server_reset(id);
-}
-
-void mapif_on_parse_accinfo(int account_id, int u_fd, int u_aid, int u_group, int map_fd) {
- do { if (( (chr->login_fd > 0) ?
-# 2879 "../../../server-code/src/char/char.c" 3 4
-0
-# 2879 "../../../server-code/src/char/char.c"
-: (nullpo->assert_report("../../../server-code/src/char/char.c", 2879, __func__, "chr->login_fd > 0", "failed assertion"),
-# 2879 "../../../server-code/src/char/char.c" 3 4
-1
-# 2879 "../../../server-code/src/char/char.c"
-) )) return; } while(0);
- WFIFOHEAD(chr->login_fd,22);
- WFIFOW(chr->login_fd,0) = 0x2740;
- WFIFOL(chr->login_fd,2) = account_id;
- WFIFOL(chr->login_fd,6) = u_fd;
- WFIFOL(chr->login_fd,10) = u_aid;
- WFIFOL(chr->login_fd,14) = u_group;
- WFIFOL(chr->login_fd,18) = map_fd;
- WFIFOSET(chr->login_fd,22);
-}
-
-void char_parse_frommap_datasync(int fd)
-{
- sockt->datasync(fd,
-# 2892 "../../../server-code/src/char/char.c" 3 4
- 0
-# 2892 "../../../server-code/src/char/char.c"
- );
- RFIFOSKIP(fd,RFIFOW(fd,2));
-}
-
-void char_parse_frommap_skillid2idx(int fd)
-{
- int i;
- int j = RFIFOW(fd, 2) - 4;
-
- memset(&skillid2idx, 0, sizeof(skillid2idx));
- if( j )
- j /= 4;
- for(i = 0; i < j; i++) {
- if( RFIFOW(fd, 4 + (i*4)) > 10015 ) {
- (showmsg->showWarning(("Error skillid2dx[%d] = %d failed, %d is higher than MAX_SKILL_ID (%d)\n"),RFIFOW(fd, 4 + (i*4)), RFIFOW(fd, 6 + (i*4)),RFIFOW(fd, 4 + (i*4)),10015));
- continue;
- }
- skillid2idx[RFIFOW(fd, 4 + (i*4))] = RFIFOW(fd, 6 + (i*4));
- }
- RFIFOSKIP(fd, RFIFOW(fd, 2));
-}
-
-void char_map_received_ok(int fd)
-{
- WFIFOHEAD(fd, 3 + (23 + 1));
- WFIFOW(fd,0) = 0x2afb;
- WFIFOB(fd,2) = 0;
- memcpy(WFIFOP(fd,3), wisp_server_name, (23 + 1));
- WFIFOSET(fd,3+(23 + 1));
-}
-
-void char_send_maps(int fd, int id, int j)
-{
- int k,i;
-
- if (j == 0) {
- (showmsg->showWarning(("Map-server %d has NO maps.\n"), id));
- } else {
- unsigned char buf[16384];
-
- WBUFW(buf,0) = 0x2b04;
- WBUFW(buf,2) = j * 4 + 10;
- WBUFL(buf,4) = htonl(chr->server[id].ip);
- WBUFW(buf,8) = htons(chr->server[id].port);
- memcpy(WBUFP(buf,10), RFIFOP(fd,4), j * 4);
- mapif->sendallwos(fd, buf, WBUFW(buf,2));
- }
-
- for(k = 0; k < ( (int)(sizeof(chr->server)/sizeof((chr->server)[0])) ); k++) {
- if (chr->server[k].fd > 0 && k != id) {
- WFIFOHEAD(fd,10 + 4 * ( (chr->server[k].maps)._len_ ));
- WFIFOW(fd,0) = 0x2b04;
- WFIFOL(fd,4) = htonl(chr->server[k].ip);
- WFIFOW(fd,8) = htons(chr->server[k].port);
- j = 0;
- for(i = 0; i < ( (chr->server[k].maps)._len_ ); i++) {
- uint16 m = ( ( (chr->server[k].maps)._data_ )[i] );
- if (m != 0)
- WFIFOW(fd,10+(j++)*4) = m;
- }
- if (j > 0) {
- WFIFOW(fd,2) = j * 4 + 10;
- WFIFOSET(fd,WFIFOW(fd,2));
- }
- }
- }
-}
-
-void char_parse_frommap_map_names(int fd, int id)
-{
- int i;
-
- do { if (( (chr->server[id].maps)._max_ ) > 0) { (iMalloc->free((( (chr->server[id].maps)._data_ )),"../../../server-code/src/char/char.c", 2964, __func__)); ( (chr->server[id].maps)._data_ ) =
-# 2964 "../../../server-code/src/char/char.c" 3 4
-((void *)0)
-# 2964 "../../../server-code/src/char/char.c"
-; ( (chr->server[id].maps)._max_ ) = 0; ( (chr->server[id].maps)._len_ ) = 0; } } while(
-# 2964 "../../../server-code/src/char/char.c" 3 4
-0
-# 2964 "../../../server-code/src/char/char.c"
-);
- do { int _empty_ = ( (chr->server[id].maps)._max_ )-( (chr->server[id].maps)._len_ ); if (((RFIFOW(fd, 2) - 4) / 4) > _empty_) { while (((RFIFOW(fd, 2) - 4) / 4) > _empty_) _empty_ += (1); do { if ((_empty_+( (chr->server[id].maps)._len_ )) > ( (chr->server[id].maps)._max_ )) { if (( (chr->server[id].maps)._max_ ) == 0) ( (chr->server[id].maps)._data_ ) = (iMalloc->malloc(((_empty_+( (chr->server[id].maps)._len_ ))*sizeof(( ( ( (chr->server[id].maps)._data_ )[0] ) ))),"../../../server-code/src/char/char.c", 2965, __func__)); else ( (chr->server[id].maps)._data_ ) = (iMalloc->realloc((( (chr->server[id].maps)._data_ )),((_empty_+( (chr->server[id].maps)._len_ ))*sizeof(( ( ( (chr->server[id].maps)._data_ )[0] ) ))),"../../../server-code/src/char/char.c", 2965, __func__)); memset(( (chr->server[id].maps)._data_ )+( (chr->server[id].maps)._len_ ), 0, (( (chr->server[id].maps)._max_ )-( (chr->server[id].maps)._len_ ))*sizeof(( ( ( (chr->server[id].maps)._data_ )[0] ) ))); ( (chr->server[id].maps)._max_ ) = (_empty_+( (chr->server[id].maps)._len_ )); } else if ((_empty_+( (chr->server[id].maps)._len_ )) == 0 && ( (chr->server[id].maps)._max_ ) > 0) { (iMalloc->free((( (chr->server[id].maps)._data_ )),"../../../server-code/src/char/char.c", 2965, __func__)); ( (chr->server[id].maps)._data_ ) =
-# 2965 "../../../server-code/src/char/char.c" 3 4
-((void *)0)
-# 2965 "../../../server-code/src/char/char.c"
-; ( (chr->server[id].maps)._max_ ) = 0; ( (chr->server[id].maps)._len_ ) = 0; } else if ((_empty_+( (chr->server[id].maps)._len_ )) < ( (chr->server[id].maps)._max_ )) { ( (chr->server[id].maps)._data_ ) = (iMalloc->realloc((( (chr->server[id].maps)._data_ )),((_empty_+( (chr->server[id].maps)._len_ ))*sizeof(( ( ( (chr->server[id].maps)._data_ )[0] ) ))),"../../../server-code/src/char/char.c", 2965, __func__)); ( (chr->server[id].maps)._max_ ) = (_empty_+( (chr->server[id].maps)._len_ )); if ((_empty_+( (chr->server[id].maps)._len_ )) - ( (chr->server[id].maps)._len_ ) > 0) ( (chr->server[id].maps)._len_ ) = (_empty_+( (chr->server[id].maps)._len_ )); } } while(
-# 2965 "../../../server-code/src/char/char.c" 3 4
-0
-# 2965 "../../../server-code/src/char/char.c"
-); } } while(
-# 2965 "../../../server-code/src/char/char.c" 3 4
-0
-# 2965 "../../../server-code/src/char/char.c"
-);
- for (i = 4; i < RFIFOW(fd,2); i += 4) {
- do { ( ( (chr->server[id].maps)._data_ )[( (chr->server[id].maps)._len_ )] ) = (RFIFOW(fd,i)); ++( (chr->server[id].maps)._len_ ); }while(
-# 2967 "../../../server-code/src/char/char.c" 3 4
- 0
-# 2967 "../../../server-code/src/char/char.c"
- );
- }
-
- (showmsg->showStatus(("Map-Server %d connected: %d maps, from IP %u.%u.%u.%u port %d.\n"), id, (int)( (chr->server[id].maps)._len_ ), CONVIP(chr->server[id].ip), chr->server[id].port))
- ;
- (showmsg->showStatus(("Map-server %d loading complete.\n"), id));
-
-
- chr->map_received_ok(fd);
- chr->send_fame_list(fd);
- chr->send_maps(fd, id, (int)( (chr->server[id].maps)._len_ ));
- RFIFOSKIP(fd,RFIFOW(fd,2));
-}
-
-void char_send_scdata(int fd, int aid, int cid)
-{
-
- if( (-1) == SQL->Query(inter->sql_handle, "SELECT `type`, `tick`, `val1`, `val2`, `val3`, `val4` "
- "FROM `%s` WHERE `account_id` = '%d' AND `char_id`='%d'",
- scdata_db, aid, cid) )
- {
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 2988));
- return;
- }
- if( SQL->NumRows(inter->sql_handle) > 0 ) {
- struct status_change_data scdata;
- int count;
- char* data;
-
- memset(&scdata, 0, sizeof(scdata));
- WFIFOHEAD(fd,14+50*sizeof(struct status_change_data));
- WFIFOW(fd,0) = 0x2b1d;
- WFIFOL(fd,4) = aid;
- WFIFOL(fd,8) = cid;
- for( count = 0; count < 50 && 0 == SQL->NextRow(inter->sql_handle); ++count )
- {
- SQL->GetData(inter->sql_handle, 0, &data,
-# 3003 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 3003 "../../../server-code/src/char/char.c"
- ); scdata.type = atoi(data);
- SQL->GetData(inter->sql_handle, 1, &data,
-# 3004 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 3004 "../../../server-code/src/char/char.c"
- ); scdata.tick = atoi(data);
- SQL->GetData(inter->sql_handle, 2, &data,
-# 3005 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 3005 "../../../server-code/src/char/char.c"
- ); scdata.val1 = atoi(data);
- SQL->GetData(inter->sql_handle, 3, &data,
-# 3006 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 3006 "../../../server-code/src/char/char.c"
- ); scdata.val2 = atoi(data);
- SQL->GetData(inter->sql_handle, 4, &data,
-# 3007 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 3007 "../../../server-code/src/char/char.c"
- ); scdata.val3 = atoi(data);
- SQL->GetData(inter->sql_handle, 5, &data,
-# 3008 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 3008 "../../../server-code/src/char/char.c"
- ); scdata.val4 = atoi(data);
- memcpy(WFIFOP(fd, 14+count*sizeof(struct status_change_data)), &scdata, sizeof(struct status_change_data));
- }
- if (count >= 50)
- (showmsg->showWarning(("Too many status changes for %d:%d, some of them were not loaded.\n"), aid, cid));
- if (count > 0) {
- WFIFOW(fd,2) = 14 + count*sizeof(struct status_change_data);
- WFIFOW(fd,12) = count;
- WFIFOSET(fd,WFIFOW(fd,2));
-
-
- if( (-1) == SQL->Query(inter->sql_handle, "DELETE FROM `%s` WHERE `account_id` = '%d' AND `char_id`='%d'", scdata_db, aid, cid) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 3020));
- }
- } else {
- WFIFOHEAD(fd,14);
- WFIFOW(fd,0) = 0x2b1d;
- WFIFOW(fd,2) = 14;
- WFIFOL(fd,4) = aid;
- WFIFOL(fd,8) = cid;
- WFIFOW(fd,12) = 0;
- WFIFOSET(fd,WFIFOW(fd,2));
- }
- SQL->FreeResult(inter->sql_handle);
-
-}
-
-void char_parse_frommap_request_scdata(int fd)
-{
-
- int aid = RFIFOL(fd,2);
- int cid = RFIFOL(fd,6);
- chr->send_scdata(fd, aid, cid);
-
- RFIFOSKIP(fd, 10);
-}
-
-void char_parse_frommap_set_users_count(int fd, int id)
-{
- if (RFIFOW(fd,2) != chr->server[id].users) {
- chr->server[id].users = RFIFOW(fd,2);
- (showmsg->showInfo(("User Count: %d (Server: %d)\n"), chr->server[id].users, id));
- }
- RFIFOSKIP(fd, 4);
-}
-
-void char_parse_frommap_set_users(int fd, int id)
-{
-
- int i;
-
- chr->server[id].users = RFIFOW(fd,4);
- chr->online_char_db->foreach(chr->online_char_db,chr->db_setoffline,id);
- for(i = 0; i < chr->server[id].users; i++) {
- int aid = RFIFOL(fd,6+i*8);
- int cid = RFIFOL(fd,6+i*8+4);
- struct online_char_data *character = ( DB->data2ptr((chr->online_char_db)->ensure((chr->online_char_db),DB->i2key(aid),(chr->create_online_char_data))) );
- if (character->server > -1 && character->server != id) {
- (showmsg->showNotice(("Set map user: Character (%d:%d) marked on map server %d, but map server %d claims to have (%d:%d) online!\n"), character->account_id, character->char_id, character->server, id, aid, cid))
- ;
- mapif->disconnectplayer(chr->server[character->server].fd, character->account_id, character->char_id, 2);
- }
- character->server = id;
- character->char_id = cid;
- }
-
- RFIFOSKIP(fd,RFIFOW(fd,2));
-}
-
-void char_save_character_ack(int fd, int aid, int cid)
-{
- WFIFOHEAD(fd,10);
- WFIFOW(fd,0) = 0x2b21;
- WFIFOL(fd,2) = aid;
- WFIFOL(fd,6) = cid;
- WFIFOSET(fd,10);
-}
-
-void char_parse_frommap_save_character(int fd, int id)
-{
- int aid = RFIFOL(fd,4), cid = RFIFOL(fd,8), size = RFIFOW(fd,2);
- struct online_char_data* character;
-
- if (size - 13 != sizeof(struct mmo_charstatus)) {
- (showmsg->showError(("parse_from_map (save-char): Size mismatch! %d != %""z" "u""\n"), size-13, sizeof(struct mmo_charstatus)));
- RFIFOSKIP(fd,size);
- return;
- }
-
- if (RFIFOB(fd,12)
- || ( (character = (struct online_char_data*)( DB->data2ptr((chr->online_char_db)->get((chr->online_char_db),DB->i2key(aid))) )) !=
-# 3098 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-
-# 3099 "../../../server-code/src/char/char.c"
- && character->char_id == cid)
- ) {
- struct mmo_charstatus char_dat;
- memcpy(&char_dat, RFIFOP(fd,13), sizeof(struct mmo_charstatus));
- chr->mmo_char_tosql(cid, &char_dat);
- } else {
-
- (showmsg->showError(("parse_from_map (save-char): Received data for non-existing/offline character (%d:%d).\n"), aid, cid));
- chr->set_char_online(id, cid, aid);
- }
-
- if (RFIFOB(fd,12)) {
-
- chr->set_char_offline(cid, aid);
- chr->save_character_ack(fd, aid, cid);
- }
- RFIFOSKIP(fd,size);
-}
-
-
-
-void char_select_ack(int fd, int account_id, uint8 flag)
-{
- WFIFOHEAD(fd,7);
- WFIFOW(fd,0) = 0x2b03;
- WFIFOL(fd,2) = account_id;
- WFIFOB(fd,6) = flag;
- WFIFOSET(fd,7);
-}
-
-void char_parse_frommap_char_select_req(int fd)
-{
- int account_id = RFIFOL(fd,2);
- uint32 login_id1 = RFIFOL(fd,6);
- uint32 login_id2 = RFIFOL(fd,10);
- uint32 ip = RFIFOL(fd,14);
- int32 group_id = RFIFOL(fd, 18);
- RFIFOSKIP(fd,22);
-
- if( core->runflag != CHARSERVER_ST_RUNNING )
- {
- chr->select_ack(fd, account_id, 0);
- }
- else
- {
- struct char_auth_node* node;
-
-
- ((node) = (struct char_auth_node *) (iMalloc->calloc(((1)),(sizeof(struct char_auth_node)),"../../../server-code/src/char/char.c", 3147, __func__)));
- node->account_id = account_id;
- node->char_id = 0;
- node->login_id1 = login_id1;
- node->login_id2 = login_id2;
- node->group_id = group_id;
-
- node->ip = ntohl(ip);
-
-
-
- ( (auth_db)->put((auth_db),DB->i2key(account_id),DB->ptr2data(node),
-# 3158 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 3158 "../../../server-code/src/char/char.c"
- ) );
-
-
- chr->set_char_charselect(account_id);
- chr->select_ack(fd, account_id, 1);
- }
-}
-
-void char_change_map_server_ack(int fd, const uint8 *data,
-# 3166 "../../../server-code/src/char/char.c" 3 4
- _Bool
-# 3166 "../../../server-code/src/char/char.c"
- ok)
-{
- WFIFOHEAD(fd,30);
- WFIFOW(fd,0) = 0x2b06;
- memcpy(WFIFOP(fd,2), data, 28);
- if (!ok)
- WFIFOL(fd,6) = 0;
- WFIFOSET(fd,30);
-}
-
-void char_parse_frommap_change_map_server(int fd)
-{
- int map_id, map_fd = -1;
- struct mmo_charstatus* char_data;
-
- map_id = chr->search_mapserver(RFIFOW(fd,18), ntohl(RFIFOL(fd,24)), ntohs(RFIFOW(fd,28)));
- if (map_id >= 0)
- map_fd = chr->server[map_id].fd;
-
- char_data = (struct mmo_charstatus*)( DB->data2ptr((chr->char_db_)->get((chr->char_db_),DB->ui2key(RFIFOL(fd,14)))) );
- if (char_data ==
-# 3186 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 3186 "../../../server-code/src/char/char.c"
- ) {
-
- struct mmo_charstatus char_dat;
- chr->mmo_char_fromsql(RFIFOL(fd,14), &char_dat,
-# 3189 "../../../server-code/src/char/char.c" 3 4
- 1
-# 3189 "../../../server-code/src/char/char.c"
- );
- char_data = (struct mmo_charstatus*)( DB->data2ptr((chr->char_db_)->get((chr->char_db_),DB->ui2key(RFIFOL(fd,14)))) );
- }
-
- if (core->runflag == CHARSERVER_ST_RUNNING && sockt->session_is_active(map_fd) && char_data) {
-
- struct online_char_data* data;
- struct char_auth_node* node;
-
-
- char_data->last_point.map = RFIFOW(fd,18);
- char_data->last_point.x = RFIFOW(fd,20);
- char_data->last_point.y = RFIFOW(fd,22);
- char_data->sex = RFIFOB(fd,30);
-
-
- ((node) = (struct char_auth_node *) (iMalloc->calloc(((1)),(sizeof(struct char_auth_node)),"../../../server-code/src/char/char.c", 3205, __func__)));
- node->account_id = RFIFOL(fd,2);
- node->char_id = RFIFOL(fd,14);
- node->login_id1 = RFIFOL(fd,6);
- node->login_id2 = RFIFOL(fd,10);
- node->sex = RFIFOB(fd,30);
- node->expiration_time = 0;
- node->ip = ntohl(RFIFOL(fd,31));
- node->group_id = RFIFOL(fd,35);
- node->changing_mapservers = 1;
- ( (auth_db)->put((auth_db),DB->i2key(RFIFOL(fd,2)),DB->ptr2data(node),
-# 3215 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 3215 "../../../server-code/src/char/char.c"
- ) );
-
- data = ( DB->data2ptr((chr->online_char_db)->ensure((chr->online_char_db),DB->i2key(RFIFOL(fd,2)),(chr->create_online_char_data))) );
- data->char_id = char_data->char_id;
- data->server = map_id;
-
-
- chr->change_map_server_ack(fd, RFIFOP(fd,2),
-# 3222 "../../../server-code/src/char/char.c" 3 4
- 1
-# 3222 "../../../server-code/src/char/char.c"
- );
- } else {
- chr->change_map_server_ack(fd, RFIFOP(fd,2),
-# 3224 "../../../server-code/src/char/char.c" 3 4
- 0
-# 3224 "../../../server-code/src/char/char.c"
- );
- }
- RFIFOSKIP(fd,39);
-}
-
-void char_parse_frommap_remove_friend(int fd)
-{
- int char_id = RFIFOL(fd,2);
- int friend_id = RFIFOL(fd,6);
- if( (-1) == SQL->Query(inter->sql_handle, "DELETE FROM `%s` WHERE `char_id`='%d' AND `friend_id`='%d' LIMIT 1",
- friend_db, char_id, friend_id) ) {
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 3235));
- }
- RFIFOSKIP(fd,10);
-}
-
-void char_char_name_ack(int fd, int char_id)
-{
- WFIFOHEAD(fd,30);
- WFIFOW(fd,0) = 0x2b09;
- WFIFOL(fd,2) = char_id;
- chr->loadName(char_id, WFIFOP(fd,6));
- WFIFOSET(fd,30);
-}
-
-void char_parse_frommap_char_name_request(int fd)
-{
- chr->char_name_ack(fd, RFIFOL(fd,2));
- RFIFOSKIP(fd,6);
-}
-
-void char_parse_frommap_change_email(int fd)
-{
- if (chr->login_fd > 0) {
- WFIFOHEAD(chr->login_fd,86);
- memcpy(WFIFOP(chr->login_fd,0), RFIFOP(fd,0),86);
- WFIFOW(chr->login_fd,0) = 0x2722;
- WFIFOSET(chr->login_fd,86);
- }
- RFIFOSKIP(fd, 86);
-}
-
-void mapif_char_ban(int char_id, time_t timestamp)
-{
- unsigned char buf[11];
- WBUFW(buf,0) = 0x2b14;
- WBUFL(buf,2) = char_id;
- WBUFB(buf,6) = 2;
- WBUFL(buf,7) = (unsigned int)timestamp;
- mapif->sendall(buf, 11);
-}
-
-void char_ban(int account_id, int char_id, time_t *unban_time, short year, short month, short day, short hour, short minute, short second)
-{
- time_t timestamp;
- struct tm *tmtime;
- struct SqlStmt *stmt = SQL->StmtMalloc(inter->sql_handle);
-
- do { if (((void)(unban_time),
-# 3282 "../../../server-code/src/char/char.c" 3 4
-0
-# 3282 "../../../server-code/src/char/char.c"
-)) return; } while(0);
-
- if (*unban_time == 0 || *unban_time < time(
-# 3284 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 3284 "../../../server-code/src/char/char.c"
- ))
- timestamp = time(
-# 3285 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 3285 "../../../server-code/src/char/char.c"
- );
- else
- timestamp = *unban_time;
-
- tmtime = localtime(&timestamp);
- tmtime->tm_year = tmtime->tm_year + year;
- tmtime->tm_mon = tmtime->tm_mon + month;
- tmtime->tm_mday = tmtime->tm_mday + day;
- tmtime->tm_hour = tmtime->tm_hour + hour;
- tmtime->tm_min = tmtime->tm_min + minute;
- tmtime->tm_sec = tmtime->tm_sec + second;
- timestamp = mktime(tmtime);
-
- if( 0 != SQL->StmtPrepare(stmt,
- "UPDATE `%s` SET `unban_time` = ? WHERE `char_id` = ? LIMIT 1",
- char_db)
- || 0 != SQL->StmtBindParam(stmt, 0, SQLDT_LONG, &timestamp, sizeof(timestamp))
- || 0 != SQL->StmtBindParam(stmt, 1, SQLDT_INT, &char_id, sizeof(char_id))
- || 0 != SQL->StmtExecute(stmt)
- ) {
- (SQL->StmtShowDebug_((stmt), "../../../server-code/src/char/char.c", 3305));
- }
-
- SQL->StmtFree(stmt);
-
-
- if( timestamp > time(
-# 3311 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 3311 "../../../server-code/src/char/char.c"
- ) ) {
- mapif->char_ban(char_id, timestamp);
-
- chr->disconnect_player(account_id);
- }
-}
-
-void char_unban(int char_id, int *result)
-{
-
- if( (-1) == SQL->Query(inter->sql_handle, "UPDATE `%s` SET `unban_time` = '0' WHERE `char_id` = '%d' LIMIT 1", char_db, char_id) ) {
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 3322));
- if (result)
- *result = 1;
- }
-}
-
-void char_ask_name_ack(int fd, int acc, const char* name, int type, int result)
-{
- do { if (((void)(name),
-# 3330 "../../../server-code/src/char/char.c" 3 4
-0
-# 3330 "../../../server-code/src/char/char.c"
-)) return; } while(0);
- WFIFOHEAD(fd,34);
- WFIFOW(fd,0) = 0x2b0f;
- WFIFOL(fd, 2) = acc;
- (strlib->safestrncpy_((WFIFOP(fd,6)),(name),((23 + 1))));
- WFIFOW(fd,30) = type;
- WFIFOW(fd,32) = result;
- WFIFOSET(fd,34);
-}
-# 3350 "../../../server-code/src/char/char.c"
-int char_changecharsex(int char_id, int sex)
-{
- int class_ = 0, guild_id = 0, account_id = 0;
- char *data;
-
-
- if ((-1) == SQL->Query(inter->sql_handle, "SELECT `account_id`,`class`,`guild_id` FROM `%s` WHERE `char_id` = '%d'", char_db, char_id)) {
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 3357));
- return 1;
- }
- if (SQL->NumRows(inter->sql_handle) != 1 || (-1) == SQL->NextRow(inter->sql_handle)) {
- SQL->FreeResult(inter->sql_handle);
- return 1;
- }
- SQL->GetData(inter->sql_handle, 0, &data,
-# 3364 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 3364 "../../../server-code/src/char/char.c"
- ); account_id = atoi(data);
- SQL->GetData(inter->sql_handle, 1, &data,
-# 3365 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 3365 "../../../server-code/src/char/char.c"
- ); class_ = atoi(data);
- SQL->GetData(inter->sql_handle, 2, &data,
-# 3366 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 3366 "../../../server-code/src/char/char.c"
- ); guild_id = atoi(data);
- SQL->FreeResult(inter->sql_handle);
-
- if ((-1) == SQL->Query(inter->sql_handle, "UPDATE `%s` SET `sex` = '%c' WHERE `char_id` = '%d'", char_db, sex == SEX_MALE ? 'M' : 'F', char_id)) {
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 3370));
- return 1;
- }
- char_change_sex_sub(sex, account_id, char_id, class_, guild_id);
-
-
- chr->disconnect_player(account_id);
-
-
- chr->changesex(account_id, sex);
- return 0;
-}
-
-void char_parse_frommap_change_account(int fd)
-{
- int result = 0;
- char esc_name[(23 + 1)*2+1];
-
- int acc = RFIFOL(fd,2);
- const char *name = RFIFOP(fd,6);
- int type = RFIFOW(fd,30);
- short year = 0, month = 0, day = 0, hour = 0, minute = 0, second = 0;
- int sex = SEX_MALE;
- if (type == 2 || type == 6) {
- year = RFIFOW(fd,32);
- month = RFIFOW(fd,34);
- day = RFIFOW(fd,36);
- hour = RFIFOW(fd,38);
- minute = RFIFOW(fd,40);
- second = RFIFOW(fd,42);
- } else if (type == 8) {
- sex = RFIFOB(fd, 32);
- }
- RFIFOSKIP(fd,44);
-
- SQL->EscapeStringLen(inter->sql_handle, esc_name, name, (strlib->strnlen_((name),((23 + 1)))));
-
- if((-1) == SQL->Query(inter->sql_handle, "SELECT `account_id`,`char_id`,`unban_time` FROM `%s` WHERE `name` = '%s'", char_db, esc_name)) {
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 3408));
- } else if (SQL->NumRows(inter->sql_handle) == 0) {
- SQL->FreeResult(inter->sql_handle);
- result = 1;
- } else if (0 != SQL->NextRow(inter->sql_handle)) {
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 3413));
- SQL->FreeResult(inter->sql_handle);
- result = 1;
- } else {
- int account_id, char_id;
- char *data;
- time_t unban_time;
-
- SQL->GetData(inter->sql_handle, 0, &data,
-# 3421 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 3421 "../../../server-code/src/char/char.c"
- ); account_id = atoi(data);
- SQL->GetData(inter->sql_handle, 1, &data,
-# 3422 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 3422 "../../../server-code/src/char/char.c"
- ); char_id = atoi(data);
- SQL->GetData(inter->sql_handle, 2, &data,
-# 3423 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 3423 "../../../server-code/src/char/char.c"
- ); unban_time = atol(data);
- SQL->FreeResult(inter->sql_handle);
-
- if( chr->login_fd <= 0 ) {
- result = 3;
-
-
-
-
- } else {
- switch (type) {
- case CHAR_ASK_NAME_BLOCK:
- loginif->block_account(account_id, 5);
- break;
- case CHAR_ASK_NAME_BAN:
- loginif->ban_account(account_id, year, month, day, hour, minute, second);
- break;
- case CHAR_ASK_NAME_UNBLOCK:
- loginif->block_account(account_id, 0);
- break;
- case CHAR_ASK_NAME_UNBAN:
- loginif->unban_account(account_id);
- break;
- case CHAR_ASK_NAME_CHANGESEX:
- loginif->changesex(account_id);
- break;
- case CHAR_ASK_NAME_CHARBAN:
-
- chr->ban(account_id, char_id, &unban_time, year, month, day, hour, minute, second);
- break;
- case CHAR_ASK_NAME_CHARUNBAN:
- chr->unban(char_id, &result);
- break;
- case CHAR_ASK_NAME_CHANGECHARSEX:
- result = chr->changecharsex(char_id, sex);
- break;
- }
- }
- }
-
-
- if (acc != -1 && type != CHAR_ASK_NAME_CHANGESEX && type != CHAR_ASK_NAME_CHANGECHARSEX) {
- chr->ask_name_ack(fd, acc, name, type, result);
- }
-}
-
-void char_parse_frommap_fame_list(int fd)
-{
- int cid = RFIFOL(fd, 2);
- int fame = RFIFOL(fd, 6);
- char type = RFIFOB(fd, 10);
- int size;
- struct fame_list* list;
- int player_pos;
- int fame_pos;
-
- switch(type) {
- case RANKTYPE_BLACKSMITH: size = fame_list_size_smith; list = smith_fame_list; break;
- case RANKTYPE_ALCHEMIST: size = fame_list_size_chemist; list = chemist_fame_list; break;
- case RANKTYPE_TAEKWON: size = fame_list_size_taekwon; list = taekwon_fame_list; break;
- default: size = 0; list =
-# 3483 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 3483 "../../../server-code/src/char/char.c"
- ; break;
- }
-
- if (!list) {
- RFIFOSKIP(fd, 11);
- return;
- }
- do { for ((player_pos) = (0); (player_pos) < (size); ++(player_pos)) if (list[player_pos].id == cid) break; } while(
-# 3490 "../../../server-code/src/char/char.c" 3 4
-0
-# 3490 "../../../server-code/src/char/char.c"
-);
- do { for ((fame_pos) = (0); (fame_pos) < (size); ++(fame_pos)) if (list[fame_pos].fame <= fame) break; } while(
-# 3491 "../../../server-code/src/char/char.c" 3 4
-0
-# 3491 "../../../server-code/src/char/char.c"
-);
-
- if( player_pos == size && fame_pos == size )
- ;
- else if( fame_pos == player_pos ) {
-
- list[player_pos].fame = fame;
- chr->update_fame_list(type, player_pos, fame);
- } else {
-
- if( player_pos == size ) {
-
- do { if ((size - 1) != (fame_pos)) { struct fame_list _backup_; memmove(&_backup_, (list)+(size - 1), sizeof(struct fame_list)); if ((size - 1) < (fame_pos)) memmove((list)+(size - 1), (list)+(size - 1)+1, ((fame_pos)-(size - 1))*sizeof(struct fame_list)); else if ((size - 1) > (fame_pos)) memmove((list)+(fame_pos)+1, (list)+(fame_pos), ((size - 1)-(fame_pos))*sizeof(struct fame_list)); memmove((list)+(fame_pos), &_backup_, sizeof(struct fame_list)); } } while(
-# 3503 "../../../server-code/src/char/char.c" 3 4
- 0
-# 3503 "../../../server-code/src/char/char.c"
- );
- list[fame_pos].id = cid;
- list[fame_pos].fame = fame;
- chr->loadName(cid, list[fame_pos].name);
- } else {
-
- if( fame_pos == size )
- --fame_pos;
- do { if ((player_pos) != (fame_pos)) { struct fame_list _backup_; memmove(&_backup_, (list)+(player_pos), sizeof(struct fame_list)); if ((player_pos) < (fame_pos)) memmove((list)+(player_pos), (list)+(player_pos)+1, ((fame_pos)-(player_pos))*sizeof(struct fame_list)); else if ((player_pos) > (fame_pos)) memmove((list)+(fame_pos)+1, (list)+(fame_pos), ((player_pos)-(fame_pos))*sizeof(struct fame_list)); memmove((list)+(fame_pos), &_backup_, sizeof(struct fame_list)); } } while(
-# 3511 "../../../server-code/src/char/char.c" 3 4
- 0
-# 3511 "../../../server-code/src/char/char.c"
- );
- list[fame_pos].fame = fame;
- }
- chr->send_fame_list(-1);
- }
-
- RFIFOSKIP(fd,11);
-}
-
-void char_parse_frommap_divorce_char(int fd)
-{
- chr->divorce_char_sql(RFIFOL(fd,2), RFIFOL(fd,6));
- RFIFOSKIP(fd,10);
-}
-
-void char_parse_frommap_ragsrvinfo(int fd)
-{
- char esc_server_name[sizeof(chr->server_name)*2+1];
-
- SQL->EscapeString(inter->sql_handle, esc_server_name, chr->server_name);
-
- if( (-1) == SQL->Query(inter->sql_handle, "INSERT INTO `%s` SET `index`='%d',`name`='%s',`exp`='%u',`jexp`='%u',`drop`='%u'",
- ragsrvinfo_db, fd, esc_server_name, RFIFOL(fd,2), RFIFOL(fd,6), RFIFOL(fd,10)) )
- {
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 3535));
- }
- RFIFOSKIP(fd,14);
-}
-
-void char_parse_frommap_set_char_offline(int fd)
-{
- chr->set_char_offline(RFIFOL(fd,2),RFIFOL(fd,6));
- RFIFOSKIP(fd,10);
-}
-
-void char_parse_frommap_set_all_offline(int fd, int id)
-{
- chr->set_all_offline(id);
- RFIFOSKIP(fd,2);
-}
-
-void char_parse_frommap_set_char_online(int fd, int id)
-{
- chr->set_char_online(id, RFIFOL(fd,2),RFIFOL(fd,6));
- RFIFOSKIP(fd,10);
-}
-
-void char_parse_frommap_build_fame_list(int fd)
-{
- chr->read_fame_list();
- chr->send_fame_list(-1);
- RFIFOSKIP(fd,2);
-}
-
-void char_parse_frommap_save_status_change_data(int fd)
-{
-
- int aid = RFIFOL(fd, 4);
- int cid = RFIFOL(fd, 8);
- int count = RFIFOW(fd, 12);
-
-
- if( (-1) == SQL->Query(inter->sql_handle, "DELETE FROM `%s` WHERE `account_id` = '%d' AND `char_id`='%d'", scdata_db, aid, cid) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 3574));
-
- if( count > 0 )
- {
- struct status_change_data data;
- StringBuf buf;
- int i;
-
- StrBuf->Init(&buf);
- StrBuf->Printf(&buf, "INSERT INTO `%s` (`account_id`, `char_id`, `type`, `tick`, `val1`, `val2`, `val3`, `val4`) VALUES ", scdata_db);
- for( i = 0; i < count; ++i )
- {
- memcpy (&data, RFIFOP(fd, 14+i*sizeof(struct status_change_data)), sizeof(struct status_change_data));
- if( i > 0 )
- StrBuf->AppendStr(&buf, ", ");
- StrBuf->Printf(&buf, "('%d','%d','%hu','%d','%d','%d','%d','%d')", aid, cid,
- data.type, data.tick, data.val1, data.val2, data.val3, data.val4);
- }
- if( (-1) == SQL->QueryStr(inter->sql_handle, StrBuf->Value(&buf)) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 3593));
- StrBuf->Destroy(&buf);
- }
-
- RFIFOSKIP(fd, RFIFOW(fd, 2));
-}
-
-void char_send_pong(int fd)
-{
- WFIFOHEAD(fd,2);
- WFIFOW(fd,0) = 0x2b24;
- WFIFOSET(fd,2);
-}
-
-void char_parse_frommap_ping(int fd)
-{
- chr->send_pong(fd);
- RFIFOSKIP(fd,2);
-}
-
-void char_map_auth_ok(int fd, int account_id, struct char_auth_node* node, struct mmo_charstatus* cd)
-{
- do { if (((void)(cd),
-# 3615 "../../../server-code/src/char/char.c" 3 4
-0
-# 3615 "../../../server-code/src/char/char.c"
-)) return; } while(0);
- WFIFOHEAD(fd,25 + sizeof(struct mmo_charstatus));
- WFIFOW(fd,0) = 0x2afd;
- WFIFOW(fd,2) = 25 + sizeof(struct mmo_charstatus);
- WFIFOL(fd,4) = account_id;
- if (node)
- {
- WFIFOL(fd,8) = node->login_id1;
- WFIFOL(fd,12) = node->login_id2;
- WFIFOL(fd,16) = (uint32)node->expiration_time;
- WFIFOL(fd,20) = node->group_id;
- WFIFOB(fd,24) = node->changing_mapservers;
- }
- else
- {
- WFIFOL(fd,8) = 0;
- WFIFOL(fd,12) = 0;
- WFIFOL(fd,16) = 0;
- WFIFOL(fd,20) = 0;
- WFIFOB(fd,24) = 0;
- }
- memcpy(WFIFOP(fd,25), cd, sizeof(struct mmo_charstatus));
- WFIFOSET(fd, WFIFOW(fd,2));
-}
-
-void char_map_auth_failed(int fd, int account_id, int char_id, int login_id1, char sex, uint32 ip)
-{
- WFIFOHEAD(fd,19);
- WFIFOW(fd,0) = 0x2b27;
- WFIFOL(fd,2) = account_id;
- WFIFOL(fd,6) = char_id;
- WFIFOL(fd,10) = login_id1;
- WFIFOB(fd,14) = sex;
- WFIFOL(fd,15) = htonl(ip);
- WFIFOSET(fd,19);
-}
-
-void char_parse_frommap_auth_request(int fd, int id)
-{
- struct mmo_charstatus char_dat;
- struct char_auth_node* node;
- struct mmo_charstatus* cd;
-
- int account_id = RFIFOL(fd,2);
- int char_id = RFIFOL(fd,6);
- int login_id1 = RFIFOL(fd,10);
- char sex = RFIFOB(fd,14);
- uint32 ip = ntohl(RFIFOL(fd,15));
- char standalone = RFIFOB(fd, 19);
- RFIFOSKIP(fd,20);
-
- node = (struct char_auth_node*)( DB->data2ptr((auth_db)->get((auth_db),DB->i2key(account_id))) );
- cd = (struct mmo_charstatus*)( DB->data2ptr((chr->char_db_)->get((chr->char_db_),DB->ui2key(char_id))) );
-
- if( cd ==
-# 3669 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 3669 "../../../server-code/src/char/char.c"
- ) {
- chr->mmo_char_fromsql(char_id, &char_dat,
-# 3670 "../../../server-code/src/char/char.c" 3 4
- 1
-# 3670 "../../../server-code/src/char/char.c"
- );
- cd = (struct mmo_charstatus*)( DB->data2ptr((chr->char_db_)->get((chr->char_db_),DB->ui2key(char_id))) );
- }
-
- if( core->runflag == CHARSERVER_ST_RUNNING && cd && standalone ) {
- cd->sex = sex;
-
- chr->map_auth_ok(fd, account_id,
-# 3677 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 3677 "../../../server-code/src/char/char.c"
- , cd);
- chr->set_char_online(id, char_id, account_id);
- return;
- }
-
- if( core->runflag == CHARSERVER_ST_RUNNING &&
- cd !=
-# 3683 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 3683 "../../../server-code/src/char/char.c"
- &&
- node !=
-# 3684 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 3684 "../../../server-code/src/char/char.c"
- &&
- node->account_id == account_id &&
- node->char_id == char_id &&
- node->login_id1 == login_id1
-
- )
- {
- if( cd->sex == 99 )
- cd->sex = sex;
-
- chr->map_auth_ok(fd, account_id, node, cd);
-
- ( (auth_db)->remove((auth_db),DB->i2key(account_id),
-# 3696 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 3696 "../../../server-code/src/char/char.c"
- ) );
- chr->set_char_online(id, char_id, account_id);
- }
- else
- {
- chr->map_auth_failed(fd, account_id, char_id, login_id1, sex, ip);
- }
-}
-
-void char_parse_frommap_update_ip(int fd, int id)
-{
- chr->server[id].ip = ntohl(RFIFOL(fd, 2));
- (showmsg->showInfo(("Updated IP address of map-server #%d to %u.%u.%u.%u.\n"), id, CONVIP(chr->server[id].ip)));
- RFIFOSKIP(fd,6);
-}
-
-void char_parse_frommap_request_stats_report(int fd)
-{
- int sfd;
- struct hSockOpt opt;
- RFIFOSKIP(fd, 2);
-
- opt.silent = 1;
- opt.setTimeo = 1;
-
- if ((sfd = sockt->make_connection(sockt->host2ip("stats.herc.ws"),(uint16)25427,&opt) ) == -1) {
- RFIFOSKIP(fd, RFIFOW(fd,2) );
- RFIFOFLUSH(fd);
- return;
- }
-
- sockt->session[sfd]->flag.server = 1;
- sockt->realloc_fifo(sfd, FIFOSIZE_SERVERLINK, FIFOSIZE_SERVERLINK);
-
- WFIFOHEAD(sfd, RFIFOW(fd,2) );
-
- memcpy(WFIFOP(sfd,0), RFIFOP(fd, 0), RFIFOW(fd,2));
-
- WFIFOSET(sfd, RFIFOW(fd,2) );
-
- do {
- sockt->flush(sfd);
- sleep(1);
- } while( !sockt->session[sfd]->flag.eof && sockt->session[sfd]->wdata_size );
-
- sockt->close(sfd);
-
- RFIFOSKIP(fd, RFIFOW(fd,2) );
- RFIFOFLUSH(fd);
-}
-
-void char_parse_frommap_scdata_update(int fd)
-{
- int account_id = RFIFOL(fd, 2);
- int char_id = RFIFOL(fd, 6);
- int val1 = RFIFOL(fd, 12);
- int val2 = RFIFOL(fd, 16);
- int val3 = RFIFOL(fd, 20);
- int val4 = RFIFOL(fd, 24);
- short type = RFIFOW(fd, 10);
-
- if ((-1) == SQL->Query(inter->sql_handle, "REPLACE INTO `%s`"
- " (`account_id`,`char_id`,`type`,`tick`,`val1`,`val2`,`val3`,`val4`)"
- " VALUES ('%d','%d','%d','%d','%d','%d','%d','%d')",
- scdata_db, account_id, char_id, type, (-1), val1, val2, val3, val4)
- ) {
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 3762));
- }
- RFIFOSKIP(fd, 28);
-}
-
-void char_parse_frommap_scdata_delete(int fd)
-{
- int account_id = RFIFOL(fd, 2);
- int char_id = RFIFOL(fd, 6);
- short type = RFIFOW(fd, 10);
-
- if( (-1) == SQL->Query(inter->sql_handle, "DELETE FROM `%s` WHERE `account_id` = '%d' AND `char_id` = '%d' AND `type` = '%d' LIMIT 1",
- scdata_db, account_id, char_id, type) )
- {
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 3776));
- }
- RFIFOSKIP(fd, 12);
-}
-
-int char_parse_frommap(int fd)
-{
- int id;
-
- do { for ((id) = (0); (id) < (( (int)(sizeof(chr->server)/sizeof((chr->server)[0])) )); ++(id)) if (chr->server[id].fd == fd) break; } while(
-# 3785 "../../../server-code/src/char/char.c" 3 4
-0
-# 3785 "../../../server-code/src/char/char.c"
-);
- if( id == ( (int)(sizeof(chr->server)/sizeof((chr->server)[0])) ) ) {
- (showmsg->showDebug(("chr->parse_frommap: Disconnecting invalid session #%d (is not a map-server)\n"), fd));
- sockt->close(fd);
- return 0;
- }
- if( sockt->session[fd]->flag.eof ) {
- sockt->close(fd);
- chr->server[id].fd = -1;
- mapif->on_disconnect(id);
- return 0;
- }
-
- while (RFIFOREST(fd) >= 2) {
- int packet_id = RFIFOW(fd,0);
- if (( (HPM->packets[hpParse_FromMap])._len_ ) > 0) {
- int result = HPM->parse_packets(fd,packet_id,hpParse_FromMap);
- if (result == 1)
- continue;
- if (result == 2)
- return 0;
- }
-
- switch (packet_id) {
- case 0x2b0a:
- if( RFIFOREST(fd) < RFIFOW(fd, 2) )
- return 0;
- chr->parse_frommap_datasync(fd);
- break;
-
- case 0x2b0b:
- if( RFIFOREST(fd) < RFIFOW(fd, 2) )
- return 0;
- chr->parse_frommap_skillid2idx(fd);
- break;
- case 0x2afa:
- if (RFIFOREST(fd) < 4 || RFIFOREST(fd) < RFIFOW(fd,2))
- return 0;
- chr->parse_frommap_map_names(fd, id);
- break;
-
- case 0x2afc:
- if (RFIFOREST(fd) < 10)
- return 0;
- {
- chr->parse_frommap_request_scdata(fd);
- }
- break;
-
- case 0x2afe:
- if (RFIFOREST(fd) < 4)
- return 0;
- chr->parse_frommap_set_users_count(fd, id);
- break;
-
- case 0x2aff:
- if (RFIFOREST(fd) < 6 || RFIFOREST(fd) < RFIFOW(fd,2))
- return 0;
- {
- chr->parse_frommap_set_users(fd, id);
- }
- break;
-
- case 0x2b01:
- if (RFIFOREST(fd) < 4 || RFIFOREST(fd) < RFIFOW(fd,2))
- return 0;
- {
- chr->parse_frommap_save_character(fd, id);
-
- }
- break;
-
- case 0x2b02:
- if( RFIFOREST(fd) < 22 )
- return 0;
- {
- chr->parse_frommap_char_select_req(fd);
- }
- break;
-
- case 0x2b05:
- if (RFIFOREST(fd) < 39)
- return 0;
- {
- chr->parse_frommap_change_map_server(fd);
- }
- break;
-
- case 0x2b07:
- if (RFIFOREST(fd) < 10)
- return 0;
- {
- chr->parse_frommap_remove_friend(fd);
- }
- break;
-
- case 0x2b08:
- if (RFIFOREST(fd) < 6)
- return 0;
-
- chr->parse_frommap_char_name_request(fd);
- break;
-
- case 0x2b0c:
- if (RFIFOREST(fd) < 86)
- return 0;
- chr->parse_frommap_change_email(fd);
- break;
-
- case 0x2b0e:
- if (RFIFOREST(fd) < 44)
- return 0;
- {
- chr->parse_frommap_change_account(fd);
- }
- break;
-
- case 0x2b10:
- if (RFIFOREST(fd) < 11)
- return 0;
- {
- chr->parse_frommap_fame_list(fd);
- }
- break;
-
-
- case 0x2b11:
- if( RFIFOREST(fd) < 10 )
- return 0;
-
- chr->parse_frommap_divorce_char(fd);
- break;
-
- case 0x2b16:
- if( RFIFOREST(fd) < 14 )
- return 0;
- {
- chr->parse_frommap_ragsrvinfo(fd);
- }
- break;
-
- case 0x2b17:
- if (RFIFOREST(fd) < 6)
- return 0;
- chr->parse_frommap_set_char_offline(fd);
- break;
-
- case 0x2b18:
- chr->parse_frommap_set_all_offline(fd, id);
- break;
-
- case 0x2b19:
- if (RFIFOREST(fd) < 10)
- return 0;
- chr->parse_frommap_set_char_online(fd, id);
- break;
-
- case 0x2b1a:
- if (RFIFOREST(fd) < 2)
- return 0;
- chr->parse_frommap_build_fame_list(fd);
- break;
-
- case 0x2b1c:
- if (RFIFOREST(fd) < 4 || RFIFOREST(fd) < RFIFOW(fd,2))
- return 0;
- {
- chr->parse_frommap_save_status_change_data(fd);
- }
- break;
-
- case 0x2b23:
- chr->parse_frommap_ping(fd);
- break;
-
- case 0x2b26:
- if (RFIFOREST(fd) < 20)
- return 0;
-
- {
- chr->parse_frommap_auth_request(fd, id);
- }
- break;
-
- case 0x2736:
- if (RFIFOREST(fd) < 6) return 0;
- chr->parse_frommap_update_ip(fd, id);
- break;
-
- case 0x3008:
- if( RFIFOREST(fd) < RFIFOW(fd,4) )
- return 0;
- else {
- chr->parse_frommap_request_stats_report(fd);
- }
- break;
-
-
- case 0x2740:
- if( RFIFOREST(fd) < 28 )
- return 0;
- else {
- chr->parse_frommap_scdata_update(fd);
- }
- break;
-
-
- case 0x2741:
- if( RFIFOREST(fd) < 12 )
- return 0;
- else {
- chr->parse_frommap_scdata_delete(fd);
- }
- break;
-
- default:
- {
-
- int r = inter->parse_frommap(fd);
- if (r == 1) break;
- if (r == 2) return 0;
-
-
- (showmsg->showError(("Unknown packet 0x%04x from map server, disconnecting.\n"), RFIFOW(fd,0)));
- sockt->eof(fd);
- return 0;
- }
- }
- }
-
- return 0;
-}
-
-void do_init_mapif(void)
-{
- int i;
- for( i = 0; i < ( (int)(sizeof(chr->server)/sizeof((chr->server)[0])) ); ++i )
- mapif->server_init(i);
-}
-
-void do_final_mapif(void)
-{
- int i;
- for( i = 0; i < ( (int)(sizeof(chr->server)/sizeof((chr->server)[0])) ); ++i )
- mapif->server_destroy(i);
-}
-
-
-
-int char_search_mapserver(unsigned short map, uint32 ip, uint16 port)
-{
- int i, j;
-
- for(i = 0; i < ( (int)(sizeof(chr->server)/sizeof((chr->server)[0])) ); i++)
- {
- if (chr->server[i].fd > 0
- && (ip == (uint32)-1 || chr->server[i].ip == ip)
- && (port == (uint16)-1 || chr->server[i].port == port)
- ) {
- do { for ((j) = (0); (j) < (( (chr->server[i].maps)._len_ )); ++(j)) if (( ( (chr->server[i].maps)._data_ )[j] ) == map) break; } while(
-# 4044 "../../../server-code/src/char/char.c" 3 4
- 0
-# 4044 "../../../server-code/src/char/char.c"
- );
- if (j != ( (chr->server[i].maps)._len_ ))
- return i;
- }
- }
-
- return -1;
-}
-
-
-static int char_mapif_init(int fd)
-{
- return inter->mapif_init(fd);
-}
-# 4066 "../../../server-code/src/char/char.c"
-uint32 char_lan_subnet_check(uint32 ip)
-{
- struct s_subnet lan = {0};
- if (sockt->lan_subnet_check(ip, &lan)) {
- (showmsg->showInfo(("Subnet check [%u.%u.%u.%u]: Matches ""\033[1;36m""%u.%u.%u.%u/%u.%u.%u.%u""\033[0m""\n"), CONVIP(ip), CONVIP(lan.ip & lan.mask), CONVIP(lan.mask)));
- return lan.ip;
- }
- (showmsg->showInfo(("Subnet check [%u.%u.%u.%u]: ""\033[1;36m""WAN""\033[0m""\n"), CONVIP(ip)));
- return 0;
-}
-# 4086 "../../../server-code/src/char/char.c"
-void char_delete2_ack(int fd, int char_id, uint32 result, time_t delete_date)
-{
- WFIFOHEAD(fd,14);
- WFIFOW(fd,0) = 0x828;
- WFIFOL(fd,2) = char_id;
- WFIFOL(fd,6) = result;
-
- WFIFOL(fd,10) = (int)(delete_date - time(
-# 4093 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 4093 "../../../server-code/src/char/char.c"
- ));
-
-
-
-
- WFIFOSET(fd,14);
-}
-
-void char_delete2_accept_actual_ack(int fd, int char_id, uint32 result)
-{
- WFIFOHEAD(fd,10);
- WFIFOW(fd,0) = 0x82a;
- WFIFOL(fd,2) = char_id;
- WFIFOL(fd,6) = result;
- WFIFOSET(fd,10);
-}
-# 4118 "../../../server-code/src/char/char.c"
-void char_delete2_accept_ack(int fd, int char_id, uint32 result)
-{
-
- if( result == 1 ) {
- struct char_session_data* sd = (struct char_session_data*)sockt->session[fd]->session_data;
- chr->mmo_char_send099d(fd, sd);
- }
-
- chr->delete2_accept_actual_ack(fd, char_id, result);
-}
-
-
-
-
-
-void char_delete2_cancel_ack(int fd, int char_id, uint32 result)
-{
- WFIFOHEAD(fd,10);
- WFIFOW(fd,0) = 0x82c;
- WFIFOL(fd,2) = char_id;
- WFIFOL(fd,6) = result;
- WFIFOSET(fd,10);
-}
-
-static void char_delete2_req(int fd, struct char_session_data* sd)
-{
- int char_id, i;
- char* data;
- time_t delete_date;
-
- char_id = RFIFOL(fd,2);
- do { if (((void)(sd),
-# 4149 "../../../server-code/src/char/char.c" 3 4
-0
-# 4149 "../../../server-code/src/char/char.c"
-)) return; } while(0);
-
- do { for ((i) = (0); (i) < (9); ++(i)) if (sd->found_char[i] == char_id) break; } while(
-# 4151 "../../../server-code/src/char/char.c" 3 4
-0
-# 4151 "../../../server-code/src/char/char.c"
-);
- if( i == 9 )
- {
- chr->delete2_ack(fd, char_id, 3, 0);
- return;
- }
-
- if( 0 != SQL->Query(inter->sql_handle, "SELECT `delete_date` FROM `%s` WHERE `char_id`='%d'", char_db, char_id) || 0 != SQL->NextRow(inter->sql_handle) )
- {
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 4160));
- chr->delete2_ack(fd, char_id, 3, 0);
- return;
- }
-
- SQL->GetData(inter->sql_handle, 0, &data,
-# 4165 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 4165 "../../../server-code/src/char/char.c"
- ); delete_date = strtoul(data,
-# 4165 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 4165 "../../../server-code/src/char/char.c"
- , 10);
-
- if( delete_date ) {
- chr->delete2_ack(fd, char_id, 0, 0);
- return;
- }
-
-
-
-
- if (char_aegis_delete) {
- int party_id = 0, guild_id = 0;
- if( 0 != SQL->Query(inter->sql_handle, "SELECT `party_id`, `guild_id` FROM `%s` WHERE `char_id`='%d'", char_db, char_id)
- || 0 != SQL->NextRow(inter->sql_handle)
- ) {
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 4180));
- chr->delete2_ack(fd, char_id, 3, 0);
- return;
- }
- SQL->GetData(inter->sql_handle, 0, &data,
-# 4184 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 4184 "../../../server-code/src/char/char.c"
- ); party_id = atoi(data);
- SQL->GetData(inter->sql_handle, 1, &data,
-# 4185 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 4185 "../../../server-code/src/char/char.c"
- ); guild_id = atoi(data);
-
- if( guild_id )
- {
- chr->delete2_ack(fd, char_id, 4, 0);
- return;
- }
-
- if( party_id )
- {
- chr->delete2_ack(fd, char_id, 5, 0);
- return;
- }
- }
-
-
- delete_date = time(
-# 4201 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 4201 "../../../server-code/src/char/char.c"
- )+char_del_delay;
-
- if( 0 != SQL->Query(inter->sql_handle, "UPDATE `%s` SET `delete_date`='%lu' WHERE `char_id`='%d'", char_db, (unsigned long)delete_date, char_id) )
- {
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 4205));
- chr->delete2_ack(fd, char_id, 3, 0);
- return;
- }
-
- chr->delete2_ack(fd, char_id, 1, delete_date);
-}
-
-static void char_delete2_accept(int fd, struct char_session_data* sd)
-{
- char birthdate[8+1];
- int char_id, i;
- unsigned int base_level;
- char* data;
- time_t delete_date;
-
- do { if (((void)(sd),
-# 4221 "../../../server-code/src/char/char.c" 3 4
-0
-# 4221 "../../../server-code/src/char/char.c"
-)) return; } while(0);
- char_id = RFIFOL(fd,2);
-
- (showmsg->showInfo(("\033[1;31m""Request Char Deletion: ""\033[1;32m""%d (%d)""\033[0m""\n"), sd->account_id, char_id));
-
-
- birthdate[0] = RFIFOB(fd,6);
- birthdate[1] = RFIFOB(fd,7);
- birthdate[2] = '-';
- birthdate[3] = RFIFOB(fd,8);
- birthdate[4] = RFIFOB(fd,9);
- birthdate[5] = '-';
- birthdate[6] = RFIFOB(fd,10);
- birthdate[7] = RFIFOB(fd,11);
- birthdate[8] = 0;
-
- do { for ((i) = (0); (i) < (9); ++(i)) if (sd->found_char[i] == char_id) break; } while(
-# 4237 "../../../server-code/src/char/char.c" 3 4
-0
-# 4237 "../../../server-code/src/char/char.c"
-);
- if( i == 9 )
- {
- chr->delete2_accept_ack(fd, char_id, 3);
- return;
- }
-
- if( 0 != SQL->Query(inter->sql_handle, "SELECT `base_level`,`delete_date` FROM `%s` WHERE `char_id`='%d'", char_db, char_id) || 0 != SQL->NextRow(inter->sql_handle) )
- {
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 4246));
- chr->delete2_accept_ack(fd, char_id, 3);
- return;
- }
-
- SQL->GetData(inter->sql_handle, 0, &data,
-# 4251 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 4251 "../../../server-code/src/char/char.c"
- ); base_level = (unsigned int)strtoul(data,
-# 4251 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 4251 "../../../server-code/src/char/char.c"
- , 10);
- SQL->GetData(inter->sql_handle, 1, &data,
-# 4252 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 4252 "../../../server-code/src/char/char.c"
- ); delete_date = strtoul(data,
-# 4252 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 4252 "../../../server-code/src/char/char.c"
- , 10);
-
- if( !delete_date || delete_date>time(
-# 4254 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 4254 "../../../server-code/src/char/char.c"
- ) )
- {
- chr->delete2_accept_ack(fd, char_id, 4);
- return;
- }
-
- if( strcmp(sd->birthdate+2, birthdate) )
- {
- chr->delete2_accept_ack(fd, char_id, 5);
- return;
- }
-
- if( ( char_del_level > 0 && base_level >= (unsigned int)char_del_level ) || ( char_del_level < 0 && base_level <= (unsigned int)(-char_del_level) ) )
- {
- chr->delete2_accept_ack(fd, char_id, 2);
- return;
- }
-
-
- if( chr->delete_char_sql(char_id) < 0 )
- {
- chr->delete2_accept_ack(fd, char_id, 3);
- return;
- }
-
-
- sd->found_char[i] = -1;
-
- chr->delete2_accept_ack(fd, char_id, 1);
-}
-
-static void char_delete2_cancel(int fd, struct char_session_data* sd)
-{
- int char_id, i;
-
- do { if (((void)(sd),
-# 4289 "../../../server-code/src/char/char.c" 3 4
-0
-# 4289 "../../../server-code/src/char/char.c"
-)) return; } while(0);
- char_id = RFIFOL(fd,2);
-
- do { for ((i) = (0); (i) < (9); ++(i)) if (sd->found_char[i] == char_id) break; } while(
-# 4292 "../../../server-code/src/char/char.c" 3 4
-0
-# 4292 "../../../server-code/src/char/char.c"
-);
- if( i == 9 )
- {
- chr->delete2_cancel_ack(fd, char_id, 2);
- return;
- }
-
-
-
-
- if( 0 != SQL->Query(inter->sql_handle, "UPDATE `%s` SET `delete_date`='0' WHERE `char_id`='%d'", char_db, char_id) )
- {
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 4304));
- chr->delete2_cancel_ack(fd, char_id, 2);
- return;
- }
-
- chr->delete2_cancel_ack(fd, char_id, 1);
-}
-
-void char_send_account_id(int fd, int account_id)
-{
- WFIFOHEAD(fd,4);
- WFIFOL(fd,0) = account_id;
- WFIFOSET(fd,4);
-}
-
-void char_parse_char_connect(int fd, struct char_session_data* sd, uint32 ipl)
-{
- int account_id = RFIFOL(fd,2);
- uint32 login_id1 = RFIFOL(fd,6);
- uint32 login_id2 = RFIFOL(fd,10);
- int sex = RFIFOB(fd,16);
- struct char_auth_node* node;
-
- RFIFOSKIP(fd,17);
-
- (showmsg->showInfo(("request connect - account_id:%d/login_id1:%u/login_id2:%u\n"), account_id, login_id1, login_id2));
-
- if (sd) {
-
-
-
- return;
- }
-
- ((sockt->session[fd]->session_data) = (struct char_session_data *) (iMalloc->calloc(((1)),(sizeof(struct char_session_data)),"../../../server-code/src/char/char.c", 4338, __func__)));
- sd = (struct char_session_data*)sockt->session[fd]->session_data;
- sd->account_id = account_id;
- sd->login_id1 = login_id1;
- sd->login_id2 = login_id2;
- sd->sex = sex;
- sd->auth =
-# 4344 "../../../server-code/src/char/char.c" 3 4
- 0
-# 4344 "../../../server-code/src/char/char.c"
- ;
-
-
- chr->send_account_id(fd, account_id);
-
- if( core->runflag != CHARSERVER_ST_RUNNING ) {
- chr->auth_error(fd, 0);
- return;
- }
-
-
- node = (struct char_auth_node*)( DB->data2ptr((auth_db)->get((auth_db),DB->i2key(account_id))) );
- if( node !=
-# 4356 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 4356 "../../../server-code/src/char/char.c"
- &&
- node->account_id == account_id &&
- node->login_id1 == login_id1 &&
- node->login_id2 == login_id2
- )
- {
-
- if( chr->server_type == CST_MAINTENANCE && node->group_id < char_maintenance_min_group_id ) {
- chr->auth_error(fd, 0);
- return;
- }
-
- if( chr->server_type == CST_PAYING && (time_t)node->expiration_time < time(
-# 4368 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 4368 "../../../server-code/src/char/char.c"
- ) ) {
- chr->auth_error(fd, 0);
- return;
- }
- ( (auth_db)->remove((auth_db),DB->i2key(account_id),
-# 4372 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 4372 "../../../server-code/src/char/char.c"
- ) );
- chr->auth_ok(fd, sd);
- }
- else
- {
- if (chr->login_fd > 0) {
- loginif->auth(fd, sd, ipl);
- } else {
- chr->auth_error(fd, 0);
- }
- }
-}
-
-void char_send_map_info(int fd, int i, uint32 subnet_map_ip, struct mmo_charstatus *cd)
-{
- do { if (((void)(cd),
-# 4387 "../../../server-code/src/char/char.c" 3 4
-0
-# 4387 "../../../server-code/src/char/char.c"
-)) return; } while(0);
- WFIFOHEAD(fd,28);
- WFIFOW(fd,0) = 0x71;
- WFIFOL(fd,2) = cd->char_id;
- mapindex->getmapname_ext(mapindex->id2name((cd->last_point.map),"../../../server-code/src/char/char.c", 4391, __func__), WFIFOP(fd,6));
- WFIFOL(fd,22) = htonl((subnet_map_ip) ? subnet_map_ip : chr->server[i].ip);
- WFIFOW(fd,26) = sockt->ntows(htons(chr->server[i].port));
- WFIFOSET(fd,28);
-}
-
-void char_send_wait_char_server(int fd)
-{
- WFIFOHEAD(fd, 24);
- WFIFOW(fd,0) = 0x840;
- WFIFOW(fd,2) = 24;
- (strlib->safestrncpy_((WFIFOP(fd,4)),("0"),(20)));
- WFIFOSET(fd, 24);
-}
-
-int char_search_default_maps_mapserver(struct mmo_charstatus *cd)
-{
- int i;
- int j;
- do { if (((void)(cd),
-# 4410 "../../../server-code/src/char/char.c" 3 4
-0
-# 4410 "../../../server-code/src/char/char.c"
-)) return(-1); } while(0);
- if ((i = chr->search_mapserver((j=mapindex->name2id("prontera")),-1,-1)) >= 0) {
- cd->last_point.x = 273;
- cd->last_point.y = 354;
- } else if ((i = chr->search_mapserver((j=mapindex->name2id("geffen")),-1,-1)) >= 0) {
- cd->last_point.x = 120;
- cd->last_point.y = 100;
- } else if ((i = chr->search_mapserver((j=mapindex->name2id("morocc")),-1,-1)) >= 0) {
- cd->last_point.x = 160;
- cd->last_point.y = 94;
- } else if ((i = chr->search_mapserver((j=mapindex->name2id("alberta")),-1,-1)) >= 0) {
- cd->last_point.x = 116;
- cd->last_point.y = 57;
- } else if ((i = chr->search_mapserver((j=mapindex->name2id("payon")),-1,-1)) >= 0) {
- cd->last_point.x = 87;
- cd->last_point.y = 117;
- } else if ((i = chr->search_mapserver((j=mapindex->name2id("izlude")),-1,-1)) >= 0) {
- cd->last_point.x = 94;
- cd->last_point.y = 103;
- }
- if (i >= 0)
- {
- cd->last_point.map = j;
- (showmsg->showWarning(("Unable to find map-server for '%s', sending to major city '%s'.\n"), mapindex->id2name((cd->last_point.map),"../../../server-code/src/char/char.c", 4433, __func__), mapindex->id2name((j),"../../../server-code/src/char/char.c", 4433, __func__)));
- }
- return i;
-}
-
-void char_parse_char_select(int fd, struct char_session_data* sd, uint32 ipl) __attribute__((nonnull (2)));
-void char_parse_char_select(int fd, struct char_session_data* sd, uint32 ipl)
-{
- struct mmo_charstatus char_dat;
- struct mmo_charstatus *cd;
- struct char_auth_node* node;
- char* data;
- int char_id;
- int server_id = 0;
- int i;
- int map_fd;
- uint32 subnet_map_ip;
- int slot = RFIFOB(fd,2);
-
- RFIFOSKIP(fd,3);
-
-
- if( pincode->enabled ){
- struct online_char_data* character;
- character = (struct online_char_data*)( DB->data2ptr((chr->online_char_db)->get((chr->online_char_db),DB->i2key(sd->account_id))) );
- if( character && character->pincode_enable == -1){
- chr->auth_error(fd, 0);
- return;
- }
- }
-
-
- do { for ((server_id) = (0); (server_id) < (( (int)(sizeof(chr->server)/sizeof((chr->server)[0])) )); ++(server_id)) if (chr->server[server_id].fd > 0 && ( (chr->server[server_id].maps)._len_ ) > 0) break; } while(
-# 4465 "../../../server-code/src/char/char.c" 3 4
-0
-# 4465 "../../../server-code/src/char/char.c"
-);
-
-
- if( server_id == ( (int)(sizeof(chr->server)/sizeof((chr->server)[0])) ) ) {
- chr->send_wait_char_server(fd);
- return;
- }
-
- if (0 != SQL->Query(inter->sql_handle, "SELECT `char_id` FROM `%s` WHERE `account_id`='%d' AND `char_num`='%d'", char_db, sd->account_id, slot)
- || 0 != SQL->NextRow(inter->sql_handle)
- || 0 != SQL->GetData(inter->sql_handle, 0, &data,
-# 4475 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 4475 "../../../server-code/src/char/char.c"
- )
- ) {
-
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 4478));
- SQL->FreeResult(inter->sql_handle);
- chr->auth_error(fd, 0);
- return;
- }
-
- char_id = atoi(data);
- SQL->FreeResult(inter->sql_handle);
-
-
- if( sd->found_char[slot] == char_id && sd->unban_time[slot] > time(
-# 4488 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 4488 "../../../server-code/src/char/char.c"
- ) ) {
- chr->auth_error(fd, 0);
- return;
- }
-
-
- chr->set_char_online(-2,char_id,sd->account_id);
- if( !chr->mmo_char_fromsql(char_id, &char_dat,
-# 4495 "../../../server-code/src/char/char.c" 3 4
- 1
-# 4495 "../../../server-code/src/char/char.c"
- ) ) {
- chr->set_char_offline(char_id, sd->account_id);
-
- chr->auth_error(fd, 0);
- return;
- }
-
-
- cd = (struct mmo_charstatus *)( DB->data2ptr((chr->char_db_)->get((chr->char_db_),DB->i2key(char_id))) );
- do { if (((void)(cd),
-# 4504 "../../../server-code/src/char/char.c" 3 4
-0
-# 4504 "../../../server-code/src/char/char.c"
-)) return; } while(0);
- if( cd->sex == 99 )
- cd->sex = sd->sex;
-
- if (log_char) {
- char esc_name[(23 + 1)*2+1];
-
- SQL->EscapeStringLen(inter->sql_handle, esc_name, char_dat.name, (strlib->strnlen_((char_dat.name),((23 + 1)))));
- if( (-1) == SQL->Query(inter->sql_handle,
- "INSERT INTO `%s`(`time`, `account_id`, `char_id`, `char_num`, `name`) VALUES (NOW(), '%d', '%d', '%d', '%s')",
- charlog_db, sd->account_id, cd->char_id, slot, esc_name) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 4515));
- }
- (showmsg->showInfo(("Selected char: (Account %d: %d - %s)\n"), sd->account_id, slot, char_dat.name));
-
-
- i = chr->search_mapserver(cd->last_point.map, -1, -1);
-
-
- if (i < 0 || !cd->last_point.map) {
- unsigned short j;
-
- do { for ((j) = (0); (j) < (( (int)(sizeof(chr->server)/sizeof((chr->server)[0])) )); ++(j)) if (chr->server[j].fd >= 0 && ( (chr->server[j].maps)._len_ ) > 0) break; } while(
-# 4526 "../../../server-code/src/char/char.c" 3 4
- 0
-# 4526 "../../../server-code/src/char/char.c"
- );
- if (j == ( (int)(sizeof(chr->server)/sizeof((chr->server)[0])) )) {
- (showmsg->showInfo(("Connection Closed. No map servers available.\n")));
- chr->authfail_fd(fd, 1);
- return;
- }
- i = chr->search_default_maps_mapserver(cd);
- if (i < 0)
- {
- (showmsg->showInfo(("Connection Closed. No map server available that has a major city, and unable to find map-server for '%s'.\n"), mapindex->id2name((cd->last_point.map),"../../../server-code/src/char/char.c", 4535, __func__)));
- chr->authfail_fd(fd, 1);
- return;
- }
- }
-
-
-
- if ((map_fd = chr->server[i].fd) < 1 || sockt->session[map_fd] ==
-# 4543 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 4543 "../../../server-code/src/char/char.c"
- )
- {
- (showmsg->showError(("chr->parse_char: Attempting to write to invalid session %d! Map Server #%d disconnected.\n"), map_fd, i));
- chr->server[i].fd = -1;
- memset(&chr->server[i], 0, sizeof(struct mmo_map_server));
- chr->authfail_fd(fd, 1);
- return;
- }
-
- subnet_map_ip = chr->lan_subnet_check(ipl);
-
- chr->send_map_info(fd, i, subnet_map_ip, cd);
-
-
- ((node) = (struct char_auth_node *) (iMalloc->calloc(((1)),(sizeof(struct char_auth_node)),"../../../server-code/src/char/char.c", 4557, __func__)));
- node->account_id = sd->account_id;
- node->char_id = cd->char_id;
- node->login_id1 = sd->login_id1;
- node->login_id2 = sd->login_id2;
- node->sex = sd->sex;
- node->expiration_time = sd->expiration_time;
- node->group_id = sd->group_id;
- node->ip = ipl;
- ( (auth_db)->put((auth_db),DB->i2key(sd->account_id),DB->ptr2data(node),
-# 4566 "../../../server-code/src/char/char.c" 3 4
-((void *)0)
-# 4566 "../../../server-code/src/char/char.c"
-) );
-}
-
-void char_creation_failed(int fd, int result)
-{
- WFIFOHEAD(fd,3);
- WFIFOW(fd,0) = 0x6e;
-
-
-
-
- switch (result) {
- case -1: WFIFOB(fd,2) = 0x00; break;
- case -2: WFIFOB(fd,2) = 0xFF; break;
- case -3: WFIFOB(fd,2) = 0x01; break;
- case -4: WFIFOB(fd,2) = 0x03; break;
- case -5: WFIFOB(fd,2) = 0x02; break;
-
- default:
- (showmsg->showWarning(("chr->parse_char: Unknown result received from chr->make_new_char_sql!\n")));
- WFIFOB(fd,2) = 0xFF;
- break;
- }
- WFIFOSET(fd,3);
-}
-
-void char_creation_ok(int fd, struct mmo_charstatus *char_dat)
-{
- int len;
-
-
- WFIFOHEAD(fd,2+150);
- WFIFOW(fd,0) = 0x6d;
- len = 2 + chr->mmo_char_tobuf(WFIFOP(fd,2), char_dat);
- WFIFOSET(fd,len);
-}
-
-void char_parse_char_create_new_char(int fd, struct char_session_data* sd) __attribute__((nonnull (2)));
-void char_parse_char_create_new_char(int fd, struct char_session_data* sd)
-{
- int result;
- if( !char_new ) {
-
- result = -2;
- } else {
-
- result = chr->make_new_char_sql(sd, RFIFOP(fd,2), 1, 1, 1, 1, 1, 1, RFIFOB(fd,26),RFIFOW(fd,27),RFIFOW(fd,29));
-
-
-
- }
-
-
- if (result < 0) {
- chr->creation_failed(fd, result);
- } else {
-
- struct mmo_charstatus char_dat;
- chr->mmo_char_fromsql(result, &char_dat,
-# 4624 "../../../server-code/src/char/char.c" 3 4
- 0
-# 4624 "../../../server-code/src/char/char.c"
- );
- chr->creation_ok(fd, &char_dat);
-
-
- sd->found_char[char_dat.slot] = result;
- }
-
- RFIFOSKIP(fd,31);
-
-
-
-}
-
-
-
-void char_delete_char_failed(int fd, int flag)
-{
- WFIFOHEAD(fd,3);
- WFIFOW(fd,0) = 0x70;
- WFIFOB(fd,2) = flag;
- WFIFOSET(fd,3);
-}
-
-void char_delete_char_ok(int fd)
-{
- WFIFOHEAD(fd,2);
- WFIFOW(fd,0) = 0x6f;
- WFIFOSET(fd,2);
-}
-
-void char_parse_char_delete_char(int fd, struct char_session_data* sd, unsigned short cmd) __attribute__((nonnull (2)));
-void char_parse_char_delete_char(int fd, struct char_session_data* sd, unsigned short cmd)
-{
- char email[40];
- int cid = RFIFOL(fd,2);
- int i;
-
-
- if (pincode->enabled) {
- struct online_char_data* character;
- character = (struct online_char_data*)( DB->data2ptr((chr->online_char_db)->get((chr->online_char_db),DB->i2key(sd->account_id))) );
- if( character && character->pincode_enable == -1 ){
- chr->auth_error(fd, 0);
- RFIFOSKIP(fd,( cmd == 0x68) ? 46 : 56);
- return;
- }
- }
-
- (showmsg->showInfo(("\033[1;31m""Request Char Deletion: ""\033[1;32m""%d (%d)""\033[0m""\n"), sd->account_id, cid));
- memcpy(email, RFIFOP(fd,6), 40);
- RFIFOSKIP(fd,( cmd == 0x68) ? 46 : 56);
-
-
- if (strcasecmp(email, sd->email) != 0
- && ( strcmp("a@a.com", sd->email) != 0
- || (strcmp("a@a.com", email) != 0 && strcmp("", email) != 0)
- )) {
-
- chr->delete_char_failed(fd, 0);
- return;
- }
-
-
- do { for ((i) = (0); (i) < (9); ++(i)) if (sd->found_char[i] == cid) break; } while(
-# 4687 "../../../server-code/src/char/char.c" 3 4
-0
-# 4687 "../../../server-code/src/char/char.c"
-);
- if( i == 9 )
- {
- chr->delete_char_failed(fd, 0);
- return;
- }
-
-
- sd->found_char[i] = -1;
-
-
- if(chr->delete_char_sql(cid)<0){
-
-
-
- chr->delete_char_failed(fd, 0);
- return;
- }
-
- chr->delete_char_ok(fd);
-}
-
-void char_parse_char_ping(int fd)
-{
- RFIFOSKIP(fd,6);
-}
-
-void char_allow_rename(int fd, int flag)
-{
- WFIFOHEAD(fd, 4);
- WFIFOW(fd,0) = 0x28e;
- WFIFOW(fd,2) = flag;
- WFIFOSET(fd,4);
-}
-
-void char_parse_char_rename_char(int fd, struct char_session_data* sd) __attribute__((nonnull (2)));
-void char_parse_char_rename_char(int fd, struct char_session_data* sd)
-{
- int i, cid =RFIFOL(fd,2);
- char name[(23 + 1)];
- char esc_name[(23 + 1)*2+1];
- (strlib->safestrncpy_((name),(RFIFOP(fd,6)),((23 + 1))));
- RFIFOSKIP(fd,30);
-
- do { for ((i) = (0); (i) < (9); ++(i)) if (sd->found_char[i] == cid) break; } while(
-# 4731 "../../../server-code/src/char/char.c" 3 4
-0
-# 4731 "../../../server-code/src/char/char.c"
-);
- if( i == 9 )
- return;
-
- (strlib->normalize_name_((name),("\255\xA0\032\t\x0A\x0D ")));
- SQL->EscapeStringLen(inter->sql_handle, esc_name, name, (strlib->strnlen_((name),((23 + 1)))));
- if( !chr->check_char_name(name,esc_name) ) {
- i = 1;
- (strlib->safestrncpy_((sd->new_name),(name),((23 + 1))));
- } else {
- i = 0;
- }
-
- chr->allow_rename(fd, i);
-}
-
-void char_parse_char_rename_char2(int fd, struct char_session_data* sd) __attribute__((nonnull (2)));
-void char_parse_char_rename_char2(int fd, struct char_session_data* sd)
-{
- int i, aid = RFIFOL(fd,2), cid =RFIFOL(fd,6);
- char name[(23 + 1)];
- char esc_name[(23 + 1)*2+1];
- (strlib->safestrncpy_((name),(RFIFOP(fd,10)),((23 + 1))));
- RFIFOSKIP(fd,34);
-
- if( aid != sd->account_id )
- return;
- do { for ((i) = (0); (i) < (9); ++(i)) if (sd->found_char[i] == cid) break; } while(
-# 4758 "../../../server-code/src/char/char.c" 3 4
-0
-# 4758 "../../../server-code/src/char/char.c"
-);
- if( i == 9 )
- return;
-
- (strlib->normalize_name_((name),("\255\xA0\032\t\x0A\x0D ")));
- SQL->EscapeStringLen(inter->sql_handle, esc_name, name, (strlib->strnlen_((name),((23 + 1)))));
- if( !chr->check_char_name(name,esc_name) )
- {
- i = 1;
- (strlib->safestrncpy_((sd->new_name),(name),((23 + 1))));
- }
- else
- i = 0;
-
- chr->allow_rename(fd, i);
-}
-
-void char_rename_char_ack(int fd, int flag)
-{
- WFIFOHEAD(fd, 4);
- WFIFOW(fd,0) = 0x290;
- WFIFOW(fd,2) = flag;
- WFIFOSET(fd,4);
-}
-
-void char_parse_char_rename_char_confirm(int fd, struct char_session_data* sd) __attribute__((nonnull (2)));
-void char_parse_char_rename_char_confirm(int fd, struct char_session_data* sd)
-{
- int i;
- int cid = RFIFOL(fd,2);
- RFIFOSKIP(fd,6);
-
- do { for ((i) = (0); (i) < (9); ++(i)) if (sd->found_char[i] == cid) break; } while(
-# 4790 "../../../server-code/src/char/char.c" 3 4
-0
-# 4790 "../../../server-code/src/char/char.c"
-);
- if( i == 9 )
- return;
- i = chr->rename_char_sql(sd, cid);
-
- chr->rename_char_ack(fd, i);
-}
-
-void char_captcha_notsupported(int fd)
-{
- WFIFOHEAD(fd,5);
- WFIFOW(fd,0) = 0x7e9;
- WFIFOW(fd,2) = 5;
- WFIFOB(fd,4) = 1;
- WFIFOSET(fd,5);
-}
-
-void char_parse_char_request_captcha(int fd)
-{
- chr->captcha_notsupported(fd);
- RFIFOSKIP(fd,8);
-}
-
-void char_parse_char_check_captcha(int fd)
-{
- chr->captcha_notsupported(fd);
- RFIFOSKIP(fd,32);
-}
-
-void char_parse_char_delete2_req(int fd, struct char_session_data* sd)
-{
- chr->delete2_req(fd, sd);
- RFIFOSKIP(fd,6);
-}
-
-void char_parse_char_delete2_accept(int fd, struct char_session_data* sd)
-{
- chr->delete2_accept(fd, sd);
- RFIFOSKIP(fd,12);
-}
-
-void char_parse_char_delete2_cancel(int fd, struct char_session_data* sd)
-{
- chr->delete2_cancel(fd, sd);
- RFIFOSKIP(fd,6);
-}
-
-
-
-
-void char_login_map_server_ack(int fd, uint8 flag)
-{
- WFIFOHEAD(fd,3);
- WFIFOW(fd,0) = 0x2af9;
- WFIFOB(fd,2) = flag;
- WFIFOSET(fd,3);
-}
-
-void char_parse_char_login_map_server(int fd, uint32 ipl)
-{
- char l_user[24], l_pass[24];
- int i;
- (strlib->safestrncpy_((l_user),(RFIFOP(fd,2)),(24)));
- (strlib->safestrncpy_((l_pass),(RFIFOP(fd,26)),(24)));
-
- do { for ((i) = (0); (i) < (( (int)(sizeof(chr->server)/sizeof((chr->server)[0])) )); ++(i)) if (chr->server[i].fd <= 0) break; } while(
-# 4855 "../../../server-code/src/char/char.c" 3 4
-0
-# 4855 "../../../server-code/src/char/char.c"
-);
- if (core->runflag != CHARSERVER_ST_RUNNING ||
- i == ( (int)(sizeof(chr->server)/sizeof((chr->server)[0])) ) ||
- strcmp(l_user, chr->userid) != 0 ||
- strcmp(l_pass, chr->passwd) != 0 ||
- !sockt->allowed_ip_check(ipl))
- {
- chr->login_map_server_ack(fd, 3);
- } else {
- chr->login_map_server_ack(fd, 0);
-
- chr->server[i].fd = fd;
- chr->server[i].ip = ntohl(RFIFOL(fd,54));
- chr->server[i].port = ntohs(RFIFOW(fd,58));
- chr->server[i].users = 0;
- sockt->session[fd]->func_parse = chr->parse_frommap;
- sockt->session[fd]->flag.server = 1;
- sockt->realloc_fifo(fd, FIFOSIZE_SERVERLINK, FIFOSIZE_SERVERLINK);
- chr->mapif_init(fd);
- }
- sockt->datasync(fd,
-# 4875 "../../../server-code/src/char/char.c" 3 4
- 1
-# 4875 "../../../server-code/src/char/char.c"
- );
-
- RFIFOSKIP(fd,60);
-}
-
-void char_parse_char_pincode_check(int fd, struct char_session_data* sd) __attribute__((nonnull (2)));
-void char_parse_char_pincode_check(int fd, struct char_session_data* sd)
-{
- if (RFIFOL(fd,2) == sd->account_id)
- pincode->check(fd, sd);
-
- RFIFOSKIP(fd, 10);
-}
-
-void char_parse_char_pincode_window(int fd, struct char_session_data* sd) __attribute__((nonnull (2)));
-void char_parse_char_pincode_window(int fd, struct char_session_data* sd)
-{
- if (RFIFOL(fd,2) == sd->account_id)
- pincode->sendstate(fd, sd, PINCODE_NOTSET);
-
- RFIFOSKIP(fd, 6);
-}
-
-void char_parse_char_pincode_change(int fd, struct char_session_data* sd) __attribute__((nonnull (2)));
-void char_parse_char_pincode_change(int fd, struct char_session_data* sd)
-{
- if (RFIFOL(fd,2) == sd->account_id)
- pincode->change(fd, sd);
-
- RFIFOSKIP(fd, 14);
-}
-
-void char_parse_char_pincode_first_pin(int fd, struct char_session_data* sd) __attribute__((nonnull (2)));
-void char_parse_char_pincode_first_pin(int fd, struct char_session_data* sd)
-{
- if (RFIFOL(fd,2) == sd->account_id)
- pincode->setnew (fd, sd);
- RFIFOSKIP(fd, 10);
-}
-
-void char_parse_char_request_chars(int fd, struct char_session_data* sd)
-{
- chr->mmo_char_send099d(fd, sd);
- RFIFOSKIP(fd,2);
-}
-
-void char_change_character_slot_ack(int fd,
-# 4921 "../../../server-code/src/char/char.c" 3 4
- _Bool
-# 4921 "../../../server-code/src/char/char.c"
- ret)
-{
- WFIFOHEAD(fd, 8);
- WFIFOW(fd,0) = 0x8d5;
- WFIFOW(fd,2) = 8;
- WFIFOW(fd,4) = ret?0:1;
- WFIFOW(fd,6) = 0;
- WFIFOSET(fd, 8);
-}
-
-void char_parse_char_move_character(int fd, struct char_session_data* sd)
-{
-
-# 4933 "../../../server-code/src/char/char.c" 3 4
-_Bool
-# 4933 "../../../server-code/src/char/char.c"
- ret = chr->char_slotchange(sd, fd, RFIFOW(fd, 2), RFIFOW(fd, 4));
- chr->change_character_slot_ack(fd, ret);
-
- if( ret )
-
- chr->mmo_char_send099d(fd, sd);
-
-
-
- RFIFOSKIP(fd, 8);
-}
-
-int char_parse_char_unknown_packet(int fd, uint32 ipl)
-{
- (showmsg->showError(("chr->parse_char: Received unknown packet ""\033[1;37m""0x%x""\033[0m"" from ip '""\033[1;37m""%s""\033[0m""'! Disconnecting!\n"), RFIFOW(fd,0), sockt->ip2str(ipl,
-# 4947 "../../../server-code/src/char/char.c" 3 4
-((void *)0)
-# 4947 "../../../server-code/src/char/char.c"
-)));
- sockt->eof(fd);
- return 1;
-}
-
-int char_parse_char(int fd)
-{
- unsigned short cmd;
- struct char_session_data* sd;
- uint32 ipl = sockt->session[fd]->client_addr;
-
- sd = (struct char_session_data*)sockt->session[fd]->session_data;
-
-
- if(chr->login_fd < 0)
- sockt->eof(fd);
-
- if(sockt->session[fd]->flag.eof)
- {
- if( sd !=
-# 4966 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 4966 "../../../server-code/src/char/char.c"
- && sd->auth ) {
-
- struct online_char_data* data = (struct online_char_data*)( DB->data2ptr((chr->online_char_db)->get((chr->online_char_db),DB->i2key(sd->account_id))) );
- if( data !=
-# 4969 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 4969 "../../../server-code/src/char/char.c"
- && data->fd == fd)
- data->fd = -1;
- if( data ==
-# 4971 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 4971 "../../../server-code/src/char/char.c"
- || data->server == -1)
- chr->set_char_offline(-1,sd->account_id);
- }
- sockt->close(fd);
- return 0;
- }
-
- while (RFIFOREST(fd) >= 2) {
- cmd = RFIFOW(fd,0);
-
-
-
-
- if (( (HPM->packets[hpParse_Char])._len_ ) > 0) {
- int result = HPM->parse_packets(fd,cmd,hpParse_Char);
- if (result == 1)
- continue;
- if (result == 2)
- return 0;
- }
-
- switch (cmd) {
-
-
- case 0x65:
- if( RFIFOREST(fd) < 17 )
- return 0;
- {
- chr->parse_char_connect(fd, sd, ipl);
- }
- break;
-
-
- case 0x66:
- do { if(RFIFOREST(fd) < (3)) return 0; if (sd==
-# 5005 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 5005 "../../../server-code/src/char/char.c"
- || !sd->auth) { RFIFOSKIP(fd,(3)); return 0; } } while (0);
- {
- chr->parse_char_select(fd, sd, ipl);
- }
- break;
-
-
-
-
- case 0x970:
- {
- do { if(RFIFOREST(fd) < (31)) return 0; if (sd==
-# 5016 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 5016 "../../../server-code/src/char/char.c"
- || !sd->auth) { RFIFOSKIP(fd,(31)); return 0; } } while (0);
-
-
-
-
-
-
-
- chr->parse_char_create_new_char(fd, sd);
- }
- break;
-
-
- case 0x68:
-
- case 0x1fb:
- if (cmd == 0x68) do { if(RFIFOREST(fd) < (46)) return 0; if (sd==
-# 5032 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 5032 "../../../server-code/src/char/char.c"
- || !sd->auth) { RFIFOSKIP(fd,(46)); return 0; } } while (0);
- if (cmd == 0x1fb) do { if(RFIFOREST(fd) < (56)) return 0; if (sd==
-# 5033 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 5033 "../../../server-code/src/char/char.c"
- || !sd->auth) { RFIFOSKIP(fd,(56)); return 0; } } while (0);
- {
- chr->parse_char_delete_char(fd, sd, cmd);
- }
- break;
-
-
-
- case 0x187:
- if (RFIFOREST(fd) < 6)
- return 0;
- chr->parse_char_ping(fd);
- break;
-
-
- case 0x8fc:
- do { if(RFIFOREST(fd) < (30)) return 0; if (sd==
-# 5049 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 5049 "../../../server-code/src/char/char.c"
- || !sd->auth) { RFIFOSKIP(fd,(30)); return 0; } } while (0);
- {
- chr->parse_char_rename_char(fd, sd);
- }
- break;
-
-
-
- case 0x28d:
- do { if(RFIFOREST(fd) < (34)) return 0; if (sd==
-# 5058 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 5058 "../../../server-code/src/char/char.c"
- || !sd->auth) { RFIFOSKIP(fd,(34)); return 0; } } while (0);
- {
- chr->parse_char_rename_char2(fd, sd);
- }
- break;
-
-
- case 0x28f:
-
-
-
-
-
- do { if(RFIFOREST(fd) < (6)) return 0; if (sd==
-# 5071 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 5071 "../../../server-code/src/char/char.c"
- || !sd->auth) { RFIFOSKIP(fd,(6)); return 0; } } while (0);
- {
- chr->parse_char_rename_char_confirm(fd, sd);
- }
- break;
-
-
-
- case 0x7e5:
- chr->parse_char_request_captcha(fd);
- break;
-
-
-
- case 0x7e7:
- chr->parse_char_check_captcha(fd);
- break;
-
-
- case 0x827:
- do { if(RFIFOREST(fd) < (6)) return 0; if (sd==
-# 5091 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 5091 "../../../server-code/src/char/char.c"
- || !sd->auth) { RFIFOSKIP(fd,(6)); return 0; } } while (0);
- chr->parse_char_delete2_req(fd, sd);
- break;
-
-
- case 0x829:
- do { if(RFIFOREST(fd) < (12)) return 0; if (sd==
-# 5097 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 5097 "../../../server-code/src/char/char.c"
- || !sd->auth) { RFIFOSKIP(fd,(12)); return 0; } } while (0);
- chr->parse_char_delete2_accept(fd, sd);
- break;
-
-
- case 0x82b:
- do { if(RFIFOREST(fd) < (6)) return 0; if (sd==
-# 5103 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 5103 "../../../server-code/src/char/char.c"
- || !sd->auth) { RFIFOSKIP(fd,(6)); return 0; } } while (0);
- chr->parse_char_delete2_cancel(fd, sd);
- break;
-
-
- case 0x2af8:
- if (RFIFOREST(fd) < 60)
- return 0;
- {
- chr->parse_char_login_map_server(fd, ipl);
- }
- return 0;
-
-
- case 0x8b8:
- do { if(RFIFOREST(fd) < (10)) return 0; if (sd==
-# 5118 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 5118 "../../../server-code/src/char/char.c"
- || !sd->auth) { RFIFOSKIP(fd,(10)); return 0; } } while (0);
- chr->parse_char_pincode_check(fd, sd);
- break;
-
-
- case 0x8c5:
- do { if(RFIFOREST(fd) < (6)) return 0; if (sd==
-# 5124 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 5124 "../../../server-code/src/char/char.c"
- || !sd->auth) { RFIFOSKIP(fd,(6)); return 0; } } while (0);
- chr->parse_char_pincode_window(fd, sd);
- break;
-
-
- case 0x8be:
- do { if(RFIFOREST(fd) < (14)) return 0; if (sd==
-# 5130 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 5130 "../../../server-code/src/char/char.c"
- || !sd->auth) { RFIFOSKIP(fd,(14)); return 0; } } while (0);
- chr->parse_char_pincode_change(fd, sd);
- break;
-
-
- case 0x8ba:
- do { if(RFIFOREST(fd) < (10)) return 0; if (sd==
-# 5136 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 5136 "../../../server-code/src/char/char.c"
- || !sd->auth) { RFIFOSKIP(fd,(10)); return 0; } } while (0);
- chr->parse_char_pincode_first_pin(fd, sd);
- break;
-
- case 0x9a1:
- do { if(RFIFOREST(fd) < (2)) return 0; if (sd==
-# 5141 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 5141 "../../../server-code/src/char/char.c"
- || !sd->auth) { RFIFOSKIP(fd,(2)); return 0; } } while (0);
- chr->parse_char_request_chars(fd, sd);
- break;
-
-
- case 0x8d4:
- do { if(RFIFOREST(fd) < (8)) return 0; if (sd==
-# 5147 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 5147 "../../../server-code/src/char/char.c"
- || !sd->auth) { RFIFOSKIP(fd,(8)); return 0; } } while (0);
- {
- chr->parse_char_move_character(fd, sd);
- }
- break;
-
-
- default:
- if (chr->parse_char_unknown_packet(fd, ipl))
- return 0;
- }
- }
-
- RFIFOFLUSH(fd);
- return 0;
-}
-
-int mapif_sendall(const unsigned char *buf, unsigned int len)
-{
- int i, c;
-
- do { if (((void)(buf),
-# 5168 "../../../server-code/src/char/char.c" 3 4
-0
-# 5168 "../../../server-code/src/char/char.c"
-)) return(0); } while(0);
- c = 0;
- for(i = 0; i < ( (int)(sizeof(chr->server)/sizeof((chr->server)[0])) ); i++) {
- int fd;
- if ((fd = chr->server[i].fd) > 0) {
- WFIFOHEAD(fd,len);
- memcpy(WFIFOP(fd,0), buf, len);
- WFIFOSET(fd,len);
- c++;
- }
- }
-
- return c;
-}
-
-int mapif_sendallwos(int sfd, unsigned char *buf, unsigned int len)
-{
- int i, c;
-
- do { if (((void)(buf),
-# 5187 "../../../server-code/src/char/char.c" 3 4
-0
-# 5187 "../../../server-code/src/char/char.c"
-)) return(0); } while(0);
- c = 0;
- for(i = 0; i < ( (int)(sizeof(chr->server)/sizeof((chr->server)[0])) ); i++) {
- int fd;
- if ((fd = chr->server[i].fd) > 0 && fd != sfd) {
- WFIFOHEAD(fd,len);
- memcpy(WFIFOP(fd,0), buf, len);
- WFIFOSET(fd,len);
- c++;
- }
- }
-
- return c;
-}
-
-int mapif_send(int fd, unsigned char *buf, unsigned int len)
-{
- do { if (((void)(buf),
-# 5204 "../../../server-code/src/char/char.c" 3 4
-0
-# 5204 "../../../server-code/src/char/char.c"
-)) return(0); } while(0);
- if (fd >= 0) {
- int i;
- do { for ((i) = (0); (i) < (( (int)(sizeof(chr->server)/sizeof((chr->server)[0])) )); ++(i)) if (fd == chr->server[i].fd) break; } while(
-# 5207 "../../../server-code/src/char/char.c" 3 4
- 0
-# 5207 "../../../server-code/src/char/char.c"
- );
- if( i < ( (int)(sizeof(chr->server)/sizeof((chr->server)[0])) ) )
- {
- WFIFOHEAD(fd,len);
- memcpy(WFIFOP(fd,0), buf, len);
- WFIFOSET(fd,len);
- return 1;
- }
- }
- return 0;
-}
-
-void mapif_send_users_count(int users)
-{
- uint8 buf[6];
-
- WBUFW(buf,0) = 0x2b00;
- WBUFL(buf,2) = users;
- mapif->sendall(buf,6);
-}
-
-int char_broadcast_user_count(int tid, int64 tick, int id, intptr_t data) {
- int users = chr->count_users();
-
-
- static int prev_users = 0;
- if( prev_users == users )
- return 0;
- prev_users = users;
-
- if( chr->login_fd > 0 && sockt->session[chr->login_fd] )
- {
-
- loginif->send_users_count(users);
- }
-
- mapif->send_users_count(users);
-
- return 0;
-}
-
-
-
-
-
-static int char_send_accounts_tologin_sub(union DBKey key, struct DBData *data, va_list ap)
-{
- struct online_char_data* character = DB->data2ptr(data);
- int* i =
-# 5255 "../../../server-code/src/char/char.c" 3 4
- __builtin_va_arg(
-# 5255 "../../../server-code/src/char/char.c"
- ap
-# 5255 "../../../server-code/src/char/char.c" 3 4
- ,
-# 5255 "../../../server-code/src/char/char.c"
- int*
-# 5255 "../../../server-code/src/char/char.c" 3 4
- )
-# 5255 "../../../server-code/src/char/char.c"
- ;
-
- do { if (((void)(character),
-# 5257 "../../../server-code/src/char/char.c" 3 4
-0
-# 5257 "../../../server-code/src/char/char.c"
-)) return(0); } while(0);
- if(character->server > -1)
- {
- WFIFOL(chr->login_fd,8+(*i)*4) = character->account_id;
- (*i)++;
- return 1;
- }
- return 0;
-}
-
-int char_send_accounts_tologin(int tid, int64 tick, int id, intptr_t data) {
- if (chr->login_fd > 0 && sockt->session[chr->login_fd])
- {
-
- int users = chr->online_char_db->size(chr->online_char_db);
- int i = 0;
-
- WFIFOHEAD(chr->login_fd,8+users*4);
- WFIFOW(chr->login_fd,0) = 0x272d;
- chr->online_char_db->foreach(chr->online_char_db, chr->send_accounts_tologin_sub, &i, users);
- WFIFOW(chr->login_fd,2) = 8+ i*4;
- WFIFOL(chr->login_fd,4) = i;
- WFIFOSET(chr->login_fd,WFIFOW(chr->login_fd,2));
- }
- return 0;
-}
-
-int char_check_connect_login_server(int tid, int64 tick, int id, intptr_t data) {
- if (chr->login_fd > 0 && sockt->session[chr->login_fd] !=
-# 5285 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 5285 "../../../server-code/src/char/char.c"
- )
- return 0;
-
- (showmsg->showInfo(("Attempt to connect to login-server...\n")));
-
- if ((chr->login_fd = sockt->make_connection(login_ip, login_port,
-# 5290 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 5290 "../../../server-code/src/char/char.c"
- )) == -1) {
- chr->login_fd = 0;
- return 0;
- }
-
- sockt->session[chr->login_fd]->func_parse = chr->parse_fromlogin;
- sockt->session[chr->login_fd]->flag.server = 1;
- sockt->realloc_fifo(chr->login_fd, FIFOSIZE_SERVERLINK, FIFOSIZE_SERVERLINK);
-
- loginif->connect_to_server();
-
- return 1;
-}
-
-
-
-
-
-static int char_waiting_disconnect(int tid, int64 tick, int id, intptr_t data) {
- struct online_char_data* character;
- if ((character = (struct online_char_data*)( DB->data2ptr((chr->online_char_db)->get((chr->online_char_db),DB->i2key(id))) )) !=
-# 5310 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 5310 "../../../server-code/src/char/char.c"
- && character->waiting_disconnect == tid) {
-
- character->waiting_disconnect = (-1);
- chr->set_char_offline(character->char_id, character->account_id);
- }
- return 0;
-}
-
-
-
-
-static int char_online_data_cleanup_sub(union DBKey key, struct DBData *data, va_list ap)
-{
- struct online_char_data *character= DB->data2ptr(data);
- do { if (((void)(character),
-# 5324 "../../../server-code/src/char/char.c" 3 4
-0
-# 5324 "../../../server-code/src/char/char.c"
-)) return(0); } while(0);
- if (character->fd != -1)
- return 0;
- if (character->server == -2)
- chr->set_char_offline(character->char_id, character->account_id);
- if (character->server < 0)
-
- ( (chr->online_char_db)->remove((chr->online_char_db),(key),
-# 5331 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 5331 "../../../server-code/src/char/char.c"
- ) );
- return 0;
-}
-
-static int char_online_data_cleanup(int tid, int64 tick, int id, intptr_t data) {
- chr->online_char_db->foreach(chr->online_char_db, chr->online_data_cleanup_sub);
- return 0;
-}
-
-void char_sql_config_read(const char* cfgName)
-{
- char line[1024], w1[1024], w2[1024];
- FILE* fp;
-
- if ((fp = fopen(cfgName, "r")) ==
-# 5345 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 5345 "../../../server-code/src/char/char.c"
- ) {
- (showmsg->showError(("File not found: %s\n"), cfgName));
- return;
- }
-
- while(fgets(line, sizeof(line), fp))
- {
- if(line[0] == '/' && line[1] == '/')
- continue;
-
- if (sscanf(line, "%1023[^:]: %1023[^\r\n]", w1, w2) != 2)
- continue;
-
- if(!strcasecmp(w1,"char_db"))
- (strlib->safestrncpy_((char_db),(w2),(sizeof(char_db))));
- else if(!strcasecmp(w1,"scdata_db"))
- (strlib->safestrncpy_((scdata_db),(w2),(sizeof(scdata_db))));
- else if(!strcasecmp(w1,"cart_db"))
- (strlib->safestrncpy_((cart_db),(w2),(sizeof(cart_db))));
- else if(!strcasecmp(w1,"inventory_db"))
- (strlib->safestrncpy_((inventory_db),(w2),(sizeof(inventory_db))));
- else if(!strcasecmp(w1,"charlog_db"))
- (strlib->safestrncpy_((charlog_db),(w2),(sizeof(charlog_db))));
- else if(!strcasecmp(w1,"storage_db"))
- (strlib->safestrncpy_((storage_db),(w2),(sizeof(storage_db))));
- else if(!strcasecmp(w1,"skill_db"))
- (strlib->safestrncpy_((skill_db),(w2),(sizeof(skill_db))));
- else if(!strcasecmp(w1,"interlog_db"))
- (strlib->safestrncpy_((interlog_db),(w2),(sizeof(interlog_db))));
- else if(!strcasecmp(w1,"memo_db"))
- (strlib->safestrncpy_((memo_db),(w2),(sizeof(memo_db))));
- else if(!strcasecmp(w1,"guild_db"))
- (strlib->safestrncpy_((guild_db),(w2),(sizeof(guild_db))));
- else if(!strcasecmp(w1,"guild_alliance_db"))
- (strlib->safestrncpy_((guild_alliance_db),(w2),(sizeof(guild_alliance_db))));
- else if(!strcasecmp(w1,"guild_castle_db"))
- (strlib->safestrncpy_((guild_castle_db),(w2),(sizeof(guild_castle_db))));
- else if(!strcasecmp(w1,"guild_expulsion_db"))
- (strlib->safestrncpy_((guild_expulsion_db),(w2),(sizeof(guild_expulsion_db))));
- else if(!strcasecmp(w1,"guild_member_db"))
- (strlib->safestrncpy_((guild_member_db),(w2),(sizeof(guild_member_db))));
- else if(!strcasecmp(w1,"guild_skill_db"))
- (strlib->safestrncpy_((guild_skill_db),(w2),(sizeof(guild_skill_db))));
- else if(!strcasecmp(w1,"guild_position_db"))
- (strlib->safestrncpy_((guild_position_db),(w2),(sizeof(guild_position_db))));
- else if(!strcasecmp(w1,"guild_storage_db"))
- (strlib->safestrncpy_((guild_storage_db),(w2),(sizeof(guild_storage_db))));
- else if(!strcasecmp(w1,"party_db"))
- (strlib->safestrncpy_((party_db),(w2),(sizeof(party_db))));
- else if(!strcasecmp(w1,"pet_db"))
- (strlib->safestrncpy_((pet_db),(w2),(sizeof(pet_db))));
- else if(!strcasecmp(w1,"mail_db"))
- (strlib->safestrncpy_((mail_db),(w2),(sizeof(mail_db))));
- else if(!strcasecmp(w1,"auction_db"))
- (strlib->safestrncpy_((auction_db),(w2),(sizeof(auction_db))));
- else if(!strcasecmp(w1,"friend_db"))
- (strlib->safestrncpy_((friend_db),(w2),(sizeof(friend_db))));
- else if(!strcasecmp(w1,"hotkey_db"))
- (strlib->safestrncpy_((hotkey_db),(w2),(sizeof(hotkey_db))));
- else if(!strcasecmp(w1,"quest_db"))
- (strlib->safestrncpy_((quest_db),(w2),(sizeof(quest_db))));
- else if(!strcasecmp(w1,"homunculus_db"))
- (strlib->safestrncpy_((homunculus_db),(w2),(sizeof(homunculus_db))));
- else if(!strcasecmp(w1,"skill_homunculus_db"))
- (strlib->safestrncpy_((skill_homunculus_db),(w2),(sizeof(skill_homunculus_db))));
- else if(!strcasecmp(w1,"mercenary_db"))
- (strlib->safestrncpy_((mercenary_db),(w2),(sizeof(mercenary_db))));
- else if(!strcasecmp(w1,"mercenary_owner_db"))
- (strlib->safestrncpy_((mercenary_owner_db),(w2),(sizeof(mercenary_owner_db))));
- else if(!strcasecmp(w1,"ragsrvinfo_db"))
- (strlib->safestrncpy_((ragsrvinfo_db),(w2),(sizeof(ragsrvinfo_db))));
- else if(!strcasecmp(w1,"elemental_db"))
- (strlib->safestrncpy_((elemental_db),(w2),(sizeof(elemental_db))));
- else if(!strcasecmp(w1,"account_data_db"))
- (strlib->safestrncpy_((account_data_db),(w2),(sizeof(account_data_db))));
- else if(!strcasecmp(w1,"char_reg_num_db"))
- (strlib->safestrncpy_((char_reg_num_db),(w2),(sizeof(char_reg_num_db))));
- else if(!strcasecmp(w1,"char_reg_str_db"))
- (strlib->safestrncpy_((char_reg_str_db),(w2),(sizeof(char_reg_str_db))));
- else if(!strcasecmp(w1,"acc_reg_str_db"))
- (strlib->safestrncpy_((acc_reg_str_db),(w2),(sizeof(acc_reg_str_db))));
- else if(!strcasecmp(w1,"acc_reg_num_db"))
- (strlib->safestrncpy_((acc_reg_num_db),(w2),(sizeof(acc_reg_num_db))));
-
- else if(!strcasecmp(w1,"import"))
- chr->sql_config_read(w2);
- else
- HPM->parseConf(w1, w2, HPCT_CHAR_INTER);
- }
- fclose(fp);
- (showmsg->showInfo(("Done reading %s.\n"), cfgName));
-}
-
-void char_config_dispatch(char *w1, char *w2) {
-
-# 5439 "../../../server-code/src/char/char.c" 3 4
-_Bool
-# 5439 "../../../server-code/src/char/char.c"
- (*dispatch_to[]) (char *w1, char *w2) = {
-
- pincode->config_read
- };
- int i, len = ( (int)(sizeof(dispatch_to)/sizeof((dispatch_to)[0])) );
- for(i = 0; i < len; i++) {
- if( (*dispatch_to[i])(w1,w2) )
- break;
- }
- if (i == len)
- HPM->parseConf(w1, w2, HPCT_CHAR);
-}
-
-int char_config_read(const char* cfgName)
-{
- char line[1024], w1[1024], w2[1024];
- FILE* fp = fopen(cfgName, "r");
-
- if (fp ==
-# 5457 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 5457 "../../../server-code/src/char/char.c"
- ) {
- (showmsg->showError(("Configuration file not found: %s.\n"), cfgName));
- return 1;
- }
-
- while(fgets(line, sizeof(line), fp)) {
- if (line[0] == '/' && line[1] == '/')
- continue;
-
- if (sscanf(line, "%1023[^:]: %1023[^\r\n]", w1, w2) != 2)
- continue;
-
- (strlib->remove_control_chars_(w1));
- (strlib->remove_control_chars_(w2));
- if(strcasecmp(w1,"timestamp_format") == 0) {
- (strlib->safestrncpy_((showmsg->timestamp_format),(w2),(sizeof(showmsg->timestamp_format))));
- } else if(strcasecmp(w1,"console_silent")==0){
- showmsg->silent = atoi(w2);
- if (showmsg->silent)
- (showmsg->showInfo(("Console Silent Setting: %d\n"), atoi(w2)));
- } else if(strcasecmp(w1,"stdout_with_ansisequence")==0){
- showmsg->stdout_with_ansisequence = (strlib->config_switch_(w2)) ?
-# 5478 "../../../server-code/src/char/char.c" 3 4
- 1
-# 5478 "../../../server-code/src/char/char.c"
- :
-# 5478 "../../../server-code/src/char/char.c" 3 4
- 0
-# 5478 "../../../server-code/src/char/char.c"
- ;
- } else if (strcasecmp(w1, "userid") == 0) {
- (strlib->safestrncpy_((chr->userid),(w2),(sizeof(chr->userid))));
- } else if (strcasecmp(w1, "passwd") == 0) {
- (strlib->safestrncpy_((chr->passwd),(w2),(sizeof(chr->passwd))));
- } else if (strcasecmp(w1, "server_name") == 0) {
- (strlib->safestrncpy_((chr->server_name),(w2),(sizeof(chr->server_name))));
- } else if (strcasecmp(w1, "wisp_server_name") == 0) {
- if (strlen(w2) >= 4) {
- (strlib->safestrncpy_((wisp_server_name),(w2),(sizeof(wisp_server_name))));
- }
- } else if (strcasecmp(w1, "login_ip") == 0) {
- login_ip = sockt->host2ip(w2);
- if (login_ip) {
- char ip_str[16];
- (strlib->safestrncpy_((login_ip_str),(w2),(sizeof(login_ip_str))));
- (showmsg->showStatus(("Login server IP address : %s -> %s\n"), w2, sockt->ip2str(login_ip, ip_str)));
- }
- } else if (strcasecmp(w1, "login_port") == 0) {
- login_port = atoi(w2);
- } else if (strcasecmp(w1, "char_ip") == 0) {
- chr->ip = sockt->host2ip(w2);
- if (chr->ip) {
- char ip_str[16];
- (strlib->safestrncpy_((char_ip_str),(w2),(sizeof(char_ip_str))));
- (showmsg->showStatus(("Character server IP address : %s -> %s\n"), w2, sockt->ip2str(chr->ip, ip_str)));
- }
- } else if (strcasecmp(w1, "bind_ip") == 0) {
- bind_ip = sockt->host2ip(w2);
- if (bind_ip) {
- char ip_str[16];
- (strlib->safestrncpy_((bind_ip_str),(w2),(sizeof(bind_ip_str))));
- (showmsg->showStatus(("Character server binding IP address : %s -> %s\n"), w2, sockt->ip2str(bind_ip, ip_str)));
- }
- } else if (strcasecmp(w1, "char_port") == 0) {
- chr->port = atoi(w2);
- } else if (strcasecmp(w1, "char_server_type") == 0) {
- chr->server_type = atoi(w2);
- } else if (strcasecmp(w1, "char_new") == 0) {
- char_new = (
-# 5517 "../../../server-code/src/char/char.c" 3 4
- _Bool
-# 5517 "../../../server-code/src/char/char.c"
- )atoi(w2);
- } else if (strcasecmp(w1, "char_new_display") == 0) {
- chr->new_display = atoi(w2);
- } else if (strcasecmp(w1, "max_connect_user") == 0) {
- max_connect_user = atoi(w2);
- if (max_connect_user < -1)
- max_connect_user = -1;
- } else if(strcasecmp(w1, "gm_allow_group") == 0) {
- gm_allow_group = atoi(w2);
- } else if (strcasecmp(w1, "autosave_time") == 0) {
- autosave_interval = atoi(w2) * 1000;
- if (autosave_interval <= 0)
- autosave_interval = (300*1000);
- } else if (strcasecmp(w1, "save_log") == 0) {
- save_log = (strlib->config_switch_(w2));
- }
-
- else if (strcasecmp(w1, "start_point_re") == 0) {
- char map[((11 + 1) + 4)];
- int x, y;
- if (sscanf(w2, "%15[^,],%d,%d", map, &x, &y) < 3)
- continue;
- start_point.map = mapindex->name2id(map);
- if (!start_point.map)
- (showmsg->showError(("Specified start_point_re '%s' not found in map-index cache.\n"), map));
- start_point.x = x;
- start_point.y = y;
- }
-# 5558 "../../../server-code/src/char/char.c"
- else if (strcasecmp(w1, "start_items") == 0) {
- int i;
- char *split;
-
- i = 0;
- split = strtok(w2, ",");
- while (split !=
-# 5564 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 5564 "../../../server-code/src/char/char.c"
- && i < 32 * 3) {
- char *split2 = split;
- split = strtok(
-# 5566 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 5566 "../../../server-code/src/char/char.c"
- , ",");
- start_items[i] = atoi(split2);
-
- if (start_items[i] < 0)
- start_items[i] = 0;
-
- ++i;
- }
-
-
- if( i%3 )
- {
- (showmsg->showWarning(("chr->config_read: There are not enough parameters in start_items, ignoring last item...\n")));
- if( i%3 == 1 )
- start_items[i-1] = 0;
- else
- start_items[i-2] = 0;
- }
- } else if (strcasecmp(w1, "start_zeny") == 0) {
- start_zeny = atoi(w2);
- if (start_zeny < 0)
- start_zeny = 0;
- } else if(strcasecmp(w1,"log_char")==0) {
- log_char = atoi(w2);
- } else if (strcasecmp(w1, "unknown_char_name") == 0) {
- (strlib->safestrncpy_((unknown_char_name),(w2),(sizeof(unknown_char_name))));
- unknown_char_name[(23 + 1)-1] = '\0';
- } else if (strcasecmp(w1, "name_ignoring_case") == 0) {
- name_ignoring_case = (
-# 5594 "../../../server-code/src/char/char.c" 3 4
- _Bool
-# 5594 "../../../server-code/src/char/char.c"
- )(strlib->config_switch_(w2));
- } else if (strcasecmp(w1, "char_name_option") == 0) {
- char_name_option = atoi(w2);
- } else if (strcasecmp(w1, "char_name_letters") == 0) {
- (strlib->safestrncpy_((char_name_letters),(w2),(sizeof(char_name_letters))));
- } else if (strcasecmp(w1, "char_del_level") == 0) {
- char_del_level = atoi(w2);
- } else if (strcasecmp(w1, "char_del_delay") == 0) {
- char_del_delay = atoi(w2);
- } else if (strcasecmp(w1, "char_aegis_delete") == 0) {
- char_aegis_delete = atoi(w2);
- } else if(strcasecmp(w1,"db_path")==0) {
- (strlib->safestrncpy_((db_path),(w2),(sizeof(db_path))));
- } else if (strcasecmp(w1, "fame_list_alchemist") == 0) {
- fame_list_size_chemist = atoi(w2);
- if (fame_list_size_chemist > 10) {
- (showmsg->showWarning(("Max fame list size is %d (fame_list_alchemist)\n"), 10));
- fame_list_size_chemist = 10;
- }
- } else if (strcasecmp(w1, "fame_list_blacksmith") == 0) {
- fame_list_size_smith = atoi(w2);
- if (fame_list_size_smith > 10) {
- (showmsg->showWarning(("Max fame list size is %d (fame_list_blacksmith)\n"), 10));
- fame_list_size_smith = 10;
- }
- } else if (strcasecmp(w1, "fame_list_taekwon") == 0) {
- fame_list_size_taekwon = atoi(w2);
- if (fame_list_size_taekwon > 10) {
- (showmsg->showWarning(("Max fame list size is %d (fame_list_taekwon)\n"), 10));
- fame_list_size_taekwon = 10;
- }
- } else if (strcasecmp(w1, "guild_exp_rate") == 0) {
- guild_exp_rate = atoi(w2);
- } else if (strcasecmp(w1, "char_maintenance_min_group_id") == 0) {
- char_maintenance_min_group_id = atoi(w2);
- } else if (strcasecmp(w1, "import") == 0) {
- chr->config_read(w2);
- } else
- chr->config_dispatch(w1,w2);
- }
- fclose(fp);
-
- (showmsg->showInfo(("Done reading %s.\n"), cfgName));
- return 0;
-}
-
-int do_final(void) {
- int i;
-
- (showmsg->showStatus(("Terminating...\n")));
-
- HPM->event(HPET_FINAL);
-
- chr->set_all_offline(-1);
- chr->set_all_offline_sql();
-
- inter->final();
-
- sockt->flush_fifos();
-
- do_final_mapif();
- loginif->final();
-
- if( (-1) == SQL->Query(inter->sql_handle, "DELETE FROM `%s`", ragsrvinfo_db) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 5658));
-
- chr->char_db_->destroy(chr->char_db_,
-# 5660 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 5660 "../../../server-code/src/char/char.c"
- );
- chr->online_char_db->destroy(chr->online_char_db,
-# 5661 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 5661 "../../../server-code/src/char/char.c"
- );
- auth_db->destroy(auth_db,
-# 5662 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 5662 "../../../server-code/src/char/char.c"
- );
-
- if( chr->char_fd != -1 ) {
- sockt->close(chr->char_fd);
- chr->char_fd = -1;
- }
-
- HPM_char_do_final();
-
- SQL->Free(inter->sql_handle);
- mapindex->final();
-
- for (i = 0; i < 2; i++)
- do { if (( (chr->server[i].maps)._max_ ) > 0) { (iMalloc->free((( (chr->server[i].maps)._data_ )),"../../../server-code/src/char/char.c", 5675, __func__)); ( (chr->server[i].maps)._data_ ) =
-# 5675 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 5675 "../../../server-code/src/char/char.c"
- ; ( (chr->server[i].maps)._max_ ) = 0; ( (chr->server[i].maps)._len_ ) = 0; } } while(
-# 5675 "../../../server-code/src/char/char.c" 3 4
- 0
-# 5675 "../../../server-code/src/char/char.c"
- );
-
- (iMalloc->free((chr->CHAR_CONF_NAME),"../../../server-code/src/char/char.c", 5677, __func__));
- (iMalloc->free((chr->NET_CONF_NAME),"../../../server-code/src/char/char.c", 5678, __func__));
- (iMalloc->free((chr->SQL_CONF_NAME),"../../../server-code/src/char/char.c", 5679, __func__));
- (iMalloc->free((chr->INTER_CONF_NAME),"../../../server-code/src/char/char.c", 5680, __func__));
-
- HPM->event(HPET_POST_FINAL);
-
- (showmsg->showStatus(("Finished.\n")));
- return
-# 5685 "../../../server-code/src/char/char.c" 3 4
- 0
-# 5685 "../../../server-code/src/char/char.c"
- ;
-}
-
-
-
-
-
-void do_abort(void)
-{
-}
-
-void set_server_type(void) {
- (core->server_type) = SERVER_TYPE_CHAR;
-}
-
-
-void do_shutdown(void)
-{
- if( core->runflag != CHARSERVER_ST_SHUTDOWN )
- {
- int id;
- core->runflag = CHARSERVER_ST_SHUTDOWN;
- (showmsg->showStatus(("Shutting down...\n")));
-
- for( id = 0; id < ( (int)(sizeof(chr->server)/sizeof((chr->server)[0])) ); ++id )
- mapif->server_reset(id);
- loginif->check_shutdown();
- sockt->flush_fifos();
- core->runflag = CORE_ST_STOP;
- }
-}
-
-
-
-
-
-
-
-static
-# 5723 "../../../server-code/src/char/char.c" 3 4
- _Bool
-# 5723 "../../../server-code/src/char/char.c"
- cmdline_arg_charconfig (const char *name, const char *params)
-{
- (iMalloc->free((chr->CHAR_CONF_NAME),"../../../server-code/src/char/char.c", 5725, __func__));
- chr->CHAR_CONF_NAME = (iMalloc->astrdup((params),"../../../server-code/src/char/char.c", 5726, __func__));
- return
-# 5727 "../../../server-code/src/char/char.c" 3 4
- 1
-# 5727 "../../../server-code/src/char/char.c"
- ;
-}
-
-
-
-
-
-
-static
-# 5735 "../../../server-code/src/char/char.c" 3 4
- _Bool
-# 5735 "../../../server-code/src/char/char.c"
- cmdline_arg_interconfig (const char *name, const char *params)
-{
- (iMalloc->free((chr->INTER_CONF_NAME),"../../../server-code/src/char/char.c", 5737, __func__));
- chr->INTER_CONF_NAME = (iMalloc->astrdup((params),"../../../server-code/src/char/char.c", 5738, __func__));
- return
-# 5739 "../../../server-code/src/char/char.c" 3 4
- 1
-# 5739 "../../../server-code/src/char/char.c"
- ;
-}
-
-
-
-
-
-
-static
-# 5747 "../../../server-code/src/char/char.c" 3 4
- _Bool
-# 5747 "../../../server-code/src/char/char.c"
- cmdline_arg_netconfig (const char *name, const char *params)
-{
- (iMalloc->free((chr->NET_CONF_NAME),"../../../server-code/src/char/char.c", 5749, __func__));
- chr->NET_CONF_NAME = (iMalloc->astrdup((params),"../../../server-code/src/char/char.c", 5750, __func__));
- return
-# 5751 "../../../server-code/src/char/char.c" 3 4
- 1
-# 5751 "../../../server-code/src/char/char.c"
- ;
-}
-
-
-
-void cmdline_args_init_local(void)
-{
- cmdline->arg_add(((unsigned int)-1), "--" "char-config", '\0', cmdline_arg_charconfig, "Alternative char-server configuration.", CMDLINE_OPT_PARAM);
- cmdline->arg_add(((unsigned int)-1), "--" "inter-config", '\0', cmdline_arg_interconfig, "Alternative inter-server configuration.", CMDLINE_OPT_PARAM);
- cmdline->arg_add(((unsigned int)-1), "--" "net-config", '\0', cmdline_arg_netconfig, "Alternative network configuration.", CMDLINE_OPT_PARAM);
-}
-
-int do_init(int argc, char **argv) {
- int i;
- memset(&skillid2idx, 0, sizeof(skillid2idx));
-
- char_load_defaults();
-
- chr->CHAR_CONF_NAME = (iMalloc->astrdup(("conf/char-server.conf"),"../../../server-code/src/char/char.c", 5769, __func__));
- chr->NET_CONF_NAME = (iMalloc->astrdup(("conf/network.conf"),"../../../server-code/src/char/char.c", 5770, __func__));
- chr->SQL_CONF_NAME = (iMalloc->astrdup(("conf/inter-server.conf"),"../../../server-code/src/char/char.c", 5771, __func__));
- chr->INTER_CONF_NAME = (iMalloc->astrdup(("conf/inter-server.conf"),"../../../server-code/src/char/char.c", 5772, __func__));
-
- for (i = 0; i < 2; i++)
- memset(&(chr->server[i].maps), 0, sizeof(chr->server[i].maps));
-
- HPM_char_do_init();
- cmdline->exec(argc, argv, CMDLINE_OPT_PREINIT);
- HPM->config_read();
- HPM->event(HPET_PRE_INIT);
-
-
- mapindex->init();
-
-
- start_point.map = mapindex->name2id("iz_int");
-
-
-
-
- cmdline->exec(argc, argv, CMDLINE_OPT_NORMAL);
- chr->config_read(chr->CHAR_CONF_NAME);
- sockt->net_config_read(chr->NET_CONF_NAME);
- chr->sql_config_read(chr->SQL_CONF_NAME);
-
- if (strcmp(chr->userid, "s1")==0 && strcmp(chr->passwd, "p1")==0) {
- (showmsg->showWarning(("Using the default user/password s1/p1 is NOT RECOMMENDED.\n")));
- (showmsg->showNotice(("Please edit your 'login' table to create a proper inter-server user/password (gender 'S')\n")));
- (showmsg->showNotice(("And then change the user/password to use in conf/char-server.conf (or conf/import/char_conf.txt)\n")));
- }
-
- inter->init_sql(chr->INTER_CONF_NAME);
-
- auth_db = DB->alloc("../../../server-code/src/char/char.c",__func__,5804,DB_INT,(DB_OPT_RELEASE_DATA),sizeof(int));
- chr->online_char_db = DB->alloc("../../../server-code/src/char/char.c",__func__,5805,DB_INT,(DB_OPT_RELEASE_DATA),sizeof(int));
-
- HPM->event(HPET_INIT);
-
- chr->mmo_char_sql_init();
- chr->read_fame_list();
-
- if ((sockt->naddr_ != 0) && (!login_ip || !chr->ip)) {
- char ip_str[16];
- sockt->ip2str(sockt->addr_[0], ip_str);
-
- if (sockt->naddr_ > 1)
- (showmsg->showStatus(("Multiple interfaces detected.. using %s as our IP address\n"), ip_str));
- else
- (showmsg->showStatus(("Defaulting to %s as our IP address\n"), ip_str));
- if (!login_ip) {
- (strlib->safestrncpy_((login_ip_str),(ip_str),(sizeof(login_ip_str))));
- login_ip = sockt->str2ip(login_ip_str);
- }
- if (!chr->ip) {
- (strlib->safestrncpy_((char_ip_str),(ip_str),(sizeof(char_ip_str))));
- chr->ip = sockt->str2ip(char_ip_str);
- }
- }
-
- loginif->init();
- do_init_mapif();
-
-
- timer->add_func_list(chr->broadcast_user_count, "chr->broadcast_user_count");
- timer->add_interval(timer->gettick() + 1000, chr->broadcast_user_count, 0, 0, 5 * 1000);
-
-
- timer->add_func_list(chr->waiting_disconnect, "chr->waiting_disconnect");
-
-
- timer->add_func_list(chr->online_data_cleanup, "chr->online_data_cleanup");
- timer->add_interval(timer->gettick() + 1000, chr->online_data_cleanup, 0, 0, 600 * 1000);
-
-
-
- if( (-1) == SQL->Query(inter->sql_handle, "DELETE FROM `%s` WHERE `account_id` = '0'", char_db) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 5847));
-
-
- if( (-1) == SQL->Query(inter->sql_handle, "DELETE FROM `%s` WHERE `guild_lv` = '0' AND `max_member` = '0' AND `exp` = '0' AND `next_exp` = '0' AND `average_lv` = '0'", guild_db) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 5851));
-
-
- if( (-1) == SQL->Query(inter->sql_handle, "DELETE FROM `%s` WHERE `guild_id` = '0' AND `account_id` = '0' AND `char_id` = '0'", guild_member_db) )
- (SQL->ShowDebug_((inter->sql_handle), "../../../server-code/src/char/char.c", 5855));
-
- sockt->set_defaultparse(chr->parse_char);
-
- if ((chr->char_fd = sockt->make_listen_bind(bind_ip,chr->port)) == -1) {
- (showmsg->showFatalError(("Failed to bind to port '""\033[1;37m""%d""\033[0m""'\n"),chr->port));
- exit(
-# 5861 "../../../server-code/src/char/char.c" 3 4
- 1
-# 5861 "../../../server-code/src/char/char.c"
- );
- }
-
- Sql_HerculesUpdateCheck(inter->sql_handle);
-
- console->input->setSQL(inter->sql_handle);
- console->display_gplnotice();
-
- (showmsg->showStatus(("The char-server is ""\033[1;32m""ready""\033[0m"" (Server is listening on the port %d).\n\n"), chr->port));
-
- if( core->runflag != CORE_ST_STOP )
- {
- core->shutdown_callback = do_shutdown;
- core->runflag = CHARSERVER_ST_RUNNING;
- }
-
- HPM->event(HPET_READY);
-
- return 0;
-}
-
-void char_load_defaults(void)
-{
- mapindex_defaults();
- pincode_defaults();
- char_defaults();
- loginif_defaults();
- mapif_defaults();
- inter_auction_defaults();
- inter_elemental_defaults();
- inter_guild_defaults();
- inter_homunculus_defaults();
- inter_mail_defaults();
- inter_mercenary_defaults();
- inter_party_defaults();
- inter_pet_defaults();
- inter_quest_defaults();
- inter_storage_defaults();
- inter_defaults();
- geoip_defaults();
-}
-
-void char_defaults(void)
-{
- chr = &char_s;
-
- memset(chr->server, 0, sizeof(chr->server));
-
- chr->login_fd = 0;
- chr->char_fd = -1;
- chr->online_char_db =
-# 5911 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 5911 "../../../server-code/src/char/char.c"
- ;
- chr->char_db_ =
-# 5912 "../../../server-code/src/char/char.c" 3 4
- ((void *)0)
-# 5912 "../../../server-code/src/char/char.c"
- ;
-
- memset(chr->userid, 0, sizeof(chr->userid));
- memset(chr->passwd, 0, sizeof(chr->passwd));
- memset(chr->server_name, 0, sizeof(chr->server_name));
-
- chr->ip = 0;
- chr->port = 6121;
- chr->server_type = 0;
- chr->new_display = 0;
-
- chr->waiting_disconnect = char_waiting_disconnect;
- chr->delete_char_sql = char_delete_char_sql;
- chr->create_online_char_data = char_create_online_char_data;
- chr->set_account_online = char_set_account_online;
- chr->set_account_offline = char_set_account_offline;
- chr->set_char_charselect = char_set_char_charselect;
- chr->set_char_online = char_set_char_online;
- chr->set_char_offline = char_set_char_offline;
- chr->db_setoffline = char_db_setoffline;
- chr->db_kickoffline = char_db_kickoffline;
- chr->set_login_all_offline = char_set_login_all_offline;
- chr->set_all_offline = char_set_all_offline;
- chr->set_all_offline_sql = char_set_all_offline_sql;
- chr->create_charstatus = char_create_charstatus;
- chr->mmo_char_tosql = char_mmo_char_tosql;
- chr->memitemdata_to_sql = char_memitemdata_to_sql;
- chr->mmo_gender = char_mmo_gender;
- chr->mmo_chars_fromsql = char_mmo_chars_fromsql;
- chr->mmo_char_fromsql = char_mmo_char_fromsql;
- chr->mmo_char_sql_init = char_mmo_char_sql_init;
- chr->char_slotchange = char_char_slotchange;
- chr->rename_char_sql = char_rename_char_sql;
- chr->check_char_name = char_check_char_name;
- chr->make_new_char_sql = char_make_new_char_sql;
- chr->divorce_char_sql = char_divorce_char_sql;
- chr->count_users = char_count_users;
- chr->mmo_char_tobuf = char_mmo_char_tobuf;
- chr->mmo_char_send099d = char_mmo_char_send099d;
- chr->mmo_char_send_ban_list = char_mmo_char_send_ban_list;
- chr->mmo_char_send_slots_info = char_mmo_char_send_slots_info;
- chr->mmo_char_send_characters = char_mmo_char_send_characters;
- chr->char_married = char_char_married;
- chr->char_child = char_char_child;
- chr->char_family = char_char_family;
- chr->disconnect_player = char_disconnect_player;
- chr->authfail_fd = char_authfail_fd;
- chr->request_account_data = char_request_account_data;
- chr->auth_ok = char_auth_ok;
- chr->ping_login_server = char_ping_login_server;
- chr->parse_fromlogin_connection_state = char_parse_fromlogin_connection_state;
- chr->auth_error = char_auth_error;
- chr->parse_fromlogin_auth_state = char_parse_fromlogin_auth_state;
- chr->parse_fromlogin_account_data = char_parse_fromlogin_account_data;
- chr->parse_fromlogin_login_pong = char_parse_fromlogin_login_pong;
- chr->changesex = char_changesex;
- chr->parse_fromlogin_changesex_reply = char_parse_fromlogin_changesex_reply;
- chr->parse_fromlogin_account_reg2 = char_parse_fromlogin_account_reg2;
- chr->parse_fromlogin_ban = char_parse_fromlogin_ban;
- chr->parse_fromlogin_kick = char_parse_fromlogin_kick;
- chr->update_ip = char_update_ip;
- chr->parse_fromlogin_update_ip = char_parse_fromlogin_update_ip;
- chr->parse_fromlogin_accinfo2_failed = char_parse_fromlogin_accinfo2_failed;
- chr->parse_fromlogin_accinfo2_ok = char_parse_fromlogin_accinfo2_ok;
- chr->parse_fromlogin = char_parse_fromlogin;
- chr->request_accreg2 = char_request_accreg2;
- chr->global_accreg_to_login_start = char_global_accreg_to_login_start;
- chr->global_accreg_to_login_send = char_global_accreg_to_login_send;
- chr->global_accreg_to_login_add = char_global_accreg_to_login_add;
- chr->read_fame_list = char_read_fame_list;
- chr->send_fame_list = char_send_fame_list;
- chr->update_fame_list = char_update_fame_list;
- chr->loadName = char_loadName;
- chr->parse_frommap_datasync = char_parse_frommap_datasync;
- chr->parse_frommap_skillid2idx = char_parse_frommap_skillid2idx;
- chr->map_received_ok = char_map_received_ok;
- chr->send_maps = char_send_maps;
- chr->parse_frommap_map_names = char_parse_frommap_map_names;
- chr->send_scdata = char_send_scdata;
- chr->parse_frommap_request_scdata = char_parse_frommap_request_scdata;
- chr->parse_frommap_set_users_count = char_parse_frommap_set_users_count;
- chr->parse_frommap_set_users = char_parse_frommap_set_users;
- chr->save_character_ack = char_save_character_ack;
- chr->parse_frommap_save_character = char_parse_frommap_save_character;
- chr->select_ack = char_select_ack;
- chr->parse_frommap_char_select_req = char_parse_frommap_char_select_req;
- chr->change_map_server_ack = char_change_map_server_ack;
- chr->parse_frommap_change_map_server = char_parse_frommap_change_map_server;
- chr->parse_frommap_remove_friend = char_parse_frommap_remove_friend;
- chr->char_name_ack = char_char_name_ack;
- chr->parse_frommap_char_name_request = char_parse_frommap_char_name_request;
- chr->parse_frommap_change_email = char_parse_frommap_change_email;
- chr->ban = char_ban;
- chr->unban = char_unban;
- chr->ask_name_ack = char_ask_name_ack;
- chr->changecharsex = char_changecharsex;
- chr->parse_frommap_change_account = char_parse_frommap_change_account;
- chr->parse_frommap_fame_list = char_parse_frommap_fame_list;
- chr->parse_frommap_divorce_char = char_parse_frommap_divorce_char;
- chr->parse_frommap_ragsrvinfo = char_parse_frommap_ragsrvinfo;
- chr->parse_frommap_set_char_offline = char_parse_frommap_set_char_offline;
- chr->parse_frommap_set_all_offline = char_parse_frommap_set_all_offline;
- chr->parse_frommap_set_char_online = char_parse_frommap_set_char_online;
- chr->parse_frommap_build_fame_list = char_parse_frommap_build_fame_list;
- chr->parse_frommap_save_status_change_data = char_parse_frommap_save_status_change_data;
- chr->send_pong = char_send_pong;
- chr->parse_frommap_ping = char_parse_frommap_ping;
- chr->map_auth_ok = char_map_auth_ok;
- chr->map_auth_failed = char_map_auth_failed;
- chr->parse_frommap_auth_request = char_parse_frommap_auth_request;
- chr->parse_frommap_update_ip = char_parse_frommap_update_ip;
- chr->parse_frommap_request_stats_report = char_parse_frommap_request_stats_report;
- chr->parse_frommap_scdata_update = char_parse_frommap_scdata_update;
- chr->parse_frommap_scdata_delete = char_parse_frommap_scdata_delete;
- chr->parse_frommap = char_parse_frommap;
- chr->search_mapserver = char_search_mapserver;
- chr->mapif_init = char_mapif_init;
- chr->lan_subnet_check = char_lan_subnet_check;
- chr->delete2_ack = char_delete2_ack;
- chr->delete2_accept_actual_ack = char_delete2_accept_actual_ack;
- chr->delete2_accept_ack = char_delete2_accept_ack;
- chr->delete2_cancel_ack = char_delete2_cancel_ack;
- chr->delete2_req = char_delete2_req;
- chr->delete2_accept = char_delete2_accept;
- chr->delete2_cancel = char_delete2_cancel;
- chr->send_account_id = char_send_account_id;
- chr->parse_char_connect = char_parse_char_connect;
- chr->send_map_info = char_send_map_info;
- chr->send_wait_char_server = char_send_wait_char_server;
- chr->search_default_maps_mapserver = char_search_default_maps_mapserver;
- chr->parse_char_select = char_parse_char_select;
- chr->creation_failed = char_creation_failed;
- chr->creation_ok = char_creation_ok;
- chr->parse_char_create_new_char = char_parse_char_create_new_char;
- chr->delete_char_failed = char_delete_char_failed;
- chr->delete_char_ok = char_delete_char_ok;
- chr->parse_char_delete_char = char_parse_char_delete_char;
- chr->parse_char_ping = char_parse_char_ping;
- chr->allow_rename = char_allow_rename;
- chr->parse_char_rename_char = char_parse_char_rename_char;
- chr->parse_char_rename_char2 = char_parse_char_rename_char2;
- chr->rename_char_ack = char_rename_char_ack;
- chr->parse_char_rename_char_confirm = char_parse_char_rename_char_confirm;
- chr->captcha_notsupported = char_captcha_notsupported;
- chr->parse_char_request_captcha = char_parse_char_request_captcha;
- chr->parse_char_check_captcha = char_parse_char_check_captcha;
- chr->parse_char_delete2_req = char_parse_char_delete2_req;
- chr->parse_char_delete2_accept = char_parse_char_delete2_accept;
- chr->parse_char_delete2_cancel = char_parse_char_delete2_cancel;
- chr->login_map_server_ack = char_login_map_server_ack;
- chr->parse_char_login_map_server = char_parse_char_login_map_server;
- chr->parse_char_pincode_check = char_parse_char_pincode_check;
- chr->parse_char_pincode_window = char_parse_char_pincode_window;
- chr->parse_char_pincode_change = char_parse_char_pincode_change;
- chr->parse_char_pincode_first_pin = char_parse_char_pincode_first_pin;
- chr->parse_char_request_chars = char_parse_char_request_chars;
- chr->change_character_slot_ack = char_change_character_slot_ack;
- chr->parse_char_move_character = char_parse_char_move_character;
- chr->parse_char_unknown_packet = char_parse_char_unknown_packet;
- chr->parse_char = char_parse_char;
- chr->broadcast_user_count = char_broadcast_user_count;
- chr->send_accounts_tologin_sub = char_send_accounts_tologin_sub;
- chr->send_accounts_tologin = char_send_accounts_tologin;
- chr->check_connect_login_server = char_check_connect_login_server;
- chr->online_data_cleanup_sub = char_online_data_cleanup_sub;
- chr->online_data_cleanup = char_online_data_cleanup;
- chr->sql_config_read = char_sql_config_read;
- chr->config_dispatch = char_config_dispatch;
- chr->config_read = char_config_read;
-}