Working with Checkouts

 

Author: Eike Stepper

The key concept of working with models in the Project Explorer is a checkout. See Checking Out from Repositories for details on how to to create online transactional checkouts, online historical checkouts, and offline checkouts.

A checkout represents a named combination of the following pieces of information:

Once created, checkouts are displayed in the Project Explorer like workspace projects and decorated with a small blue repository image. In contrast to workspace projects the displayed checkouts have no physical representation in the workspace.

Table of Contents

Renaming Checkouts
Duplicating Checkouts
Opening and Closing Checkouts
Deleting Checkouts
Switching the Branch of a Checkout
5.1 Switching to a New Branch
5.2 Switching to an Other Branch
Switching the Time Stamp of a Checkout
6.1 Switching to an Other Branch Point
6.2 Switching to a Commit
Comparing Checkouts
7.1 Comparing with an Other Branch
7.2 Comparing with an Other Branch Point
7.3 Comparing with a Commit
Merging Checkouts
8.1 Merging from an Other Branch
8.2 Merging from an Other Branch Point
8.3 Merging from a Commit
Showing Checkouts in Other Views
9.1 Showing Checkouts in the CDO Sessions View
9.2 Showing Checkouts in the CDO Time Machine View
9.3 Showing Checkouts in the CDO Server Browser
9.4 Showing Checkouts in the Properties View
9.5 Showing Checkouts in the History View
9.6 Showing Checkouts in the System Explorer
10 Working with Offline Checkouts
10.1 Updating an Offline Checkout
10.2 Checking In an Offline Checkout
10.3 Reverting an Offline Checkout

1  Renaming Checkouts

CDO supports renaming an existing checkout, i.e., changing its label, at any time. A checkout can be renamed by selecting it and pressing the F2 key or selecting the Rename action in the context menu. The following dialog will pop up:

The dialog can only be finished with the OK button if the checkout label is either unchanged or changed to a not existing label.

2  Duplicating Checkouts

Sometimes it is useful to have two or more checkouts from the same repository in the Project Explorer. A checkout can be duplicated by selecting it, opening the context menu, and selecting the Duplicate Checkout action. The result is an identical checkout with a unique default label:

3  Opening and Closing Checkouts

To work with a configured checkout the checkout must be in opened state. Directly after creation a checkout is open. Directly after the startup of Eclipse all checkouts are in closed state.

If a checkout is closed it can be opened by double-clicking it or by selecting Open Checkout in its context menu.

If a checkout is open it can be closed by selecting Close Checkout in its context menu.

4  Deleting Checkouts

An existing checkout can be deleted by selecting that checkout and pressing the Del key or selecting the Delete action in the context menu. Several checkouts can be deleted at once. The following dialog will pop up:

Deleting a checkout does not delete the associated repository or any data in it. If the "Delete checkout contents on disk" checkbox is selected (i.e., checked) the locally replicated data of the possibly selected offline checkouts is deleted permanently!

5  Switching the Branch of a Checkout

Online transactional checkouts from repositories that are configured with the versioning mode branching can be switched to other branches by selecting the checkout, opening the context menu and selecting the Switch To sub menu:

See Property supportingBranches for instructions on how to enable branching for remote repositories, Creating Local Repositories for instructions on how to enable branching for local repositories.

The Switch To sub menu consists of the following action groups:

Switching the branch of a checkout is also possible by dragging elements and dropping them onto the target checkout without holding any modifier keys pressed. The following elements can be dropped onto the target:

When a checkout is switched to a different branch the nested resource nodes and model elements, as well as all the contents of all open resource editors are changed instantly to reflect the state of the new branch.

See Also:

5.1  Switching to a New Branch

Online transactional checkouts can be switched to a newly created branch with the Switch To -> New Branch context menu action. The New Branch dialog will pop up:

See Creating Branches for an explanation on how to use the New Branch dialog.

5.2  Switching to an Other Branch

Online transactional checkouts can be switched to any other branch with the Switch To -> Other Branch context menu action. The Select Branch Point dialog (without a time stamp area) will pop up:

.

6  Switching the Time Stamp of a Checkout

Online historical checkouts from repositories that are configured with the versioning modes auditing or branching can be switched to other branch points by selecting the checkout, opening the context menu and selecting the Switch To sub menu:

See Property supportingAudits for instructions on how to enable auditing remote repositories, Property supportingBranchesfor instructions on how to enable branching for remote repositories, or Creating Local Repositories for instructions on how to enable auditing or branching for local repositories.

The Switch To sub menu consists of the following action groups:

Switching the branch point of a checkout is also possible by dragging elements and dropping them onto the target checkout without holding any modifier keys pressed. The following elements can be dropped on to the target:

Switching the branch point of a checkout is also possible by using the CDO Time Machine View.

When a checkout is switched to a different branch point the nested resource nodes and model elements, as well as all the contents of all open resource editors are changed instantly to reflect the state of the new branch point.

See Also:

6.1  Switching to an Other Branch Point

Online historical checkouts can be switched to any other branch point with the Switch To -> Other Branch Point context menu action. The Select Branch Point dialog (with a time stamp area) will pop up:

.

6.2  Switching to a Commit

Online historical checkouts can be switched to a commit with the Switch To -> Commit context menu action. The Select Commit dialog will pop up:

.

7  Comparing Checkouts

All types of checkouts can be compared with other time stamps or other branches from the same repository by selecting the checkout, opening the context menu and selecting the Compare With sub menu:

The Compare With sub menu consists of the following action groups:

Comparing a checkout is also possible by dragging elements and dropping them onto the target checkout with the Shift and Ctrl keys pressed. The following elements can be dropped onto the target:

When a checkout is compared with a different branch point an EMF Compare editor is opened with the left side showing the selected compare source (e.g., the drag source) and the right side showing the selected compare target (e.g., the drop target):

See Also:

7.1  Comparing with an Other Branch

Checkouts can be compared with any other branch with the Compare With -> Other Branch context menu action. The Select Branch Point dialog (without a time stamp area) will pop up:

.

7.2  Comparing with an Other Branch Point

Checkouts can be compared with any other branch point with the Compare With -> Other Branch Point context menu action. The Select Branch Point dialog (with a time stamp area) will pop up:

.

7.3  Comparing with a Commit

Checkouts can be compared with a commit with the Compare With -> Commit context menu action. The Select Commit dialog will pop up:

.

8  Merging Checkouts

Offline and online transactional checkouts can be merged from other time stamps or other branches from the same repository by selecting the checkout, opening the context menu and selecting the Merge From sub menu:

The Merge From sub menu consists of the following action groups:

Merging a checkout is also possible by dragging elements and dropping them onto the target checkout with the Shift and Ctrl keys pressed. The following elements can be dropped onto the target:

When a checkout is merged from a different branch point an EMF Merge editor is opened with the left side showing the selected merge source (e.g., the drag source) and the right side showing the selected merge target (e.g., the drop target):

See Also:

8.1  Merging from an Other Branch

Checkouts can be merged from any other branch with the Merge From -> Other Branch context menu action. The Select Branch Point dialog (without a time stamp area) will pop up:

.

8.2  Merging from an Other Branch Point

Checkouts can be merged from any other branch point with the Merge From -> Other Branch Point context menu action. The Select Branch Point dialog (with a time stamp area) will pop up:

.

8.3  Merging from a Commit

Checkouts can be merged from a commit with the Merge From -> Commit context menu action. The Select Commit dialog will pop up:

.

9  Showing Checkouts in Other Views

Checkouts can be shown in a number of other views depending on the type of the checkout by selecting them, opening their context menu, opening the Show In sub menu, and selecting one of the Show In actions.

Online transactional checkouts can be shown in the following views:

Online historical checkouts can be shown in the following views:

Offline checkouts can be shown in the following views:

9.1  Showing Checkouts in the CDO Sessions View

Online checkouts can be shown in the CDO Sessions view:

A new session with the same target repository as the selected checkout is opened in the CDO Sessions view. A new transaction is opened on that session, pointing at the same branch point as the selected checkout.

9.2  Showing Checkouts in the CDO Time Machine View

Online histrical checkouts can be shown in the CDO Time Machine view:

9.3  Showing Checkouts in the CDO Server Browser

Offline checkouts can be shown in the CDO Server Browser:

The CDO Server Browser allows to introspect the internal data of the locally replicated repository in a web browser. It is only meant to be used for test and debug purposes. It is not meant to be a production tool that would scale to arbitrary repository sizes!

9.4  Showing Checkouts in the Properties View

All checkouts can be shown in the Properties view:

9.5  Showing Checkouts in the History View

All checkouts can be shown in the History view:

This is particularly useful if the "Link with Editor and Selection" button in the toolbar of the History view is not enabled and the history page does not automatically adjust to the workbench selection.

9.6  Showing Checkouts in the System Explorer

All checkouts can be shown in the System Explorer:

Each checkout owns a dedicated directory under .metadata of the current workspace. This directory contains the checkout.properties file that contains the configuration of the checkout. Offline checkouts also store the database of the locally replicated repository and baseline data of dirty model elements in this directory.

10  Working with Offline Checkouts

Online checkouts operate directly on the data stored in their repository and therefore require an active network connection; i.e., the repository must be in connected state. They are ideally suited to support real-time collaboration on models, but they can only be open when the underlying repository is reachable, which is not necessarily always the case for remote repositories.

Offline checkouts, in contrast, operate on locally replicated data of their repository and therefore do not require an active network connection; i.e., the repository can be in disconnected state. They are ideally suited to support offline work on models even during periods when the underlying repository is not reachable. Collaboration on the contained models is restricted to explicit synchronization times, i.e., when updating the checkout from remote or checking it in to remote.

Offline checkouts, as well as all their models and model elements are decorated with their local editing state, i.e., clean, dirty, or new.

Apart from these subtle differences offline checkouts are designed to behave in a very similar way as online checkouts. In addition a few special operations are available for them, which are explained in the following nested sections.

See Also:

10.1  Updating an Offline Checkout

Because the models and model elements in an offline checkout are not updated in real-time they need to be updated manually at appropriate times, e.g., before attempting to check it in to a remotely modified repository.

To update an offline checkout from remote the checkout is selected and the Update action chosen from its context menu. The update process tries to merge all trivial conflicts they may arise. Trivial conflicts are:

If non-trivial changes are detected, i.e., changes to the same single-valued EStructuralFeature feature on both sides of the same model element, an EMF Merge editor is opened:

The left side of the merge editor shows the remote repository and the right side shows the selected offline checkout. Saving the merge editor applies the needed changes to the local model elements and closed the merge editor. The update/merge process can be canceled by closing the merge editor without saving it.

Updating an offline checkout is a remote operation.

See Also:

10.2  Checking In an Offline Checkout

After having worked with the models and model elements in an offline checkout for a while it may seem appropriate to check in the changes that accumulated during this period back into the remote repository.

To update an offline checkout from remote the checkout is selected and the Checkin action chosen from its context menu.

Checking in does not strictly require the local offline checkout to be up-to-date as long as the local changes and the remote changes are not conflicting (i.e., neither trivial nor non-trivial conflicts exist). If conflicts are detected during the check-in process the following dialog pops up, asking to update the checkout first:

Checking in an offline checkout is a remote operation.

10.3  Reverting an Offline Checkout

Sometimes it may seem useful to discard all local editing state of the models and model elements in an offline checkout, effectively reverting the checkout to the most recently updated state.

To revert an offline checkout the checkout is selected and the Revert action chosen from its context menu. The following confirmation dialog will pop up:

Reverting an offline checkout is a local operation.