WIP self.current_map

conquest_develop
bobloy 4 years ago
parent 80db00890d
commit 2d0c9e31b3

@ -13,6 +13,7 @@ from redbot.core.bot import Red
from redbot.core.data_manager import bundled_data_path, cog_data_path from redbot.core.data_manager import bundled_data_path, cog_data_path
from redbot.core.utils.predicates import MessagePredicate from redbot.core.utils.predicates import MessagePredicate
from conquest.conquestgame import ConquestGame
from conquest.regioner import ConquestMap, MapMaker, composite_regions from conquest.regioner import ConquestMap, MapMaker, composite_regions
@ -28,6 +29,9 @@ class Conquest(commands.Cog):
# Usage: self.config.games.get_raw("game_name", "is_custom") # Usage: self.config.games.get_raw("game_name", "is_custom")
default_games = {"map_name": None, "is_custom": False} default_games = {"map_name": None, "is_custom": False}
ext = "PNG"
ext_format = "PNG"
def __init__(self, bot: Red): def __init__(self, bot: Red):
super().__init__() super().__init__()
self.bot = bot self.bot = bot
@ -54,12 +58,9 @@ class Conquest(commands.Cog):
self.asset_path: Optional[pathlib.Path] = None self.asset_path: Optional[pathlib.Path] = None
self.current_maps = {} # key, value = guild.id, game_name self.current_games = {} # key, value = guild.id, game_name
self.map_data = {} # key, value = guild.id, ConquestGame self.map_data = {} # key, value = guild.id, ConquestGame
self.ext = "PNG"
self.ext_format = "PNG"
self.mm: Optional[MapMaker] = None self.mm: Optional[MapMaker] = None
async def red_delete_data_for_user(self, **kwargs): async def red_delete_data_for_user(self, **kwargs):
@ -82,32 +83,30 @@ class Conquest(commands.Cog):
if game_name is not None: if game_name is not None:
await self.load_guild_data(guild, game_name) await self.load_guild_data(guild, game_name)
if self.current_map: # for guild_id, game_name in self.current_maps.items():
await self.current_map_load() # await self.current_map_load(guild_id, game_name)
async def load_guild_data(self, guild: discord.Guild, game_name: str): async def load_guild_data(self, guild: discord.Guild, game_name: str):
game_name = await self.config.guild(guild).current_game() map_data = self.config.games.get_raw(game_name)
if game_name is not None: map_name = map_data["map_name"]
map_data = self.config.games.get_raw(game_name) map_path = self._path_if_custom(map_data["is_custom"]) / map_name
map_name = map_data["map_name"]
map_path = self._path_if_custom(map_data["is_custom"]) / map_name self.current_games[guild.id] = ConquestGame(
map_path, map_name, self.current_map_folder / map_name
self.current_maps[guild.id] = ConquestGame( )
map_path, map_name, self.current_map_folder / map_name
)
async def current_map_load(self): # async def current_map_load(self):
map_path = self._path_if_custom() # map_path = self._path_if_custom()
self.map_data = ConquestMap(map_path / self.current_map) # self.map_data = ConquestMap(map_path / self.current_map)
await self.map_data.load_data() # await self.map_data.load_data()
# map_data_path = map_path / self.current_map / "data.json" # # map_data_path = map_path / self.current_map / "data.json"
# try: # # try:
# with map_data_path.open() as mapdata: # # with map_data_path.open() as mapdata:
# self.map_data: dict = json.load(mapdata) # # self.map_data: dict = json.load(mapdata)
# except FileNotFoundError as e: # # except FileNotFoundError as e:
# print(e) # # print(e)
# await self.config.current_map.set(None) # # await self.config.current_map.set(None)
# return # # return
async def _get_current_map_path(self): async def _get_current_map_path(self):
return self.current_map_folder / self.current_map return self.current_map_folder / self.current_map
@ -406,7 +405,7 @@ class Conquest(commands.Cog):
Base command for conquest cog. Start with `[p]conquest set map` to select a map. Base command for conquest cog. Start with `[p]conquest set map` to select a map.
""" """
if ctx.invoked_subcommand is None: if ctx.invoked_subcommand is None:
if self.current_map is not None: if self.current_maps[ctx.guild.id] is not None:
await self._conquest_current(ctx) await self._conquest_current(ctx)
@conquest.command(name="list") @conquest.command(name="list")

Loading…
Cancel
Save