Revert "Merge pull request #4972 from matrix-org/travis/room-list/prelaunch/3-remove-debug"
This reverts commit e1b34acdc8.
			
			
				pull/21833/head
			
			
		
							parent
							
								
									4903ce55bb
								
							
						
					
					
						commit
						e955feb12d
					
				|  | @ -39,6 +39,9 @@ declare global { | |||
|         mx_RoomListStore2: RoomListStore2; | ||||
|         mx_RoomListLayoutStore: RoomListLayoutStore; | ||||
|         mxPlatformPeg: PlatformPeg; | ||||
| 
 | ||||
|         // TODO: Remove flag before launch: https://github.com/vector-im/riot-web/issues/14231
 | ||||
|         mx_QuietRoomListLogging: boolean; | ||||
|     } | ||||
| 
 | ||||
|     // workaround for https://github.com/microsoft/TypeScript/issues/30933
 | ||||
|  |  | |||
|  | @ -209,7 +209,13 @@ export default class RoomList2 extends React.Component<IProps, IState> { | |||
|     }; | ||||
| 
 | ||||
|     private updateLists = () => { | ||||
|         this.setState({sublists: RoomListStore.instance.orderedLists}, () => { | ||||
|         const newLists = RoomListStore.instance.orderedLists; | ||||
|         if (!window.mx_QuietRoomListLogging) { | ||||
|             // TODO: Remove debug: https://github.com/vector-im/riot-web/issues/14035
 | ||||
|             console.log("new lists", newLists); | ||||
|         } | ||||
| 
 | ||||
|         this.setState({sublists: newLists}, () => { | ||||
|             this.props.onResize(); | ||||
|         }); | ||||
|     }; | ||||
|  |  | |||
|  | @ -154,6 +154,10 @@ export class RoomListStore2 extends AsyncStoreWithClient<ActionPayload> { | |||
|                 console.warn(`${activeRoomId} is current in RVS but missing from client - clearing sticky room`); | ||||
|                 await this.algorithm.setStickyRoom(null); | ||||
|             } else if (activeRoom !== this.algorithm.stickyRoom) { | ||||
|                 if (!window.mx_QuietRoomListLogging) { | ||||
|                     // TODO: Remove debug: https://github.com/vector-im/riot-web/issues/14035
 | ||||
|                     console.log(`Changing sticky room to ${activeRoomId}`); | ||||
|                 } | ||||
|                 await this.algorithm.setStickyRoom(activeRoom); | ||||
|             } | ||||
|         } | ||||
|  | @ -214,12 +218,20 @@ export class RoomListStore2 extends AsyncStoreWithClient<ActionPayload> { | |||
|                     console.warn(`Own read receipt was in unknown room ${room.roomId}`); | ||||
|                     return; | ||||
|                 } | ||||
|                 if (!window.mx_QuietRoomListLogging) { | ||||
|                     // TODO: Remove debug: https://github.com/vector-im/riot-web/issues/14035
 | ||||
|                     console.log(`[RoomListDebug] Got own read receipt in ${room.roomId}`); | ||||
|                 } | ||||
|                 await this.handleRoomUpdate(room, RoomUpdateCause.ReadReceipt); | ||||
|                 this.updateFn.trigger(); | ||||
|                 return; | ||||
|             } | ||||
|         } else if (payload.action === 'MatrixActions.Room.tags') { | ||||
|             const roomPayload = (<any>payload); // TODO: Type out the dispatcher types
 | ||||
|             if (!window.mx_QuietRoomListLogging) { | ||||
|                 // TODO: Remove debug: https://github.com/vector-im/riot-web/issues/14035
 | ||||
|                 console.log(`[RoomListDebug] Got tag change in ${roomPayload.room.roomId}`); | ||||
|             } | ||||
|             await this.handleRoomUpdate(roomPayload.room, RoomUpdateCause.PossibleTagChange); | ||||
|             this.updateFn.trigger(); | ||||
|         } else if (payload.action === 'MatrixActions.Room.timeline') { | ||||
|  | @ -231,7 +243,16 @@ export class RoomListStore2 extends AsyncStoreWithClient<ActionPayload> { | |||
|             const roomId = eventPayload.event.getRoomId(); | ||||
|             const room = this.matrixClient.getRoom(roomId); | ||||
|             const tryUpdate = async (updatedRoom: Room) => { | ||||
|                 if (!window.mx_QuietRoomListLogging) { | ||||
|                     // TODO: Remove debug: https://github.com/vector-im/riot-web/issues/14035
 | ||||
|                     console.log(`[RoomListDebug] Live timeline event ${eventPayload.event.getId()}` + | ||||
|                         ` in ${updatedRoom.roomId}`); | ||||
|                 } | ||||
|                 if (eventPayload.event.getType() === 'm.room.tombstone' && eventPayload.event.getStateKey() === '') { | ||||
|                     if (!window.mx_QuietRoomListLogging) { | ||||
|                         // TODO: Remove debug: https://github.com/vector-im/riot-web/issues/14035
 | ||||
|                         console.log(`[RoomListDebug] Got tombstone event - trying to remove now-dead room`); | ||||
|                     } | ||||
|                     const newRoom = this.matrixClient.getRoom(eventPayload.event.getContent()['replacement_room']); | ||||
|                     if (newRoom) { | ||||
|                         // If we have the new room, then the new room check will have seen the predecessor
 | ||||
|  | @ -261,10 +282,18 @@ export class RoomListStore2 extends AsyncStoreWithClient<ActionPayload> { | |||
|                 console.warn(`Event ${eventPayload.event.getId()} was decrypted in an unknown room ${roomId}`); | ||||
|                 return; | ||||
|             } | ||||
|             if (!window.mx_QuietRoomListLogging) { | ||||
|                 // TODO: Remove debug: https://github.com/vector-im/riot-web/issues/14035
 | ||||
|                 console.log(`[RoomListDebug] Decrypted timeline event ${eventPayload.event.getId()} in ${roomId}`); | ||||
|             } | ||||
|             await this.handleRoomUpdate(room, RoomUpdateCause.Timeline); | ||||
|             this.updateFn.trigger(); | ||||
|         } else if (payload.action === 'MatrixActions.accountData' && payload.event_type === 'm.direct') { | ||||
|             const eventPayload = (<any>payload); // TODO: Type out the dispatcher types
 | ||||
|             if (!window.mx_QuietRoomListLogging) { | ||||
|                 // TODO: Remove debug: https://github.com/vector-im/riot-web/issues/14035
 | ||||
|                 console.log(`[RoomListDebug] Received updated DM map`); | ||||
|             } | ||||
|             const dmMap = eventPayload.event.getContent(); | ||||
|             for (const userId of Object.keys(dmMap)) { | ||||
|                 const roomIds = dmMap[userId]; | ||||
|  | @ -288,29 +317,54 @@ export class RoomListStore2 extends AsyncStoreWithClient<ActionPayload> { | |||
|             const oldMembership = getEffectiveMembership(membershipPayload.oldMembership); | ||||
|             const newMembership = getEffectiveMembership(membershipPayload.membership); | ||||
|             if (oldMembership !== EffectiveMembership.Join && newMembership === EffectiveMembership.Join) { | ||||
|                 if (!window.mx_QuietRoomListLogging) { | ||||
|                     // TODO: Remove debug: https://github.com/vector-im/riot-web/issues/14035
 | ||||
|                     console.log(`[RoomListDebug] Handling new room ${membershipPayload.room.roomId}`); | ||||
|                 } | ||||
| 
 | ||||
|                 // If we're joining an upgraded room, we'll want to make sure we don't proliferate
 | ||||
|                 // the dead room in the list.
 | ||||
|                 const createEvent = membershipPayload.room.currentState.getStateEvents("m.room.create", ""); | ||||
|                 if (createEvent && createEvent.getContent()['predecessor']) { | ||||
|                     if (!window.mx_QuietRoomListLogging) { | ||||
|                         // TODO: Remove debug: https://github.com/vector-im/riot-web/issues/14035
 | ||||
|                         console.log(`[RoomListDebug] Room has a predecessor`); | ||||
|                     } | ||||
|                     const prevRoom = this.matrixClient.getRoom(createEvent.getContent()['predecessor']['room_id']); | ||||
|                     if (prevRoom) { | ||||
|                         const isSticky = this.algorithm.stickyRoom === prevRoom; | ||||
|                         if (isSticky) { | ||||
|                             if (!window.mx_QuietRoomListLogging) { | ||||
|                                 // TODO: Remove debug: https://github.com/vector-im/riot-web/issues/14035
 | ||||
|                                 console.log(`[RoomListDebug] Clearing sticky room due to room upgrade`); | ||||
|                             } | ||||
|                             await this.algorithm.setStickyRoom(null); | ||||
|                         } | ||||
| 
 | ||||
|                         // Note: we hit the algorithm instead of our handleRoomUpdate() function to
 | ||||
|                         // avoid redundant updates.
 | ||||
|                         if (!window.mx_QuietRoomListLogging) { | ||||
|                             // TODO: Remove debug: https://github.com/vector-im/riot-web/issues/14035
 | ||||
|                             console.log(`[RoomListDebug] Removing previous room from room list`); | ||||
|                         } | ||||
|                         await this.algorithm.handleRoomUpdate(prevRoom, RoomUpdateCause.RoomRemoved); | ||||
|                     } | ||||
|                 } | ||||
| 
 | ||||
|                 if (!window.mx_QuietRoomListLogging) { | ||||
|                     // TODO: Remove debug: https://github.com/vector-im/riot-web/issues/14035
 | ||||
|                     console.log(`[RoomListDebug] Adding new room to room list`); | ||||
|                 } | ||||
|                 await this.handleRoomUpdate(membershipPayload.room, RoomUpdateCause.NewRoom); | ||||
|                 this.updateFn.trigger(); | ||||
|                 return; | ||||
|             } | ||||
| 
 | ||||
|             if (oldMembership !== EffectiveMembership.Invite && newMembership === EffectiveMembership.Invite) { | ||||
|                 if (!window.mx_QuietRoomListLogging) { | ||||
|                     // TODO: Remove debug: https://github.com/vector-im/riot-web/issues/14035
 | ||||
|                     console.log(`[RoomListDebug] Handling invite to ${membershipPayload.room.roomId}`); | ||||
|                 } | ||||
|                 await this.handleRoomUpdate(membershipPayload.room, RoomUpdateCause.NewRoom); | ||||
|                 this.updateFn.trigger(); | ||||
|                 return; | ||||
|  | @ -318,6 +372,10 @@ export class RoomListStore2 extends AsyncStoreWithClient<ActionPayload> { | |||
| 
 | ||||
|             // If it's not a join, it's transitioning into a different list (possibly historical)
 | ||||
|             if (oldMembership !== newMembership) { | ||||
|                 if (!window.mx_QuietRoomListLogging) { | ||||
|                     // TODO: Remove debug: https://github.com/vector-im/riot-web/issues/14035
 | ||||
|                     console.log(`[RoomListDebug] Handling membership change in ${membershipPayload.room.roomId}`); | ||||
|                 } | ||||
|                 await this.handleRoomUpdate(membershipPayload.room, RoomUpdateCause.PossibleTagChange); | ||||
|                 this.updateFn.trigger(); | ||||
|                 return; | ||||
|  | @ -328,6 +386,10 @@ export class RoomListStore2 extends AsyncStoreWithClient<ActionPayload> { | |||
|     private async handleRoomUpdate(room: Room, cause: RoomUpdateCause): Promise<any> { | ||||
|         const shouldUpdate = await this.algorithm.handleRoomUpdate(room, cause); | ||||
|         if (shouldUpdate) { | ||||
|             if (!window.mx_QuietRoomListLogging) { | ||||
|                 // TODO: Remove debug: https://github.com/vector-im/riot-web/issues/14035
 | ||||
|                 console.log(`[DEBUG] Room "${room.name}" (${room.roomId}) triggered by ${cause} requires list update`); | ||||
|             } | ||||
|             this.updateFn.mark(); | ||||
|         } | ||||
|     } | ||||
|  | @ -447,6 +509,10 @@ export class RoomListStore2 extends AsyncStoreWithClient<ActionPayload> { | |||
|     } | ||||
| 
 | ||||
|     private onAlgorithmListUpdated = () => { | ||||
|         if (!window.mx_QuietRoomListLogging) { | ||||
|             // TODO: Remove debug: https://github.com/vector-im/riot-web/issues/14035
 | ||||
|             console.log("Underlying algorithm has triggered a list update - marking"); | ||||
|         } | ||||
|         this.updateFn.mark(); | ||||
|     }; | ||||
| 
 | ||||
|  | @ -493,6 +559,10 @@ export class RoomListStore2 extends AsyncStoreWithClient<ActionPayload> { | |||
|     } | ||||
| 
 | ||||
|     public addFilter(filter: IFilterCondition): void { | ||||
|         if (!window.mx_QuietRoomListLogging) { | ||||
|             // TODO: Remove debug: https://github.com/vector-im/riot-web/issues/14035
 | ||||
|             console.log("Adding filter condition:", filter); | ||||
|         } | ||||
|         this.filterConditions.push(filter); | ||||
|         if (this.algorithm) { | ||||
|             this.algorithm.addFilterCondition(filter); | ||||
|  | @ -501,6 +571,10 @@ export class RoomListStore2 extends AsyncStoreWithClient<ActionPayload> { | |||
|     } | ||||
| 
 | ||||
|     public removeFilter(filter: IFilterCondition): void { | ||||
|         if (!window.mx_QuietRoomListLogging) { | ||||
|             // TODO: Remove debug: https://github.com/vector-im/riot-web/issues/14035
 | ||||
|             console.log("Removing filter condition:", filter); | ||||
|         } | ||||
|         const idx = this.filterConditions.indexOf(filter); | ||||
|         if (idx >= 0) { | ||||
|             this.filterConditions.splice(idx, 1); | ||||
|  |  | |||
|  | @ -319,6 +319,11 @@ export class Algorithm extends EventEmitter { | |||
|                 } | ||||
|             } | ||||
|             newMap[tagId] = allowedRoomsInThisTag; | ||||
| 
 | ||||
|             if (!window.mx_QuietRoomListLogging) { | ||||
|                 // TODO: Remove debug: https://github.com/vector-im/riot-web/issues/14035
 | ||||
|                 console.log(`[DEBUG] ${newMap[tagId].length}/${rooms.length} rooms filtered into ${tagId}`); | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         const allowedRooms = Object.values(newMap).reduce((rv, v) => { rv.push(...v); return rv; }, <Room[]>[]); | ||||
|  | @ -330,6 +335,10 @@ export class Algorithm extends EventEmitter { | |||
|     protected recalculateFilteredRoomsForTag(tagId: TagID): void { | ||||
|         if (!this.hasFilters) return; // don't bother doing work if there's nothing to do
 | ||||
| 
 | ||||
|         if (!window.mx_QuietRoomListLogging) { | ||||
|             // TODO: Remove debug: https://github.com/vector-im/riot-web/issues/14035
 | ||||
|             console.log(`Recalculating filtered rooms for ${tagId}`); | ||||
|         } | ||||
|         delete this.filteredRooms[tagId]; | ||||
|         const rooms = this.cachedRooms[tagId].map(r => r); // cheap clone
 | ||||
|         this.tryInsertStickyRoomToFilterSet(rooms, tagId); | ||||
|  | @ -337,6 +346,11 @@ export class Algorithm extends EventEmitter { | |||
|         if (filteredRooms.length > 0) { | ||||
|             this.filteredRooms[tagId] = filteredRooms; | ||||
|         } | ||||
| 
 | ||||
|         if (!window.mx_QuietRoomListLogging) { | ||||
|             // TODO: Remove debug: https://github.com/vector-im/riot-web/issues/14035
 | ||||
|             console.log(`[DEBUG] ${filteredRooms.length}/${rooms.length} rooms filtered into ${tagId}`); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     protected tryInsertStickyRoomToFilterSet(rooms: Room[], tagId: TagID) { | ||||
|  | @ -375,6 +389,10 @@ export class Algorithm extends EventEmitter { | |||
|         } | ||||
| 
 | ||||
|         if (!this._cachedStickyRooms || !updatedTag) { | ||||
|             if (!window.mx_QuietRoomListLogging) { | ||||
|                 // TODO: Remove debug: https://github.com/vector-im/riot-web/issues/14035
 | ||||
|                 console.log(`Generating clone of cached rooms for sticky room handling`); | ||||
|             } | ||||
|             const stickiedTagMap: ITagMap = {}; | ||||
|             for (const tagId of Object.keys(this.cachedRooms)) { | ||||
|                 stickiedTagMap[tagId] = this.cachedRooms[tagId].map(r => r); // shallow clone
 | ||||
|  | @ -385,6 +403,10 @@ export class Algorithm extends EventEmitter { | |||
|         if (updatedTag) { | ||||
|             // Update the tag indicated by the caller, if possible. This is mostly to ensure
 | ||||
|             // our cache is up to date.
 | ||||
|             if (!window.mx_QuietRoomListLogging) { | ||||
|                 // TODO: Remove debug: https://github.com/vector-im/riot-web/issues/14035
 | ||||
|                 console.log(`Replacing cached sticky rooms for ${updatedTag}`); | ||||
|             } | ||||
|             this._cachedStickyRooms[updatedTag] = this.cachedRooms[updatedTag].map(r => r); // shallow clone
 | ||||
|         } | ||||
| 
 | ||||
|  | @ -393,6 +415,10 @@ export class Algorithm extends EventEmitter { | |||
|         // we might have updated from the cache is also our sticky room.
 | ||||
|         const sticky = this._stickyRoom; | ||||
|         if (!updatedTag || updatedTag === sticky.tag) { | ||||
|             if (!window.mx_QuietRoomListLogging) { | ||||
|                 // TODO: Remove debug: https://github.com/vector-im/riot-web/issues/14035
 | ||||
|                 console.log(`Inserting sticky room ${sticky.room.roomId} at position ${sticky.position} in ${sticky.tag}`); | ||||
|             } | ||||
|             this._cachedStickyRooms[sticky.tag].splice(sticky.position, 0, sticky.room); | ||||
|         } | ||||
| 
 | ||||
|  | @ -617,6 +643,10 @@ export class Algorithm extends EventEmitter { | |||
|      * processing. | ||||
|      */ | ||||
|     public async handleRoomUpdate(room: Room, cause: RoomUpdateCause): Promise<boolean> { | ||||
|         if (!window.mx_QuietRoomListLogging) { | ||||
|             // TODO: Remove debug: https://github.com/vector-im/riot-web/issues/14035
 | ||||
|             console.log(`Handle room update for ${room.roomId} called with cause ${cause}`); | ||||
|         } | ||||
|         if (!this.algorithms) throw new Error("Not ready: no algorithms to determine tags from"); | ||||
| 
 | ||||
|         // Note: check the isSticky against the room ID just in case the reference is wrong
 | ||||
|  | @ -673,6 +703,10 @@ export class Algorithm extends EventEmitter { | |||
|             const diff = arrayDiff(oldTags, newTags); | ||||
|             if (diff.removed.length > 0 || diff.added.length > 0) { | ||||
|                 for (const rmTag of diff.removed) { | ||||
|                     if (!window.mx_QuietRoomListLogging) { | ||||
|                         // TODO: Remove debug: https://github.com/vector-im/riot-web/issues/14035
 | ||||
|                         console.log(`Removing ${room.roomId} from ${rmTag}`); | ||||
|                     } | ||||
|                     const algorithm: OrderingAlgorithm = this.algorithms[rmTag]; | ||||
|                     if (!algorithm) throw new Error(`No algorithm for ${rmTag}`); | ||||
|                     await algorithm.handleRoomUpdate(room, RoomUpdateCause.RoomRemoved); | ||||
|  | @ -684,6 +718,10 @@ export class Algorithm extends EventEmitter { | |||
|                     this.recalculateStickyRoom(rmTag); | ||||
|                 } | ||||
|                 for (const addTag of diff.added) { | ||||
|                     if (!window.mx_QuietRoomListLogging) { | ||||
|                         // TODO: Remove debug: https://github.com/vector-im/riot-web/issues/14035
 | ||||
|                         console.log(`Adding ${room.roomId} to ${addTag}`); | ||||
|                     } | ||||
|                     const algorithm: OrderingAlgorithm = this.algorithms[addTag]; | ||||
|                     if (!algorithm) throw new Error(`No algorithm for ${addTag}`); | ||||
|                     await algorithm.handleRoomUpdate(room, RoomUpdateCause.NewRoom); | ||||
|  | @ -693,9 +731,17 @@ export class Algorithm extends EventEmitter { | |||
|                 // Update the tag map so we don't regen it in a moment
 | ||||
|                 this.roomIdsToTags[room.roomId] = newTags; | ||||
| 
 | ||||
|                 if (!window.mx_QuietRoomListLogging) { | ||||
|                     // TODO: Remove debug: https://github.com/vector-im/riot-web/issues/14035
 | ||||
|                     console.log(`Changing update cause for ${room.roomId} to Timeline to sort rooms`); | ||||
|                 } | ||||
|                 cause = RoomUpdateCause.Timeline; | ||||
|                 didTagChange = true; | ||||
|             } else { | ||||
|                 if (!window.mx_QuietRoomListLogging) { | ||||
|                     // TODO: Remove debug: https://github.com/vector-im/riot-web/issues/14035
 | ||||
|                     console.log(`Received no-op update for ${room.roomId} - changing to Timeline update`); | ||||
|                 } | ||||
|                 cause = RoomUpdateCause.Timeline; | ||||
|             } | ||||
| 
 | ||||
|  | @ -721,15 +767,28 @@ export class Algorithm extends EventEmitter { | |||
|         // as the sticky room relies on this.
 | ||||
|         if (cause !== RoomUpdateCause.NewRoom && cause !== RoomUpdateCause.RoomRemoved) { | ||||
|             if (this.stickyRoom === room) { | ||||
|                 if (!window.mx_QuietRoomListLogging) { | ||||
|                     // TODO: Remove debug: https://github.com/vector-im/riot-web/issues/14035
 | ||||
|                     console.warn(`[RoomListDebug] Received ${cause} update for sticky room ${room.roomId} - ignoring`); | ||||
|                 } | ||||
|                 return false; | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         if (!this.roomIdsToTags[room.roomId]) { | ||||
|             if (CAUSES_REQUIRING_ROOM.includes(cause)) { | ||||
|                 if (!window.mx_QuietRoomListLogging) { | ||||
|                     // TODO: Remove debug: https://github.com/vector-im/riot-web/issues/14035
 | ||||
|                     console.warn(`Skipping tag update for ${room.roomId} because we don't know about the room`); | ||||
|                 } | ||||
|                 return false; | ||||
|             } | ||||
| 
 | ||||
|             if (!window.mx_QuietRoomListLogging) { | ||||
|                 // TODO: Remove debug: https://github.com/vector-im/riot-web/issues/14035
 | ||||
|                 console.log(`[RoomListDebug] Updating tags for room ${room.roomId} (${room.name})`); | ||||
|             } | ||||
| 
 | ||||
|             // Get the tags for the room and populate the cache
 | ||||
|             const roomTags = this.getTagsForRoom(room).filter(t => !isNullOrUndefined(this.cachedRooms[t])); | ||||
| 
 | ||||
|  | @ -738,6 +797,16 @@ export class Algorithm extends EventEmitter { | |||
|             if (!roomTags.length) throw new Error(`Tags cannot be determined for ${room.roomId}`); | ||||
| 
 | ||||
|             this.roomIdsToTags[room.roomId] = roomTags; | ||||
| 
 | ||||
|             if (!window.mx_QuietRoomListLogging) { | ||||
|                 // TODO: Remove debug: https://github.com/vector-im/riot-web/issues/14035
 | ||||
|                 console.log(`[RoomListDebug] Updated tags for ${room.roomId}:`, roomTags); | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         if (!window.mx_QuietRoomListLogging) { | ||||
|             // TODO: Remove debug: https://github.com/vector-im/riot-web/issues/14035
 | ||||
|             console.log(`[RoomListDebug] Reached algorithmic handling for ${room.roomId} and cause ${cause}`); | ||||
|         } | ||||
| 
 | ||||
|         const tags = this.roomIdsToTags[room.roomId]; | ||||
|  | @ -760,6 +829,10 @@ export class Algorithm extends EventEmitter { | |||
|             changed = true; | ||||
|         } | ||||
| 
 | ||||
|         if (!window.mx_QuietRoomListLogging) { | ||||
|             // TODO: Remove debug: https://github.com/vector-im/riot-web/issues/14035
 | ||||
|             console.log(`[RoomListDebug] Finished handling ${room.roomId} with cause ${cause} (changed=${changed})`); | ||||
|         } | ||||
|         return changed; | ||||
|     } | ||||
| } | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	 Travis Ralston
						Travis Ralston