mirror of
				https://github.com/MarioSpore/Grinch-AP.git
				synced 2025-10-21 20:21:32 -06:00 
			
		
		
		
	make activity timer actually based on activity and add connection timer for connection timing information
Also optimize "register_location_checks", because I was editing it anyway
This commit is contained in:
		| @@ -47,12 +47,14 @@ class Client: | ||||
|         self.version = [0, 0, 0] | ||||
|         self.messageprocessor = ClientMessageProcessor(ctx, self) | ||||
|         self.ctx = weakref.ref(ctx) | ||||
|         ctx.client_connection_timers[self.team, self.slot] = datetime.datetime.now(datetime.timezone.utc) | ||||
|  | ||||
|     async def disconnect(self): | ||||
|         ctx = self.ctx() | ||||
|         if ctx: | ||||
|             await on_client_disconnected(ctx, self) | ||||
|             ctx.clients.remove(self) | ||||
|             ctx.client_connection_timers[self.team, self.slot] = datetime.datetime.now(datetime.timezone.utc) | ||||
|  | ||||
|     @property | ||||
|     def wants_item_notification(self): | ||||
| @@ -86,7 +88,8 @@ class Context: | ||||
|         self.remaining_mode: str = remaining_mode | ||||
|         self.item_cheat = item_cheat | ||||
|         self.running = True | ||||
|         self.client_activity_timers = {} | ||||
|         self.client_activity_timers: typing.Dict[typing.Tuple[int, int], datetime.datetime] = {} # datatime of last new item check | ||||
|         self.client_connection_timers: typing.Dict[typing.Tuple[int, int], datetime.datetime] = {} # datetime of last connection | ||||
|         self.client_game_state: typing.Dict[typing.Tuple[int, int], int] = collections.defaultdict(int) | ||||
|         self.er_hint_data: typing.Dict[int, typing.Dict[int, str]] = {} | ||||
|         self.commandprocessor = ServerCommandProcessor(self) | ||||
| @@ -335,9 +338,11 @@ def get_remaining(ctx: Context, team: int, slot: int) -> typing.List[int]: | ||||
|     return sorted(items) | ||||
|  | ||||
| def register_location_checks(ctx: Context, team: int, slot: int, locations): | ||||
|     ctx.client_activity_timers[team, slot] = datetime.datetime.now(datetime.timezone.utc) | ||||
|     found_items = False | ||||
|     for location in locations: | ||||
|     new_locations = set(locations) - ctx.location_checks[team, slot] | ||||
|     if new_locations: | ||||
|         ctx.client_activity_timers[team, slot] = datetime.datetime.now(datetime.timezone.utc) | ||||
|         for location in new_locations: | ||||
|             if (location, slot) in ctx.locations: | ||||
|                 target_item, target_player = ctx.locations[(location, slot)] | ||||
|                 if target_player != slot or slot in ctx.remote_items: | ||||
| @@ -352,7 +357,7 @@ def register_location_checks(ctx: Context, team: int, slot: int, locations): | ||||
|                         new_item = ReceivedItem(target_item, location, slot) | ||||
|                         recvd_items.append(new_item) | ||||
|                         if slot != target_player: | ||||
|                         broadcast_team(ctx, team, [['ItemSent', (slot, location, target_player, target_item)]]) | ||||
|                             broadcast_team(ctx,team, [['ItemSent', (slot, location, target_player, target_item)]]) | ||||
|                         logging.info('(Team #%d) %s sent %s to %s (%s)' % ( | ||||
|                         team + 1, ctx.player_names[(team, slot)], get_item_name_from_id(target_item), | ||||
|                         ctx.player_names[(team, target_player)], get_location_name_from_address(location))) | ||||
| @@ -363,7 +368,7 @@ def register_location_checks(ctx: Context, team: int, slot: int, locations): | ||||
|                             if client.team == team and client.wants_item_notification: | ||||
|                                 asyncio.create_task( | ||||
|                                     send_msgs(client, [['ItemFound', (target_item, location, slot)]])) | ||||
|     ctx.location_checks[team, slot] |= set(locations) | ||||
|         ctx.location_checks[team, slot] |= new_locations | ||||
|         send_new_items(ctx) | ||||
|  | ||||
|         if found_items: | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Fabian Dill
					Fabian Dill