mech_1 = """\ndef move_player(self, action):
    moves = {0: (-1, 0), 1: (1, 0), 2: (0, -1), 3: (0, 1)}  # Up, Down, Left, Right
    dx, dy = moves[action]
    new_row = self.player_position[0] + dx
    new_col = self.player_position[1] + dy
    reward = 0
    if 0 <= new_row < len(self.map) and 0 <= new_col < len(self.map[0]):
        new_tile = self.map[new_row][new_col]
        if new_tile in self.walkable_tiles:
            self.update_player_position(new_row, new_col, new_tile)
    return reward"""

mech_2 = """\ndef pick_object(self):
    reward = 0
    # Check adjacent tiles for interactive objects and pick them if present
    adjacent_positions = [(0, -1), (0, 1), (-1, 0), (1, 0)]  # Up, Down, Left, Right
    for dx, dy in adjacent_positions:
        x, y = self.player_position
        new_x = x + dx
        new_y = y + dy
        if 0 <= new_x < self.grid_width and 0 <= new_y < self.grid_height:
            target_tile = self.map[new_y][new_x]
            if target_tile in self.interactive_object_tiles:
                self.map[new_y][new_x] = self.default_walkable_tile 
                reward = 1
                break  # Exit after picking up one object
    return reward"""

mech_3 = """\ndef hit_enemy(self):
    reward = 0
    # Check adjacent tiles for enemies and hit them if present
    adjacent_positions = [(0, -1), (0, 1), (-1, 0), (1, 0)]  # Up, Down, Left, Right
    for dx, dy in adjacent_positions:
        row, col = self.player_position  # player_position is in (row, col) format
        new_row = row + dx
        new_col = col + dy
        if 0 <= new_row < self.grid_height and 0 <= new_col < self.grid_width:  # Check grid bounds
            target_tile = self.map[new_row][new_col]
            if target_tile in self.enemy_tiles:
                self.map[new_row][new_col] = self.default_walkable_tile
                reward = 1
                break  # Exit after hitting one enemy
    return reward"""

mech_6 = """\ndef push_object(self):
    reward = 0
    adjacent_positions = [(0, -1), (0, 1), (-1, 0), (1, 0)]  # Up, Down, Left, Right
    for dy, dx in adjacent_positions:  # Swapped to dy, dx to match map indexing
        y, x = self.player_position  # Player position is in (row, col) format
        new_y, new_x = y + dy, x + dx
        if 0 <= new_y < self.grid_height and 0 <= new_x < self.grid_width:  # Check bounds using height/width correctly
            target_tile = self.map[new_y][new_x]
            if target_tile in self.interactive_object_tiles:
                push_y, push_x = new_y + dy, new_x + dx  # Push in same direction
                if 0 <= push_y < self.grid_height and 0 <= push_x < self.grid_width:
                    if self.map[push_y][push_x] in self.walkable_tiles:
                        self.map[push_y][push_x] = target_tile
                        self.map[new_y][new_x] = self.default_walkable_tile
                        reward = 1
                        break
    return reward"""

mech_4 = """\ndef teleport_player(self):
    # Find all walkable tiles that are not adjacent to the player
    non_adjacent_walkable_positions = []
    adjacency_offsets = [(0, -1), (0, 1), (-1, 0), (1, 0)]  # Up, Down, Left, Right
    reward = 0
    # Search the map for walkable and non-adjacent tiles
    for row in range(len(self.map)):
        for col in range(len(self.map[0])):
            if self.map[row][col] in self.walkable_tiles:
                is_adjacent = False
                for dx, dy in adjacency_offsets:
                    if (row == self.player_position[0] + dx) and (col == self.player_position[1] + dy):
                        is_adjacent = True
                        break
                if not is_adjacent:
                    non_adjacent_walkable_positions.append((row, col))
    # Teleport the player to a random walkable, non-adjacent position
    if non_adjacent_walkable_positions:
        new_position = random.choice(non_adjacent_walkable_positions)
        self.update_player_position(new_position[0], new_position[1], self.map[new_position[0]][new_position[1]])
        reward += 1
    return reward"""

mech_5 = """\ndef swap_positions(self):
    # Find all enemy positions on the map
    enemy_positions = []
    reward = 0
    for row in range(len(self.map)):
        for col in range(len(self.map[0])):
            if self.map[row][col] in self.enemy_tiles:
                enemy_positions.append((row, col))
    # If there are enemies, randomly swap the player's position with an enemy's position
    if enemy_positions:
        swap_with = random.choice(enemy_positions)
        enemy_row, enemy_col = swap_with
        player_row, player_col = self.player_position
        # Swap positions of player and enemy on the map
        self.map[player_row][player_col], self.map[enemy_row][enemy_col] = self.map[enemy_row][enemy_col], self.map[player_row][player_col]
        # Update the player's position to the swapped position
        self.player_position = (enemy_row, enemy_col)
        # Optional: Output the result of the swap
        reward += 1
    return reward"""

mech_7 = """\ndef jump_player(self):
    reward = 0
    # Define possible jump directions
    jump_directions = [(0, -2), (0, 2), (-2, 0), (2, 0)]  # Up, Down, Left, Right (2 tiles)
    for dx, dy in jump_directions:
        x, y = self.player_position
        mid_x, mid_y = x + dx // 2, y + dy // 2  # Middle tile (jumped over)
        new_x, new_y = x + dx, y + dy  # Landing tile
        # Check if the jump is within bounds
        if 0 <= new_x < self.grid_width and 0 <= new_y < self.grid_height:
            target_tile = self.map[new_y][new_x]
            # Check if the landing tile is walkable
            if target_tile in self.walkable_tiles:
                # Perform the jump
                self.update_player_position(new_x, new_y, target_tile)
                reward = 1
                break  # Exit after a successful jump
    return reward"""
mech_8 = """\ndef drop_object(self):
    reward = 0
    # Check adjacent tiles for empty walkable space
    adjacent_positions = [(0, -1), (0, 1), (-1, 0), (1, 0)]  # Up, Down, Left, Right
    for dx, dy in adjacent_positions:
        row, col = self.player_position
        new_row = row + dx
        new_col = col + dy
        # Check if position is within bounds and walkable
        if 0 <= new_row < self.grid_height and 0 <= new_col < self.grid_width:
            if self.map[new_row][new_col] in self.walkable_tiles:
                # Place an interactive object
                self.map[new_row][new_col] = self.interactive_object_tiles[0]  # Using first interactive object tile
                reward = 1
                break  # Exit after dropping one object        
    return reward"""