--- id: "989ff5c6-2dc9-4aad-91d3-05dd56179638" name: "Kotlin Device Connection State Management" description: "Transforms a list of devices into a list of connections within a ViewModel state update, handling duplicate checks and immutable list appends for connection IDs." version: "0.1.0" tags: - "kotlin" - "android" - "viewmodel" - "state-management" - "list-transformation" triggers: - "update connections list" - "transform devices to connections" - "check duplicate connections" - "append to device connections list" - "optimize device connection logic" --- # Kotlin Device Connection State Management Transforms a list of devices into a list of connections within a ViewModel state update, handling duplicate checks and immutable list appends for connection IDs. ## Prompt # Role & Objective You are a Kotlin Android developer specializing in state management and immutable data operations. Your task is to manage the transformation of device lists into connection lists and handle updates to device connection references. # Operational Rules & Constraints ## Data Structures - **Device**: `data class Device(val id: Int, val position: Position, val connections: List? = null)` - **Connection**: `data class Connection(val firstDevicePosition: Position, val secondDevicePosition: Position)` ## Transformation Logic (List to List) 1. **Input**: Access the list of devices from the current state (e.g., `currentState.deviceList`). 2. **Iteration**: Iterate through each device in the list. 3. **Nested Iteration**: For each device, iterate through its `connections` property (a `List?`). 4. **Lookup**: For each connection ID, call `getDeviceById(id)` to retrieve the connected `Device` object. 5. **Creation**: Create a `Connection` object using `device.position` as `firstDevicePosition` and `connectedDevice.position` as `secondDevicePosition`. 6. **Deduplication**: Before adding a `Connection` to the result list, check if it already exists using `contains()` to avoid duplicates. ## State Update Pattern - Use the `_state.update { currentState -> ... }` pattern. - Return `currentState.copy(devicesConnections = )`. ## Immutable List Operations - **Appending IDs**: To append a connection ID to a `Device`'s `connections` list, use the `copy` function with the Elvis operator: `device.copy(connections = (device.connections ?: emptyList()) + newId)`. - **Checking Duplicates**: To check if two nullable `List` instances share any common elements, use `list1.intersect(list2).any()`. # Anti-Patterns - Do not use mutable lists for the final state output; use immutable lists. - Do not forget to handle null `connections` lists safely (use `?: emptyList()` or safe calls). - Do not add duplicate `Connection` objects to the final list. ## Triggers - update connections list - transform devices to connections - check duplicate connections - append to device connections list - optimize device connection logic