/** * Copyright 2010 JBoss Inc * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.drools.planner.core.move; import java.util.Arrays; import java.util.Collection; import java.util.HashSet; import java.util.List; import java.util.Collections; import java.util.ArrayList; import java.util.Set; import org.drools.WorkingMemory; import org.drools.planner.core.localsearch.decider.acceptor.tabu.TabuPropertyEnabled; /** * A CompositeMove is composed out of multiple other moves. * <p/> * Warning: one of the moveList moves should not rely on the effect on of a previous moveList move * to create an uncorrupted undoMove. In other words, * @see Move * @author Geoffrey De Smet */ public class CompositeMove implements Move, TabuPropertyEnabled { protected List<Move> moveList; public List<Move> getMoveList() { return moveList; } /** * @param moveList cannot be null */ public CompositeMove(List<Move> moveList) { this.moveList = moveList; } public boolean isMoveDoable(WorkingMemory workingMemory) { for (Move move : moveList) { if (!move.isMoveDoable(workingMemory)) { return false; } } return true; } public Move createUndoMove(WorkingMemory workingMemory) { List<Move> undoMoveList = new ArrayList<Move>(moveList.size()); for (Move move : moveList) { // Note: this undoMove doesn't have the affect of a previous move in the moveList // This could be made possible by merging the methods createUndoMove and doMove... Move undoMove = move.createUndoMove(workingMemory); undoMoveList.add(undoMove); } Collections.reverse(undoMoveList); return new CompositeMove(undoMoveList); } public void doMove(WorkingMemory workingMemory) { for (Move move : moveList) { move.doMove(workingMemory); } } public Collection<? extends Object> getTabuProperties() { Set<Object> tabuProperties = new HashSet<Object>(moveList.size() * 2); for (Move move : moveList) { tabuProperties.addAll(((TabuPropertyEnabled) move).getTabuProperties()); } return tabuProperties; } public boolean equals(Object o) { if (this == o) { return true; } else if (o instanceof CompositeMove) { CompositeMove other = (CompositeMove) o; return moveList.equals(other.moveList); } else { return false; } } public int hashCode() { return moveList.hashCode(); } public String toString() { return moveList.toString(); } }