Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance. Project price only 1 $
You can buy this project and download/modify it how often you want.
/*******************************************************************************
* Stefan Meyer, 2012 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.atemsource.atem.utility.compare.builder;
import java.util.ArrayList;
import java.util.Collection;
import java.util.HashSet;
import java.util.Iterator;
import java.util.LinkedList;
import java.util.List;
import java.util.Set;
import org.atemsource.atem.api.attribute.OrderableCollection;
import org.atemsource.atem.api.type.Type;
import org.atemsource.atem.utility.compare.AttributeComparison;
import org.atemsource.atem.utility.compare.CompareContext;
import org.atemsource.atem.utility.compare.Comparison;
import org.atemsource.atem.utility.compare.Difference;
/**
* this comparison works in the following way: 1. find elements in both collection that are equal. These are considered
* rearrangements. 2. go through the elements of both collections in one iteration. 2.1. If both elements are part of
* rearrangements continue 2.2. If one of the elements is part of a rearrangement then the other one is considered to be
* removed or added. 2.3. If none is part of a rearrangement and they have the same type the element is considered
* changed. 2.4. If none is part of a rearrangement and they don't have the same type the old element is considered to
* be removed and a new one added. 3. All rearrangements that are caused by additions or removals are removed from the
* list of changes.
*/
public class OrderableCollectionAttributeComparison extends AttributeComparison
{
private IdentityCheck identityCheck;
private void convertPreliminaryRearragements(Object a, Object b, OrderableCollection