diff options
Diffstat (limited to 'servergreps/hercules/20141016/src/char.c')
-rw-r--r-- | servergreps/hercules/20141016/src/char.c | 16364 |
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(×tamp); - 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, ×tamp, 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; -} |