Instance Method


Returns the set of moves available to the specified player.



func gameModelUpdates(for player: GKGameModelPlayer) -> [GKGameModelUpdate]?



An instance of your game’s player class (a custom class implementing the GKGameModelPlayer protocol) representing the player whose moves are to be evaluated.

Return Value

An array of instances of your game’s move class (a custom class implementing the GKGameModelUpdate protocol), each representing a possible move for the specified player.


Your implementation of the GKGameModelUpdate protocol, or move class, should add properties or methods that describe a move in terms of your game. In this method, you create one instance of your move class for each move currently allowed to the specified player, filling in each instance’s custom properties with the information that describes that move. GameplayKit calls this method to speculate about possible future moves and their effects, using a copy of the active game board.

For example, in a Tic-Tac-Toe game, the move class would identify which of the nine spaces on the board to place a mark in. Your gameModelUpdates(for:) method would create an instance of the move class for each space not already marked. Your implementation should also take into account whether any moves are possible at all—if the game has already been won or has resulted in a draw, this method should return nil.

This method should return nil if the specified player is not valid or if no moves are available to that player.

See Also

Evaluating a Game Model

func score(for: GKGameModelPlayer) -> Int

Returns a number rating the desirability of the game model’s current state from the perspective of the specified player.

func isLoss(for: GKGameModelPlayer) -> Bool

Returns a Boolean value indicating whether the specified player has lost the game.

func isWin(for: GKGameModelPlayer) -> Bool

Returns a Boolean value indicating whether the current state of the game model reflects a win for the specified player.