blob: 3677d7b074d009acf71ce3dc02174bcc3317ef58 [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2000, 2005 IBM Corporation and others.
*
* This program and the accompanying materials
* are made available under the terms of the Eclipse Public License 2.0
* which accompanies this distribution, and is available at
* https://www.eclipse.org/legal/epl-2.0/
*
* SPDX-License-Identifier: EPL-2.0
*
* Contributors:
* IBM Corporation - initial API and implementation
*******************************************************************************/
package org.eclipse.jface.text;
/**
* A painter is responsible for creating, managing, updating, and removing visual decorations on an
* <code>ITextViewer</code>'s text widget. Examples are the highlighting of the caret line, the
* print margin, or the highlighting of matching peer characters such as pairs of brackets.
* <p>
* Clients may implement this interface.
* </p>
* <p>
* Painters should be registered with a {@link org.eclipse.jface.text.PaintManager}. The paint
* manager tracks several classes of events issued by an <code>ITextViewer</code> and reacts by
* appropriately invoking the registered painters.
* </p>
* <p>
* Painters are either active or inactive. Usually, painters are initially inactive and are
* activated by the first call to their <code>paint</code> method. Painters can be deactivated by
* calling <code>deactivate</code>. Inactive painter can be reactivated by calling
* <code>paint</code>.
* </p>
* <p>
* Painters usually have to manage state information. E.g., a painter painting a caret line
* highlight must redraw the previous and the actual caret line in the advent of a change of the
* caret position. This state information must be adapted to changes of the viewer's content. In
* order to support this common scenario, the <code>PaintManager</code> gives a painter access to a
* {@link org.eclipse.jface.text.IPaintPositionManager}. The painter can use this updater to manage
* its state information.
* </p>
*
* @see org.eclipse.jface.text.PaintManager
* @see org.eclipse.jface.text.IPaintPositionManager
* @since 2.1
*/
public interface IPainter {
/**
* Constant describing the reason of a repaint request: selection changed.
*/
int SELECTION= 0;
/**
* Constant describing the reason of a repaint request: text changed.
*/
int TEXT_CHANGE= 1;
/**
* Constant describing the reason of a repaint request: key pressed.
*/
int KEY_STROKE= 2;
/**
* Constant describing the reason of a repaint request: mouse button pressed.
*/
int MOUSE_BUTTON= 4;
/**
* Constant describing the reason of a repaint request: paint manager internal change.
*/
int INTERNAL= 8;
/**
* Constant describing the reason of a repaint request: paint manager or painter configuration changed.
*/
int CONFIGURATION= 16;
/**
* Disposes this painter. Prior to disposing, a painter should be deactivated. A disposed
* painter can not be reactivated.
*
* @see #deactivate(boolean)
*/
void dispose();
/**
* Requests this painter to repaint because of the given reason. Based on
* the given reason the painter can decide whether it will repaint or not.
* If it repaints and is inactive, it will activate itself.
*
* @param reason the repaint reason, value is one of the constants defined
* in this interface
*/
void paint(int reason);
/**
* Deactivates this painter. If the painter is inactive, this call does not
* have any effect. <code>redraw</code> indicates whether the painter
* should remove any decoration it previously applied. A deactivated painter
* can be reactivated by calling <code>paint</code>.
*
* @param redraw <code>true</code> if any previously applied decoration
* should be removed
* @see #paint(int)
*/
void deactivate(boolean redraw);
/**
* Sets the paint position manager that can be used by this painter or removes any previously
* set paint position manager.
*
* @param manager the paint position manager or <code>null</code>
*/
void setPositionManager(IPaintPositionManager manager);
}