shufflemap list

This commit is contained in:
kremsy 2014-01-11 17:06:32 +01:00 committed by Steffen Schröder
parent 7bc09fca3b
commit 8afdfeb450
2 changed files with 18 additions and 14 deletions

View File

@ -46,7 +46,7 @@ class MapCommands implements CommandListener, ManialinkPageAnswerListener, Callb
$this->maniaControl->commandManager->registerCommandListener('restartmap', $this, 'command_RestartMap', true);
$this->maniaControl->commandManager->registerCommandListener('addmap', $this, 'command_AddMap', true);
$this->maniaControl->commandManager->registerCommandListener(array('removemap', 'removethis', 'erasemap', 'erasethis'), $this, 'command_RemoveMap', true);
$this->maniaControl->commandManager->registerCommandListener(array('shufflemaps', 'shuffle'), $this, 'command_ShuffleMap', true);
$this->maniaControl->commandManager->registerCommandListener(array('shufflemaps', 'shuffle'), $this, 'command_ShuffleMaps', true);
// Register for player chat commands
$this->maniaControl->commandManager->registerCommandListener(array('maps', 'list'), $this, 'command_List');

View File

@ -164,18 +164,22 @@ class MapManager implements CallbackListener {
* @return bool
*/
public function shuffleMapList() {
if(!$this->maniaControl->client->query('GetMapList', 100, 0)) {
trigger_error("Couldn't fetch mapList. " . $this->maniaControl->getClientErrorText());
return false;
shuffle($this->maps);
$mapArray = array();
foreach($this->maps as $map) {
/** @var Map $map */
$mapArray[] = $map->fileName;
}
$mapList = $this->maniaControl->client->getResponse();
shuffle($mapList);
if(!$this->maniaControl->client->query('ChooseNextChallengeList', $mapList)) {
if(!$this->maniaControl->client->query('ChooseNextMapList', $mapArray)) {
trigger_error("Couldn't shuffle mapList. " . $this->maniaControl->getClientErrorText());
return false;
}
$this->fetchCurrentMap();
return true;
}