/* * Copyright 2000-2012 JetBrains s.r.o. * * 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 com.intellij.openapi.editor; import com.intellij.openapi.Disposable; import com.intellij.openapi.editor.event.DocumentListener; import com.intellij.openapi.util.TextRange; import com.intellij.openapi.util.UserDataHolder; import org.jetbrains.annotations.NonNls; import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.Nullable; import java.beans.PropertyChangeListener; /** * Represents the contents of a text file loaded into memory, and possibly opened in an IDEA * text editor. Line breaks in the document text are always normalized as single \n characters, * and are converted to proper format when the document is saved. * <p/> * Please see <a href="http://confluence.jetbrains.net/display/IDEADEV/IntelliJ+IDEA+Architectural+Overview">IntelliJ IDEA Architectural Overview </a> * for high-level overview. * * @see Editor#getDocument() * @see com.intellij.psi.PsiDocumentManager * @see com.intellij.openapi.fileEditor.FileDocumentManager * @see EditorFactory#createDocument(CharSequence) */ public interface Document extends UserDataHolder { Document[] EMPTY_ARRAY = new Document[0]; @NonNls String PROP_WRITABLE = "writable"; /** * Retrieves a copy of the document content. For obvious performance reasons use * {@link #getCharsSequence()} whenever it's possible. * * @return document content. */ String getText(); @NotNull String getText(@NotNull TextRange range); /** * Use this method instead of {@link #getText()} if you do not need to create a copy of the content. * Content represented by returned CharSequence is subject to change whenever document is modified via delete/replace/insertString method * calls. It is necessary to obtain Application.runWriteAction() to modify content of the document though so threading issues won't * arise. * * @return inplace document content. * @see #getTextLength() */ @NotNull CharSequence getCharsSequence(); /** * @deprecated Use {@link #getCharsSequence()} or {@link #getText()} instead. */ @NotNull char[] getChars(); /** * Returns the length of the document text. * * @return the length of the document text. * @see #getCharsSequence() */ int getTextLength(); /** * Returns the number of lines in the document. * * @return the number of lines in the document. */ int getLineCount(); /** * Returns the line number (0-based) corresponding to the specified offset in the document. * * @param offset the offset to get the line number for (must be in the range from 0 to * getTextLength()-1) * @return the line number corresponding to the offset. */ int getLineNumber(int offset); /** * Returns the start offset for the line with the specified number. * * @param line the line number (from 0 to getLineCount()-1) * @return the start offset for the line. */ int getLineStartOffset(int line); /** * Returns the end offset for the line with the specified number. * * @param line the line number (from 0 to getLineCount()-1) * @return the end offset for the line. */ int getLineEndOffset(int line); /** * Inserts the specified text at the specified offset in the document. Line breaks in * the inserted text must be normalized as \n. * * @param offset the offset to insert the text at. * @param s the text to insert. * @throws ReadOnlyModificationException if the document is read-only. * @throws ReadOnlyFragmentModificationException if the fragment to be modified is covered by a guarded block. */ void insertString(int offset, @NotNull CharSequence s); /** * Deletes the specified range of text from the document. * * @param startOffset the start offset of the range to delete. * @param endOffset the end offset of the range to delete. * @throws ReadOnlyModificationException if the document is read-only. * @throws ReadOnlyFragmentModificationException if the fragment to be modified is covered by a guarded block. */ void deleteString(int startOffset, int endOffset); /** * Replaces the specified range of text in the document with the specified string. * Line breaks in the text to replace with must be normalized as \n. * * @param startOffset the start offset of the range to replace. * @param endOffset the end offset of the range to replace. * @param s the text to replace with. * @throws ReadOnlyModificationException if the document is read-only. * @throws ReadOnlyFragmentModificationException if the fragment to be modified is covered by a guarded block. */ void replaceString(int startOffset, int endOffset, @NotNull CharSequence s); /** * Checks if the document text is read-only. * * @return true if the document text is writable, false if it is read-only. * @see #fireReadOnlyModificationAttempt() */ boolean isWritable(); /** * Gets the modification stamp value. Modification stamp is a value changed by any modification * of the content of the file. Note that it is not related to the file modification time. * * @return the modification stamp value. * @see com.intellij.psi.PsiFile#getModificationStamp() * @see com.intellij.openapi.vfs.VirtualFile#getModificationStamp() */ long getModificationStamp(); /** * Fires a notification that the user would like to remove the read-only state * from the document (the read-only state can be removed by checking the file out * from the version control system, or by clearing the read-only attribute on the file). */ void fireReadOnlyModificationAttempt(); /** * Adds a listener for receiving notifications about changes in the document content. * * @param listener the listener instance. */ void addDocumentListener(@NotNull DocumentListener listener); void addDocumentListener(@NotNull DocumentListener listener, @NotNull Disposable parentDisposable); /** * Removes a listener for receiving notifications about changes in the document content. * * @param listener the listener instance. */ void removeDocumentListener(@NotNull DocumentListener listener); /** * Creates a range marker which points to the specified range of text in the document and * is automatically adjusted when the document text is changed. The marker is invalidated * by external changes to the document text (for example, reloading the file from disk). * * @param startOffset the start offset for the range of text covered by the marker. * @param endOffset the end offset for the range of text covered by the marker. * @return the marker instance. */ @NotNull RangeMarker createRangeMarker(int startOffset, int endOffset); /** * Creates a range marker which points to the specified range of text in the document and * is automatically adjusted when the document text is changed. The marker is optionally * invalidated by external changes to the document text (for example, reloading the file from disk). * * @param startOffset the start offset for the range of text covered by the marker. * @param endOffset the end offset for the range of text covered by the marker. * @param surviveOnExternalChange if true, the marker is not invalidated by external changes. * @return the marker instance. */ @NotNull RangeMarker createRangeMarker(int startOffset, int endOffset, boolean surviveOnExternalChange); /** * Adds a listener for receiving notifications about changes in the properties of the document * (for example, its read-only state). * * @param listener the listener instance. */ void addPropertyChangeListener(@NotNull PropertyChangeListener listener); /** * Removes a listener for receiving notifications about changes in the properties of the document * (for example, its read-only state). * * @param listener the listener instance. */ void removePropertyChangeListener(@NotNull PropertyChangeListener listener); /** * Marks the document as read-only or read/write. This method only modifies the flag stored * in the document instance - no checkouts or file changes are performed. * * @param isReadOnly the new value of the read-only flag. * @see #isWritable() * @see #fireReadOnlyModificationAttempt() */ void setReadOnly(boolean isReadOnly); /** * Marks a range of text in the document as read-only (attempts to modify text in the * range cause {@link ReadOnlyFragmentModificationException} to be thrown). * * @param startOffset the start offset of the text range to mark as read-only. * @param endOffset the end offset of the text range to mark as read-only. * @return the marker instance. * @see #removeGuardedBlock(RangeMarker) * @see #startGuardedBlockChecking() * @see com.intellij.openapi.editor.actionSystem.EditorActionManager#setReadonlyFragmentModificationHandler(com.intellij.openapi.editor.actionSystem.ReadonlyFragmentModificationHandler) */ @NotNull RangeMarker createGuardedBlock(int startOffset, int endOffset); /** * Removes a marker marking a range of text in the document as read-only. * * @param block the marker to remove. * @see #createGuardedBlock(int, int) */ void removeGuardedBlock(@NotNull RangeMarker block); /** * Returns the read-only marker covering the specified offset in the document. * * @param offset the offset for which the marker is requested. * @return the marker instance, or null if the specified offset is not covered by a read-only marker. */ @Nullable RangeMarker getOffsetGuard(int offset); /** * Returns the read-only marker covering the specified range in the document. * * @param start the start offset of the range for which the marker is requested. * @param end the end offset of the range for which the marker is requested. * @return the marker instance, or null if the specified range is not covered by a read-only marker. */ @Nullable RangeMarker getRangeGuard(int start, int end); /** * Enables checking for read-only markers when the document is modified. Checking is disabled by default. * * @see #createGuardedBlock(int, int) * @see #stopGuardedBlockChecking() */ void startGuardedBlockChecking(); /** * Disables checking for read-only markers when the document is modified. Checking is disabled by default. * * @see #createGuardedBlock(int, int) * @see #startGuardedBlockChecking() */ void stopGuardedBlockChecking(); /** * Sets the maximum size of the cyclic buffer used for the document. If the document uses * a cyclic buffer, text added to the end of the document exceeding the maximum size causes * text to be removed from the beginning of the document. * * @param bufferSize the cyclic buffer size, or 0 if the document should not use a cyclic buffer. */ void setCyclicBufferSize(int bufferSize); void setText(@NotNull final CharSequence text); @NotNull RangeMarker createRangeMarker(@NotNull TextRange textRange); int getLineSeparatorLength(int line); }