mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-10-08 14:51:49 +00:00
125781 rmunteanu: Merged 5.1.N (5.1.2) to 5.2.N (5.2.1) 125603 rmunteanu: Merged 5.1.1 (5.1.1) to 5.1.N (5.1.2) 125484 slanglois: MNT-16155 Update source headers - remove old Copyrights from Java and JSP dource files git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@127808 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
54 lines
1.5 KiB
Java
54 lines
1.5 KiB
Java
package org.alfresco.util.schemacomp;
|
|
|
|
import java.util.List;
|
|
|
|
import org.alfresco.util.schemacomp.model.DbObject;
|
|
import org.alfresco.util.schemacomp.validator.DbValidator;
|
|
|
|
/**
|
|
* Invokes the correct validator for a given DbObject.
|
|
*
|
|
* @author Matt Ward
|
|
*/
|
|
public class ValidatingVisitor implements DbObjectVisitor
|
|
{
|
|
private DiffContext ctx;
|
|
private ComparisonUtils comparisonUtils = new DefaultComparisonUtils();
|
|
|
|
public ValidatingVisitor(DiffContext ctx)
|
|
{
|
|
this.ctx = ctx;
|
|
}
|
|
|
|
|
|
@Override
|
|
public void visit(DbObject referenceObj)
|
|
{
|
|
List<DbObject> matches = comparisonUtils.findEquivalentObjects(ctx.getTargetSchema(), referenceObj);
|
|
|
|
if (matches.size() > 1)
|
|
{
|
|
ctx.getComparisonResults().add(new RedundantDbObject(referenceObj, matches));
|
|
}
|
|
|
|
// Validate each matching target object against the reference object
|
|
// using each of the available validators for that reference object.
|
|
for (DbValidator validator : referenceObj.getValidators())
|
|
{
|
|
for (DbObject target : matches)
|
|
{
|
|
validator.validate(referenceObj, target, ctx);
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* @param comparisonUtils the comparisonUtils to set
|
|
*/
|
|
public void setComparisonUtils(ComparisonUtils comparisonUtils)
|
|
{
|
|
this.comparisonUtils = comparisonUtils;
|
|
}
|
|
}
|