int_elemental.c 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  1. // Copyright (c) Athena Dev Teams - Licensed under GNU GPL
  2. // For more information, see LICENCE in the main folder
  3. #include "../common/mmo.h"
  4. #include "../common/strlib.h"
  5. #include "../common/showmsg.h"
  6. #include "../common/socket.h"
  7. #include "../common/sql.h"
  8. #include "char.h"
  9. #include "inter.h"
  10. #include <stdlib.h>
  11. bool mapif_elemental_save(struct s_elemental* ele) {
  12. bool flag = true;
  13. if( ele->elemental_id == 0 ) { // Create new DB entry
  14. if( SQL_ERROR == Sql_Query(sql_handle,
  15. "INSERT INTO `%s` (`char_id`,`class`,`mode`,`hp`,`sp`,`max_hp`,`max_sp`,`atk1`,`atk2`,`matk`,`aspd`,`def`,`mdef`,`flee`,`hit`,`life_time`)"
  16. "VALUES ('%d','%d','%d','%d','%d','%d','%d','%d','%d','%d','%d','%d','%d','%d','%d','%u')",
  17. schema_config.elemental_db, ele->char_id, ele->class_, ele->mode, ele->hp, ele->sp, ele->max_hp, ele->max_sp, ele->atk, ele->atk2, ele->matk, ele->amotion, ele->def, ele->mdef, ele->flee, ele->hit, ele->life_time) )
  18. {
  19. Sql_ShowDebug(sql_handle);
  20. flag = false;
  21. }
  22. else
  23. ele->elemental_id = (int)Sql_LastInsertId(sql_handle);
  24. } else if( SQL_ERROR == Sql_Query(sql_handle,
  25. "UPDATE `%s` SET `char_id` = '%d', `class` = '%d', `mode` = '%d', `hp` = '%d', `sp` = '%d',"
  26. "`max_hp` = '%d', `max_sp` = '%d', `atk1` = '%d', `atk2` = '%d', `matk` = '%d', `aspd` = '%d', `def` = '%d',"
  27. "`mdef` = '%d', `flee` = '%d', `hit` = '%d', `life_time` = '%u' WHERE `ele_id` = '%d'", schema_config.elemental_db,
  28. ele->char_id, ele->class_, ele->mode, ele->hp, ele->sp, ele->max_hp, ele->max_sp, ele->atk, ele->atk2,
  29. ele->matk, ele->amotion, ele->def, ele->mdef, ele->flee, ele->hit, ele->life_time, ele->elemental_id) )
  30. { // Update DB entry
  31. Sql_ShowDebug(sql_handle);
  32. flag = false;
  33. }
  34. return flag;
  35. }
  36. bool mapif_elemental_load(int ele_id, uint32 char_id, struct s_elemental *ele) {
  37. char* data;
  38. memset(ele, 0, sizeof(struct s_elemental));
  39. ele->elemental_id = ele_id;
  40. ele->char_id = char_id;
  41. if( SQL_ERROR == Sql_Query(sql_handle, "SELECT `class`, `mode`, `hp`, `sp`, `max_hp`, `max_sp`, `atk1`, `atk2`, `matk`, `aspd`,"
  42. "`def`, `mdef`, `flee`, `hit`, `life_time` FROM `%s` WHERE `ele_id` = '%d' AND `char_id` = '%d'",
  43. schema_config.elemental_db, ele_id, char_id) ) {
  44. Sql_ShowDebug(sql_handle);
  45. return false;
  46. }
  47. if( SQL_SUCCESS != Sql_NextRow(sql_handle) ) {
  48. Sql_FreeResult(sql_handle);
  49. return false;
  50. }
  51. Sql_GetData(sql_handle, 0, &data, NULL); ele->class_ = atoi(data);
  52. Sql_GetData(sql_handle, 1, &data, NULL); ele->mode = atoi(data);
  53. Sql_GetData(sql_handle, 2, &data, NULL); ele->hp = atoi(data);
  54. Sql_GetData(sql_handle, 3, &data, NULL); ele->sp = atoi(data);
  55. Sql_GetData(sql_handle, 4, &data, NULL); ele->max_hp = atoi(data);
  56. Sql_GetData(sql_handle, 5, &data, NULL); ele->max_sp = atoi(data);
  57. Sql_GetData(sql_handle, 6, &data, NULL); ele->atk = atoi(data);
  58. Sql_GetData(sql_handle, 7, &data, NULL); ele->atk2 = atoi(data);
  59. Sql_GetData(sql_handle, 8, &data, NULL); ele->matk = atoi(data);
  60. Sql_GetData(sql_handle, 9, &data, NULL); ele->amotion = atoi(data);
  61. Sql_GetData(sql_handle, 10, &data, NULL); ele->def = atoi(data);
  62. Sql_GetData(sql_handle, 11, &data, NULL); ele->mdef = atoi(data);
  63. Sql_GetData(sql_handle, 12, &data, NULL); ele->flee = atoi(data);
  64. Sql_GetData(sql_handle, 13, &data, NULL); ele->hit = atoi(data);
  65. Sql_GetData(sql_handle, 14, &data, NULL); ele->life_time = atoi(data);
  66. Sql_FreeResult(sql_handle);
  67. if( charserv_config.save_log )
  68. ShowInfo("Elemental loaded (ID: %d / Class: %d / CID: %d).\n", ele->elemental_id, ele->class_, ele->char_id);
  69. return true;
  70. }
  71. bool mapif_elemental_delete(int ele_id) {
  72. if( SQL_ERROR == Sql_Query(sql_handle, "DELETE FROM `%s` WHERE `ele_id` = '%d'", schema_config.elemental_db, ele_id) ) {
  73. Sql_ShowDebug(sql_handle);
  74. return false;
  75. }
  76. return true;
  77. }
  78. static void mapif_elemental_send(int fd, struct s_elemental *ele, unsigned char flag) {
  79. int size = sizeof(struct s_elemental) + 5;
  80. WFIFOHEAD(fd,size);
  81. WFIFOW(fd,0) = 0x387c;
  82. WFIFOW(fd,2) = size;
  83. WFIFOB(fd,4) = flag;
  84. memcpy(WFIFOP(fd,5),ele,sizeof(struct s_elemental));
  85. WFIFOSET(fd,size);
  86. }
  87. static void mapif_parse_elemental_create(int fd, struct s_elemental* ele) {
  88. bool result = mapif_elemental_save(ele);
  89. mapif_elemental_send(fd, ele, result);
  90. }
  91. static void mapif_parse_elemental_load(int fd, int ele_id, uint32 char_id) {
  92. struct s_elemental ele;
  93. bool result = mapif_elemental_load(ele_id, char_id, &ele);
  94. mapif_elemental_send(fd, &ele, result);
  95. }
  96. static void mapif_elemental_deleted(int fd, unsigned char flag) {
  97. WFIFOHEAD(fd,3);
  98. WFIFOW(fd,0) = 0x387d;
  99. WFIFOB(fd,2) = flag;
  100. WFIFOSET(fd,3);
  101. }
  102. static void mapif_parse_elemental_delete(int fd, int ele_id) {
  103. bool result = mapif_elemental_delete(ele_id);
  104. mapif_elemental_deleted(fd, result);
  105. }
  106. static void mapif_elemental_saved(int fd, unsigned char flag) {
  107. WFIFOHEAD(fd,3);
  108. WFIFOW(fd,0) = 0x387e;
  109. WFIFOB(fd,2) = flag;
  110. WFIFOSET(fd,3);
  111. }
  112. static void mapif_parse_elemental_save(int fd, struct s_elemental* ele) {
  113. bool result = mapif_elemental_save(ele);
  114. mapif_elemental_saved(fd, result);
  115. }
  116. void inter_elemental_sql_init(void) {
  117. return;
  118. }
  119. void inter_elemental_sql_final(void) {
  120. return;
  121. }
  122. /*==========================================
  123. * Inter Packets
  124. *------------------------------------------*/
  125. int inter_elemental_parse_frommap(int fd) {
  126. unsigned short cmd = RFIFOW(fd,0);
  127. switch( cmd ) {
  128. case 0x307c: mapif_parse_elemental_create(fd, (struct s_elemental*)RFIFOP(fd,4)); break;
  129. case 0x307d: mapif_parse_elemental_load(fd, (int)RFIFOL(fd,2), (int)RFIFOL(fd,6)); break;
  130. case 0x307e: mapif_parse_elemental_delete(fd, (int)RFIFOL(fd,2)); break;
  131. case 0x307f: mapif_parse_elemental_save(fd, (struct s_elemental*)RFIFOP(fd,4)); break;
  132. default:
  133. return 0;
  134. }
  135. return 1;
  136. }