Agregar un delay aleatorio de 1-5s a las acciones de los bots

This commit is contained in:
Araozu 2020-12-28 11:03:39 -05:00
parent e390d23da2
commit 1ddb05a55d
2 changed files with 32 additions and 10 deletions

View File

@ -208,4 +208,15 @@ class Juego(val idJuego: String) {
enviarDatosATodos() enviarDatosATodos()
} }
suspend fun manejarRon(idUsuario: String, cartaDescartada: Int) {
val jugadorRon = jugadores.find { it.idUsuario == idUsuario } ?: return
val jugadorDescate = jugadores[posJugadorActual]
val ronExitoso = jugadorRon.manejarRon(cartaDescartada)
if (!ronExitoso) return
estadoJuego = EstadoJuego.Terminado
}
} }

View File

@ -7,6 +7,7 @@ import kotlinx.coroutines.delay
import kotlinx.coroutines.isActive import kotlinx.coroutines.isActive
import kotlinx.coroutines.launch import kotlinx.coroutines.launch
import kotlinx.coroutines.sync.Mutex import kotlinx.coroutines.sync.Mutex
import kotlinx.coroutines.time.delay
sealed class Jugador(val juego: Juego, val idUsuario: String) { sealed class Jugador(val juego: Juego, val idUsuario: String) {
@ -69,10 +70,10 @@ sealed class Jugador(val juego: Juego, val idUsuario: String) {
} }
// Oportunidades win (ron) // Oportunidades win (ron)
val oportunidadWin = OportunidadWin.verificar(cartaDescartada, mano.cartas, mano.cartasReveladas) val oportunidadRon = OportunidadRon.verificar(cartaDescartada, mano.cartas, mano.cartasReveladas)
if (oportunidadWin != null) { if (oportunidadRon != null) {
hayOportunidad = true hayOportunidad = true
mano.oportunidades.add(oportunidadWin) mano.oportunidades.add(oportunidadRon)
} }
if (hayOportunidad) oportunidadesRestantes++ if (hayOportunidad) oportunidadesRestantes++
@ -121,6 +122,17 @@ sealed class Jugador(val juego: Juego, val idUsuario: String) {
return true return true
} }
fun manejarRon(cartaDescartada: Int): Boolean {
// Verificar que el jugador tenga la oportunidad
// Verificar que la carta descartada sea correcta
// Verificar los yaku
return false
}
private fun ultimaCartaDescartadaEs(carta: Int): Boolean = private fun ultimaCartaDescartadaEs(carta: Int): Boolean =
mano.descartes[mano.descartes.size - 1] == carta mano.descartes[mano.descartes.size - 1] == carta
@ -175,21 +187,20 @@ class JugadorBot(juego: Juego, idUsuario: String) : Jugador(juego, idUsuario) {
private val mutexOportunidad = Mutex() private val mutexOportunidad = Mutex()
override suspend fun send(v: Frame.Text) { override suspend fun send(v: Frame.Text) {
println("Datos enviados a bot, pero ignorados.")
} }
override fun actualizarConexion(ws: WebSocketSession) {} override fun actualizarConexion(ws: WebSocketSession) {}
override suspend fun enviarDatos(datos: DatosJuego) { override suspend fun enviarDatos(datos: DatosJuego) {
println("Bot $idUsuario pensando")
// Si el bot tiene una carta adicional // Si el bot tiene una carta adicional
if (mano.sigCarta != -1) { if (mano.sigCarta != -1) {
// Espera 1s y la descarta // Espera 1s y la descarta
GlobalScope.launch { GlobalScope.launch {
mutexDescarte.lock() mutexDescarte.lock()
delay(1000) delay((Math.random() * 5 + 1).toLong() * 1000)
println("Bot $idUsuario descartando la carta que recibio (${mano.sigCarta})")
juego.manejarDescarte(idUsuario, mano.sigCarta) juego.manejarDescarte(idUsuario, mano.sigCarta)
mutexDescarte.unlock() mutexDescarte.unlock()
} }
@ -200,8 +211,8 @@ class JugadorBot(juego: Juego, idUsuario: String) : Jugador(juego, idUsuario) {
// Espera 1s e ignora oportunidades // Espera 1s e ignora oportunidades
GlobalScope.launch { GlobalScope.launch {
mutexOportunidad.lock() mutexOportunidad.lock()
delay(1000) delay((Math.random() * 5 + 1).toLong() * 1000)
println("Bot $idUsuario ignorando sus oportunidades (${mano.oportunidades.size}")
juego.ignorarOportunidades(idUsuario) juego.ignorarOportunidades(idUsuario)
mutexOportunidad.unlock() mutexOportunidad.unlock()
} }
@ -210,7 +221,7 @@ class JugadorBot(juego: Juego, idUsuario: String) : Jugador(juego, idUsuario) {
} }
override fun verificarTsumo() { override fun verificarTsumo() {
System.err.println("Tsumo no implementado D:")
} }
} }