Closed GoogleCodeExporter closed 8 years ago
Hm.. Some times it dosn't crashed, but more often crashes... very strange
bug... It's seems it can enter world while server is offline... )))
next step 0xA9 Packet it's again wrong for HS.
It must be smt like this:
if (fluo::net::Manager::getSingleton()->getProtocolVersion() >= ProtocolVersion::HS) // this code is not only for HS but for SA clients above 7.0.13.0
for (unsigned int i = 0; i < cityCount_; ++i) {
ret &= PacketReader::read(buf, len, index, idx);
cityIndices_.push_back(idx);
ret &= PacketReader::readUtf8Fixed(buf, len, index, tmp, 32);
cityNames_.push_back(tmp);
ret &= PacketReader::readUtf8Fixed(buf, len, index, tmp, 32);
tavernNames_.push_back(tmp);
uint32_t temp; // just read and skip values
PacketReader::read(buf, len, index, temp); // X
PacketReader::read(buf, len, index, temp); // Y
PacketReader::read(buf, len, index, temp); // Z
PacketReader::read(buf, len, index, temp); // Map
PacketReader::read(buf, len, index, temp); // Description (cliloc ID)
PacketReader::read(buf, len, index, temp); // 0
}
else
for (unsigned int i = 0; i < cityCount_; ++i) {
ret &= PacketReader::read(buf, len, index, idx);
cityIndices_.push_back(idx);
ret &= PacketReader::readUtf8Fixed(buf, len, index, tmp, 31);
cityNames_.push_back(tmp);
ret &= PacketReader::readUtf8Fixed(buf, len, index, tmp, 31);
tavernNames_.push_back(tmp);
}
unsigned int readSize = (fluo::net::Manager::getSingleton()->getProtocolVersion() >= ProtocolVersion::HS) // this code is not only for HS but for SA clients above 7.0.13.0
? 5 + charCount_*60 + cityCount_*89 : 5 + charCount_*60 + cityCount_*63;
Original comment by staticz@uoquint.ru
on 17 Aug 2012 at 4:08
PS Please Ither delete default config ither don't forget to update it's
content. I spend a lot of time trying understand why anything doesn't work
looking for it....
Original comment by staticz@uoquint.ru
on 17 Aug 2012 at 4:13
I made misstake in last line, the correct one:
if (fluo::net::Manager::getSingleton()->getProtocolVersion() >=
ProtocolVersion::HS) // this code is not only for HS but for SA clients above
7.0.13.0
for (unsigned int i = 0; i < cityCount_; ++i) {
ret &= PacketReader::read(buf, len, index, idx);
cityIndices_.push_back(idx);
ret &= PacketReader::readUtf8Fixed(buf, len, index, tmp, 32);
cityNames_.push_back(tmp);
ret &= PacketReader::readUtf8Fixed(buf, len, index, tmp, 32);
tavernNames_.push_back(tmp);
uint32_t temp; // just read and skip values
PacketReader::read(buf, len, index, temp); // X
PacketReader::read(buf, len, index, temp); // Y
PacketReader::read(buf, len, index, temp); // Z
PacketReader::read(buf, len, index, temp); // Map
PacketReader::read(buf, len, index, temp); // Description (cliloc ID)
PacketReader::read(buf, len, index, temp); // 0
unsigned int readSize = 5 + charCount_*60 + cityCount_*89;
if (size_ - readSize == 4 || size_ - readSize == 6) {
PacketReader::read(buf, len, index, flags_);
}
if (size_ - readSize == 6) {
uint16_t temp2; // just read and skip values
PacketReader::read(buf, len, index, temp2); // Last Character Slot
}
}
else
for (unsigned int i = 0; i < cityCount_; ++i) {
ret &= PacketReader::read(buf, len, index, idx);
cityIndices_.push_back(idx);
ret &= PacketReader::readUtf8Fixed(buf, len, index, tmp, 31);
cityNames_.push_back(tmp);
ret &= PacketReader::readUtf8Fixed(buf, len, index, tmp, 31);
tavernNames_.push_back(tmp);
unsigned int readSize = 5 + charCount_*60 + cityCount_*63;
if (size_ - readSize == 4) {
PacketReader::read(buf, len, index, flags_);
}
}
Original comment by staticz@uoquint.ru
on 17 Aug 2012 at 5:18
maybe it's better to name protocol as client version like runuo:
"post6.0.14.3", "post7.0.13.0", etc?
Original comment by staticz@uoquint.ru
on 17 Aug 2012 at 5:35
i found line in manager.cpp
void Manager::systemMessage(const UnicodeString& msg, unsigned int hue,
unsigned int font) {
LOG_INFO << "SysMsg: " << msg << std::endl;
sysLog_->add(msg, hue, font);
// TODO: add to journal
}
and delted "sysLog_->add(msg, hue, font);" now client doesn't crashing at
lohing, but ofcourse there are no any text... So the problem is related with
fontengine.
Original comment by staticz@uoquint.ru
on 17 Aug 2012 at 7:43
It's difficult without debuger.. ))
Original comment by staticz@uoquint.ru
on 17 Aug 2012 at 7:44
With the most recent version, the debugger was working (at least on my
computer).
Maybe this is related to one of the changes I had to make to get the debugger
running:
misc/string.cpp, try changing line 34 back to
UnicodeString ret = UnicodeString::fromUTF8(string);
It did not work for me in the debugger, maybe I should use some preprocessor
instructions around it.
I'll integrate the packet fix in one of the next updates.
Original comment by spin@fluorescence-client.org
on 18 Aug 2012 at 5:55
should be fixed in the next release
Original comment by spin@fluorescence-client.org
on 9 Nov 2012 at 7:14
Original issue reported on code.google.com by
staticz@uoquint.ru
on 17 Aug 2012 at 12:15Attachments: