Delete table when empty
This commit is contained in:
parent
15d2b3d670
commit
f97604e3bf
@ -110,11 +110,16 @@ final class TableManagement {
|
||||
guard let oldTable = currentTable(for: player.name) else {
|
||||
return database.eventLoop.makeSucceededVoidFuture()
|
||||
}
|
||||
player.$table.id = nil
|
||||
guard let table = WaitingTable(oldTable: oldTable, removing: player.name) else {
|
||||
tables[oldTable.id] = nil
|
||||
return Table.query(on: database).filter(\.$id == oldTable.id).delete().flatMap {
|
||||
player.update(on: database)
|
||||
}
|
||||
}
|
||||
/// `player.canStartGame` is automatically set to false, because table is not full
|
||||
let table = WaitingTable(oldTable: oldTable, removing: player.name)
|
||||
tables[table.id] = table
|
||||
table.sendUpdateToAllPlayers()
|
||||
player.$table.id = nil
|
||||
// TODO: Update points for all players
|
||||
return player.update(on: database)
|
||||
}
|
||||
|
@ -39,7 +39,7 @@ final class WaitingTable: AbstractTable<WaitingPlayer> {
|
||||
- Parameter oldTable: The table to convert
|
||||
- Parameter player: The name of the player to remove from the table.
|
||||
*/
|
||||
init(oldTable: ManageableTable, removing player: PlayerName) {
|
||||
init?(oldTable: ManageableTable, removing player: PlayerName) {
|
||||
// TODO: End game and distribute points
|
||||
let players = oldTable.allPlayers
|
||||
.filter {
|
||||
@ -50,6 +50,9 @@ final class WaitingTable: AbstractTable<WaitingPlayer> {
|
||||
return false
|
||||
}
|
||||
.map { WaitingPlayer(name: $0.name, points: $0.totalPoints, socket: $0.socket) }
|
||||
guard !players.isEmpty else {
|
||||
return nil
|
||||
}
|
||||
players.first!.isNextActor = true
|
||||
super.init(table: oldTable, players: players)
|
||||
}
|
||||
@ -58,7 +61,7 @@ final class WaitingTable: AbstractTable<WaitingPlayer> {
|
||||
Convert another table to a waiting table.
|
||||
|
||||
This is needed when a player leaves an active table.
|
||||
- Parameter oldTable: The table to convert
|
||||
- Parameter table: The table to convert
|
||||
*/
|
||||
init(oldTableAdvancedByOne table: ManageableTable) {
|
||||
let players = table.allPlayers
|
||||
|
Loading…
x
Reference in New Issue
Block a user