Class TextEditorBuffer
- java.lang.Object
- 
- org.eclipse.handly.ui.texteditor.TextEditorBuffer
 
- 
- All Implemented Interfaces:
- java.lang.AutoCloseable,- IBuffer,- ISnapshotProvider,- IReferenceCountable
 
 public final class TextEditorBuffer extends java.lang.Object implements IBuffer Implementation ofIBufferbacked by a text editor document.An instance of this class is safe for use by multiple threads, provided that the underlying text editor document is thread-safe. However, certain operations can only be executed by the UI thread: - save
- isDirty
- applyChange- if save is requested
- addListener
- removeListener
 
- 
- 
Constructor SummaryConstructors Constructor Description TextEditorBuffer(org.eclipse.ui.texteditor.IDocumentProvider provider, org.eclipse.ui.IEditorInput input)Creates a new buffer instance and connects it to the document provided for the given editor input via the given provider.TextEditorBuffer(org.eclipse.ui.texteditor.ITextEditor editor)Deprecated.UseTextEditorBuffer(IDocumentProvider, IEditorInput)instead.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddListener(IBufferListener listener)Adds the given listener to this buffer.voidaddRef()Spawns a new independent ownership of this object.IBufferChangeapplyChange(IBufferChange change, org.eclipse.core.runtime.IProgressMonitor monitor)Applies the given change to this buffer.org.eclipse.jface.text.source.IAnnotationModelgetAnnotationModel()Returns the annotation model of this buffer, if any.org.eclipse.jface.text.IDocumentgetDocument()Returns the underlying document of this buffer.ISnapshotgetSnapshot()Returns the current snapshot of this buffer.intgetSupportedListenerMethods()Returns a bit-mask describing the listener methods supported by this buffer.booleanisDirty()Returns whether this buffer has been modified since the last time it was opened or saved.voidrelease()Relinquishes an independent ownership of this object.voidremoveListener(IBufferListener listener)Removes the given listener from this buffer.voidsave(IContext context, org.eclipse.core.runtime.IProgressMonitor monitor)Saves this buffer.- 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 - 
Methods inherited from interface org.eclipse.handly.util.IReferenceCountableclose
 
- 
 
- 
- 
- 
Constructor Detail- 
TextEditorBufferpublic TextEditorBuffer(org.eclipse.ui.texteditor.ITextEditor editor) throws org.eclipse.core.runtime.CoreExceptionDeprecated.UseTextEditorBuffer(IDocumentProvider, IEditorInput)instead.Creates a new buffer instance and connects it to the current document of the given text editor.Note: The association between the buffer and the document will not change even if the association between the text editor and the document changes (e.g., when a new editor input is set). It is the client responsibility to releasethe created buffer after it is no longer needed.This constructor can only be executed by the UI thread. - Parameters:
- editor- not- null
- Throws:
- org.eclipse.core.runtime.CoreException- if the buffer could not be connected
 
 - 
TextEditorBufferpublic TextEditorBuffer(org.eclipse.ui.texteditor.IDocumentProvider provider, org.eclipse.ui.IEditorInput input) throws org.eclipse.core.runtime.CoreExceptionCreates a new buffer instance and connects it to the document provided for the given editor input via the given provider.It is the client responsibility to releasethe created buffer after it is no longer needed.This constructor can only be executed by the UI thread. - Parameters:
- provider- a document provider (not- null)
- input- an editor input (not- null)
- Throws:
- org.eclipse.core.runtime.CoreException- if the buffer could not be connected
- Since:
- 1.5
 
 
- 
 - 
Method Detail- 
getDocumentpublic org.eclipse.jface.text.IDocument getDocument() Description copied from interface:IBufferReturns the underlying document of this buffer. The relationship between a buffer and its document does not change over the lifetime of the buffer.- Specified by:
- getDocumentin interface- IBuffer
- Returns:
- the buffer's underlying document (never null)
 
 - 
getAnnotationModelpublic org.eclipse.jface.text.source.IAnnotationModel getAnnotationModel() Description copied from interface:IBufferReturns the annotation model of this buffer, if any.- Specified by:
- getAnnotationModelin interface- IBuffer
- Returns:
- the buffer's annotation model, or nullif none
 
 - 
getSnapshotpublic ISnapshot getSnapshot() Description copied from interface:IBufferReturns the current snapshot of this buffer. The returned snapshot may immediately become stale or expire.Note that it is possible to obtain a non-expiringsnapshot from the buffer, although protractedly holding on non-expiring snapshots is not recommended as they may potentially consume large amount of space.- Specified by:
- getSnapshotin interface- IBuffer
- Specified by:
- getSnapshotin interface- ISnapshotProvider
- Returns:
- the buffer's current snapshot (never null)
 
 - 
applyChangepublic IBufferChange applyChange(IBufferChange change, org.eclipse.core.runtime.IProgressMonitor monitor) throws org.eclipse.core.runtime.CoreException Description copied from interface:IBufferApplies the given change to this buffer.Note that an update conflict may occur if the buffer's contents have changed since the inception of the snapshot on which the change is based. In that case, a StaleSnapshotExceptionis thrown.- Specified by:
- applyChangein interface- IBuffer
- Parameters:
- change- a buffer change (not- null)
- monitor- a progress monitor, or- nullif progress reporting is not desired. The caller must not rely on- IProgressMonitor.done()having been called by the receiver
- Returns:
- undo change, if requested by the change. Otherwise, null
- Throws:
- org.eclipse.core.runtime.CoreException- if the change's edit tree is not in a valid state, or if one of the edits in the tree could not be executed, or if save is requested by the change but the buffer could not be saved
 
 - 
savepublic void save(IContext context, org.eclipse.core.runtime.IProgressMonitor monitor) throws org.eclipse.core.runtime.CoreException Description copied from interface:IBufferSaves this buffer. It is up to the implementors of this method to decide what saving means. Typically, the contents of the underlying resource is changed to the contents of the buffer.- Specified by:
- savein interface- IBuffer
- Parameters:
- context- the operation context (not- null)
- monitor- a progress monitor, or- nullif progress reporting is not desired. The caller must not rely on- IProgressMonitor.done()having been called by the receiver
- Throws:
- org.eclipse.core.runtime.CoreException- if the buffer could not be saved
 
 - 
isDirtypublic boolean isDirty() Description copied from interface:IBufferReturns whether this buffer has been modified since the last time it was opened or saved.
 - 
getSupportedListenerMethodspublic int getSupportedListenerMethods() Description copied from interface:IBufferReturns a bit-mask describing the listener methods supported by this buffer. The buffer will never invoke a listener method it does not support.- Specified by:
- getSupportedListenerMethodsin interface- IBuffer
- Returns:
- a bit-mask describing the supported listener methods
- See Also:
- IBufferListener
 
 - 
addListenerpublic void addListener(IBufferListener listener) Description copied from interface:IBufferAdds the given listener to this buffer. Has no effect if the same listener is already registered.- Specified by:
- addListenerin interface- IBuffer
- Parameters:
- listener- not- null
 
 - 
removeListenerpublic void removeListener(IBufferListener listener) Description copied from interface:IBufferRemoves the given listener from this buffer. Has no effect if the same listener was not already registered.- Specified by:
- removeListenerin interface- IBuffer
- Parameters:
- listener- not- null
 
 - 
addRefpublic void addRef() Description copied from interface:IReferenceCountableSpawns a new independent ownership of this object. Each successful call toaddRef()must ultimately be followed by exactly one call toIReferenceCountable.release().- Specified by:
- addRefin interface- IBuffer
- Specified by:
- addRefin interface- IReferenceCountable
- Specified by:
- addRefin interface- ISnapshotProvider
 
 - 
releasepublic void release() Description copied from interface:IReferenceCountableRelinquishes an independent ownership of this object. Each independent ownership of the object must ultimately end with exactly one call to this method.- Specified by:
- releasein interface- IBuffer
- Specified by:
- releasein interface- IReferenceCountable
- Specified by:
- releasein interface- ISnapshotProvider
- See Also:
- IReferenceCountable.close()
 
 
- 
 
-