/*******************************************************************************
* Copyright (c) 2005 IBM Corporation and others. All rights reserved. This program and the
* accompanying materials are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html Contributors: IBM Corporation - initial API and
* implementation
*******************************************************************************/
package org.eclipse.wst.sse.ui.internal.reconcile.validator;
import org.eclipse.jface.text.IDocument;
import org.eclipse.jface.text.IRegion;
import org.eclipse.wst.validation.internal.provisional.core.IReporter;
import org.eclipse.wst.validation.internal.provisional.core.IValidationContext;
/**
* Interface to allow for "partial document" as you type validation.
*/
public interface ISourceValidator {
/**
* As you type validation is getting "hooked up" to this IDocument. This is the instance of
* IDocument that the validator should operate on for each validate call.
*
* @param document
*/
void connect(IDocument document);
/**
* The same IDocument passed in from the connect() method. This indicates that as you type
* validation is "shutting down" for this IDocument.
*
* @param document
*/
void disconnect(IDocument document);
/**
* Like IValidator#validate(IValidationContext helper, IReporter reporter) except passes the dirty
* region, so document validation can be better optimized.
*
* @param dirtyRegion
* @param helper
* @param reporter
*/
void validate(IRegion dirtyRegion, IValidationContext helper, IReporter reporter);
}