Interface IWorkingCopy

All Superinterfaces:
org.eclipse.core.runtime.IAdaptable, IBufferChangedListener, ICElement, IOpenable, IParent, ISourceManipulation, ISourceReference, ITranslationUnit

public interface IWorkingCopy extends ITranslationUnit

A working copy of a C element acts just like a regular element (handle), except it is not attached to an underlying resource. A working copy is not visible to the rest of the C model. Changes in a working copy's buffer are not realized in a resource. To bring the C model up-to-date with a working copy's contents, an explicit commit must be performed on the working copy. Other operations performed on a working copy update the contents of the working copy's buffer but do not commit the contents of the working copy.

Note: The contents of a working copy is determined when a working copy is created, based on the current content of the element the working copy is created from. If a working copy is an ICFile and is explicitly closed, the working copy's buffer will be thrown away. However, clients should not explicitly open and close working copies.

The client that creates a working copy is responsible for destroying the working copy. The C model will never automatically destroy or close a working copy. (Note that destroying a working copy does not commit it to the model, it only frees up the memory occupied by the element). After a working copy is destroyed, the working copy cannot be accessed again. Non- handle methods will throw a CModelException indicating the C element does not exist.

A working copy cannot be created from another working copy. Calling getWorkingCopy on a working copy returns the receiver.

Restriction:
This interface is not intended to be implemented by clients.
Restriction:
This interface is not intended to be extended by clients.
  • Method Details

    • commit

      void commit(boolean force, org.eclipse.core.runtime.IProgressMonitor monitor) throws CModelException
      Commits the contents of this working copy to its original element and underlying resource, bringing the C model up-to-date with the current contents of the working copy.

      It is possible that the contents of the original resource have changed since this working copy was created, in which case there is an update conflict. The value of the force parameter effects the resolution of such a conflict:

      • true - in this case the contents of this working copy are applied to the underlying resource even though this working copy was created before a subsequent change in the resource
      • false - in this case a CModelException is thrown
      Throws:
      CModelException
    • destroy

      void destroy()
      Destroys this working copy, closing its buffer and discarding its structure. Subsequent attempts to access non-handle information for this working copy will result in CModelExceptions. Has no effect if this element is not a working copy.

      If this working copy is shared, it is destroyed only when the number of calls to destroy() is the same as the number of calls to getSharedWorkingCopy(IProgressMonitor, IBufferFactory). A REMOVED CElementDelta is then reported on this working copy.

    • getOriginal

      ICElement getOriginal(ICElement workingCopyElement)
      Returns the original element the specified working copy element was created from, or null if this is not a working copy element.
      Parameters:
      workingCopyElement - the specified working copy element
      Returns:
      the original element the specified working copy element was created from, or null if this is not a working copy element
    • getOriginalElement

      ITranslationUnit getOriginalElement()
      Returns the original element this working copy was created from, or null if this is not a working copy.
    • isBasedOn

      boolean isBasedOn(org.eclipse.core.resources.IResource resource)
      Returns whether this working copy's original element's content has not changed since the inception of this working copy.
      Returns:
      true if this working copy's original element's content has not changed since the inception of this working copy, false otherwise
    • reconcile

      org.eclipse.core.resources.IMarker[] reconcile() throws CModelException
      Reconciles the contents of this working copy. It performs the reconciliation by locally caching the contents of the working copy, updating the contents, then creating a delta over the cached contents and the new contents, and finally firing this delta.

      If the working copy hasn't changed, then no problem will be detected, this is equivalent to IWorkingCopy#reconcile(false, null).

      Throws:
      CModelException
    • reconcile

      void reconcile(boolean forceProblemDetection, org.eclipse.core.runtime.IProgressMonitor monitor) throws CModelException
      Reconciles the contents of this working copy. It performs the reconciliation by locally caching the contents of the working copy, updating the contents, then creating a delta over the cached contents and the new contents, and finally firing this delta.

      Parameters:
      forceProblemDetection - The boolean argument allows to force problem detection even if the working copy is already consistent.
      monitor - a progress monitor
      Throws:
      CModelException - if the contents of the original element cannot be accessed
    • reconcile

      IASTTranslationUnit reconcile(boolean computeAST, boolean forceProblemDetection, org.eclipse.core.runtime.IProgressMonitor monitor) throws CModelException
      Reconciles the contents of this working copy. It performs the reconciliation by locally caching the contents of the working copy, updating the contents, then creating a delta over the cached contents and the new contents, and finally firing this delta.

      The boolean argument allows to force problem detection even if the working copy is already consistent.

      EXPERIMENTAL. This method has been added as part of a work in progress. There is no guarantee that this API will work or that it will remain the same. Please do not use this API without consulting with the CDT team.

      Parameters:
      computeAST - flag to indicate if an AST should be returned
      forceProblemDetection - The boolean argument allows to force problem detection even if the working copy is already consistent.
      monitor - a progress monitor
      Returns:
      the AST or null
      Throws:
      CModelException - if the contents of the original element cannot be accessed
      Since:
      4.0
    • restore

      void restore() throws CModelException
      Restores the contents of this working copy to the current contents of this working copy's original element. Has no effect if this element is not a working copy.
      Throws:
      CModelException