Ir para conteúdo
  • 0

[SQLite] -=[TFS]=- 0.4 8.60 Não to conseguindo usa o comando !character list


Muvuka

Pergunta

[SQLite] -=[TFS]=- 0.4 8.60 Não to conseguindo usa o comando !character list

 

<?xml version="1.0" encoding="ISO-8859-1"?>
<mod name="Characters Market System" version="1.0" author="LuckOake" contact="none" enabled="yes">
------------------------------------------------------------------------------------
<config name="market"><![CDATA[
price = 27112
owner = 27113
level = 30 -- Level min of character.--
min_price = 100 -- Price min of character--
max_price = 1000000 -- Price maximum of character--
 
function doTransferCharacter(cid, accId)
        return db.executeQuery("UPDATE `players` SET `account_id` = "..accId.." WHERE `id` = "..getPlayerGUIDByName(cid).."")
end
 
function doOfflinePlayerAddMoney(guid, money)
        return db.executeQuery("UPDATE `players` SET `balance` = `balance` + '"..money.."' WHERE `id` = '"..getPlayerGUIDByName(guid).."';")
end
 
function setOfflinePlayerStorageValue(name, key, value)
        local result = db.getResult("SELECT * FROM `player_storage` WHERE `player_id` = ".. getPlayerGUIDByName(name) .." AND `key` = ".. key ..";")
        if result:getID() == -1 then
                return db.executeQuery("INSERT INTO `player_storage` (`player_id`, `key`, `value`) VALUES (".. getPlayerGUIDByName(name) ..", ".. key ..", ".. value ..");")
        else
                result:free()
                return db.executeQuery("UPDATE `player_storage` SET `value` = ".. value .." WHERE `player_id` = ".. getPlayerGUIDByName(name) .." AND `key` = ".. key ..";")
        end
end
 
function getOfflinePlayerStorageValue(name, key)
        local result, ret = db.getResult("SELECT `value` FROM `player_storage` WHERE `player_id` = '".. getPlayerGUIDByName(name) .."' AND `key` = ".. key ..";")
        if result:getID() == -1 then
                return nil
        end
        ret = result:getDataInt("value")
        result:free()
        return ret
end
 
function getOfflinePlayerValue(name, value)
        local result, ret = db.getResult("SELECT `"..value.."` FROM `players` WHERE `id` = "..getPlayerGUIDByName(name)..";")
        ret = result:getDataInt(value)
        result:free()
        return ret
end
 
function isCharacterForSale(name)
        if not getOfflinePlayerStorageValue(name, price) or getOfflinePlayerStorageValue(name, price) < 1 then
        return false
        else
        return true
        end
end
]]></config>
------------------------------------------------------------------------------------
<talkaction words="!character" event="buffer"><![CDATA[
domodlib('market')
        local t = string.explode(param, ",")
       
        if t[1] == "sell" then
                if not t[3] or not tonumber(t[3]) or t[4] or tonumber(t[2]) then
                        doPlayerSendTextMessage(cid, MESSAGE_STATUS_CONSOLE_ORANGE, "Incorrect Params. Specify the character name and the price.") return true
                elseif getPlayerAccountId(cid) ~= getAccountIdByName(t[2]) then
                        doPlayerSendTextMessage(cid, MESSAGE_STATUS_CONSOLE_ORANGE, "This is not your character.") return true
                elseif isCharacterForSale(t[2]) then
                        doPlayerSendTextMessage(cid, MESSAGE_STATUS_CONSOLE_ORANGE, "This character is already for sale.") return true
                elseif getPlayerGUIDByName(t[2]) == getPlayerGUID(cid) then
                        doPlayerSendTextMessage(cid, MESSAGE_STATUS_CONSOLE_ORANGE, "You cannot sell yourself.") return true
                elseif getPlayerByName(t[2]) then
                        doPlayerSendTextMessage(cid, MESSAGE_STATUS_CONSOLE_ORANGE, "The character must be offline to be sold.") return true
                elseif getOfflinePlayerValue(t[2], "level") < level then
                        doPlayerSendTextMessage(cid, MESSAGE_STATUS_CONSOLE_ORANGE, "Your character can't be sold until it has level "..level..".") return true
                elseif tonumber(t[3]) < min_price then
                        doPlayerSendTextMessage(cid, MESSAGE_STATUS_CONSOLE_ORANGE, "Sorry, but the minimum price for selling a character is "..min_price..".") return true
                elseif tonumber(t[3]) > max_price then
                        doPlayerSendTextMessage(cid, MESSAGE_STATUS_CONSOLE_ORANGE, "Sorry, but the maximum price for selling a character is "..max_price..".") return true
                end
       
                        setOfflinePlayerStorageValue(t[2], price, t[3])
                        setOfflinePlayerStorageValue(t[2], owner, getPlayerGUID(cid))
                        doPlayerSendTextMessage(cid, MESSAGE_STATUS_CONSOLE_BLUE, 'Your character "'..t[2]..'" is now for sale for the price of "'..t[3]..'" gold coins.')
        elseif t[1] == "buy" then
                if not t[2] then
                        doPlayerSendTextMessage(cid, MESSAGE_STATUS_CONSOLE_ORANGE, "Incorrect Params. Specify the character name.") return true
                elseif not playerExists(t[2]) then
                        doPlayerSendTextMessage(cid, MESSAGE_STATUS_CONSOLE_ORANGE, "This character doesn't exist.") return true
                elseif getPlayerAccountId(cid) == getAccountIdByName(t[2]) then
                        doPlayerSendTextMessage(cid, MESSAGE_STATUS_CONSOLE_ORANGE, "You can't buy your own character.") return true
                elseif not isCharacterForSale(t[2]) then
                        doPlayerSendTextMessage(cid, MESSAGE_STATUS_CONSOLE_ORANGE, "This character is not for sale.") return true
                elseif not doPlayerRemoveMoney(cid, getOfflinePlayerStorageValue(t[2], price)) then
                        doPlayerSendTextMessage(cid, MESSAGE_STATUS_CONSOLE_ORANGE, "Not enough money. This character's price is "..getOfflinePlayerStorageValue(t[2], price).." gold coins.") return true
                end
                       
                if not getPlayerByGUID(getOfflinePlayerStorageValue(t[2], owner)) then
                        doOfflinePlayerAddMoney(getPlayerNameByGUID(getOfflinePlayerStorageValue(t[2], owner)), getOfflinePlayerStorageValue(t[2], price))
                        setOfflinePlayerStorageValue(getPlayerNameByGUID(getOfflinePlayerStorageValue(t[2], owner)), 41792, getPlayerGUIDByName(t[2]))
                else
                        doPlayerAddMoney(getPlayerByGUID(getOfflinePlayerStorageValue(t[2], owner)), getOfflinePlayerStorageValue(t[2], price))
                        doPlayerSendTextMessage(getPlayerByGUID(getOfflinePlayerStorageValue(t[2], owner)), MESSAGE_STATUS_CONSOLE_BLUE, 'Your character "'..t[2]..'" has been sold for the price of '..getOfflinePlayerStorageValue(t[2], price)..' gold coins.')
                end
                        doTransferCharacter(t[2], getPlayerAccountId(cid))
                        doPlayerSendTextMessage(cid, MESSAGE_STATUS_CONSOLE_BLUE, 'You bought the character "'..t[2]..'" for the price of '..getOfflinePlayerStorageValue(t[2], price)..' gold coins.')
                        setOfflinePlayerStorageValue(t[2], owner, -1)
                        setOfflinePlayerStorageValue(t[2], price, -1) return true
        elseif t[1] == "remove" then
                if not t[2] then
                        doPlayerSendTextMessage(cid, MESSAGE_STATUS_CONSOLE_ORANGE, "Incorrect Params. Specify the character name.") return true
                elseif getPlayerAccountId(cid) ~= getAccountIdByName(t[2]) then
                        doPlayerSendTextMessage(cid, MESSAGE_STATUS_CONSOLE_ORANGE, "This is not your character.") return true
                elseif not isCharacterForSale(t[2]) then
                        doPlayerSendTextMessage(cid, MESSAGE_STATUS_CONSOLE_ORANGE, "This character is not for sale.") return true
                end
               
                        setOfflinePlayerStorageValue(t[2], price, -1)
                        doPlayerSendTextMessage(cid, MESSAGE_STATUS_CONSOLE_BLUE, 'You removed the character "'..t[2]..'" from the Characters Market.') return true
        elseif t[1] == "list" then
                local result = db.getResult("SELECT `name` FROM `players`")
                if result:getID() == -1 then
                        return true
                end
                local msg = "Characters for Sale:\n\n"
                while true do
                        local name = result:getDataString("name")
                        if isCharacterForSale(name) then
                        local sex = getOfflinePlayerValue(name, "sex") == 1 and "Male" or "Female"
                                msg = ""..msg.." - ".. name .." (Level: "..getOfflinePlayerValue(name, "level").." / Vocation: "..getVocationInfo(getOfflinePlayerValue(name, "vocation")).name.." / Sex: "..sex.." / Owner: "..getPlayerNameByGUID(getOfflinePlayerStorageValue(name, owner))..") [Price: "..getOfflinePlayerStorageValue(name, price).."] \n"
                        end
                        if not result:next() then
                                break
                        end
                end
                        doPlayerPopupFYI(cid, msg) return true
        elseif not t[1] or t[1] ~= "buy" or t[1] ~= "sell" or t[1] ~= "remove" or t[1] ~= "list" then
                doPlayerSendTextMessage(cid, MESSAGE_STATUS_CONSOLE_BLUE, "Incorrect params. You can only 'buy' or 'sell' a character, 'remove' it from the Characters Market or see the 'list' of characters for sale.") return true
        end
return true
]]></talkaction>
------------------------------------------------------------------------------------
<event type="login" name="MarketLogin" event="script"><![CDATA[
function onLogin(cid)
domodlib('market')
        if getPlayerStorageValue(cid, price) > 0 then return false
        elseif getPlayerStorageValue(cid, 41792) ~= -1 then
                doPlayerSendTextMessage(cid, MESSAGE_STATUS_CONSOLE_ORANGE, "You sold the character "..getPlayerNameByGUID(getPlayerStorageValue(cid, 41792))..". The money is in your bank account.")
                setPlayerStorageValue(cid, 41792, -1)
        end
return true
end
]]></event>
</mod>

 

APARECE ISSO NO CONSOLE 

 

[11/03/2024 08:49:51] [Error - TalkAction Interface] 
[11/03/2024 08:49:52] buffer
[11/03/2024 08:49:52] Description: 
[11/03/2024 08:49:52] [string "price = 27112..."]:26: attempt to concatenate a nil value

 

Link para o comentário
Compartilhar em outros sites

4 respostass a esta questão

Posts Recomendados

  • 1

O erro que você está vendo parece indicar que há uma tentativa de concatenar um valor nulo em algum lugar do seu código. Mais especificamente, o erro está na linha 26 do seu código, na função !character.
Nessa linha, você está tentando verificar se o primeiro elemento da tabela t não é "buy", "sell", "remove", ou "list". Parece que há um erro de lógica aqui. O problema é que você está usando or em vez de and. Como resultado, essa condição sempre será verdadeira, porque t[1] não pode ser todas essas opções simultaneamente. Isso significa que o bloco de código abaixo dessa linha será sempre executado, mesmo quando t[1] for um desses valores, causando a tentativa de acessar um índice nulo em algum lugar.

 

elseif not t[1] or (t[1] ~= "buy" and t[1] ~= "sell" and t[1] ~= "remove" and t[1] ~= "list") then

Isso garantirá que a condição seja verdadeira apenas se t[1] não for nenhum desses valores. Isso deve resolver o problema de tentar concatenar um valor nulo.

Link para o comentário
Compartilhar em outros sites

  • 0

SÓ FUNCIONO QUANDO RESETEI A DATABASE AGORA QUANDO EU VOLTEI COM A MESMA NÃO PEGA APARECE ESSE ERRO AI

EU USEI PRINT NO CODIDO UM POR CADA UM E APARECEU ISSO NO CONSOLE

 

[01/07/2024 06:17:50] Error: Could not get player GUID for character Harkaricus
[01/07/2024 06:17:51] Error: Could not get player GUID for character Chera Xana
[01/07/2024 06:17:51] Error: Could not get player GUID for character Avalost
[01/07/2024 06:17:51] Error: Could not get player GUID for character Mirkwin Aki
[01/07/2024 06:17:51] Error: Could not get player GUID for character Menezinho foda
[01/07/2024 06:17:51] Error: Could not get player GUID for character Fude ate esquentar
[01/07/2024 06:17:51] Error: Could not get player GUID for character Fuder ate respawnar
[01/07/2024 06:17:51] Error: Could not get player GUID for character Fude falando
[01/07/2024 06:17:51] Error: Could not get player GUID for character Fude opeitorosado
[01/07/2024 06:17:51] Error: Could not get player GUID for character Fude os Nascimento
[01/07/2024 06:17:51] Error: Could not get player GUID for character Fude ate raiar
[01/07/2024 06:17:51] Error: Could not get player GUID for character Fude ate criar
[01/07/2024 06:17:51] Error: Could not get player GUID for character Fude bugando
[01/07/2024 06:17:51] Error: Could not get player GUID for character Yrapuru
[01/07/2024 06:17:51] Error: Could not get player GUID for character Xxt'zaao
[01/07/2024 06:17:51] Error: Could not get player GUID for character Mc Donalds
[01/07/2024 06:17:51] Error: Could not get player GUID for character Otome
[01/07/2024 06:17:51] Error: Could not get player GUID for character Linkin Har
[01/07/2024 06:17:51] Error: Could not get player GUID for character Morte Pala Pes
[01/07/2024 06:17:51] Error: Could not get player GUID for character Rozinx
[01/07/2024 06:17:51] Error: Could not get player GUID for character Vibud
[01/07/2024 06:17:51] Error: Could not get player GUID for character Maurolkit
[01/07/2024 06:17:52] Error: Could not get player GUID for character Lucifer
[01/07/2024 06:17:52] Error: Could not get player GUID for character Hammer
[01/07/2024 06:17:52] Error: Could not get player GUID for character Aeropostale
[01/07/2024 06:17:52] Error: Could not get player GUID for character Vladimir
[01/07/2024 06:17:53] Error: Could not get player GUID for character Jivelin'o
[01/07/2024 06:17:53] Error: Could not get player GUID for character Queen Of Darkness
[01/07/2024 06:17:53] Error: Could not get player GUID for character Female
[01/07/2024 06:17:53] Error: Could not get player GUID for character Born
[01/07/2024 06:17:54] Error: Could not get player GUID for character Druidzinha
[01/07/2024 06:17:54] Error: Could not get player GUID for character Hill
[01/07/2024 06:17:54] Error: Could not get player GUID for character Shazam
[01/07/2024 06:17:54] Error: Could not get player GUID for character Mage The Hell
[01/07/2024 06:17:54] Error: Could not get player GUID for character Lirmex
[01/07/2024 06:17:55] Error: Could not get player GUID for character Madrugah
[01/07/2024 06:17:55] Error: Could not get player GUID for character Luan
[01/07/2024 06:17:55] Error: Could not get player GUID for character Killer Druid
[01/07/2024 06:17:55] Error: Could not get player GUID for character Lord'pala
[01/07/2024 06:17:56] Error: Could not get player GUID for character Mahogannyy
[01/07/2024 06:17:56] Error: Could not get player GUID for character Vickk
[01/07/2024 06:17:57] Error: Could not get player GUID for character Jockbk
[01/07/2024 06:17:57] Error: Could not get player GUID for character Jocksm
[01/07/2024 06:17:58] Error: Could not get player GUID for character Holy
[01/07/2024 06:17:59] Error: Could not get player GUID for character Geen Arrow
[01/07/2024 06:18:01] Error: Could not get player GUID for character Lerdo
[01/07/2024 06:18:01] Error: Could not get player GUID for character Doldorn
[01/07/2024 06:18:01] Error: Could not get player GUID for character Nyarix
[01/07/2024 06:18:01] Error: Could not get player GUID for character Kirigaya Kazuto
[01/07/2024 06:18:01] Error: Could not get player GUID for character Paladin Dislexico
[01/07/2024 06:18:01] Error: Could not get player GUID for character Arranha Ceu
[01/07/2024 06:18:02] Error: Could not get player GUID for character Pancheri
[01/07/2024 06:18:02] Error: Could not get player GUID for character Dieghoul
[01/07/2024 06:18:05] Error: Could not get player GUID for character Mage Crrupt
[01/07/2024 06:18:05] Error: Could not get player GUID for character Gostoza
[01/07/2024 06:18:06] Error: Could not get player GUID for character Home Viu
[01/07/2024 06:18:07] Error: Could not get player GUID for character Pepinto

 

 

Link para o comentário
Compartilhar em outros sites

  • 0
Make dating stress-free and enjoyable with the best casual dating experience.
Authentic Damsels
[URL=https://datesnow.life]Finest casual Dating[/URL]
Link para o comentário
Compartilhar em outros sites

  • Quem Está Navegando   0 membros estão online

    • Nenhum usuário registrado visualizando esta página.
×
×
  • Criar Novo...