mirror of
https://github.com/EQEmu/Server.git
synced 2026-06-16 22:18:20 +00:00
Phase 1 Offline Trading
Cleanup and testing Zone updated builds ok World updated builds ok Update guild_base.h
This commit is contained in:
+15
-11
@@ -1845,7 +1845,7 @@ namespace RoF2
|
||||
e->zoneinstance = 0;
|
||||
e->zone_id = htons(emu_e->zone_id);
|
||||
e->unknown_one2 = htonl(1);
|
||||
e->unknown04 = 0;
|
||||
e->offline_mode = htonl(emu_e->offline_mode);
|
||||
|
||||
#undef SlideStructString
|
||||
#undef PutFieldN
|
||||
@@ -1862,14 +1862,12 @@ namespace RoF2
|
||||
{
|
||||
SETUP_DIRECT_ENCODE(GuildMemberUpdate_Struct, structs::GuildMemberUpdate_Struct);
|
||||
|
||||
OUT(GuildID);
|
||||
memcpy(eq->MemberName, emu->MemberName, sizeof(eq->MemberName));
|
||||
//OUT(ZoneID);
|
||||
//OUT(InstanceID);
|
||||
eq->InstanceID = emu->InstanceID;
|
||||
eq->ZoneID = emu->ZoneID;
|
||||
OUT(LastSeen);
|
||||
eq->Unknown76 = 0;
|
||||
eq->guild_id = emu->GuildID;
|
||||
eq->last_seen = emu->LastSeen;
|
||||
eq->instance_id = emu->InstanceID;
|
||||
eq->zone_id = emu->ZoneID;
|
||||
eq->offline_mode = emu->offline_mode;
|
||||
memcpy(eq->member_name, emu->MemberName, sizeof(eq->member_name));
|
||||
|
||||
FINISH_ENCODE();
|
||||
}
|
||||
@@ -4475,6 +4473,7 @@ namespace RoF2
|
||||
*p = nullptr;
|
||||
|
||||
char *InBuffer = (char *)in->pBuffer;
|
||||
std::vector<uint32> p_ids { 0x430, 0x420 };
|
||||
|
||||
WhoAllReturnStruct *wars = (WhoAllReturnStruct*)InBuffer;
|
||||
|
||||
@@ -4500,8 +4499,9 @@ namespace RoF2
|
||||
x = VARSTRUCT_DECODE_TYPE(uint32, InBuffer);
|
||||
VARSTRUCT_ENCODE_TYPE(uint32, OutBuffer, x);
|
||||
|
||||
InBuffer += 4;
|
||||
VARSTRUCT_ENCODE_TYPE(uint32, OutBuffer, 0);
|
||||
x = VARSTRUCT_DECODE_TYPE(uint32, InBuffer);
|
||||
VARSTRUCT_ENCODE_TYPE(uint32, OutBuffer, std::ranges::find(p_ids.begin(), p_ids.end(), x) == p_ids.end() ? 0 : x);
|
||||
|
||||
VARSTRUCT_ENCODE_TYPE(uint32, OutBuffer, 0xffffffff);
|
||||
|
||||
char Name[64];
|
||||
@@ -4737,6 +4737,10 @@ namespace RoF2
|
||||
OtherData = OtherData | 0x01;
|
||||
}
|
||||
|
||||
if (emu->offline) {
|
||||
OtherData = OtherData | 0x02;
|
||||
}
|
||||
|
||||
VARSTRUCT_ENCODE_TYPE(uint8, Buffer, OtherData);
|
||||
// float EmitterScalingRadius
|
||||
|
||||
|
||||
@@ -3681,22 +3681,22 @@ struct SimpleMessage_Struct{
|
||||
// Size: 52 + strings
|
||||
// Other than the strings, all of this packet is network byte order (reverse from normal)
|
||||
struct GuildMemberEntry_Struct {
|
||||
char name[1]; // variable length
|
||||
uint32 level;
|
||||
uint32 banker; // 1=yes, 0=no
|
||||
uint32 class_;
|
||||
uint32 rank;
|
||||
uint32 time_last_on;
|
||||
uint32 tribute_enable;
|
||||
uint32 unknown01; // Seen 0
|
||||
uint32 total_tribute; // total guild tribute donated, network byte order
|
||||
uint32 last_tribute; // unix timestamp
|
||||
uint32 unknown_one; // unknown, set to 1
|
||||
char public_note[1]; // variable length.
|
||||
uint16 zoneinstance; // Seen 0s or -1 in RoF2
|
||||
uint16 zone_id; // Seen 0s or -1 in RoF2
|
||||
uint32 unknown_one2; // unknown, set to 1
|
||||
uint32 unknown04; // Seen 0
|
||||
char name[1]; // variable length
|
||||
uint32 level;
|
||||
uint32 banker; // 1=yes, 0=no
|
||||
uint32 class_;
|
||||
uint32 rank;
|
||||
uint32 time_last_on;
|
||||
uint32 tribute_enable;
|
||||
uint32 unknown01; // Seen 0
|
||||
uint32 total_tribute; // total guild tribute donated, network byte order
|
||||
uint32 last_tribute; // unix timestamp
|
||||
uint32 unknown_one; // unknown, set to 1
|
||||
char public_note[1]; // variable length.
|
||||
uint16 zoneinstance; // Seen 0s or -1 in RoF2
|
||||
uint16 zone_id; // Seen 0s or -1 in RoF2
|
||||
uint32 unknown_one2; // unknown, set to 1
|
||||
uint32 offline_mode; // Displays OFFLINE MODE instead of Zone Name
|
||||
};
|
||||
|
||||
//just for display purposes, this is not actually used in the message encoding other than for size.
|
||||
@@ -3731,13 +3731,12 @@ struct GuildStatus_Struct
|
||||
};
|
||||
|
||||
struct GuildMemberUpdate_Struct {
|
||||
/*00*/ uint32 GuildID;
|
||||
/*04*/ char MemberName[64];
|
||||
/*68*/ uint16 ZoneID;
|
||||
/*70*/ uint16 InstanceID; //speculated
|
||||
/*72*/ uint32 LastSeen; //unix timestamp
|
||||
/*76*/ uint32 Unknown76;
|
||||
/*80*/
|
||||
/*00*/ uint32 guild_id;
|
||||
/*04*/ char member_name[64];
|
||||
/*68*/ uint16 zone_id;
|
||||
/*70*/ uint16 instance_id; //speculated
|
||||
/*72*/ uint32 last_seen; //unix timestamp
|
||||
/*76*/ uint32 offline_mode;
|
||||
};
|
||||
|
||||
struct GuildMemberLevelUpdate_Struct {
|
||||
|
||||
Reference in New Issue
Block a user