rathena/src/map/log.hpp
Lemongrass3110 e40da669ed
Initial release of barter shops (#6508)
Fixes #5062

Thanks to @Atemo and @aleos89

Co-authored-by: Atemo <Atemo@users.noreply.github.com>
Co-authored-by: Aleos <aleos89@users.noreply.github.com>
2022-01-21 00:59:16 +01:00

105 lines
3.4 KiB
C++

// Copyright (c) rAthena Dev Teams - Licensed under GNU GPL
// For more information, see LICENCE in the main folder
#ifndef LOG_HPP
#define LOG_HPP
#include "../common/cbasetypes.hpp"
#include "../common/mmo.hpp"
struct block_list;
struct map_session_data;
struct mob_data;
struct item;
enum e_log_chat_type : uint8
{
LOG_CHAT_GLOBAL = 0x01,
LOG_CHAT_WHISPER = 0x02,
LOG_CHAT_PARTY = 0x04,
LOG_CHAT_GUILD = 0x08,
LOG_CHAT_MAINCHAT = 0x10,
LOG_CHAT_CLAN = 0x20,
// all
LOG_CHAT_ALL = 0xFF,
};
enum e_log_pick_type : uint32
{
LOG_TYPE_NONE = 0x0000000,
LOG_TYPE_TRADE = 0x0000001,
LOG_TYPE_VENDING = 0x0000002,
LOG_TYPE_PICKDROP_PLAYER = 0x0000004,
LOG_TYPE_PICKDROP_MONSTER = 0x0000008,
LOG_TYPE_NPC = 0x0000010,
LOG_TYPE_SCRIPT = 0x0000020,
LOG_TYPE_STEAL = 0x0000040,
LOG_TYPE_CONSUME = 0x0000080,
LOG_TYPE_PRODUCE = 0x0000100,
LOG_TYPE_MVP = 0x0000200,
LOG_TYPE_COMMAND = 0x0000400,
LOG_TYPE_STORAGE = 0x0000800,
LOG_TYPE_GSTORAGE = 0x0001000,
LOG_TYPE_MAIL = 0x0002000,
LOG_TYPE_AUCTION = 0x0004000,
LOG_TYPE_BUYING_STORE = 0x0008000,
LOG_TYPE_OTHER = 0x0010000,
LOG_TYPE_CASH = 0x0020000,
LOG_TYPE_BANK = 0x0040000,
LOG_TYPE_BOUND_REMOVAL = 0x0080000,
LOG_TYPE_ROULETTE = 0x0100000,
LOG_TYPE_MERGE_ITEM = 0x0200000,
LOG_TYPE_QUEST = 0x0400000,
LOG_TYPE_PRIVATE_AIRSHIP = 0x0800000,
LOG_TYPE_BARTER = 0x1000000,
// combinations
LOG_TYPE_LOOT = LOG_TYPE_PICKDROP_MONSTER|LOG_TYPE_CONSUME,
// all
LOG_TYPE_ALL = 0xFFFFFFF,
};
enum e_log_cash_type : uint8
{
LOG_CASH_TYPE_CASH = 0x1,
LOG_CASH_TYPE_KAFRA = 0x2
};
enum e_log_feeding_type : uint8
{
LOG_FEED_HOMUNCULUS = 0x1,
LOG_FEED_PET = 0x2,
};
/// new logs
void log_pick_pc(struct map_session_data* sd, e_log_pick_type type, int amount, struct item* itm);
void log_pick_mob(struct mob_data* md, e_log_pick_type type, int amount, struct item* itm);
void log_zeny(struct map_session_data* sd, e_log_pick_type type, struct map_session_data* src_sd, int amount);
void log_cash( struct map_session_data* sd, e_log_pick_type type, e_log_cash_type cash_type, int amount );
void log_npc( struct npc_data* nd, const char* message );
void log_npc(struct map_session_data* sd, const char *message);
void log_chat(e_log_chat_type type, int type_id, int src_charid, int src_accid, const char* map, int x, int y, const char* dst_charname, const char* message);
void log_atcommand(struct map_session_data* sd, const char* message);
void log_feeding(struct map_session_data *sd, e_log_feeding_type type, t_itemid nameid);
/// old, but useful logs
void log_branch(struct map_session_data* sd);
void log_mvpdrop(struct map_session_data* sd, int monster_id, t_itemid nameid, t_exp exp);
int log_config_read(const char* cfgName);
extern struct Log_Config
{
e_log_pick_type enable_logs;
int filter;
bool sql_logs;
bool log_chat_woe_disable;
bool cash;
int rare_items_log,refine_items_log,price_items_log,amount_items_log; //for filter
int branch, mvpdrop, zeny, commands, npc, chat;
unsigned feeding : 2;
char log_branch[64], log_pick[64], log_zeny[64], log_mvpdrop[64], log_gm[64], log_npc[64], log_chat[64], log_cash[64];
char log_feeding[64];
} log_config;
#endif /* LOG_HPP */