int_elemental.cpp 5.7 KB

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