Ir para conteúdo

Featured Replies

Postado

Olá galera, eu estou com um erro que sério... não consigo arrumar, to a 1 dia já tentando arrumar essa merda, já fui tudo que é forum, mas mesmo assim não achei...

 

simplesmente dá esse erro na distro sem parar....

o erro é na lib (GETDATINT)

Eu já modifiquei o shop.lua 999x, tem uns que parou com o erro, mas quando o player comprava o item não chegava, esse chega porem fica flodando esse erro na distro e os items não para de vir..

alguem pode me ajudar ?

vale lembrar que ja troquei tambem a 004-database.lua e mesmo assim continua dando esse erro.. ;s

lib.png.60ab79a74f44d628b307d584e4f85baa.png

 

 

dou rep++

  • Respostas 6
  • Visualizações 388
  • Created
  • Última resposta

Top Posters In This Topic

Posted Images

Postado
  • Autor

function onThink(interval, lastExecution, thinkInterval)


    local result = db.getResult("SELECT * FROM shop_history WHERE `processed` = 0;")
        
        if(result:getID() ~= -1) then
            while(true) do
                cid = getCreatureByName(tostring(result:getDataString("player")))
                product = tonumber(result:getDataInt("product"))
                itemr = db.getResult("SELECT * FROM shop_offer WHERE `id` = "..product..";")
                    if isPlayer(cid) then
                        local item = tonumber(itemr:getDataInt("item"))
                        local tid = tonumber(result:getDataInt("id"))
                        local count = tonumber(itemr:getDataInt("count"))
                        local tipe = tonumber(itemr:getDataInt("type"))
                        local productn = tostring(itemr:getDataString("name"))
                        if isInArray({5,8},tipe) then
                            if getPlayerFreeCap(cid) >= getItemWeightById(id, count) then
                                if isContainer(getPlayerSlotItem(cid, 3).uid) then
                                    received = doAddContainerItem(getPlayerSlotItem(cid, 3).uid, id,count)
                                    if received then
                                        doPlayerSendTextMessage(cid,19, "Voce recebeu >> "..productn.." << de seu Shop System.")
                                        db.query("UPDATE `shop_history` SET `processed`='1' WHERE id = " .. tid .. ";")
                                    else
                                        doPlayerSendTextMessage(cid,19, "Desculpe, voce não tem nenhum espaço na bp para receber >> "..productn.." <<")
                                    end
                                else
                                    doPlayerSendTextMessage(cid,19, "Desculpe, voce não tem nenhuma bp para receber >> "..productn.." <<")
                                end
                            else
                                doPlayerSendTextMessage(cid,19, "Desculpe, voce não tem cap suficiente para receber >> "..productn.." << (Voce precisa de: "..getItemWeightById(id, count).." de cap.)")
                            end
                        elseif isInArray({6,7},tipe) then
                            if tipe == 6 then
                                bcap = 8
                                bid = 1987
                            elseif tipe == 7 then
                                bcap = 20
                                bid = 1988
                            end
                            if getPlayerFreeCap(cid) >= 5000 then
                                local bag = doCreateItemEx(bid, 1)
                                for i = 1,bcap do
                                    doAddContainerItem(bag, id, count)
                                end
                                received = doPlayerAddItemEx(cid, bag)
                                if received == RETURNVALUE_NOERROR then
                                    doPlayerSendTextMessage(cid,19, "Voce recebeu >> "..productn.." << de seu Shop System.")
                                    db.query("UPDATE `shop_history` SET `processed`='1' WHERE id = " .. tid .. ";")
                                else
                                    doPlayerSendTextMessage(cid,19, "Desculpe, voce não tem nenhum espaço na bp para receber >> "..productn.." <<")
                                end
                            else
                                doPlayerSendTextMessage(cid,19, "Desculpe, voce não tem cap suficiente para receber >> "..productn.." << (Voce precisa de 5000 de cap.)")
                            end
                        end
                    end
                itemr:free()
                if not(result:next()) then
                    break
                end
            end
            result:free()
        end
    return true
end    

Postado

@FelipeMeyrelles veja se o Meu Funciona ai...

 

function onThink(interval, lastExecution, thinkInterval)
 
local result = db.getResult("SELECT * FROM shop_history WHERE `processed` = 0;")
 
if(result:getID() ~= -1) then
while(true) do
cid = getCreatureByName(tostring(result:getDataString("player")))
product = tonumber(result:getDataInt("product"))
itemr = db.getResult("SELECT * FROM shop_offer WHERE `id` = "..product..";")
if isPlayer(cid) then
local id = tonumber(itemr:getDataInt("item"))
local tid = tonumber(result:getDataInt("id"))
local count = tonumber(itemr:getDataInt("count"))
local tipe = tonumber(itemr:getDataInt("type"))
local productn = tostring(itemr:getDataString("name"))
if isInArray({5,8},tipe) then
if getPlayerFreeCap(cid) >= getItemWeightById(id, count) then
if isContainer(getPlayerSlotItem(cid, 3).uid) then
received = doAddContainerItem(getPlayerSlotItem(cid, 3).uid, id,count)
if received then
doPlayerSendTextMessage(cid,19, "You have received >> "..productn.." << from Shop.")
db.executeQuery("UPDATE `shop_history` SET `processed`='1' WHERE id = " .. tid .. ";")
else
doPlayerSendTextMessage(cid,19, "Sorry, you don't have enough space on container to receive >> "..productn.." <<")
end
else
doPlayerSendTextMessage(cid,19, "Sorry, you don't have a container to receive >> "..productn.." <<")
end
else
doPlayerSendTextMessage(cid,19, "Sorry, you don't have enough capacity to receive >> "..productn.." << (You need: "..getItemWeightById(id, count).." Capacity)")
end
elseif isInArray({6,7},tipe) then
if tipe == 6 then
bcap = 8
bid = 1987
elseif tipe == 7 then
bcap = 20
bid = 1988
end
if isItemRune(id) then
count = 1
end
if getPlayerFreeCap(cid) >= (getItemWeightById(1987, 1) + getItemWeightById(id,count * bcap)) then
local bag = doCreateItemEx(bid, 1)
for i = 1,bcap do
doAddContainerItem(bag, id, count)
end
received = doPlayerAddItemEx(getPlayerSlotItem(cid, 3).uid, bag)
if received == RETURNVALUE_NOERROR then
doPlayerSendTextMessage(cid,19, "You have received >> "..productn.." << from Shop.")
db.executeQuery("UPDATE `shop_history` SET `processed`='1' WHERE id = " .. tid .. ";")
else
doPlayerSendTextMessage(cid,19, "Sorry, you don't have enough space to receive >> "..productn.." <<")
end
else
doPlayerSendTextMessage(cid,19, "Sorry, you don't have enough capacity to receive >> "..productn.." << (You need: "..getItemWeightById(id, count).." Capacity)")
end
end
end
itemr:free()
if not(result:next()) then
break
end
end
result:free()
end
return true
end

 

Participe da conversa

Você pode postar agora e se cadastrar mais tarde. Se você tem uma conta, faça o login para postar com sua conta.

Visitante
Responder

Quem Está Navegando 0

  • Nenhum usuário registrado visualizando esta página.

Estatísticas dos Fóruns

  • Tópicos 96.9k
  • Posts 519.6k

Informação Importante

Confirmação de Termo