Agregada funcionalidad llamar/ignorar seq

master
Araozu 2020-10-06 21:30:05 -05:00
parent 1a7e12fbb3
commit a125f820ad
5 changed files with 103 additions and 37 deletions

View File

@ -87,4 +87,9 @@ object GestorJuegos {
juego.ignorarOportunidadSeq(idUsuario) juego.ignorarOportunidadSeq(idUsuario)
} }
suspend fun manejarLlamarSeq(idJuego: String, idUsuario: String, cartaDescartada: Int, combinacion: Pair<Int, Int>) {
val juego = juegos[idJuego]!!
juego.manejarSeq(idUsuario, cartaDescartada, combinacion)
}
} }

View File

@ -8,8 +8,13 @@ import io.ktor.websocket.*
val gson = Gson() val gson = Gson()
data class DatosDescarte(val idJuego: String, val idUsuario: String, val carta: Int) data class DatosDescarte(val idJuego: String, val idUsuario: String, val carta: Int)
data class DatosIgnorarOportunidad(val idJuego: String, val idUsuario: String) data class DatosIgnorarOportunidad(val idJuego: String, val idUsuario: String)
data class DatosLlamarSeq(
val idJuego: String,
val idUsuario: String,
val cartaDescartada: Int,
val combinacion: Pair<Int, Int>
)
fun Routing.juegows() { fun Routing.juegows() {
@ -31,6 +36,15 @@ fun Routing.juegows() {
val datos = gson.fromJson(sol.datos, DatosIgnorarOportunidad::class.java) val datos = gson.fromJson(sol.datos, DatosIgnorarOportunidad::class.java)
GestorJuegos.manejarIgnorarOportunidad(datos.idJuego, datos.idUsuario) GestorJuegos.manejarIgnorarOportunidad(datos.idJuego, datos.idUsuario)
} }
"llamar_seq" -> {
val datos = gson.fromJson(sol.datos, DatosLlamarSeq::class.java)
GestorJuegos.manejarLlamarSeq(
datos.idJuego,
datos.idUsuario,
datos.cartaDescartada,
datos.combinacion
)
}
} }
} }
} }

View File

@ -1,8 +1,6 @@
package dev.araozu.juego package dev.araozu.juego
import kotlin.reflect.KClass sealed class Carta(val valor: Int) {
sealed class Carta(private val valor: Int) {
companion object { companion object {
fun obtenerCartaEspecifica(valor: Int): Carta { fun obtenerCartaEspecifica(valor: Int): Carta {
return when (valor) { return when (valor) {
@ -16,31 +14,43 @@ sealed class Carta(private val valor: Int) {
224 -> CartaRealezaQ() 224 -> CartaRealezaQ()
256 -> CartaRealezaK() 256 -> CartaRealezaK()
else -> { else -> {
throw IllegalArgumentException("Valor de carta ilegal.") throw IllegalArgumentException("Valor de carta ilegal. $valor")
} }
} }
} }
/** }
* Filtra un array list de cartas segun su tipo de clase. El parámetro T debe ser la misma clase }
* que el parametro clase, o su clase padre.
* @param valores El ArrayList del cual se filtrará sealed class CartaNumero(valor: Int, val numero: Int = (valor shl 27) ushr 28) : Carta(valor) {
* @param clase La clase que determina el filtro
*/ companion object {
fun <T: Carta> filtrarCartas(valores: ArrayList<Int>, clase: KClass<out Carta>): ArrayList<T> { fun filtrarCartasRojo(valores: ArrayList<Int>): ArrayList<CartaNumeroRojo> {
val arrl = arrayListOf<T>() val arrl = arrayListOf<CartaNumeroRojo>()
valores.forEach { valores.forEach {
println("Creando carta para filtrar: $it")
val carta = obtenerCartaEspecifica(it) val carta = obtenerCartaEspecifica(it)
if (carta::class == clase) arrl.add(carta as T) if (carta is CartaNumeroRojo) arrl.add(carta)
}
return arrl
}
fun filtrarCartasNegro(valores: ArrayList<Int>): ArrayList<CartaNumeroNegro> {
val arrl = arrayListOf<CartaNumeroNegro>()
valores.forEach {
println("Creando carta para filtrar: $it")
val carta = obtenerCartaEspecifica(it)
if (carta is CartaNumeroNegro) arrl.add(carta)
} }
return arrl return arrl
} }
} }
}
sealed class CartaNumero(valor: Int, val numero: Int = (valor shl 27) ushr 28) : Carta(valor) }
class CartaNumeroNegro(valor: Int) : CartaNumero(valor) class CartaNumeroNegro(valor: Int) : CartaNumero(valor)
class CartaNumeroRojo(valor: Int) : CartaNumero(valor) class CartaNumeroRojo(valor: Int) : CartaNumero(valor)

View File

@ -204,4 +204,43 @@ class Juego(val usuarios: ArrayList<Pair<String, Boolean>>) {
enviarDatosATodos() enviarDatosATodos()
} }
suspend fun manejarSeq(idUsuario: String, cartaDescartada: Int, combinacion: Pair<Int, Int>) {
val manoJugadorDescarte = manos[ordenJugadores[turnoActual]]!!
val descartesJ = manoJugadorDescarte.descartes
// La carta solicitada para robar es invalida
if (descartesJ[descartesJ.size - 1] != cartaDescartada) {
println("La carta a robar es invalida")
return
}
descartesJ.removeAt(descartesJ.size - 1)
val manoRobador = manos[idUsuario]!!
val cartasRobador = manoRobador.cartas
val (vCarta1, vCarta2) = combinacion
// El jugador no tiene las cartas con las que formar seq
if (!cartasRobador.contains(vCarta1) || !cartasRobador.contains(vCarta2)) {
println("El jugador no tiene las cartas que dice que tiene: $vCarta1, $vCarta2")
return
}
// Quitar cartas de la mano y moverlas a cartas reveladas
cartasRobador.remove(vCarta1)
cartasRobador.remove(vCarta2)
val seq = arrayListOf(cartaDescartada, vCarta1, vCarta2)
manoRobador.cartasReveladas.add(seq)
// Eliminar las oportunidades
manoRobador.oportunidades = arrayListOf()
// Cambiar turno al robador sin dar carta
turnoActual = (turnoActual + 1) % 4
gestorDora!!.actualizarDoraCerrado()
enviarDatosATodos()
}
} }

View File

@ -7,38 +7,36 @@ data class OportunidadSeq(override val cartaDescartada: Int, val combinaciones:
companion object { companion object {
private fun arrlCartasContiene(arrl: ArrayList<CartaNumero>, v1: Int, v2: Int): Pair<Int, Int>? { private fun <T : CartaNumero> arrlCartasContiene(arrl: ArrayList<T>, v1: Int, v2: Int): Pair<Int, Int>? {
var v1E: Int? = null var v1E: Int? = null
var v2E: Int? = null var v2E: Int? = null
for (c in arrl) { for (c in arrl) {
if (c.numero == v1) v1E = c.numero if (c.numero == v1) v1E = c.valor
if (c.numero == v2) v2E = c.numero if (c.numero == v2) v2E = c.valor
if (v1E != null && v2E != null) return Pair(v1E, v2E) if (v1E != null && v2E != null) return Pair(v1E, v2E)
} }
return null return null
} }
fun verificar(valorCarta: Int, cartasMano: ArrayList<Int>): OportunidadSeq? { fun verificar(valorCarta: Int, cartasMano: ArrayList<Int>): OportunidadSeq? {
return when (val carta = Carta.obtenerCartaEspecifica(valorCarta)) { println("Verificando carta seq $valorCarta")
is CartaNumero -> { val carta = Carta.obtenerCartaEspecifica(valorCarta)
val valor = carta.numero val (valor, cartasFiltradas) = when (carta) {
is CartaNumeroRojo -> Pair(carta.numero, CartaNumero.filtrarCartasRojo(cartasMano))
val cartasFiltradas = Carta.filtrarCartas<CartaNumero>(cartasMano, carta::class) is CartaNumeroNegro -> Pair(carta.numero, CartaNumero.filtrarCartasNegro(cartasMano))
else -> return null
val arrlRetorno = arrayListOf<Pair<Int, Int>>()
val seq1 = arrlCartasContiene(cartasFiltradas, valor + 1, valor + 2)
if (seq1 != null) arrlRetorno.add(seq1)
val seq2 = arrlCartasContiene(cartasFiltradas, valor - 1, valor + 1)
if (seq2 != null) arrlRetorno.add(seq2)
val seq3 = arrlCartasContiene(cartasFiltradas, valor - 1, valor - 2)
if (seq3 != null) arrlRetorno.add(seq3)
return if (arrlRetorno.isNotEmpty()) OportunidadSeq(valorCarta, arrlRetorno) else null
}
else -> null
} }
val arrlRetorno = arrayListOf<Pair<Int, Int>>()
val seq1 = arrlCartasContiene(cartasFiltradas, valor + 1, valor + 2)
if (seq1 != null) arrlRetorno.add(seq1)
val seq2 = arrlCartasContiene(cartasFiltradas, valor - 1, valor + 1)
if (seq2 != null) arrlRetorno.add(seq2)
val seq3 = arrlCartasContiene(cartasFiltradas, valor - 1, valor - 2)
if (seq3 != null) arrlRetorno.add(seq3)
return if (arrlRetorno.isNotEmpty()) OportunidadSeq(valorCarta, arrlRetorno) else null
} }
} }