Yardım depo safra sorunu

  • Konuyu açan Konuyu açan bosymax
  • Açılış Tarihi Açılış Tarihi
  • Yanıt Yanıt 22
  • Gösterim Gösterim 1K
Konu sahibi bu konuda soru soruyor. Sorusu ile ilgili bilgisi olanların yanıtlamasını bekliyor.

bosymax

Development
Geliştirici
MT Üye
Mesaj
230
Çözümler
14
Beğeni
113
Puan
749
Ticaret Puanı
0
öncelikle yaptığım şeylerin %80ini geri alıp kontrol edebildim fakat bulamadım depoya koyduğum itemlerin ek özellikleri safra vb şeyler gelip bozuluyor nerede hata olmuş olabilir acaba ?

depoya koyunca oluşan hata
image.png


depodan geri alınca sıkıntı yok fakat depoyu içindekiyle kapatıp açınca da
C++:
Genişlet Daralt Kopyala
0727 01:11:30345 :: Unknown packet header: 191, last: 70 67
hatası veriyor
image2af4187709c7cca7.png


client debug mod ile gözlemlediğim hata kodu

C++:
Genişlet Daralt Kopyala
CItemManager::SelectedItem Data - FIND ERROR [8192]
 

Dosya Eklentileri

  • Depodayken.webp
    Depodayken.webp
    230,4 KB · Gösterim: 196
  • Envanterdayken.webp
    Envanterdayken.webp
    150 KB · Gösterim: 199
Son düzenleme:
safebox.cpp
Linkleri görebilmek için giriş yap veya kayıt ol.

C++:
Genişlet Daralt Kopyala
#include "stdafx.h"
#include "../../libgame/include/grid.h"
#include "constants.h"
#include "safebox.h"
#include "packet.h"
#include "char.h"
#include "desc_client.h"
#include "item.h"
#include "item_manager.h"

CSafebox::CSafebox(LPCHARACTER pkChrOwner, int iSize, DWORD dwGold) : m_pkChrOwner(pkChrOwner), m_iSize(iSize), m_lGold(dwGold)
{
    assert(m_pkChrOwner != NULL);
    memset(m_pkItems, 0, sizeof(m_pkItems));

    if (m_iSize)
        m_pkGrid = M2_NEW CGrid(5, m_iSize);
    else
        m_pkGrid = NULL;

    m_bWindowMode = SAFEBOX;
}

CSafebox::~CSafebox()
{
    __Destroy();
}

void CSafebox::SetWindowMode(BYTE bMode)
{
    m_bWindowMode = bMode;
}

void CSafebox::__Destroy()
{
    for (int i = 0; i < SAFEBOX_MAX_NUM; ++i)
    {
        if (m_pkItems[i])
        {
            m_pkItems[i]->SetSkipSave(true);
            ITEM_MANAGER::instance().FlushDelayedSave(m_pkItems[i]);

            M2_DESTROY_ITEM(m_pkItems[i]->RemoveFromCharacter());
            m_pkItems[i] = NULL;
        }
    }

    if (m_pkGrid)
    {
        M2_DELETE(m_pkGrid);
        m_pkGrid = NULL;
    }
}

bool CSafebox::Add(DWORD dwPos, LPITEM pkItem)
{
    if (!IsValidPosition(dwPos))
    {
        sys_err("SAFEBOX: item on wrong position at %d (size of grid = %d)", dwPos, m_pkGrid->GetSize());
        return false;
    }

    pkItem->SetWindow(m_bWindowMode);
    pkItem->SetCell(m_pkChrOwner, dwPos);
    pkItem->Save(); // °Á¦·Î Save¸¦ ºÒ·¯Áà¾ß ÇÑ´Ù.
    ITEM_MANAGER::instance().FlushDelayedSave(pkItem);

    m_pkGrid->Put(dwPos, 1, pkItem->GetSize());
    m_pkItems[dwPos] = pkItem;

    TPacketGCItemSet pack;

    pack.header    = m_bWindowMode == SAFEBOX ? HEADER_GC_SAFEBOX_SET : HEADER_GC_MALL_SET;
    pack.Cell    = TItemPos(m_bWindowMode, dwPos);
    pack.vnum    = pkItem->GetVnum();
    pack.count    = pkItem->GetCount();
    pack.flags    = pkItem->GetFlag();
    pack.anti_flags    = pkItem->GetAntiFlag();
    thecore_memcpy(pack.alSockets, pkItem->GetSockets(), sizeof(pack.alSockets));
    thecore_memcpy(pack.aAttr, pkItem->GetAttributes(), sizeof(pack.aAttr));
  
    m_pkChrOwner->GetDesc()->Packet(&pack, sizeof(pack));
    sys_log(1, "SAFEBOX: ADD %s %s count %d", m_pkChrOwner->GetName(), pkItem->GetName(), pkItem->GetCount());
    return true;
}

LPITEM CSafebox::Get(DWORD dwPos)
{
    if (dwPos >= m_pkGrid->GetSize())
        return NULL;

    return m_pkItems[dwPos];
}

LPITEM CSafebox::Remove(DWORD dwPos)
{
    LPITEM pkItem = Get(dwPos);

    if (!pkItem)
        return NULL;

    if (!m_pkGrid)
        sys_err("Safebox::Remove : nil grid");
    else
        m_pkGrid->Get(dwPos, 1, pkItem->GetSize());

    pkItem->RemoveFromCharacter();

    m_pkItems[dwPos] = NULL;

    TPacketGCItemDel pack;

    pack.header    = m_bWindowMode == SAFEBOX ? HEADER_GC_SAFEBOX_DEL : HEADER_GC_MALL_DEL;
    pack.pos    = dwPos;

    m_pkChrOwner->GetDesc()->Packet(&pack, sizeof(pack));
    sys_log(1, "SAFEBOX: REMOVE %s %s count %d", m_pkChrOwner->GetName(), pkItem->GetName(), pkItem->GetCount());
    return pkItem;
}

void CSafebox::Save()
{
    TSafeboxTable t;

    memset(&t, 0, sizeof(TSafeboxTable));

    t.dwID = m_pkChrOwner->GetDesc()->GetAccountTable().id;
    t.dwGold = m_lGold;

    db_clientdesc->DBPacket(HEADER_GD_SAFEBOX_SAVE, 0, &t, sizeof(TSafeboxTable));
    sys_log(1, "SAFEBOX: SAVE %s", m_pkChrOwner->GetName());
}

bool CSafebox::IsEmpty(DWORD dwPos, BYTE bSize)
{
    if (!m_pkGrid)
        return false;

    return m_pkGrid->IsEmpty(dwPos, 1, bSize);
}

void CSafebox::ChangeSize(int iSize)
{
    // ÇöÀç »çÀÌÁî°¡ ÀÎÀÚº¸´Ù Å©¸é »çÀÌÁ °¡¸¸ µĞ´Ù.
    if (m_iSize >= iSize)
        return;

    m_iSize = iSize;

    CGrid * pkOldGrid = m_pkGrid;

    if (pkOldGrid) {//diviner3
        m_pkGrid = M2_NEW CGrid(pkOldGrid, 5, m_iSize);
        delete pkOldGrid;
    }
    else
        m_pkGrid = M2_NEW CGrid(5, m_iSize);
}

LPITEM CSafebox::GetItem(INT bCell)
{
    if (bCell >= 5 * m_iSize)
    {
        sys_err("CHARACTER::GetItem: invalid item cell %d", bCell);
        return NULL;
    }

    return m_pkItems[bCell];
}

bool CSafebox::MoveItem(INT bCell, INT bDestCell, short count)
{
    LPITEM item;

    int max_position = 5 * m_iSize;

    if (bCell >= max_position || bDestCell >= max_position)
        return false;

    if (!(item = GetItem(bCell)))
        return false;

    if (item->IsExchanging())
        return false;

    if (item->GetCount() < (unsigned short) count)
        return false;

    {
        LPITEM item2;

        if ((item2 = GetItem(bDestCell)) && item != item2 && item2->IsStackable() &&
                !IS_SET(item2->GetAntiFlag(), ITEM_ANTIFLAG_STACK) &&
                item2->GetVnum() == item->GetVnum()) // ÇÕÄ¥ ¼ö ÀÖ´Â ¾ÆÀÌÅÛÀÇ °æ¿ì
        {
            for (int i = 0; i < ITEM_SOCKET_MAX_NUM; ++i)
                if (item2->GetSocket(i) != item->GetSocket(i))
                    return false;

            if (count == 0)
                count = item->GetCount();

            count = MIN(ITEM_MAX_COUNT - item2->GetCount(), count);

            if (item->GetCount() >= (unsigned short) count)
                Remove(bCell);

            item->SetCount(item->GetCount() - count);
            item2->SetCount(item2->GetCount() + count);

            sys_log(1, "SAFEBOX: STACK %s %d -> %d %s count %d", m_pkChrOwner->GetName(), bCell, bDestCell, item2->GetName(), item2->GetCount());
            return true;
        }

        if (!IsEmpty(bDestCell, item->GetSize()))
            return false;

        m_pkGrid->Get(bCell, 1, item->GetSize());

        if (!m_pkGrid->Put(bDestCell, 1, item->GetSize()))
        {
            m_pkGrid->Put(bCell, 1, item->GetSize());
            return false;
        }
        else
        {
            m_pkGrid->Get(bDestCell, 1, item->GetSize());
            m_pkGrid->Put(bCell, 1, item->GetSize());
        }

        sys_log(1, "SAFEBOX: MOVE %s %d -> %d %s count %d", m_pkChrOwner->GetName(), bCell, bDestCell, item->GetName(), item->GetCount());

        Remove(bCell);
        Add(bDestCell, item);
    }

    return true;
}

bool CSafebox::IsValidPosition(DWORD dwPos)
{
    if (!m_pkGrid)
        return false;

    if (dwPos >= m_pkGrid->GetSize())
        return false;

    return true;
}

safebox.h
Linkleri görebilmek için giriş yap veya kayıt ol.

C++:
Genişlet Daralt Kopyala
#ifndef __INC_METIN_II_GAME_SAFEBOX_H__
#define __INC_METIN_II_GAME_SAFEBOX_H__

class CHARACTER;
class CItem;
class CGrid;

class CSafebox
{
    public:
        CSafebox(LPCHARACTER pkChrOwner, int iSize, DWORD dwGold);
        ~CSafebox();

        bool        Add(DWORD dwPos, LPITEM pkItem);
        LPITEM        Get(DWORD dwPos);
        LPITEM        Remove(DWORD dwPos);
        void        ChangeSize(int iSize);

        bool        MoveItem(INT bCell, INT bDestCell, short count);
        LPITEM        GetItem(INT bCell);

        void        Save();

        bool        IsEmpty(DWORD dwPos, BYTE bSize);
        bool        IsValidPosition(DWORD dwPos);

        void        SetWindowMode(BYTE bWindowMode);

    protected:
        void        __Destroy();

        LPCHARACTER    m_pkChrOwner;
        LPITEM        m_pkItems[SAFEBOX_MAX_NUM];
        CGrid *        m_pkGrid;
        int        m_iSize;
        long        m_lGold;

        BYTE        m_bWindowMode;
};

#endif

char.cpp
Linkleri görebilmek için giriş yap veya kayıt ol.

C++:
Genişlet Daralt Kopyala
void CHARACTER::ReqSafeboxLoad(const char* pszPassword)
{
    if (!*pszPassword || strlen(pszPassword) > SAFEBOX_PASSWORD_MAX_LEN)
    {
        ChatPacket(CHAT_TYPE_INFO, LC_TEXT("<â°í> À߸øµÈ ¾ÏÈ£¸¦ ÀÔ·ÂÇϼ̽À´Ï´Ù."));
        return;
    }
    else if (m_pkSafebox)
    {
        ChatPacket(CHAT_TYPE_INFO, LC_TEXT("<â°í> â°í°¡ ÀÌ¹Ì ¿·ÁÀÖ½À´Ï´Ù."));
        return;
    }

    int iPulse = thecore_pulse();

    if (iPulse - GetSafeboxLoadTime()  < PASSES_PER_SEC(10))
    {
        ChatPacket(CHAT_TYPE_INFO, LC_TEXT("<â°í> â°í¸¦ ´İÀºÁö 10ÃÊ ¾È¿¡´Â ¿ ¼ö ¾ø½À´Ï´Ù."));
        return;
    }
    else if (GetDistanceFromSafeboxOpen() > 1000)
    {
        ChatPacket(CHAT_TYPE_INFO, LC_TEXT("<â°í> °Å¸®°¡ ¸Ö¾î¼ â°í¸¦ ¿ ¼ö ¾ø½À´Ï´Ù."));
        return;
    }
    else if (m_bOpeningSafebox)
    {
        sys_log(0, "Overlapped safebox load request from %s", GetName());
        return;
    }

    SetSafeboxLoadTime();
    m_bOpeningSafebox = true;

    TSafeboxLoadPacket p;
    p.dwID = GetDesc()->GetAccountTable().id;
    strlcpy(p.szLogin, GetDesc()->GetAccountTable().login, sizeof(p.szLogin));
    strlcpy(p.szPassword, pszPassword, sizeof(p.szPassword));

    db_clientdesc->DBPacket(HEADER_GD_SAFEBOX_LOAD, GetDesc()->GetHandle(), &p, sizeof(p));
}

void CHARACTER::LoadSafebox(int iSize, DWORD dwGold, int iItemCount, TPlayerItem * pItems)
{
    bool bLoaded = false;

    //PREVENT_TRADE_WINDOW
    SetOpenSafebox(true);
    //END_PREVENT_TRADE_WINDOW

    if (m_pkSafebox)
        bLoaded = true;

    if (!m_pkSafebox)
        m_pkSafebox = M2_NEW CSafebox(this, iSize, dwGold);
    else
        m_pkSafebox->ChangeSize(iSize);

    m_iSafeboxSize = iSize;

    TPacketCGSafeboxSize p;

    p.bHeader = HEADER_GC_SAFEBOX_SIZE;
    p.bSize = iSize;

    GetDesc()->Packet(&p, sizeof(TPacketCGSafeboxSize));

    if (!bLoaded)
    {
        for (int i = 0; i < iItemCount; ++i, ++pItems)
        {
            if (!m_pkSafebox->IsValidPosition(pItems->pos))
                continue;

            LPITEM item = ITEM_MANAGER::instance().CreateItem(pItems->vnum, pItems->count, pItems->id);

            if (!item)
            {
                sys_err("cannot create item vnum %d id %u (name: %s)", pItems->vnum, pItems->id, GetName());
                continue;
            }

            item->SetSkipSave(true);
            item->SetSockets(pItems->alSockets);
            item->SetAttributes(pItems->aAttr);

            if (!m_pkSafebox->Add(pItems->pos, item))
            {
                M2_DESTROY_ITEM(item);
            }
            else
                item->SetSkipSave(false);
        }
    }
}

void CHARACTER::ChangeSafeboxSize(BYTE bSize)
{
    //if (!m_pkSafebox)
    //return;

    TPacketCGSafeboxSize p;

    p.bHeader = HEADER_GC_SAFEBOX_SIZE;
    p.bSize = bSize;

    GetDesc()->Packet(&p, sizeof(TPacketCGSafeboxSize));

    if (m_pkSafebox)
        m_pkSafebox->ChangeSize(bSize);

    m_iSafeboxSize = bSize;
}

void CHARACTER::CloseSafebox()
{
    if (!m_pkSafebox)
        return;

    //PREVENT_TRADE_WINDOW
    SetOpenSafebox(false);
    //END_PREVENT_TRADE_WINDOW

    m_pkSafebox->Save();

    M2_DELETE(m_pkSafebox);
    m_pkSafebox = NULL;

    ChatPacket(CHAT_TYPE_COMMAND, "CloseSafebox");

    SetSafeboxLoadTime();
    m_bOpeningSafebox = false;

    Save();
}

buyrun hocam
 
Buradaki kodlarda bi sorun göremedim. Sanırsam tek tek eklediğiniz sistemleri devredışı bırakarak neyden kaynaklandığını öğrenmeniz gerekiyor. :(
 
Geri
Üst