2020-04-27 16:11:54 +03:00
---
2020-07-11 11:30:46 +03:00
title: Chat e comandi
2020-04-27 16:11:54 +03:00
layout: default
root: ../..
idx: 4.2
2020-07-11 11:30:46 +03:00
description: Come registrare un comando e gestire i messaggi della chat
redirect_from: /it/chapters/chat.html
2020-04-27 16:11:54 +03:00
cmd_online:
level: warning
2020-07-11 11:30:46 +03:00
title: I giocatori offline possono eseguire comandi
2022-06-20 01:18:53 +03:00
message: |
Viene passato il nome del giocatore al posto del giocatore in sé perché le mod possono eseguire comandi in vece di un giocatore offline.
Per esempio, il ponte IRC permette ai giocatori di eseguire comandi senza dover entrare in gioco.
2020-04-27 16:11:54 +03:00
2022-06-20 01:18:53 +03:00
Assicurati quindi di non dar per scontato che un giocatore sia connesso.
Puoi controllare ciò tramite `minetest.get_player_by_name` , per vedere se ritorna qualcosa o meno.
2020-04-27 16:11:54 +03:00
cb_cmdsprivs:
level: warning
2020-07-11 11:30:46 +03:00
title: Privilegi e comandi
2022-06-20 01:18:53 +03:00
message: |
Il privilegio shout non è necessario per far sì che un giocatore attivi questo richiamo.
Questo perché i comandi sono implementati in Lua, e sono semplicemente dei messaggi in chat che iniziano con /.
2020-04-27 16:11:54 +03:00
---
2020-07-11 11:30:46 +03:00
## Introduzione <!-- omit in toc -->
2020-04-27 16:11:54 +03:00
2020-07-11 11:30:46 +03:00
Le mod possono interagire con la chat del giocatore, tra l'inviare messaggi, intercettarli e registrare dei comandi.
2020-04-27 16:11:54 +03:00
2022-06-20 01:18:53 +03:00
- [Inviare messaggi ](#inviare-messaggi )
2024-01-04 03:22:21 +03:00
- [A tutti i giocatori ](#a-tutti-i-giocatori )
- [A giocatori specifici ](#a-giocatori-specifici )
2020-07-11 11:30:46 +03:00
- [Comandi ](#comandi )
2024-01-04 03:22:21 +03:00
- [Accettare più argomenti ](#accettare-più-argomenti )
- [Usare string.split ](#usare-stringsplit )
- [Usare i pattern Lua ](#usare-i-pattern-lua )
2022-06-18 23:20:15 +03:00
- [Intercettare i messaggi ](#intercettare-i-messaggi )
2020-04-27 16:11:54 +03:00
2022-06-20 01:18:53 +03:00
## Inviare messaggi
### A tutti i giocatori
2020-04-27 16:11:54 +03:00
2020-07-11 11:30:46 +03:00
Per inviare un messaggio a tutti i giocatori connessi in gioco, si usa la funzione `chat_send_all` :
2020-04-27 16:11:54 +03:00
```lua
2020-07-11 11:30:46 +03:00
minetest.chat_send_all("Questo è un messaggio visualizzabile da tutti")
2020-04-27 16:11:54 +03:00
```
2020-07-11 11:30:46 +03:00
Segue un esempio di come apparirerebbe in gioco:
2020-04-27 16:11:54 +03:00
2020-07-11 11:30:46 +03:00
< Tizio > Guarda qui
Questo è un messaggio visualizzabile da tutti
< Caio > Eh, cosa?
2020-04-27 16:11:54 +03:00
2020-07-11 11:30:46 +03:00
Il messaggio appare su una nuova riga, per distinguerlo dai messaggi dei giocatori.
2020-04-27 16:11:54 +03:00
2022-06-20 01:18:53 +03:00
### A giocatori specifici
2020-04-27 16:11:54 +03:00
2020-07-11 11:30:46 +03:00
Per inviare un messaggio a un giocatore in particolare, si usa invece la funzione `chat_send_player` :
2020-04-27 16:11:54 +03:00
```lua
2020-07-11 11:30:46 +03:00
minetest.chat_send_player("Tizio", "Questo è un messaggio per Tizio")
2020-04-27 16:11:54 +03:00
```
2020-07-11 11:30:46 +03:00
Questo messaggio viene mostrato esattamente come il precedente, ma solo, in questo caso, a Tizio.
2020-04-27 16:11:54 +03:00
2020-07-11 11:30:46 +03:00
## Comandi
2020-04-27 16:11:54 +03:00
2020-07-11 11:30:46 +03:00
Per registrare un comando, per esempio `/foo` , si usa `register_chatcommand` :
2020-04-27 16:11:54 +03:00
```lua
minetest.register_chatcommand("foo", {
privs = {
interact = true,
},
func = function(name, param)
2020-07-11 11:30:46 +03:00
return true, "Hai detto " .. param .. "!"
2020-04-27 16:11:54 +03:00
end,
})
```
2020-07-11 11:30:46 +03:00
Nel codice qui in alto, `interact` è elencato come [privilegio ](privileges.html ) necessario; in altre parole, solo i giocatori che hanno quel privilegio possono usare il comando.
2020-04-27 16:11:54 +03:00
2022-06-20 01:18:53 +03:00
`param` è una stringa contenente tutto ciò che un giocatore scrive dopo il nome del comando.
Per esempio, in `/grantme uno,due,tre` , `param` equivarrà a `uno,due,tre` .
2020-07-11 11:30:46 +03:00
I comandi ritornano un massimo di due valori, dove il primo è un booleano che indica l'eventuale successo, mentre il secondo è un messaggio da inviare all'utente.
2020-04-27 16:11:54 +03:00
{% include notice.html notice=page.cmd_online %}
2022-06-20 01:18:53 +03:00
### Accettare più argomenti
2020-04-27 16:11:54 +03:00
2022-06-20 01:18:53 +03:00
Non è raro che i comandi richiedano più argomenti, come per esempio `/squadra entra <nome_squadra>` .
Ci sono due modi per implementare ciò: usare `string.split` o i pattern Lua.
2022-06-18 23:20:15 +03:00
2022-06-20 01:18:53 +03:00
#### Usare string.split
2022-06-18 23:20:15 +03:00
2022-06-20 01:18:53 +03:00
Una stringa può essere spezzettata in più parti tramite `string.split(" ")` :
2022-06-18 23:20:15 +03:00
```lua
2022-06-20 01:18:53 +03:00
local parti = param:split(" ")
local cmd = parti[1]
if cmd == "entra" then
local nome_squadra = parti[2]
squadra.entra(name, nome_squadra)
return true, "Sei dentro la squadra!"
elseif cmd == "gioc_max" then
local nome_squadra = parti[2]
local gioc_max = tonumber(parti[3])
if nome_squadra and gioc_max then
return true, "Giocatori massimi della squadra " .. nome_squadra .. " impostati a " .. gioc_max
2022-06-18 23:20:15 +03:00
else
2022-06-20 01:18:53 +03:00
return false, "Uso: /squadra gioc_max < nome_squadra > < numero > "
2022-06-18 23:20:15 +03:00
end
else
2022-06-20 01:18:53 +03:00
return false, "È necessario un comando"
2022-06-18 23:20:15 +03:00
end
```
2022-06-20 01:18:53 +03:00
#### Usare i pattern Lua
2020-04-27 16:11:54 +03:00
2022-06-20 01:18:53 +03:00
[I pattern Lua ](https://www.lua.org/pil/20.2.html ) sono un modo per estrapolare pezzi di testo seguendo delle regole.
Sono perfetti in caso di argomenti che contengono spazi, o comunque quando è richiesto un controllo più meticoloso dei parametri catturati.
2020-04-27 16:11:54 +03:00
```lua
2024-01-04 03:22:21 +03:00
local a, msg = string.match(param, "^([%a%d_-]+) (.+)$")
2020-04-27 16:11:54 +03:00
```
2020-07-11 11:30:46 +03:00
Il codice sovrastante implementa `/msg <a> <messaggio>` . Vediamo cos'è successo partendo da sinistra:
2020-04-27 16:11:54 +03:00
2020-07-11 11:30:46 +03:00
* `^` dice di iniziare a combaciare dall'inizio della stringa;
* `()` è un gruppo - qualsiasi cosa che combaci con ciò che è contenuto al suo interno verrà ritornato da string.match;
* `[]` significa che i caratteri al suo interno sono accettati;
* `%a` significa che accetta ogni lettera e `%d` ogni cifra.
2020-10-14 21:18:55 +03:00
* `[%a%d_-]` significa che accetta ogni lettera, cifra, `_` e `-` .
2020-07-11 11:30:46 +03:00
* `+` dice di combaciare ciò che lo precede una o più volte.
2024-01-04 03:22:21 +03:00
* `.` dice di combaciare qualsiasi tipo di carattere.
2020-07-11 11:30:46 +03:00
* `$` dice di combaciare la fine della stringa.
2020-04-27 16:11:54 +03:00
2020-07-11 11:30:46 +03:00
Detto semplicemente, il pattern cerca un nome (una parola fatta di lettere, numeri, trattini o trattini bassi), poi uno spazio e poi il messaggio (uno o più caratteri, qualsiasi essi siano).
Vengono poi ritornati nome e messaggio, perché sono inseriti nelle parentesi.
2020-04-27 16:11:54 +03:00
2020-07-11 11:30:46 +03:00
Questo è come molte mod implementano comandi complessi.
Una guida più completa ai pattern è probabilmente quella su [lua-users.org ](http://lua-users.org/wiki/PatternsTutorial ) o la [documentazione PIL ](https://www.lua.org/pil/20.2.html ).
2020-04-27 16:11:54 +03:00
< p class = "book_hide" >
2021-05-07 18:17:19 +03:00
C'è anche una libreria scritta dall'autore di questo libro che può essere usata
per creare comandi complessi senza l'utilizzo di pattern:
< a href = "https://gitlab.com/rubenwardy/ChatCmdBuilder" > Chat Command Builder< / a > .
2020-04-27 16:11:54 +03:00
< / p >
2020-07-11 11:30:46 +03:00
## Intercettare i messaggi
2020-04-27 16:11:54 +03:00
2020-07-11 11:30:46 +03:00
Per intercettare un messaggio, si usa `register_on_chat_message` :
2020-04-27 16:11:54 +03:00
```lua
minetest.register_on_chat_message(function(name, message)
2020-07-11 11:30:46 +03:00
print(name .. " ha detto " .. message)
2020-04-27 16:11:54 +03:00
return false
end)
```
2022-06-20 01:18:53 +03:00
Ritornando `false` , si permette al messaggio di essere inviato.
2020-07-11 11:30:46 +03:00
In verità `return false` può anche essere omesso in quanto `nil` verrebbe ritornato implicitamente, e nil è trattato come false.
2020-04-27 16:11:54 +03:00
{% include notice.html notice=page.cb_cmdsprivs %}
2020-07-11 11:30:46 +03:00
Dovresti assicurarti, poi, che il messaggio potrebbe essere un comando che invia messaggi in chat,
o che l'utente potrebbere non avere `shout` .
2020-04-27 16:11:54 +03:00
```lua
minetest.register_on_chat_message(function(name, message)
if message:sub(1, 1) == "/" then
2020-07-11 11:30:46 +03:00
print(name .. " ha eseguito un comando")
2020-04-27 16:11:54 +03:00
elseif minetest.check_player_privs(name, { shout = true }) then
2020-07-11 11:30:46 +03:00
print(name .. " ha detto " .. message)
2020-04-27 16:11:54 +03:00
else
2020-07-11 11:30:46 +03:00
print(name .. " ha provato a dire " .. message ..
" ma non ha lo shout")
2020-04-27 16:11:54 +03:00
end
return false
end)
```